一、 TSP简介

旅行商问题,即TSP问题(Traveling Salesman Problem)又译为旅行推销员问题、货郎担问题,是数学领域中著名问题之一。假设有一个旅行商人要拜访n个城市,他必须选择所要走的路径,路径的限制是每个城市只能拜访一次,而且最后要回到原来出发的城市。路径的选择目标是要求得的路径路程为所有路径之中的最小值。
TSP的数学模型

二、人工鱼群算法简介

1 AFSA的基本思想
人工鱼群算法(artificial fish-swarm algorithm,AFSA)是由李晓磊博士在2002年提出的一种群体智能优化算法。其基本思想是仿照鱼群在一片水域当中寻找最优解的觅食、聚群和追尾等行为,水域中的每一条鱼都对应其中的一个优化解,该水域即为被优化问题的解空间。通过分析人工鱼群的优化理念,可得其人工鱼环境模型如图4所示。假设水域中一条鱼现时状态是X,其可见范围为Visual(公式中用Zvisual表示),在某一时间点对应的视点位置为X k,如果该方位较此时状态更优,则可往该地点处向前一步,即抵达X next;若该方位无此时状态更优,则一直在可见视线内找寻其他较优地点。

2 AFSA路径规划中的具体步骤
1)初始化设置。对鱼群中的各个参数进行初始设置,包括:该人工鱼群的群体规模、视野、最大迭代次数、每一条鱼的最大移动步长Step(公式中用Lstep)等参数。
2)此时迭代的次数是0,由N条鱼组成初始鱼群,每个鱼表示从初始位置到目标位置的一条路径。
3)对每一条人工鱼都进行行为模拟:觅食、追尾、聚群与随机移动行为,选取其中最优的一种行为来操作。
2.1 觅食行为

伪代码段如下:

for i = 1:Nfor j = 1:Try_numberXj=x(i)+Visual.*rand();%人工鱼Xi按式(1)在其视野内随机选择一个状态Xjif f(Xj)<f(x(i))       %比较Xj和Xi的适应度X_next= x(i)+rand()*step*(Xj-x(i))/norm(Xj-x(i)); %人工鱼Xi按式(2)朝着Xj方向移动一步,norm()函数表示二范数 break;elseX_next=x(i)+step*rand();endend
end

2.2 聚群行为
鱼在游动过程中为了保证自身的生存和躲避危害会自然地聚集成群 。人工鱼X i X_iXi​搜索其视野内(d i j < v i s u a l d_{ij}<visualdij​<visual)的伙伴数目n f n_fnf​及中心位置X c X_cXc​,若Y c / n f < δ Y i Y_c/n_f< δY_iYc​/nf​<δYi​(求极小值时使用小于号,在求极大值时则相反;Y c Y_cYc​和Y i Y_iYi​分别为X c X_cXc​和X i X_iXi​的适应度值),表明伙伴中心位置状态较优且不太拥挤,则X i X_iXi​朝伙伴的中心位置移动一步,否则执行觅食行为;
框架图如下所示:

伪代码段如下:

nf=0;X_inside=0;
for i = 1:Nfor j = 1:N   if norm(x(j)-x(i))<Visual         % 求人工鱼Xi与其他人工鱼之间的距离nf = nf+1;                  %统计在视野范围内的鱼数量   X_inside= X_inside+x(j);    %将视野范围内的鱼进行累加endX_inside=X_inside-x(i);         %需要去除Xi本身;因为在 一开始计算时,i=j,把中心的鱼也进行了一次计算nf=nf-1;   Xc = X_inside/nf;              %此时Xc表示Xi感知范围其他伙伴的中心位置; if  f(Xc)/nf < δ*f(x(i))x_next=x(i)+rand*Step*(Xc-x(i))/norm(Xc-x(i)); else进行觅食行动endend
end

2.3 追尾行为
指鱼向其视野区域内的最优方向移动的一种行为。人工鱼X i X_iXi​搜索其视野内(d i j < v i s u a l d_{ij}<visualdij​<visual)适应度最高的个体X j X_jXj​,其适应度值为Y j Y_jYj​,并探索人工鱼X j X_jXj​视野内的伙伴数目n f n_fnf​,若Y j / n f < δ Y i Y_j/n_f< δY_iYj​/nf​<δYi​,表明X j X_jXj​状态较优且不太拥挤,则X i X_iXi​朝X j X_jXj​位置移动一步,否则执行觅食行为;
  框架图如下所示:

