-
Notifications
You must be signed in to change notification settings - Fork 56
/
Copy pathEKF_Scilab.sce
110 lines (91 loc) · 2.79 KB
/
EKF_Scilab.sce
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
clear;
clf;
dt = 0.1;
Data = csvRead('Radar_Lidar_Data1.csv',[], [], "double", [], [], [2 2 1225 10]);//Omit the header and the first column.
Radar_Measurement = [];
Lidar_Measurement = [];
EKF_Path = [];
F = [[1, 0, dt, 0];
[0, 1, 0, dt];
[0, 0, 1, 0];
[0, 0, 0, 1]];
u = 0;
B = [(dt^2)/2 (dt^2)/2 dt dt]';
P = [[1, 0, 0, 0];
[0, 1, 0, 0];
[0, 0, 1000, 0];
[0, 0, 0, 1000]];
R_l = [[0.0025, 0];
[0, 0.0025]];
R_r = [[0.09, 0, 0];
[0, 0.005, 0];
[0, 0, 0.09]];
Q = [(dt^2)/4 0 (dt^3)/2 0;
0 (dt^2)/4 0 (dt^3)/2;
(dt^3/2) 0 (dt^2) 0;
0 (dt^3)/2 0 (dt^2)];
H = [[1, 0, 0, 0];
[0, 1, 0, 0]];
I = eye(4,4);
if (Data(1,1) == 1)
x = [Data(1,2); Data(1,3); 0; 0];
else
x = [Data(1,2); Data(1,3); Data(1,4); 0];
end
for n = 1:size(Data)(1,1)
if (Data(n,1) == 2)
//prediction
x = F * x + B*u;
P = F * P * F' + Q;
//measurement update
Z = Data(n,2:4);
X = Z(1)*cos(Z(2));
Y = Z(1)*sin(Z(2));
VX = Z(3)*cos(Z(2));
VY = Z(3)*sin(Z(2));
c1 = X^2 + Y^2;
c2 = sqrt(c1);
c3 = c1 * c2;
if (c1==0 || c2==0 || c3==0)
H_Jac = [[0, 0, 0, 0];
[0, 0, 0, 0];
[0, 0, 0, 0]];
else
H_Jac = [[X/c2, Y/c2, 0, 0];
[-Y/c1, X/c1, 0, 0];
[(Y*(VX*Y-VY*X))/c3, (X*(X*VY-Y*VX))/c3, X/c2, Y/c2]];
end
Z_Car = [X; Y; VX; VY];
y = Z' - (H_Jac * Z_Car);
S = H_Jac * P * H_Jac' + R_r;
K = P * H_Jac' * inv(S);
x = Z_Car + (K * y);
P = (I - (K * H_Jac)) * P;
EKF_Path = [EKF_Path;[x(1),x(2)]];
Radar_Measurement = [Radar_Measurement; Data(n,2:4)];
else
//prediction
x = (F * x) + B*u;
P = F * P * F' + Q;
//measurement update
Z = Data(n,2:3);
y = Z' - (H * x);
S = H * P * H' + R_l;
K = P * H' * inv(S);
x = x + (K * y);
P = (I - (K * H)) * P;
EKF_Path = [EKF_Path;[x(1),x(2)]];
Lidar_Measurement = [Lidar_Measurement; Data(n,2:3)];
end
end
for i = 1:size(Radar_Measurement)(1,1)
Radar_Measurement_Cart(i,:) = [[Radar_Measurement(i,1),0];[0, Radar_Measurement(i,1)]]*[cos(Radar_Measurement(i,2));sin(Radar_Measurement(i,2))];
end
set(gca(),"auto_clear","off")
plot(Data(:,6),Data(:,7),'r','linewidth', 2);
scatter(gca(),EKF_Path(:,1),EKF_Path(:,2),,'scilabred3');
scatter(gca(),Lidar_Measurement(:,1),Lidar_Measurement(:,2),,'scilabgreen3');
scatter(Radar_Measurement_Cart(:,1),Radar_Measurement_Cart(:,2),,'skyblue');
legend(gca(),['Grundtruth';'EKF Path result';'Lidar Measurement';'Radar Measurement'],2);
//axis square; Not Implemented yet.
set(gca(),"auto_clear","on")