苏泓源 commited on
Commit
c8cf824
Β·
1 Parent(s): 8ad6835
Files changed (1) hide show
  1. app.py +30 -36
app.py CHANGED
@@ -27,6 +27,7 @@ def solver_plot(data_npy, boost=False):
27
  return actual_fig, solution_fig, actual_ac, solution_ac
28
 
29
  def demo_plot(city, facility):
 
30
  all_facility = ["🏫 School", "πŸ₯ Hospital", "🌳 Park"]
31
  for i in range(len(all_facility)):
32
  if all_facility[i] in facility:
@@ -55,7 +56,7 @@ def demo_plot(city, facility):
55
  size=10,
56
  color=px.colors.qualitative.Plotly[i]
57
  ),
58
- name=f'Facility {i+1}'
59
  ))
60
  solution_fig.add_trace(go.Scattermapbox(
61
  lat=positions[solution_facility[:, i] == 1][:, 0],
@@ -65,7 +66,7 @@ def demo_plot(city, facility):
65
  size=10,
66
  color=px.colors.qualitative.Plotly[i]
67
  ),
68
- name=f'Facility {i+1}'
69
  ))
70
 
71
  actual_fig.update_layout(
@@ -125,7 +126,7 @@ def solver_plot(data_npy, boost=False):
125
 
126
  actual_facility = []
127
  for i in range(2+p, 2+2*p):
128
- actual_facility.append(bool(int(row[i])))
129
  actual_facilities.append(actual_facility)
130
  positions = np.array(positions)
131
  demands = np.array(demands)
@@ -190,24 +191,17 @@ def solver_plot(data_npy, boost=False):
190
  return actual_fig, solution_fig, actual_ac, solution_ac
191
 
192
 
193
-
194
-
195
  def get_example():
196
  return [
197
- ("40.71 -73.93 213 0\n\
198
- 40.72 -73.99 15 1\n\
199
- 40.65 -73.88 365 1\n\
200
- 40.57 -73.96 629 0\n\
201
- 40.70 -73.97 106 0\n\
202
- 40.61 -73.95 189 1"),
203
- ("40.71 -73.93 213 124 0 1\n\
204
- 40.72 -73.99 15 43 1 0\n\
205
- 40.65 -73.88 365 214 1 0\n\
206
- 40.57 -73.96 629 431 0 1\n\
207
- 40.70 -73.97 106 241 0 1\n\
208
- 40.61 -73.95 189 264 1 0")
209
  ]
210
-
 
 
 
 
 
211
 
212
 
213
  with gr.Blocks() as demo:
@@ -218,39 +212,39 @@ with gr.Blocks() as demo:
218
  btn = gr.Button(value="πŸš€ Generate")
219
  with gr.Row():
220
  actual_map = gr.Plot(label='Actual Facility Distribution')
221
- solution_map = gr.Plot(label='Relocation Facility Distribution')
222
  with gr.Row():
223
  actual_ac = gr.Textbox(label='Real-world Access Cost')
224
- solution_ac = gr.Textbox(label='Relocation Access Cost')
225
  demo.load(fn=demo_plot, inputs=[city, facility], outputs=[actual_map, solution_map, actual_ac, solution_ac])
226
  btn.click(fn=demo_plot, inputs=[city, facility], outputs=[actual_map, solution_map, actual_ac, solution_ac])
227
 
228
- gr.Markdown("## FLP&IUMFLP Solver")
229
  with gr.Column():
230
  with gr.Row():
231
  data_npy = gr.Textbox(label="Input")
232
  data_file = gr.UploadButton(
233
  label="πŸ“ Upload a npy file",
234
- file_count="multiple",
235
  file_types=[".npy"])
236
  with gr.Row():
237
- boost = gr.Checkbox(label="Turbo Boost", value=False)
 
 
 
 
 
 
 
238
  btn2 = gr.Button(value="πŸš€ Generate")
239
  with gr.Row():
240
- actual_map = gr.Plot(label='Real-world Facility Distribution')
241
- solution_map = gr.Plot(label='Relocation Facility Distribution')
242
  with gr.Row():
243
- actual_ac = gr.Textbox(label='Real-world Access Cost')
244
- solution_ac = gr.Textbox(label='Relocation Access Cost')
245
- data_file.upload(fn=solver_plot, inputs=[data_file, boost], outputs=[actual_map, solution_map, actual_ac, solution_ac])
246
  btn2.click(fn=solver_plot, inputs=[data_npy, boost], outputs=[actual_map, solution_map, actual_ac, solution_ac])
247
 
248
- gr.Examples(
249
- examples=get_example(),
250
- inputs=[data_npy],
251
- fn=plot_from_npy,
252
- outputs=[actual_map, solution_map],
253
- )
254
-
255
  if __name__ == "__main__":
256
- demo.launch()
 
27
  return actual_fig, solution_fig, actual_ac, solution_ac
28
 
29
  def demo_plot(city, facility):
30
+ facility_name = ["🏫 School", "πŸ₯ Hospital", "🌳 Park"]
31
  all_facility = ["🏫 School", "πŸ₯ Hospital", "🌳 Park"]
32
  for i in range(len(all_facility)):
33
  if all_facility[i] in facility:
 
56
  size=10,
57
  color=px.colors.qualitative.Plotly[i]
58
  ),
59
+ name=facility_name[i],
60
  ))
