-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathData_generation_simple.py
144 lines (109 loc) · 6.45 KB
/
Data_generation_simple.py
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
# -*- coding: utf-8 -*-
"""
Created on Sat Nov 14 14:03:51 2020
@author: Flori
"""
import numpy as np
import xlrd
from geopy.distance import distance
import matplotlib.pyplot as plt
import csv
# defining the location of the airbase, pizzerias, clients
loc_airbase = np.array((52.020949, 4.393304)) # latitude longitude
loc_pizzerias = np.array([(52.012892, 4.373290), (52.017830, 4.363525), (51.996050, 4.375586)])
pizzeria_expected_arrival = np.array([600, 750, 800])
loc_clients = np.array([(51.987226, 4.349195), (51.991648, 4.348359), (51.990306, 4.358927),
(51.989985, 4.376466), (52.010301, 4.348025)])
customer_arrival_time = np.array([(700, 1300), (700, 1400), (700, 1500),
(700, 1600), (700, 1700)])
# ++++++++++++++++++ Generating the "client_1_to_client_2_distances" file ++++++++++++++++++++++++
myData_client_1_client_2_distances = [
['latitude_client_1', 'longitude_client_1', 'latitude_client_2', 'longitude_client_2', 'distance']]
for client_1 in loc_clients:
for client_2 in loc_clients:
if client_1[0] != client_2[0] and client_1[1] != client_2[1]:
myData_client_1_client_2_distances += [
[round(client_1[0], 5), round(client_1[1], 5), round(client_2[0], 5), round(client_2[1], 5),
round(distance(client_1, client_2).m, 4)]]
myFile_client_1_client_2_distances = open('client_1_client_2_distances.csv', 'w', newline="")
with myFile_client_1_client_2_distances:
writer = csv.writer(myFile_client_1_client_2_distances)
writer.writerows(myData_client_1_client_2_distances)
# ++++++++++++++++++ Generating the "client_airbase_distances" file ++++++++++++++++++++++++
myData_client_airbase_distances = [
['latitude_client', 'longitude_client', 'latitude_airbase', 'longitude_airbase', 'distance']]
for client in loc_clients:
myData_client_airbase_distances += [
[round(client[0], 5), round(client[1], 5), round(loc_airbase[0], 5), round(loc_airbase[1], 5),
round(distance(client, loc_airbase).m, 5)]]
myFile_client_airbase_distances = open('client_airbase_distances.csv', 'w', newline="")
with myFile_client_airbase_distances:
writer = csv.writer(myFile_client_airbase_distances)
writer.writerows(myData_client_airbase_distances)
# ++++++++++++++++++ Generating the "pizzeria_expected_arrival_time" file ++++++++++++++++++++++++
myData_pizzeria_expected_arrival_time = [['latitude_pizzeria', 'longitude_pizzeria', 'expected_arrival_time(in sec)']]
i = 0
for pizzeria in loc_pizzerias:
myData_pizzeria_expected_arrival_time += [
[round(pizzeria[0], 5), round(pizzeria[1], 5), round(pizzeria_expected_arrival[i], 0)]]
i += 1
myFile_pizzeria_expected_arrival_time = open('pizzeria_expected_arrival_time.csv', 'w', newline="")
with myFile_pizzeria_expected_arrival_time:
writer = csv.writer(myFile_pizzeria_expected_arrival_time)
writer.writerows(myData_pizzeria_expected_arrival_time)
# ++++++++++++++++++ Generating the "airbase_pizzerias_distances" file ++++++++++++++++++++++++
myData_airbase_pizzerias = [
['latitude_airbase', 'longitude_airbase', 'latitude_pizzeria', 'longitude_pizzeria', 'distance']]
for pizzeria in loc_pizzerias:
myData_airbase_pizzerias += [[round(loc_airbase[0], 5), round(loc_airbase[1], 5),
round(pizzeria[0], 5), round(pizzeria[1], 5),
round(distance(loc_airbase, pizzeria).m, 5)]]
myFile_airbase_pizzerias = open('airbase_pizzerias_distances.csv', 'w', newline="")
with myFile_airbase_pizzerias:
writer = csv.writer(myFile_airbase_pizzerias)
writer.writerows(myData_airbase_pizzerias)
# ++++++++++++++++++ Generating the "pizzerias_clients_distances" file ++++++++++++++++++++++++
myData_pizzerias_clients = [
['latitude_pizzeria', 'longitude_pizzeria', 'latitude_client', 'longitude_client', 'distance']]
for pizzeria in loc_pizzerias:
for client in loc_clients:
myData_pizzerias_clients += [[round(pizzeria[0], 5), round(pizzeria[1], 5),
round(client[0], 5), round(client[1], 5), round(distance(pizzeria, client).m, 5)]]
myFile_pizzerias_clients = open('pizzerias_clients.csv', 'w', newline="")
with myFile_pizzerias_clients:
writer = csv.writer(myFile_pizzerias_clients)
writer.writerows(myData_pizzerias_clients)
# ++++++++++++++++++ Generating the "customer_arrival_time" file ++++++++++++++++++++++++
myData_customer_arrival_time = [['lower_bound_time_interval', 'upper_bound_time_interval']]
for customer_time_bounds in customer_arrival_time:
myData_customer_arrival_time += [[customer_time_bounds[0], customer_time_bounds[1]]]
myFile_customer_arrival_time = open('customer_arrival_time.csv', 'w', newline="")
with myFile_customer_arrival_time:
writer = csv.writer(myFile_customer_arrival_time)
writer.writerows(myData_customer_arrival_time)
# +++++++++++++++++++ Plotting ++++++++++++++++
def plot():
imData = plt.imread("map_first_try_basic_model.JPG") # first we are plotting the background image
fig, ax = plt.subplots()
ax.set_title("Objective (total distance): " + "xxxxxxx")
ax.imshow(imData, extent=[4.3458, 4.3954, 51.98554, 52.02264])
ax.plot((loc_airbase[1]), (loc_airbase[0]), 'w*', markersize=12) # airbase as white star
ax.text((loc_airbase[1]), (loc_airbase[0]) - 0.001, 'Airbase', color='white', fontsize=10,
bbox={'facecolor': 'red', 'alpha': 0.6, 'pad': 2})
# -----plotting the info about the pizzerias------
ax.plot((loc_pizzerias[:, 1]), (loc_pizzerias[:, 0]), 'w^', markersize=7) # pizzerias white triangles
for i in range(len(loc_pizzerias)):
ax.text((loc_pizzerias[i, 1]), (loc_pizzerias[i, 0]) - 0.001,
str(i + 1) + ", " + r'$\tau$' + "=" + "blabl", color='white', fontsize=8,
bbox={'facecolor': 'red', 'alpha': 0.6, 'pad': 1})
# -----plotting the info about the clients------
ax.plot((loc_clients[:, 1]), (loc_clients[:, 0]), 'wo') # clients as white dots
for i in range(len(loc_clients)):
ax.text((loc_clients[i, 1]), (loc_clients[i, 0]) - 0.001,
str(i + 1 + len(loc_pizzerias)) + ", " + r'$\tau$' + "=" + "blabl",
color='white', fontsize=8, bbox={'facecolor': 'red', 'alpha': 0.6, 'pad': 1})
plt.xlabel("Longitutde (" + u"\N{DEGREE SIGN}" + "E)")
plt.ylabel("Latitude (" + u"\N{DEGREE SIGN}" + "N)")
plt.show()
#Uncomment the following line if you want to see where the nodes are located
plot()