-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpost_sim_plots_EKF.m
119 lines (101 loc) · 3.11 KB
/
post_sim_plots_EKF.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
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
111
112
113
114
115
116
117
%% Plotting Results from Sim with EKF
close all
n = length(t);
set(0,'DefaultLineMarkerSize',5)
mu_EKF(:, 1:4) = quat_corr(mu_EKF(:,1:4));
mu_p_EKF(:, 1:4) = quat_corr(mu_p_EKF(:, 1:4));
q_det = quat_corr(q_det_EKF);
[q] = quat_corr(q_out_EKF(:, 1:4));
t_EKF = t(1:(dt_EKF/dt):end);
for ii = 1:size(mu_EKF, 1)
z4(:,:,ii) = error_ellipse(0, sigma_EKF(4,4,ii), .95);
z_high4(ii) = max(z4(2, :, ii)) + mu_EKF(ii, 4);
z_min4(ii) = min(z4(2, :, ii))+ mu_EKF(ii, 4);
z1(:,:,ii) = error_ellipse(0, sigma_EKF(1,1,ii), .95);
z_high1(ii) = max(z1(2, :, ii)) + mu_EKF(ii, 1);
z_min1(ii) = min(z1(2, :, ii))+ mu_EKF(ii, 1);
z2(:,:,ii) = error_ellipse(0, sigma_EKF(2,2,ii), .95);
z_high2(ii) = max(z2(2, :, ii)) + mu_EKF(ii, 2);
z_min2(ii) = min(z2(2, :, ii))+ mu_EKF(ii, 2);
z3(:,:,ii) = error_ellipse(0, sigma_EKF(3,3,ii), .95);
z_high3(ii) = max(z3(2, :, ii)) + mu_EKF(ii, 3);
z_min3(ii) = min(z4(2, :, ii))+ mu_EKF(ii, 3);
end
figure()
subplot(4,1,1)
plot(t_EKF, [mu_EKF(:, 1)])
hold on
plot(t, q(:, 1),'--')
% plot(t(1:end), z_high1(1:end), 'b', 'HandleVisibility', 'off')
% plot(t(1:end), z_min1(1:end), 'b')
% plot(t(2:end), q_det(1:end-1, 1), 'b:')
grid on
ylabel('q_1')
hold off
subplot(4,1,2)
plot(t_EKF, [mu_EKF(:, 2)])
hold on
plot(t, q(:, 2),'--')
% plot(t(2:end), q_det(1:end-1, 2), 'b:')
grid on
ylabel('q_2')
hold off
subplot(4,1,3)
plot(t_EKF, [mu_EKF(:, 3)])
hold on
plot(t, q(:, 3),'--')
% plot(t(2:end), q_det(1:end-1, 3), 'b:' )
grid on
ylabel('q_3')
hold off
subplot(4,1,4)
plot(t_EKF, [mu_EKF(:, 4)])
hold on
plot(t, q(:, 4),'--')
% plot(t(2:end), q_det(1:end-1, 4), 'b:')
grid on
xlabel('time, seconds')
ylabel('q_4')
sgtitle('{\color{orange}Ground Truth Quaternion} and {\color{blue}Estimated Quaternion} vs. time'...
,'fontsize', 24)
hold off
figure()
% scatter([t; t(end)+dt], [NaN; mu_p(:, 4)], 'filled')
scatter(t_EKF, [mu_p_EKF(:, 4)], 'filled')
hold on
% scatter([t; t(end)+dt], [NaN; mu_EKF(:, 4)], 'filled')
scatter(t_EKF, [mu_EKF(:, 4)], 'filled')
plot(t, q(:, 4), 'k')
% plot(t, q_det(:, 4), 'b')
plot(t_EKF, z_high4(1:end), 'b', 'HandleVisibility', 'off')
plot(t_EKF, z_min4(1:end), 'b')
% for ii = 1:size(z, 3)-1
% plot(z(1, :, ii) + t(ii+1), z(2, :, ii) + mu_EKF(ii,4))
% end
grid on
xlabel('time, seconds')
ylabel('q_4')
legend('Pre-fit', 'Post-fit', 'Ground Truth', '95% Confidence Bound')
hold off
figure()
plot(t(1:end), abs(q_det(1:end, 4) - q(1:end, 4)))
hold on
plot(t_EKF, abs(mu_EKF(1:end, 4) - q(1:(dt_EKF/dt):end, 4)))
xlabel('time, seconds')
ylabel('Absolute Error')
if att_det_method == 1
legend('q - method', 'EKF')
else
legend('Deterministic Method', 'EKF')
end
hold off
figure()
plot(t, q_out(:, 5), 'k', t, q_out(:, 6), 'k', t, q_out(: ,7), 'k')
hold on
plot(t_EKF, mu_EKF(:, 5),'--',t_EKF, mu_EKF(:, 6),'--', t_EKF, mu_EKF(:, 7),'--')
legend('\omega_{x}', '\omega_{y}', '\omega_{z}', '\mu_{\omega_{x}}','\mu_{\omega_{y}}','\mu_{\omega_{z}}')
grid on
xlabel('time, seconds')
ylabel('$\mathbf{\vec{\omega}}, \mathrm{\frac{rad}{s}}$', 'Interpreter', 'latex')
title('$\mathbf{\vec{\omega}} \;\mathrm{over \;time}$', 'Interpreter', 'latex')
hold off