-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsimulation_run_middle.m
260 lines (230 loc) · 7.65 KB
/
simulation_run_middle.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
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
% The script to generate simulation outputs for a generated set of failures
clc
clearvars
close all
% global variables
global lambda com_range
% simulation parameters
% number of robots in the selection pool
A_n = 50;
% the vector indicating the available robots
Rob_pool = ones(A_n,1);
% tuning parameter
omega = 2; % hoops
radius_tune = 8; % radius to consider for tuning
coverage_thres = 200;
% realiability parameters
% generate mean failure time for all robots
MTTF_mean = 420;
MTTFs = normrnd(MTTF_mean, 0.1*MTTF_mean,[A_n 1]);
% max time of the mission
T_max = max(MTTFs);
% time span of the mission
T = [0 T_max];
% lambda zero in the reliability model
l0s = 1./(10*MTTFs);
% k in the reliability model
k = 0.0001 * l0s;
% required reliability
alpha = 0.3;
% Cost parameters
% the cost of each robot
max_cost = 50;
Rob_costs = max_cost*MTTFs/max(MTTFs);
budget = 500;
% environment parameters
env_size = 30; % environment size
env_min_x = 0;
env_min_y = 0;
env_max_x = 30;
env_max_y = 30;
R_x = 1; % unifrom density
delta = 2; % discretization parameter
domain_area = env_size^2;
env_x = env_min_x:delta:env_max_x;
env_y = env_min_y:delta:env_max_y;
% area covered by each robot
max_area = 200;
Rob_areas = max_area *MTTFs/max(MTTFs);
% sensing radius of the robots
Rob_sen_rads = sqrt(Rob_areas/pi);
% sensing parameter
lambda = 0.1; % sensing decay parameter
% communication range
com_range = max(Rob_sen_rads);
% compute the reliability value for all
Rob_vals = zeros(A_n,1);
for i = 1:A_n
Rob_vals(i) = reliability(T,l0s(i),k(i));
end
l_R_vals = -log(1-Rob_vals);
l_alpha = -log(alpha);
% solve the MILP to select the robots
[info, Rob_sel] = prob1_MILP(Rob_costs,Rob_areas,Rob_vals,budget,...
alpha,domain_area);
% the set containing the selected robot labels
Rob_sel_labels = find(Rob_sel);
% bounding box of the domain
b_box = [env_x(1) env_x(end)
env_x(1) env_x(end)];
% solve the greedy algorithm to place the robots
[set_gre, h_gre, ~] = gre_place(Rob_sel_labels, R_x, delta,...
b_box, Rob_sen_rads,[],[]);
% update the list of available robots
Rob_pool = Rob_pool - Rob_sel;
% update the list of active robots
Rob_active = Rob_sel;
% labels of the active robots
Rob_active_lab = find(Rob_active);
% positions of active robots
Rob_active_pos = set_gre;
% construct the graph from the robots
% adjacency matrix
% adj = zeros(length(Rob_sel_labels));
% nodenames = cell(length(Rob_sel_labels),1);
% for i = 1:length(Rob_sel_labels)
% nodenames{i} = num2str(Rob_sel_labels(i));
% end
%
% % construct the adjacent matrix
% for i = 1:length(Rob_sel_labels)
% for j = i+1:length(Rob_sel_labels)
% % compute the distance between the robots
% dist = norm(set_gre(i,:) - set_gre(j,:));
% % communication radius sum
% max_com = com_range;
% if dist <= max_com
% adj(i,j) = dist;
% adj(j,i) = dist;
% end
% end
% end
% % unweighted adjacency matrix
% adj_u = double(adj>0);
%
% C_graph = graph(adj,nodenames);
[~, h_pos] = h_compute_config(set_gre, b_box, delta, R_x,...
Rob_sen_rads(Rob_sel_labels));
plots(set_gre, b_box, delta, h_pos);
hold on
% plot the robot labels
for i = 1:length(Rob_active_lab)
text(set_gre(i,1),set_gre(i,2), num2str(Rob_active_lab(i)));
end
%% PHASE II Failure simulation
tot_area = sum(Rob_areas(Rob_active_lab));
lost_area = 0;
% select the robot closest to center to fail
x_mid = (env_x(1) + env_x(end))/2 ;
y_mid = (env_y(1) + env_y(end))/2;
mid_point = [x_mid y_mid];
dist_ = zeros(length(Rob_active_lab),1);
for i = 1:length(Rob_active_lab)
dist_(i) = norm(mid_point-set_gre(i,:));
end
dist = norm(mid_point - set_gre);
min_dist = min(dist_);
indx = find(dist_==min_dist);
% randomly select a node to fail
% indx = floor(rand(1)*sum(Rob_active));
% if indx == 0
% indx = 1;
% end
fail_rob_label = Rob_active_lab(indx);
% total area after robot failure
tot_area = tot_area - Rob_areas(fail_rob_label);
% total area lost
lost_area = lost_area + Rob_areas(fail_rob_label);
% rearrage based on omega tuning hoops tuning
% omega_tune;
% rearrange based on radius parameter
rad_tune
% rearrage the robots to this local area
% solve the greedy algorithm to place the robots
[fail_rob_nbh_pos, ~, prob_pos_gre] = gre_place(fail_rob_nbh, R_x, delta,...
b_box, Rob_sen_rads, com_fail_rob_nbh, com_fail_rob_nbh_pos);
% rearrange the active robot set to match the ones in the coordinate order
set_gre = [com_fail_rob_nbh_pos; fail_rob_nbh_pos];
Rob_active_lab = [com_fail_rob_nbh; fail_rob_nbh];
% construct the graph from the robots
% adjacency matrix
% adj = zeros(length(Rob_active_lab));
% nodenames = cell(length(Rob_active_lab),1);
% for i = 1:length(Rob_active_lab)
% nodenames{i} = num2str(Rob_active_lab(i));
% end
%
% % construct the adjacent matrix
% for i = 1:length(Rob_active_lab)
% for j = i+1:length(Rob_active_lab)
% % compute the distance between the robots
% dist = norm(set_gre(i,:) - set_gre(j,:));
% % communication radius sum
% max_com = com_range;
% if dist <= max_com
% adj(i,j) = dist;
% adj(j,i) = dist;
% end
% end
% end
% % unweighted adjacency matrix
% adj_u = double(adj>0);
t_box = [env_x(1) env_x(end)
env_y(1) env_y(end)];
rectangle('Position',[ b_box(1,1) b_box(2,1) b_box(1,2)-b_box(1,1) b_box(2,2)-b_box(2,1)])
plot(fail_rob_pos(1), fail_rob_pos(2),'b*')
% compute the new coverage values
[~, h_pos] = h_compute_config(set_gre, t_box, delta, R_x,...
Rob_sen_rads(Rob_sel_labels));
figure,
plots(set_gre, t_box, delta, h_pos);
hold on
for i = 1:length(Rob_active_lab)
text(set_gre(i,1),set_gre(i,2), num2str(Rob_active_lab(i)));
end
rectangle('Position',[ b_box(1,1) b_box(2,1) b_box(1,2)-b_box(1,1) b_box(2,2)-b_box(2,1)])
[h_gre_1, ~ ] = h_compute_config(set_gre, t_box, delta, R_x, Rob_sen_rads(Rob_active_lab));
% invoke the intermediate selection MILP to get new robot which
prob3_request = 0;
while h_gre_1 < coverage_thres
alpha1 = alpha/(prod(1-Rob_vals(Rob_active_lab)));
[info, Rob_sel] = prob3_MILP(Rob_areas,Rob_vals,...
alpha1,lost_area, Rob_pool);
% update the list of available robots
Rob_pool = Rob_pool - Rob_sel;
% add the selected robots to list of failed robot neighbors
fail_rob_nbh = [fail_rob_nbh; find(Rob_sel)];
% recompute the coverage
[fail_rob_nbh_pos, ~, prob_pos_gre] = gre_place(fail_rob_nbh, R_x, delta,...
b_box, Rob_sen_rads, com_fail_rob_nbh, com_fail_rob_nbh_pos);
% rearrange the active robot set to match the ones in the coordinate order
set_gre = [com_fail_rob_nbh_pos; fail_rob_nbh_pos];
Rob_active_lab = [com_fail_rob_nbh; fail_rob_nbh];
h_gre_1 = h_compute_config(set_gre, t_box, delta, R_x, Rob_sen_rads(Rob_active_lab));
prob3_request = prob3_request + 1;
end
% compute the new coverage values
[~, h_pos] = h_compute_config(set_gre, t_box, delta, R_x,...
Rob_sen_rads(Rob_sel_labels));
figure
plots(set_gre, t_box, delta, h_pos);
hold on
for i = 1:length(Rob_active_lab)
text(set_gre(i,1),set_gre(i,2), num2str(Rob_active_lab(i)));
end
rectangle('Position',[ b_box(1,1) b_box(2,1) b_box(1,2)-b_box(1,1) b_box(2,2)-b_box(2,1)])
% %% Writing data to file
% % set the outputs paths
% output_path = '/media/ragesh/Disk1/data/resilient_coverage/';
% % find the contents in the output directory
% files = dir(output_path);
% % Get a logical vector that tells which is a directory.
% dirFlags = [files.isdir] & ~strcmp({files.name},'.')...
% & ~strcmp({files.name},'..');
% % Extract only those that are directories.
% subFolders = files(dirFlags);
% % compute the trail number
% trail_no = length(subFolders) + 1;
%
%
% % write the data to files in appropriate folders