蚁群算法及其应用

article/2025/10/3 4:41:43

产生背景

20世纪90年代初,意大利科学家Marco Dorigo等受蚂蚁觅食行为的启发,提出蚁群算法(Ant Colony Optimization,ACO)。
一种应用于组合优化问题的启发式搜索算法。
在解决离散组合优化方面具有良好的性能。

基本思想

信息素跟踪:

按照一定的概率沿着信息素较强的路径觅食。

信息素遗留:

会在走过的路上会释放信息素,使得在一定的范围内的其他蚂蚁能够觉察到并由此影响它们的行为。
在这里插入图片描述

(1)环境:

有障碍物、有其他蚂蚁、有信息素。

(2)觅食规则:

范围内寻找是否有食物,否则看是否有信息素,每只蚂蚁都会以小概率犯错。

(3)移动规则:

都朝信息素最多的方向移动,无信息素则继续朝原方向移动,且有随机的小的扰动,有记忆性。

(4)避障规则:

移动的方向如有障碍物挡住,蚂蚁会随机选择另一个方向。

(5)信息素规则:

越靠近食物播撒的信息素越多,越离开食物播撒的信息素越少。

基本蚁群算法模型

蚁群优化算法的第一个应用是著名的旅行商问题。

旅行商问题(Traveling Salesman Problem,TSP):

在寻求单一旅行者由起点出发,通过所有给定的需求点之后,最后再回到原点的最小路径成本。

蚂蚁搜索食物的过程 :

通过个体之间的信息交流与相互协作最终找到从蚁穴到食物源的最短路径。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
其中:
在这里插入图片描述
在这里插入图片描述

蚂蚁圈系统(Ant-cycle System)

在这里插入图片描述

蚂蚁数量系统(Ant-quantity System)

在这里插入图片描述

蚂蚁密度系统(Ant-density System)

在这里插入图片描述

三种模型比较

效果最好,通常作为蚁群优化算法的基本模型。
在这里插入图片描述

全局信息更新方法

优点:
保证了残留信息素不至于无限累积;
如果路径没有被选中,那么上面的残留信息素会随时间的推移而逐渐减弱,这使算法能“忘记”不好的路径;
即使路径经常被访问也不至于因为在这里插入图片描述
的累积,而产生在这里插入图片描述
使期望值的作用无法体现;
充分体现了算法中全局范围内较短路径(较好解)的生存能力;
加强了信息正反馈性能;
提高了系统搜索收敛的速度。

蚁群算法的参数选择

信息素启发因子a

反映了蚁群在路径搜索中随机性因素作用的强度;
a值越大,蚂蚁选择以前走过的路径的可能性越大,搜索的随机性减弱;
当a过大时会使蚁群的搜索过早陷于局部最优。

期望值启发式因子b

反映了蚁群在路径搜索中先验性、确定性因素作用的强度;
b值越大,蚂蚁在某个局部点上选择局部最短路径的可能性越大;
虽然搜索的收敛速度得以加快,但蚁群在最优路径的搜索过程中随机性减弱,易于陷入局部最优。

信息素挥发度1-p

当要处理的问题规模比较大时,会使那些从来未被搜索到的路径(可行解)上的信息量减小到接近于0,因而降低了算法的全局搜索能力;
而且当1-p过大时,以前搜索过的路径被再次选择的可能性过大,也会影响到算法的随机性能和全局搜索能力;
反之,通过减小信息素挥发度 1-p虽然可以提高算法的随机性能和全局搜索能力,但又会使算法的收敛速度降低。
在这里插入图片描述

蚁群算法的应用

柔性作业车间调度问题:某加工系统有6台机床,要加工4个工件,每个工件有3道工序,如表所示。
在这里插入图片描述

