-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathKLMN.m
31 lines (31 loc) · 1.17 KB
/
KLMN.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
function [YY,XX] = KLMN(Ap,Xint_v,Uk,Qu,Vk,Qv,C,n);
Ap(2,:) = 0;
for ii = 1:1:length(Ap)-1
Ap(ii+1,ii) = 1;
end
Xminbark = Ap*Xint_v'; % FIRST STEP
Pk = Xint_v*Xint_v';
Pk = Ap*Pk*Ap' + Qv; % SECOND STEP
YY = 1;
Kk = Pk*C'*inv(C*Pk*C'+Qv); % THIRD STEP
XXn = Ap*Xminbark + [Uk(1),zeros(1:(1:length(Ap))-1)]'; % UPPER EQUATIONS.
YYn = C*XXn + [Vk(1), zeros(1:(1:length(Ap))-1)]'; % UPPER EQUATIONS.
Xupd = Xminbark + Kk*(YYn - C*Xminbark); % FOURTH STEP
Pk = (1-Kk*C)*Pk; % FIFTH STEP
OUTX(1,1) = XXn(1,1);
OUTY = YYn;
for ii = 2:1:n
Xminbark = Ap*XXn; % FIRST STEP
Pk = XXn*XXn';
Pk = Ap*Pk*Ap' + Qv; % SECOND STEP
YY = 1;
Kk = Pk*C'*inv(C*Pk*C'+Qv); % THIRD STEP
XXn = Ap*Xminbark + [Uk(ii),zeros(1:(1:length(Ap))-1)]'; % UPPER EQUATIONS.
YYn = C*XXn + [Vk(ii), zeros(1:(1:length(Ap))-1)]'; % UPPER EQUATIONS.
Xupd = Xminbark + Kk*(YYn - C*Xminbark); % FOURTH STEP
Pk = (1-Kk*C)*Pk; % FIFTH STEP
OUTX(ii) = XXn(1,1);
OUTY(ii) = YYn;
end
YY = OUTY;
XX = OUTX;