一、能量谷优化算法EVO
能量谷优化算法(Energy valley optimizer,EVO)是MahdiAzizi等人于2023年提出的一种新颖的元启发式算法,其灵感来自关于稳定性和不同粒子衰变模式的物理原理。能量谷优化算法(Energy valley optimizer,EVO)_IT猿手的博客-CSDN博客
参考文献
[1]Azizi, M., Aickelin, U., A. Khorshidi, H. et al. Energy valley optimizer: a novel metaheuristic algorithm for global and engineering optimization. Sci Rep 13, 226 (2023). https://doi.org/10.1038/s41598-022-27344-y
二、多仓库多旅行商问题MD-MTSP
多旅行商问题(Multiple Traveling Salesman Problem, MTSP)是著名的旅行商问题(Traveling Salesman Problem, TSP)的延伸,多旅行商问题定义为:给定一个𝑛座城市的城市集合,指定𝑚个推销员,每一位推销员从起点城市出发访问一定数量的城市,最后回到终点城市,要求除起点和终点城市以外,每一座城市都必须至少被一位推销员访问,并且只能访问一次,需要求解出满足上述要求并且代价最小的分配方案,其中的代价通常用总路程长度来代替,当然也可以是时间、费用等。多仓库多旅行商问题是其中一种多旅行商问题。
多旅行商问题(Multiple Traveling Salesman Problem, MTSP):单仓库多旅行商问题及多仓库多旅行商问题(含动态视频)_IT猿手的博客-CSDN博客
多仓库多旅行商问题(Multi-Depot Multiple Travelling Salesman Problem, MD-MTSP):𝑚个推销员从𝑚座不同的城市出发,访问其中一定数量的城市并且每座城市只能被某一个推销员访问一次,最后回到各自出发的城市,这种问题模型被称之为MD-MTSP。
三、能量谷优化算法EVO求解MD-MTSP
本文选取国际通用的TSP实例库TSPLIB中的测试集bayg29作为测试例子,数据集可以自行修改。
3.1部分代码(可更改起点及旅行商个数)
close all
clear
clc
global data StartPoint Tnum
%数据集参考文献 REINELT G.TSPLIB-a traveling salesman problem[J].ORSA Journal on Computing,1991,3(4):267-384.
% 导入TSP数据集 bayg29
load('data.txt')
StartPoint=[1 5 15 16 20];%起点城市的序号(可以修改) 必须由小到大排列 (建议:2到6个旅行商)
Tnum=length(StartPoint);%旅行商个数
Dim=size(data,1)-Tnum;%维度
lb=-100;%下界
ub=100;%上界
fobj=@Fun;%计算总距离
SearchAgents_no=100; % 种群大小(可以修改)
Max_iteration=300; % 最大迭代次数(可以修改)
[fMin,bestX,curve]=EVO(SearchAgents_no,Max_iteration,lb,ub,Dim,fobj);
3.2部分结果
(1)4个旅行商
第1个旅行商的路径:1->28->12->6->5->21->2->1
第1个旅行商的总路径长度:868.216563
第2个旅行商的路径:15->10->29->3->26->9->27->15
第2个旅行商的总路径长度:1759.431726
第3个旅行商的路径:16->13->18->22->14->4->25->16
第3个旅行商的总路径长度:1240.886780
第4个旅行商的路径:20->24->8->23->7->19->11->17->20
第4个旅行商的总路径长度:1730.606830
所有旅行商的总路径长度:5599.141899
(2)5个旅行商
第1个旅行商的路径:1->25->7->23->8->1
第1个旅行商的总路径长度:1380.434714
第2个旅行商的路径:5->2->6->28->12->5
第2个旅行商的总路径长度:983.564944
第3个旅行商的路径:15->4->18->14->11->15
第3个旅行商的总路径长度:686.876990
第4个旅行商的路径:16->27->24->13->19->16
第4个旅行商的总路径长度:716.937933
第5个旅行商的路径:20->29->3->26->9->21->10->22->17->20
第5个旅行商的总路径长度:1686.416319
所有旅行商的总路径长度:5454.230901
四、完整Matlab代码
文件夹内包含完整MATLAB代码,点击main.m即可运行,同时提供使用说明,可更改数据集,旅行商的数量和起点。