matlab安装可以在网上找一个安装教程,我安装的是R2020a版本的。
学习解决该问题
利用蚁群算法对给定的TSP问题进行求解,求出一条最短路径。
用的是194个城市的TSPLIB数据集,如果需要TSPLIB数据集可点击 tsp、添加了可视化,迭代400次,目前最短路径为10576.5454,实现效果如下:
首先下载一个TSPLIB数据集文件,这种文件包含描述部分和数据部分。描述部分包含文件格式信息和数据的信息。数据部分包含确切的数据。
格式大概是这种:
NAME:< string >
标识数据文件。
TYPE: < string >
表示数据的类型。有TSP:对称旅行商问题;ATSP:非对称旅行商问题。
COMMENT:< string >
附加的注释(通常包含这个问题实例的创建者或贡献者的名字)。
DIMENSION: < integer >
维数,表示节点的个数。
CAPACITY: < integer >
在车辆路径问题(CVRP)中表示卡车的容量。
EDGE_WEIGHT_TYPE: < string >
表示边如何计量。
EXPLICIT | 会明确给出 |
---|---|
EUC_2D | 二维的欧几里德距离 |
EUC_3D | 三维的欧几里德距离 |
MAX_2D | 二维空间中最大距离 |
MAX_3D | 三维空间中最大距离 |
MAN_2D | 二维的曼哈顿距离 |
MAN_3D | 三维的曼哈顿距离 |
CEIL_2D | 对二维的欧几里德距离上取整 |
GEO | 实际距离 |
ATT | 对于att48和att532的距离描述函数 |
我的TSPLIB数据集EDGE_WEIGHT_TYPE部分是EUC_2D
EOF:
结束标志。这项是可选的。
我的TSPLIB文件的EDGE_WEIGHT_TYPE是EUC_2D
新建一个工作目录 mkdir Directory
,并将其添加到搜索路径
然后改变工作目录到Directory目录下
cd 'F:\MATLABFile\bin\Directoryone'
在当前目录下新建一个单独的acoTSP.m函数文件,内容如下:
acoTSP.m:
function [bestRoute, bestCost] = acoTSP(tsplibFilename, numAnts, numIterations, alpha, beta, rho, Q)
% 读取TSPLIB文件并解析
[coords, numCities, distMatrix] = readTSPLIB(tsplibFilename);
numCities = size(distMatrix, 1);
% 检查numCities是否为正整数
if ~isnumeric(numCities) || numCities <= 0 || isnan(numCities) || isinf(numCities)
error('无效的城市数量。');
end
% 初始化参数
if numCities <= 0
error('Number of cities must be a positive integer.');
end
pheromoneMatrix = ones(numCities,numCities)* 0.1; % 信息素矩阵
pheromoneMatrix(eye(size(pheromoneMatrix)) == 1) = 0;
% 初始化保存每一代最短成本和平均成本的数组
bestCosts = zeros(numIterations, 1);
averageCosts = zeros(numIterations, 1);
% 蚁群算法主循环
bestCost = inf;
bestRoute = [];
for iter = 1:numIterations
antRoutes = zeros(numAnts, numCities + 1); % +1 for the return to the starting city
antCosts = zeros(numAnts, 1);
%disp(['Number of cities: ', num2str(numCities)]);
for ant = 1:numAnts
currentCity = randi(numCities); % 确保numCities是正整数
antRoutes(ant, 1