伪代码段如下:

Y_max=inf;nf=0;
for i = 1:N    %搜索人工鱼Xi视野范围内的最高适应度个体Xjfor j = 1:N     if norm(x(j)-x(i))<Visual && f(x(j))<Y_max        % 求人工鱼Xi与其他人工鱼之间的距离X_max=x(j);        Y_max=f(x(j));endend%搜索人工鱼Xj视野范围内的伙伴数量for j = 1:N        if(norm(x(j)-X_max)<Visual)       nf=nf+1;endendnf=nf-1;%去掉他本身if Y_max/nf<delta*f(x(i))x_next= x(i,:)+rand*Step.*(temp_maxX-x(i,:))./norm(temp_maxX-x(i,:));else进行觅食行为;end
end

2.4 算法总述
综上所述,算法在运算过程中,会同时进行聚群和追尾行为。而觅食行为属于这两种行为中发现聚群对象或者追尾对象附近拥挤度过大时,人工鱼选择的行为方式,若在觅食过程中,未发现比自身适应度高的人工鱼,则按步长step随机移动。最后对聚群行为和追尾行为得到的适应度值进行比较,选择优秀的人工鱼作为下一代的个体。其总框架图如下:

3 分析拥挤度因子δ
3.1 拥挤度因子的取值

在求极小值问题中:δ = α n m a x , α ∈ ( 0 , 1 ] δ=αn_{max}, α∈(0,1]δ=αnmax​,α∈(0,1]
在求极大值问题中:δ = 1 α n m a x , α ∈ ( 0 , 1 ] δ=\frac{1}{αn_{max}},α∈(0,1]δ=αnmax​1​,α∈(0,1]
其中α αα为极值接近水平,n m a x n_{max}nmax​为期望在该邻域内聚集的最大人工鱼数目。

3.2 拥挤度因子的作用机理
对追尾行为的描述

图中af0为人工鱼af1-5在各自视野内的最优人工鱼,其实物浓度为Y j Y_jYj​,C1为以af0为圆心,以视野范围为半径的圆,即能探知af0的最远距离,人工鱼越靠近af0,状态越优。
求极大值情况下:当δ n f ≤ 1 δn_f\leq 1δnf​≤1时,所有人工鱼af1-5都执行追尾行为,向af0游动;
δ = 1 α n m a x δ=\frac{1}{αn_{max}}δ=αnmax​1​
δ n f = n f α n m a x ≤ 1 δn_f =\frac{n_f}{αn_{max}}\leq 1δnf​=αnmax​nf​​≤1
当α αα=1的时候,可以明显看出来n f ≤ n m a x n_f \leq n_{max}nf​≤nmax​,即说明人工鱼视野范围内不拥挤。
当δ n f > 1 δn_f >1δnf​>1时,若C2的食物浓度为Y j δ n f \frac{Y_j}{δn_f }δnf​Yj​​的等浓度食物圈,则C2与C1间的人工鱼af1、af2、af3执行追尾行动,向af0游动,人工鱼af4、af5执行觅食行为。此时δnf 越大执行追尾行动的人工鱼越少,反之越多。

3.2 拥挤度因子的影响
以极大值为例(极小值的情况正好和极大值相反), δ δδ越大,表明允许的拥挤程度越小,人工鱼摆脱局部最优的能力越强;但是收敛的速度会有所减缓,这主要因为人工鱼在逼近极值的同时,会因避免过分拥挤而随机走开或者受其它人工鱼的排斥作用,不能精确逼近极值点。可见,δ δδ的引入避免了人工鱼过度拥挤而陷入局部极值,另一方面,该参数会使得位于极值点附近的人工鱼之间存在相互排斥的影响,而难以向极值点精确逼近,所以,对于某些局部极值不是很严重的具体问题,可以忽略拥挤的因素,从而在简化算法的同时也加快了算法的收敛速度和提高结果的精确程度。

三、部分源代码

