人工蜂群算法求解TSP问题

2024-06-13 10:08

本文主要是介绍人工蜂群算法求解TSP问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

人工蜂群算法求解TSP问题

【标签】 ABC TSP Matlab

data:2018-10-19 author:怡宝2号

【总起】利用人工蜂群算法(Artificial Bee Colony Algorithm, 简称ABC算法)求解TSP问题,语言:matlab

1. 算法简介

人工蜂群算法(Artificial Bee Colony Algorithm, 简称ABC算法)是一个由蜂群行为启发的算法,在2005年由Karaboga小组为优化代数问题而提出。其主要是为了解决多变量函数优化问题。

2. 算法原理

标准的ABC算法通过模拟实际蜜蜂的采蜜机制将人工蜂群分为3类: 采蜜蜂、观察蜂和侦察蜂。整个蜂群的目标是寻找花蜜量最大的蜜源。在标准的ABC算法中,采蜜蜂利用先前的蜜源信息寻找新的蜜源并与观察蜂分享蜜源信息;观察蜂在蜂房中等待并依据采蜜蜂分享的信息寻找新的蜜源;侦查蜂的任务是寻找一个新的有价值的蜜源,它们在蜂房附近随机地寻找蜜源。所以算法总体分为3个部分。
假设问题的解空间是D维的,采蜜蜂与观察蜂的个数都是S,采蜜蜂的个数或观察蜂的个数与蜜源的数量相等。则标准的ABC算法将优化问题的求解过程看成是在D维搜索空间中进行搜索。每个蜜源的位置代表问题的一个可能解,蜜源的花蜜量对应于相应的解的适应度。一个采蜜蜂与一个蜜源是相对应的。与第i个蜜源相对应的采蜜蜂依据如下公式寻找新的蜜源:
在这里插入图片描述
其中,i=1,2,···,S,表示蜜源、采蜜蜂、观察蜂的个数,D=1,2,···,D,表示优化变量的个数。Φid为[-1,1]之间的随机数,k≠i。
将新生成的可能解{Xi1’,Xi2’,···,XiD’}与原来的解{Xi1,Xi2,···,XiD}做比较,采用贪婪选择策略保留较好的解。
在这里插入图片描述
对每个采蜜蜂按上式对每个采蜜蜂计算一个概率。观察蜂以上面计算的概率接受采蜜蜂,并利用采蜜蜂更新的公式进行更新,再进行贪婪选择。
当所有的采蜜蜂和观察蜂都搜索完整个搜索空间时,如果一个蜜源的适应值在给定的步骤内(定义为控制参数“limit”) 没有被提高, 则丢弃该蜜源,而与该蜜源相对应的采蜜蜂变成侦查蜂,侦查蜂通过已下公式搜索新的可能解。
在这里插入图片描述
[xdmin]: https://img-blog.csdn.net/201810191750084?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTE2MjIyMDg=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70
其中,r是[0,1]的随机数,xmin和xmax是第d个变量空间的下界和上界。

3. 模型

TSP问题,就是从一个点出发,再回到出发点,要求整个的最短路线。具体数学公式如下:
在这里插入图片描述
在这里插入图片描述

4. 总结

  • 人工蜂群算法主要分:采蜜、观察、侦察三个阶段;
  • 整个原理和遗传算法的原理很类似,采蜜蜂就相当于初始化父代chrom,观察蜂相当于轮盘赌选择之后的子代,侦察蜂就是在limit次中没能找到更优秀的解时,舍弃该解,再随机初始化。

5. 程序和结果

