-
Notifications
You must be signed in to change notification settings - Fork 187
/
DP.py
112 lines (99 loc) · 3.23 KB
/
DP.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
import math
import matplotlib.pyplot as plt
import numpy as np
## 动态规划法
class DP(object):
def __init__(self, num_city, num_total, iteration, data):
self.num_city = num_city
self.location = data
self.dis_mat = self.compute_dis_mat(num_city, data)
# 计算不同城市之间的距离
def compute_dis_mat(self, num_city, location):
dis_mat = np.zeros((num_city, num_city))
for i in range(num_city):
for j in range(num_city):
if i == j:
dis_mat[i][j] = np.inf
continue
a = location[i]
b = location[j]
tmp = np.sqrt(sum([(x[0] - x[1]) ** 2 for x in zip(a, b)]))
dis_mat[i][j] = tmp
return dis_mat
# 计算路径长度, goback:是否计算回到起始点的路径
def compute_pathlen(self, path, dis_mat, goback=True):
try:
a = path[0]
b = path[-1]
except:
import pdb
pdb.set_trace()
if goback:
result = dis_mat[a][b]
else:
result = 0.0
for i in range(len(path) - 1):
a = path[i]
b = path[i + 1]
result += dis_mat[a][b]
return result
# 动态规划过程
def run(self):
restnum = [x for x in range(1, self.num_city)]
tmppath = [0]
tmplen = 0
while len(restnum) > 0:
c = restnum[0]
restnum = restnum[1:]
if len(tmppath) <= 1:
tmppath.append(c)
tmplen = self.compute_pathlen(tmppath, self.dis_mat)
continue
insert = 0
minlen = math.inf
for i, num in enumerate(tmppath):
a = tmppath[-1] if i == 0 else tmppath[i - 1]
b = tmppath[i]
tmp1 = self.dis_mat[c][a]
tmp2 = self.dis_mat[c][b]
curlen = tmplen + tmp1 + tmp2 - self.dis_mat[a][b]
if curlen < minlen:
minlen = curlen
insert = i
tmppath = tmppath[0:insert] + [c] + tmppath[insert:]
tmplen = minlen
return self.location[tmppath], tmplen
# 读取数据
def read_tsp(path):
lines = open(path, 'r').readlines()
assert 'NODE_COORD_SECTION\n' in lines
index = lines.index('NODE_COORD_SECTION\n')
data = lines[index + 1:-1]
tmp = []
for line in data:
line = line.strip().split(' ')
if line[0] == 'EOF':
continue
tmpline = []
for x in line:
if x == '':
continue
else:
tmpline.append(float(x))
if tmpline == []:
continue
tmp.append(tmpline)
data = tmp
return data
data = read_tsp('data/st70.tsp')
data = np.array(data)
data = data[:, 1:]
model = DP(num_city=data.shape[0], num_total=25, iteration=500, data=data.copy())
Best_path, Best = model.run()
print('规划的路径长度:{}'.format(Best))
# 显示规划结果
plt.scatter(Best_path[:, 0], Best_path[:, 1])
Best_path = np.vstack([Best_path, Best_path[0]])
plt.plot(Best_path[:, 0], Best_path[:, 1])
plt.title('st70:动态规划规划结果')
plt.show()