cleartic        afNum=50;                          %人工鱼个数iterativeTime=100;                  %迭代次数try_number=100;                    %随机试探次数crowd=0.618;                       %拥挤度因子sim_model=48;cityPosition=AFTSP_cityPosition(sim_model);cityNum=length(cityPosition);              %城市个数pcross=0.15;                               %引入交换因子crossNum=ceil(pcross*cityNum);             %交换位数for i=1:cityNum                            %任意两城市间距离Distance(i,i)=inf;for j=i+1:cityNumDistance(i,j)=norm(cityPosition(i,:)-cityPosition(j,:));   Distance(j,i)=Distance(i,j);endendfor i=1:afNum                              %初始化X(i,:)=AFTSP_init(cityNum);Ytemp(i)=AFTSP_foodconsistence(X(i,:),Distance);end[a b]=min(Ytemp);YBest=a;XBest=X(b,:);k=1;Ybest=zeros(1,iterativeTime);while(k<=iterativeTime)visual=ceil((4/5-k/(2*iterativeTime))*cityNum);for i=1:afNum    [Xi,flag1]=AFTSP_follow(X,afNum,cityNum,visual,crowd,i,Distance,crossNum);                  %尝试追尾行为if(flag1==0) [Xi,flag2]=AFTSP_swarm(X,afNum,cityNum,visual,crowd,i,Distance,crossNum);               %尝试聚群行为if(flag2==0)Xi=AFTSP_prey(X,cityNum,i,visual,try_number,Distance,crossNum);                      %再尝试觅食行为endend
%下面为考虑公告板的吸引力Xii=Xi;diff1=find(Xii~=XBest);              %求出Xi和XBest中对应元素不一样的位置if(length(diff1)>0)a=randperm(length(diff1));%在随机的floor(length(diff1)/2)个不一样的位置赋XBest的值for ii=1:floor(length(diff1)/2)Xii(a(ii))=XBest(a(ii));enddiff2=find(Xii~=XBest);iii=1;temp1=[];for ii=1:cityNum            %找出赋值后没有出现的城市号if(sum(ii==Xii)==0)temp1(iii)=ii;iii=iii+1;endendiii=1;temp2=[];for ii=1:cityNum            %找出赋值后出现两次的城市号if(sum(ii==Xii)==2)temp2(iii)=ii;iii=iii+1;endendiii=1;temp3=[];for ii=1:length(diff2)      %出现两次的城市在赋值后不同位置的位置if(sum(Xii(diff2(ii))==temp2)==1)temp3(iii)=ii;iii=iii+1;endendfor ii=1:length(temp1)      %把没出现的城市的位置赋到出现两次的城市在赋值后不同位置的位置上Xii(diff2(temp3(ii)))=temp1(ii);endendif(AFTSP_foodconsistence((Xii),Distance)<AFTSP_foodconsistence((Xi),Distance))Xi=Xii;endif(AFTSP_foodconsistence((Xi),Distance)<YBest)XBest=Xi;YBest=AFTSP_foodconsistence((Xi),Distance);endX(ceil(rand*cityNum),:)=XBest;end   disp(['第',num2str(k),'次迭代,得出的最优值:',num2str(YBest)]);k=k+1;
end
s=num2str(XBest(1));
for i=2:cityNums=strcat(s,'->');s=strcat(s,num2str(XBest(i)));
end
s=strcat(s,'->');
s=strcat(s,num2str(XBest(1)));
disp(['得出的最优路径:',s,',最优值:',num2str(YBest)]);
toc
%  plot(Ybest);
%  title('最优值随迭代次数变化曲线');
%  xlabel('迭代次数');
%  ylabel('最优值');
%  figure(2);
%  for i=1:cityNum-1
%      plot([cityPosition(XBest(i),1),cityPosition(XBest(i+1),1)],[cityPosition(XBest(i),2),cityPosition(XBest(i+1),2)]);
%      hold on;
%  end
%  plot([cityPosition(XBest(cityNum),1),cityPosition(XBest(1),1)],[cityPosition(XBest(cityNum),2),cityPosition(XBest(1),2)]);

四、运行结果

五、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1] 包子阳,余继周,杨杉.智能优化算法及其MATLAB实例(第2版)[M].电子工业出版社,2016.
[2]张岩,吴水根.MATLAB优化算法源代码[M].清华大学出版社,2017.

