-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTSP-NearestNeighbor.py
84 lines (62 loc) · 1.68 KB
/
TSP-NearestNeighbor.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
import numpy as np
import sys
import time
def Eu2D(x1, y1, x2, y2): #Function to calculate its euclidean distance
return np.sqrt( (x1-x2)**2 + (y1-y2)**2 )
tsp = open("TSP/test.tsp", "r") #Here we type the filename of the .tsp we want to use.
for x in range(3): #Jump lines to Dimension
tsp.readline()
dimension = tsp.readline().split()[1]
n = int(dimension)
for x in range(2):
tsp.readline()
node = []
dM = []
status = [True for i in range(n)]
minium = sys.float_info.max
k = 0
auxI = 0
for i in range(0, n): #Save coordinates in a matrix
x,y = tsp.readline().strip().split()[1:]
node.append([float(x), float(y)])
for i in range (0, n): #Calculate its euclidean distance
x1 = node[i][0]
y1 = node[i][1]
temp = []
for j in range(0, n):
x2 = node[j][0]
y2 = node[j][1]
eD = Eu2D(x1, y1, x2, y2)
temp.append(eD)
dM.append(temp)
i = -1
while i < 1 or i > n:
number = input("\nFrom 1 to "+dimension+"\nStart in: ") #Starting point
i = int(number)
f = i
startTime = time.time() #Calculate execution time
i -= 1
nearn = []
routeCoords = []
total = 0
while k < n:
status[i] = False
nearn.append(i+1)
for j in range(0, n):
if dM[i][j] < minium and status[j] == True and dM[i][j] != 0:
minium = dM[i][j]
auxI = j
i=auxI
k += 1
if k < n:
total += minium
if k == n:
total += dM[k-1][f-1]
minium = sys.float_info.max
execTime = time.time() - startTime
nearn.append(f)
print( "\n"+tsp.name )
print("Route: %s" %nearn)
print("Total distance: %s units" %total )
print("Execution time: %s seconds" %execTime)
tsp.close()