-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathUKF_Estimate.m
68 lines (59 loc) · 1.97 KB
/
UKF_Estimate.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
function FilterEstimateUKF = UKF_Estimate(FilterEstimateUKF,FilterMat,loopNum)
PkPlus = FilterEstimateUKF.PkPlus;
XkPlus = FilterEstimateUKF.XkPlus;
n = length(XkPlus);
alpha = 10^-3;
kappa = 0;
beta = 2;
lamda = alpha^2*(n+kappa) - n;
% Dimension the weight and sample arrays
%
noPoints = 2*n+1; % number of samples
wPts = zeros(1,noPoints); % sample weightings
XPlusPts = zeros(n,noPoints); % samples
% Calculate the weight vector
%
wPts(1) = lamda/(n+ lamda);
for i=1:2*n
wPts(i+1) = 1/(2*(n+lamda));
end
% Calculate sigma points
%
[U,Eigen,~] = svd(PkPlus);
Cxx = U*sqrt(Eigen);
c = sqrt(n+lamda);
XPlusPts(:,1) = XkPlus;
XPlusPts(:,2:n+1) = XkPlus*ones(1,n)+c*Cxx;
XPlusPts(:,n+2:2*n+1) = XkPlus*ones(1,n)-c*Cxx;
% Transform the sample points
%
XMinusPts = Trans_F(XPlusPts,FilterMat.F);
m1 = size(XMinusPts,1);
% Calculate the X_k_minus and P_k_minus
%
XkMinus = XMinusPts*wPts';
PkMinus = zeros(m1);
for i = 0: 2*n
if i == 0
PkMinus = PkMinus...
+ (wPts(i+1)+(1-alpha^2+beta))...
*(XMinusPts(:,i+1)-XkMinus)*(XMinusPts(:,i+1) - XkMinus)';
else
PkMinus = PkMinus + wPts(i+1)...
*(XMinusPts(:,i+1)-XkMinus)*(XMinusPts(:,i+1) - XkMinus)';
end
end
PkMinus = PkMinus + FilterMat.Q;
FilterEstimateUKF.XkMinus = XkMinus;
FilterEstimateUKF.PkMinus = PkMinus;
FilterEstimateUKF.XkMinusVec(:,loopNum) = XkMinus;
FilterEstimateUKF.PkVec(loopNum).Minus = PkMinus;
FilterEstimateUKF.XMinusPts = XMinusPts;
end
function output = Trans_F(input,F)
[Row,Col] = size(input);
output = zeros(Row, Col);
for i = 1:Col
output(:,i) = F*input(:,i);
end
end