% 人工蜂群算法求解TSP问题
% 参数:
% 输出:
% 
% 有问题详咨询:778961303@qq.com
% (有偿代写程序)close allclc
% 人工蜂群算法求解TSP问题
% 参数:
% 输出:
% 
% 有问题详咨询:778961303@qq.com(有偿代写程序)close all
clc
%% 参数初始化
parameter = initial();%% 画初始路径图
initialDraw(parameter);runtime=10;        %通过修改runtime的值,改变程序的运行次数,用以算法的健壮性
GlobalMins=zeros(1,runtime);
for r=1:runtime%初始化种群
%     for i =1:FoodNumberFoods = initial(runtime,NC);
%     end
%计算适应度函数值for i=1:FoodNumberroute=Foods(i,:);Fitness(i)=calculateFitness1(route);end%% 初始化搜索次数,用于和Limit比较trial=zeros(1,FoodNumber);%找出适应度函数值的最小值BestInd=find(Fitness==min(Fitness));BestInd=BestInd(end);       %避免有两个相同的位置,只取其一GlobalMin=Fitness(BestInd);GlobalParams=Foods(BestInd,:);%迭代开始iter=1;     %初始化迭代次数j=1;        %用以初始化结果while((iter<=maxCycle))%%%%%% 采蜜蜂模式 %%%%%%for i=1:FoodNumber%计算新蜜源的适应度函数值FitnessSol=calculateFitness1(route_next);%使用贪婪准则,寻找最优蜜源if (FitnessSol<Fitness(i)) %若找到更好的蜜源,搜索次数清零Foods(i,:)=route_next;Fitness(i)=FitnessSol;trial(i)=0;elsetrial(i)=trial(i)+1;  %超过设定的Limit次,则该蜂成为侦察蜂end;end;%%%%%% 根据适应度值计算彩蜜蜂被跟随的概率 %%%%%%prob=(0.9.*Fitness./max(Fitness))+0.1;%%%%%% 观察蜂 %%%%%%i=1;      %要跟随的采蜜蜂t=0;      %标记观察蜂while(t<FoodNumber)if (rand<prob(i))   %按概率选择要跟随的采蜜蜂t=t+1;%计算新蜜源的适应度函数值FitnessSol=calculateFitness1(route_next);%使用贪婪准则,寻找最优蜜源if (FitnessSol<Fitness(i))%若找到更好的蜜源,搜索次数清零Foods(i,:)=route_next;Fitness(i)=FitnessSol;trial(i)=0;elsetrial(i)=trial(i)+1;%超过设定的Limit次,则该蜂成为侦察蜂endendi=i+1;                      %要跟随的下一个采蜜蜂if (i==(FoodNumber)+1)i=1;endend% 记录此时更好的解ind=find(Fitness==min(Fitness));ind=ind(end);if (Fitness(ind)<GlobalMin)GlobalMin=Fitness(ind);GlobalParams=Foods(ind,:);end%%%%%% 侦查蜂模式 %%%%%%ind=find(trial==max(trial));ind=ind(end);if (trial(ind)>Limit)   %若搜索次数超过极限值,则进行随机搜索产生新解FitnessSol=calculateFitness1(route_new);Foods(ind,:)=route_new;Fitness(ind)=FitnessSol;end%%%%%% 建立一个次数和最优的矩阵,以便于画图 %%%%%%Cishu(j)=iter;          %迭代次数行向量zuiyou(j)=GlobalMin;    %每次迭代得到的最优解j=j+1;iter=iter+1;end % while(iter<=maxClcle)GlobalMins(r)=GlobalMin;    %程序运行完一次,记录这次的最优路径长度disp(['第',num2str(r),'次运行得到的最优路径是:',num2str(GlobalParams),',此条路径的长度是:',num2str(GlobalMins(r))])
end %end of runs
%%%%%% 画曲线图 %%%%%%
figure(2);
plot(Cishu,zuiyou,'b');
%title('优化曲线');
xlabel('迭代次数');
ylabel('路径长度');
figure(3);%%画出优化路径图
finalDraw(GlobalMin, parameter)

结果:
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

这篇关于人工蜂群算法求解TSP问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1057000

相关文章

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM

IDEA Maven提示:未解析的依赖项的问题及解决

《IDEAMaven提示:未解析的依赖项的问题及解决》:本文主要介绍IDEAMaven提示:未解析的依赖项的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录IDEA Maven提示:未解析的依编程赖项例如总结IDEA Maven提示:未解析的依赖项例如

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模