-
Notifications
You must be signed in to change notification settings - Fork 32
/
intermittent_A.m
74 lines (74 loc) · 2.14 KB
/
intermittent_A.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
% Kalman Filtering With Intermittent Observations(2004)
close all
clear
clc
A=[1.25 1 0;0 0.9 7;0 0 0.6];C=[1 0 2];Q=20*eye(3,3);R=2.5; % 参数设置
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
lambdadown=1-1/(max(eig(A)))^2; %下界
lambda=0:0.002:1; %设置步长(控制好精度,涉及上界的精度)(太大影响精度;太小影响效率)
Trs=1e5*ones(size(lambda)); %设成无穷大
k=1;
for i=lambda
A1=A*sqrt(1-i);
if i>lambdadown
s=dlyap(A1,Q);
Trs(k)=trace(s);
end
k=k+1;
end
plot(lambda,Trs,'-.r')
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
n=length(lambda); %上界
T=zeros(n,1);
for i=1:n
setlmis([]);
Y=lmivar(1,[3,1]); %与矩阵A同阶的对称矩阵
Z=lmivar(2,[3,1]); %矩阵Z的行数与矩阵A行数相等,列与矩阵C的行数相等
lmiterm([-1 1 1 Y],1,1);
lmiterm([-1 1 2 Y],sqrt(lambda(i)),A);
lmiterm([-1 1 2 Z],1,C);
lmiterm([-1 1 3 Y],sqrt(1-lambda(i)),A);
lmiterm([-1 2 2 Y],1,1);
lmiterm([-1 3 3 Y],1,1);
lmiterm([-2 1 1 Y],1,1);
lmiterm([-3 1 1 0],1);
lmiterm([3,1 1,Y],1,1);
lmisys=getlmis;
options=[0 0 0 0 1];
[t,xopt]=feasp(lmisys,options);
T(i)=t;
end
for j=1:n
if T(j)<=0
lambdaup=lambda(j);
break
end
end
TrV=zeros(size(lambda));
k1=1;
for i=lambda
m=100; %与迭代次数有关,迭代次数足够大
v=ones([size(A),m]); %与初始值有关?为使矩阵快速收敛初始值设大
for j=1:m
v(:,:,j+1)=A*v(:,:,j)*A'+Q-i*A*v(:,:,j)*C'*inv(C*v(:,:,j)*C'+R)*C*v(:,:,j)*A';
end
TrV(k1)=trace(v(:,:,m+1));
k1=k1+1;
end
hold on
plot(lambda,TrV,'-b')
legend('S','V')
% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
h=5e6; %高度范围
n=0:h;
lambdadown=lambdadown*ones(size(n));
lambdaup=lambdaup*ones(size(n));
hold on
plot(lambdadown,n,'--g',lambdaup,n,'--k')
%text(0.3,5,['\lambda','c=',num2str(lambdadown)])
xlabel('\lambda')
ylabel('S/V')
title('Special case:C is invertible')
text(0.35,-300000,'$\underline{\lambda}$','interpreter','latex');
text(0.33,300000,'$\overline{\lambda}$','interpreter','latex');
axis([0,1,0,h]); %%注意合理范围