-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathplot_animated_traj_3D.m
102 lines (86 loc) · 3.17 KB
/
plot_animated_traj_3D.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
%% creates a video of the trajectories of the vehicles actual positions in 3D
% trajectories should move in formation with the reference frame and keep
% the relative positions assigned.
% number of vehicles
N = size(vehicle_pos.data,2);
% number of timesteps
timesteps = size(vehicle_pos.data,3);
% cube setup
l = 1 % edgelength
X_u = [l l -l -l];
Y_u = [l -l -l l];
Z_u = [-l -l -l -l];
Ar_u = [X_u;Y_u;Z_u];
X_o = [l l -l -l];
Y_o = [l -l -l l];
Z_o = [l l l l];
Ar_o = [X_o;Y_o;Z_o];
X_l = [l l -l -l];
Y_l = [-l -l -l -l];
Z_l = [-l l l -l];
Ar_l = [X_l;Y_l;Z_l];
X_r = [l l -l -l];
Y_r = [l l l l];
Z_r = [-l l l -l];
Ar_r = [X_r;Y_r;Z_r];
X_v = [-l -l -l -l];
Y_v = [-l -l l l];
Z_v = [-l l l -l];
Ar_v = [X_v;Y_v;Z_v];
X_h = [l l l l];
Y_h = [-l -l l l];
Z_h = [-l l l -l];
Ar_h = [X_h;Y_h;Z_h];
cube_init = [Ar_u Ar_o Ar_l Ar_r Ar_v Ar_h [-l l -l]'];
% color vector
c = ['b','m','k','r','g','b','m','k','r','g','b','m','k','r','g','b','m',...
'k','r','g','b','m','k','r','g','b','m','k','r','g','b','m','k','r',...
'g','b','m','k','r','g','b','m','k','g','b','m','k','r','g','b','m','k',...
'g','b','m','k','r','g','b','m','k','g','b','m','k','r','g','b','m','k',...
'g','b','m','k','r','g','b','m','k','g','b','m','k','r','g','b','m','k',...
'g','b','m','k','r','g','b','m','k','r','g','b','m','k','r','g'];
% video steup
figure('Position',[0 100 800 800]);
v = VideoWriter('C:\Users\Jens\Documents\Uni Stuttgart\BA\BA ohne Video\Matlab\Consensus_3D\3 formation_control_quadro_feedback_final\Videos\Gut\vehicle_trajectories_3D_mit_des.mp4','MPEG-4');
v.FrameRate = 24;
v.Quality = 50;
open(v);
opengl('software')
% loop over each data entry of the simout results
for j=1:5:(timesteps)
% plot of the reference frame trajectory
plot3(xi_ref_contr.data(:,1),xi_ref_contr.data(:,2),xi_ref_contr.data(:,3));
hold on;
scatter3(xi_ref_contr.data(j,1),xi_ref_contr.data(j,2),xi_ref_contr.data(j,3),80,'r','o');
axis([-1 19 -10 10 0 22]);
xlabel('x-Axis (meters)');
ylabel('y-Axis (meters)');
zlabel('z-Axis (meters)');
grid on;
hold on;
% rotation of cube according to reference state
cube = desired_pos_abs(xi_ref_contr.data(j,:)',cube_init);
plot3(cube(1,1:1:4),cube(2,1:1:4),cube(3,1:1:4),'m');
plot3(cube(1,5:1:8),cube(2,5:1:8),cube(3,5:1:8),'m');
plot3(cube(1,9:1:12),cube(2,9:1:12),cube(3,9:1:12),'m');
plot3(cube(1,13:1:16),cube(2,13:1:16),cube(3,13:1:16),'m');
plot3(cube(1,16:1:20),cube(2,16:1:20),cube(3,16:1:20),'m');
plot3(cube(1,21:1:25),cube(2,21:1:25),cube(3,21:1:25),'m');
% loop over each vehicle
for i=1:1:N
% plots the x,y-values of the actual i-th robot position
x = vehicle_pos.data(1,i,j);
y = vehicle_pos.data(2,i,j);
z = vehicle_pos.data(3,i,j);
scatter3(x,y,z,60,c(i),'d','filled');
%plots i-th robot desired position
x_ref = des_pos.data(1,i,j);
y_ref = des_pos.data(2,i,j);
z_ref = des_pos.data(3,i,j);
scatter3(x_ref, y_ref, z_ref,60,c(i),'filled','o');
end
writeVideo(v,getframe);
% legend('ref','v1','v1_des','v2','v2_des','v3','v3_des','v4','v4_des');
hold off;
end
close(v);