【TSP】基于matlab改进的人工鱼群算法求解旅行商问题【含Matlab源码 1479期】相关推荐

  1. 【AFSA TSP】基于matlab改进的人工鱼群算法求解旅行商问题【含Matlab源码 1479期】

    ⛄一. TSP简介 旅行商问题,即TSP问题(Traveling Salesman Problem)又译为旅行推销员问题.货郎担问题,是数学领域中著名问题之一.假设有一个旅行商人要拜访n个城市,他必须 ...

  2. 【AFSA TSP】基于matlab人工鱼群算法求解旅行商问题【含Matlab源码 422期】

    一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[TSP]基于matlab人工鱼群算法求解旅行商问题[含Matlab源码 422期] 点击上面蓝色字体,直接付费下载,即可. 获取代码方式2 ...

  3. 【Matlab身份证识别】身份证号码识别【含GUI源码 014期】

    一.代码运行视频(哔哩哔哩) [Matlab身份证识别]身份证号码识别[含GUI源码 014期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅.MAT ...

  4. 【Matlab车牌识别】停车计费系统【含GUI源码 735期】

    一.代码运行视频(哔哩哔哩) [Matlab车牌识别]停车计费系统[含GUI源码 735期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅.MATLA ...

  5. 【Matlab生物电信号】生物电信号仿真【含GUI源码 684期】

    一.代码运行视频(哔哩哔哩) [Matlab生物电信号]生物电信号仿真[含GUI源码 684期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]董兵,超于毅,李 ...

  6. 【Matlab语音分析】语音信号分析【含GUI源码 1718期】

    一.代码运行视频(哔哩哔哩) [Matlab语音分析]语音信号分析[含GUI源码 1718期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]韩纪庆,张磊,郑铁 ...

  7. 【Matlab水果识别】自助水果超市【含GUI源码 594期】

    一.代码运行视频(哔哩哔哩) [Matlab水果识别]自助水果超市[含GUI源码 594期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]倪云峰,叶健,樊娇娇 ...

  8. 【路径规划-TSP问题】基于粒子群结合蚁群算法求解旅行商问题附matlab代码

    1 内容介绍 一种基于粒子群优化的蚁群算法求解TSP问题的方法.该方法在求解TSP问题时,利用粒子群优化的思想,对蚁群算法的参数取值进行优化并选择.在粒子群算法中,将蚁群算法的5个参数(q,α,β,ρ ...

  9. 【ACO TSP】基于matlab改进的蚁群算法求解旅行商问题【含Matlab源码 242期】

    ⛄一.TSP简介 旅行商问题,即TSP问题(Traveling Salesman Problem)又译为旅行推销员问题.货郎担问题,是数学领域中著名问题之一.假设有一个旅行商人要拜访n个城市,他必须选 ...

  10. 改进的人工鱼群算法求解TSP问题的研究(Matlab代码实现)

最新文章

  1. Leetcode 6
  2. AspNet MVC与T4,我定制的视图模板
  3. 梯度下降与delta法则
  4. 全国计算机一级在线模拟试题,全国计算机一级模拟试题及答案
  5. 交流电机数字控制系统_敲黑板!新型变频调速控制系统对交流电动机设计的特殊要求...
  6. codeforces B. Fox and Cross 解题报告
  7. 【华为HCNA】访问控制列表ACL实例配置
  8. IP头、TCP头、UDP头详解以及定义
  9. 信号与系统 chapter8 LTI连续系统的描述
  10. edpluse怎么运行c语言,[JSP]小菜也来学Editplus+Tomcat配置jsp运行环境
  11. 使用d3.v5实现折线图与面积图
  12. Pose-Aware Face Recognition in the Wild--填坑1
  13. 大数据分析常用的方法有哪些
  14. YARN REST API
  15. Js/Jquery获取input file的文件名
  16. solr4.2增量索引之同步(修改,删除,新增)
  17. 爆改串口实现OneWire驱动DS18B20
  18. 微信小程序开发多少钱?微信小程序开发费用
  19. centos7 后端部署文档
  20. 如何在web项目中访问HTML页面

热门文章

  1. MySQL-第十四篇事务管理
  2. Ubuntu下对executable (application/x-executable)文件创建快捷方式
  3. std::string std::wstring 删除最后元素 得到最后元素
  4. 线程之线程池(ExecutorService)
  5. Python 正则式学习笔记 [转]
  6. ESP8266(2)
  7. Python3入门机器学习经典算法与应用 第3章 numpy.array 中的运算
  8. 190705每日一句; 寻找内心的勇气, 一切从零开始
  9. Atitit 2018 技术趋势与没落技术总结 目录 1. 2018 技术雷达 1 1.1. HOSTED IDENTITY MANAGEMENT AS A SERVICE (SaaS)身份管理
  10. Atitit 搜索工程师的知识点体系总结 目录 1.1. 理论类 索引 与查询 1 1.2. 类库类 1 1.3. 关联知识类 1 1.4. 其他 1 2. Ref 2 2.1. Atitit 文