-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtwoRobotsCircle.m
148 lines (125 loc) · 3.61 KB
/
twoRobotsCircle.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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
% this script will run the gradient based control law for two robots moving
% in a circle
clear all
% select initial conditions for the robots
% two robot setup:
init = [0 -.25 0 -.5; 0 -.75 0 pi-.5];
shape = 'circle';
radius = .5;
% initialize the field object
S = field(length(init(:,1)), shape, radius); % CONSIDER ADDING SHAPE, POLYGON, RUNSPEED
S.sigma = .1;
S.tau = 1;
S.mu = .15;
S.gamma = .12;
S.timeToDelete = 4;
S.k1 = 1;
S.k2 = 1;
S.k3 = 1;
S.origin = [0 -.50 0];
S.precision = 6;
S.runspeed = 'fast';
% selects speed of the run, 'slow' computes each robot individually, but is
% susceptible to noise, 'fast' alternates leader robots to speed up the
% program, at the possible expense of accuracy, 'average_fast' runs
% similarly to fast, but uses the average of each rotated position,
% 'average_slow' runs at the slow speed, but sends robots to the average of
% their goal points to protect against noise and jitteriness
S.runTime = 30;
if matlabpool('size') == 0 % checking to see if matlab worker pool is
% already open
matlabpool open % can do more on computer with more cores
end
% call control law for robot motion
control_law = @(t,x) S.control_law(t,x);
noise = [0.00 0.00 0 0.000];
% calls new Miabot object that actuates robot motion
m = Miabots(init, control_law, 'velocity', S.runTime,...
'sim', false, 'Sim_noise', noise);
m.start
%%
m.shutdown()
figure
col=hsv(S.n_robots);
% plots the position within the shape, and the shape itself
for i=1:S.n_robots
hold on
plot(m.get_history(i,'x'), m.get_history(i,'y'), 'color', col(i,:));
end
xlabel('X-position');
ylabel('Y-position');
hold on
angle=0:0.01:2*pi;
x=S.radius*cos(angle);
y=S.radius*sin(angle);
plot(x+S.origin(1),y+S.origin(2));
% plots x vs t, y vs t, z vs t, and theta vs t
figure
for i=1:S.n_robots
hold on
plot(m.get_history(i,'state_times'), m.get_history(i,'x'), 'color', col(i,:));
end
xlabel('time');
ylabel('X-Position');
figure
for i=1:S.n_robots
hold on
plot(m.get_history(i,'state_times'), m.get_history(i,'y'), 'color', col(i,:));
end
xlabel('time');
ylabel('Y-Position');
figure
for i=1:S.n_robots
hold on
plot(m.get_history(i,'state_times'), m.get_history(i,'z'), 'color', col(i,:));
end
xlabel('time');
ylabel('Z-Position');
%}
%%
% generate a graph of the information entropy of the area being surveyed as
% a function of time
t = m.get_history(1,'state_times');
% take the state history
for i=1:S.n_robots
X(i,:) = m.get_history(i,'x') - S.origin(1);
Y(i,:) = m.get_history(i,'y') - S.origin(2);
Z(i,:) = m.get_history(i,'z') - S.origin(3);
end
K = zeros(0,4);
entropyList = 0;
for i=1:length(t)
for k=1:S.n_robots
K = [K; X(k,i) Y(k,i) Z(k,i) t(i)];
end
meas = zeros(0,4);
% truncate state history
for j=0:length(K(:,1))-1
meas(mod(j,30)+1,:) = K(j+1,:);
end
entropyList = [entropyList; S.determineEntropy(meas, t(i),false)];
end
n = entropyList;
figure
plot([0 t], n);
xlabel('time');
ylabel('entropic information');
%}
%%
% records a string of all inputted variables, and generates a csv file
% containing the data from the run
p1 = transpose(m.get_history(1,'state_times'));
M = zeros(length(p1), 9, S.n_robots);
for i=1:S.n_robots
p2 = transpose(m.get_history(i,'x'));
p3 = transpose(m.get_history(i,'y'));
p4 = transpose(m.get_history(i,'z'));
p5 = transpose(m.get_history(i,'vx'));
p6 = transpose(m.get_history(i,'vz'));
p7 = transpose(m.get_history(i,'theta'));
p8 = transpose(m.get_history(i,'theta_dot'));
p9 = n(2:length(n));
M(:,:,i) = [p1 p2 p3 p4 p5 p6 p7 p8 p9];
end
J = S.settings();
csvwrite('output.csv',M,1,0);