由图可以看出机器6并没有加工任何工件。分析其原因为它虽然可以加工工序p23 ,p33 ,p42 ,p43 但从表6.5可知机器6的加工时间大于其他可加工机器,特别是 p23 ,p33的加工时间,因此机器6并未分到任何加工任务。
在这里插入图片描述

最优解甘特图
在这里插入图片描述

由图可知,算法在大约30代以前就收敛到最优解,且各代最优解相差不大,可见算法较为稳定。
欢迎大家加我微信交流讨论(请备注csdn上添加)
在这里插入图片描述


http://chatgpt.dhexx.cn/article/nWiYIMl6.shtml

相关文章

蚁群算法原理及python代码实现

本文转载自:https://blog.csdn.net/fanxin_i/article/details/80380733 蚁群算法(AG)是一种模拟蚂蚁觅食行为的模拟优化算法,它是由意大利学者Dorigo M等人于1991年首先提出,并首先使用在解决TSP(旅行商问题)上。 之后…

蚁群算法原理以及应用

关键词:启发式算法 蚁群算法 迭代 正反馈 1.蚁群算法(ant colony algorithm,ACA)起源和发展历程 Marco Dorigo等人在研究新型算法的过程中,发现蚁群在寻找食物时,通过分泌一种称为信息素的生物激素交流觅食信息从而能快速的找到目标,于是在1991年在其博士论文中首次系统地提…

蚁群算法浅谈

本文参考:http://www.cnblogs.com/biaoyu/archive/2012/09/26/2704456.html http://blog.163.com/ykn_2010/blog/static/1420333362012111411258466/ 简介 蚁群算法(ant colony optimization, ACO),又称蚂蚁算法,是一种用…

【转载】蚁群算法原理及实现

转自:https://blog.csdn.net/yy2050645/article/details/80820287 蚁群算法 蚁群算法,也是优化算法当中的一种。蚁群算法擅长解决组合优化问题。蚁群算法能够有效的解决著名的旅行商问题(TSP),不止如此,在…

蚁群算法原理及c++实现

参考博客 https://blog.csdn.net/Oudasheng/article/details/84994336 https://blog.csdn.net/wayjj/article/details/72809344#commentsedit https://blog.csdn.net/Oudasheng/article/details/84994336 https://www.cnblogs.com/mahaitao/p/5572095.html https://www.cnblogs…

10分钟搞懂蚁群算法

蚂蚁几乎没有视力,但他们却能够在黑暗的世界中找到食物,而且能够找到一条从洞穴到食物的最短路径。它们是如何做到的呢? 蚂蚁寻找食物的过程 单只蚂蚁的行为及其简单,行为数量在10种以内,但成千上万只蚂蚁组成的蚁群却…

蚁群算法的简单理解

蚁群优化算法是意大利学者等人在世纪年代初提出的一种源于生物世界的新型启发式仿生算法。它是从自然界中蚂蚁觅食过程的协作方式得到启发而研究产生的。 在自然界中,蚁群可以在其觅食的过程中逐渐寻找到食物源与巢穴之间的最短路径。单个蚂蚁在运动过程中能够分泌…

蚁群算法原理及matlab代码实现

蚁群算法基本原理: 背景: 在自然界中,生物群体所表现出的智能得到越来越多的关注,许多的群智能优化算法都是通过对群体智能的模拟而实现的。其中模拟蚂蚁群体觅食的蚁群算法成为一种主要的群智能算法。 算法原理: 在…

蚁群算法介绍

前言:本篇文章主要讲述蚁群算法以及相关算法的matlab实现 一、蚁群算法 蚁群算法是在20世纪90年代由澳大利亚学者Marco Dorigo等人通过观察蚁群觅食的过程,发现众多蚂蚁在寻找食物的过程中,总能找到一条从蚂蚁巢穴到食物源之间的最短路径。随…

优化算法3--蚁群算法(原理)