61
  solution_fig.add_trace(go.Scattermapbox(
62
  lat=positions[solution_facility[:, i] == 1][:, 0],
 
66
  size=10,
67
  color=px.colors.qualitative.Plotly[i]
68
  ),
69
+ name=facility_name[i],
70
  ))
71
 
72
  actual_fig.update_layout(
 
126
 
127
  actual_facility = []
128
  for i in range(2+p, 2+2*p):
129
+ actual_facility.append(bool(int(float(row[i]))))
130
  actual_facilities.append(actual_facility)
131
  positions = np.array(positions)
132
  demands = np.array(demands)
 
191
  return actual_fig, solution_fig, actual_ac, solution_ac
192
 
193
 
 
 
194
  def get_example():
195
  return [
196
+ ('40.71 -73.93 213 0\n40.72 -73.99 15 1\n40.65 -73.88 365 1\n40.57 -73.96 629 0\n40.70 -73.97 106 0\n40.61 -73.95 189 1'),
197
+ ("40.71 -73.93 213 124 0 1\n40.72 -73.99 15 43 1 0\n40.65 -73.88 365 214 1 0\n40.57 -73.96 629 431 0 1\n40.70 -73.97 106 241 0 1\n40.61 -73.95 189 264 1 0")
 
 
 
 
 
 
 
 
 
 
198
  ]
199
+
200
+
201
+ def load_npy_file(file_obj):
202
+ data = np.load(file_obj.name)
203
+ string_array = '\n'.join([' '.join(map(str, row)) for row in data])
204
+ return string_array
205
 
206
 
207
  with gr.Blocks() as demo:
 
212
  btn = gr.Button(value="πŸš€ Generate")
213
  with gr.Row():
214
  actual_map = gr.Plot(label='Actual Facility Distribution')
215
+ solution_map = gr.Plot(label='Relocated Facility Distribution')
216
  with gr.Row():
217
  actual_ac = gr.Textbox(label='Real-world Access Cost')
218
+ solution_ac = gr.Textbox(label='Relocated Access Cost')
219
  demo.load(fn=demo_plot, inputs=[city, facility], outputs=[actual_map, solution_map, actual_ac, solution_ac])
220
  btn.click(fn=demo_plot, inputs=[city, facility], outputs=[actual_map, solution_map, actual_ac, solution_ac])
221
 
222
+ gr.Markdown("## FLP & IUMFLP Solver")
223
  with gr.Column():
224
  with gr.Row():
225
  data_npy = gr.Textbox(label="Input")
226
  data_file = gr.UploadButton(
227
  label="πŸ“ Upload a npy file",
228
+ file_count="single",
229
  file_types=[".npy"])
230
  with gr.Row():
231
+ gr.Examples(
232
+ examples=get_example(),
233
+ inputs=[data_npy],
234
+ fn=plot_from_npy,
235
+ outputs=[actual_map, solution_map],
236
+ )
237
+ with gr.Row():
238
+ boost = gr.Checkbox(label="Turbo Boost (accelerate solution generation with fewer SWAP steps)", value=False)
239
  btn2 = gr.Button(value="πŸš€ Generate")
240
  with gr.Row():
241
+ actual_map = gr.Plot(label='Initial Solution')
242
+ solution_map = gr.Plot(label='Final Solution')
243
  with gr.Row():
244
+ actual_ac = gr.Textbox(label='Initial Access Cost')
245
+ solution_ac = gr.Textbox(label='Final Access Cost')
246
+ data_file.upload(fn=load_npy_file, inputs=[data_file], outputs=[data_npy])
247
  btn2.click(fn=solver_plot, inputs=[data_npy, boost], outputs=[actual_map, solution_map, actual_ac, solution_ac])
248
 
 
 
 
 
 
 
 
249
  if __name__ == "__main__":
250
+ demo.launch()