1 算法简介 优化问题在科学和工业领域都非常重要。这些优化问题的实际例子有时间表调度、护理时间分配调度、列车调度、容量规划、旅行商问题、车辆路径问题、群店调度问题、组合优化等。为此,开发了许多优化算法。蚁群优化就是其中之一。 蚁群优化(Ant colony op…

蚁群算法(实例帮助理解)

1. 算法简介1.1 算法起源1.2 算法应用 2. 基本原理3. 算法设计3.1 算法步骤3.2 参数意义及设置3.3 构建路径3.4 更新信息素浓度3.5 判断是否中止 4. 实例演示(TSP问题) 1. 算法简介 1.1 算法起源 蚁群算法(ant colony optimization, ACO),又…

蚂蚁算法蚁群算法-原理-思路-步骤-程序实现

蚂蚁算法蚁群算法-原理-思路-步骤-程序实现 ❀算法介绍 历史 蚁群优化算法是一种用来在图中寻找优化路径的机率型算法。它由Marco Dorigo于1992年在他的博士论文中提出,其灵感来源于蚂蚁在寻找食物过程中发现路径的行为。蚁群算法是一种模拟进化算法,…

蚁群算法原理及其实现(python)

蚁群算法(AG)是一种模拟蚂蚁觅食行为的模拟优化算法,它是由意大利学者Dorigo M等人于1991年首先提出,并首先使用在解决TSP(旅行商问题)上。 之后,又系统研究了蚁群算法的基本原理和数学模型. 蚁群算法的基本思想: 蚁群…

智能算法——蚁群算法

1、原理 蚁群算法是受到对真实蚂蚁群觅食行为研究的启发而提出。生物学研究表明:一群相互协作的蚂蚁能够找到食物和巢穴之间的最短路径,而单只蚂蚁则不能。生物学家经过大量细致观察研究发现,蚂蚁个体之间的行为是相互作用相互影响的。蚂蚁在运动过程中,能够在它所…

蚁群算法理解与实现

蚁群算法,也是优化算法当中的一种。蚁群算法擅长解决组合优化问题。蚁群算法能够有效的解决著名的旅行商问题(TSP),不止如此,在其他的一些领域也取得了一定的成效,例如工序排序问题,图着色问题&…

蚁群算法(ACO)学习笔记

蚁群算法笔记 最近阅读论文,提到几种常见的搜索算法,于是对比学习一下。本文转载数据之巅大神文章对蚁群算法进行简单介绍,并用C语言编码实现蚁群算法来解决旅行商(TSP)问题。 1 蚁群算法基本原理 1.1 算法综述 对于…

【智能算法第一期】蚁群算法原理和多种改进方法

1. 什么是蚁群算法? 蚁群算法的本身来源于一种生物的自然现象,即蚂蚁在寻找食物过程中发现路径的行为,是一种模拟进化的算法。蚁群算法的寻优快速性是由通过正反馈式的信息传递和积累来实现的,分布式计算特征可以避免算法的早熟收…

蚁群算法

文章目录 一、蚁群算法原理二、蚁群算法参数改变测试 一、蚁群算法原理 蚁群算法(AG)是一种模拟蚂蚁觅食行为的模拟优化算法,它是由意大利学者Dorigo M等人于1991年首先提出,并首先使用在解决TSP(旅行商问题)上。之后&#xff0c…

蚁群算法详解

1、算法背景及原理 蚁群算法是一种智能优化算法,在TSP商旅问题上得到广泛使用。蚁群算法于1992年由Marco Dorigo首次提出,该算法来源于蚂蚁觅食行为。由于蚂蚁没有视力,所以在寻找食物源时,会在其经过的路径上释放一种信息素&…

Linux:详解 用户,用户组的解释创建等。

文章目录 Linux中用户和组的类型1、Linux下的用户可以分为三类2、Linux中的组有以下两类3、Linux中用户和用户组的配置文件(1)用户账号文件——/etc/passwdpasswd(2)用户密码文件——/etc/shadow(3)用户组账…