干货|蚁群算法求解带时间窗的车辆路径规划问题详解(附Java代码)

简介: 干货|蚁群算法求解带时间窗的车辆路径规划问题详解(附Java代码)

学 习 警 告

一眨眼春节又过去了,相信很多同学也和小编一样,度过了一段时间相对轻松的时光。

当然,玩耍过后也不能忘记学习。本着~造福人类~的心态,小编又开始干活,为大家带来 有 · 趣 的干货算法内容了!

微信图片_20220423093734.jpg


本期为大家带来的内容是蚁群算法,解决大家熟悉的带时间窗的车辆路径规划问题。关于蚁群算法,公众号内已经有相关内容介绍TSP:

干货 | 十分钟快速搞懂什么是蚁群算法(Ant Colony Algorithm, ACA)(附代码)

本文主要分为以下部分:

蚁群算法简介

蚁群算法与VRPTW

代码测试

笔记总结



01


蚁群算法简介

蚁群系统(Ant System或Ant Colony System)一种群体仿生类算法,灵感来源于在蚂蚁觅食的过程。学者们发现,单个蚂蚁的行为比较简单,但是蚁群整体却可以体现一些智能的行为,例如可以在不同的环境下找到到达食物源的最短路径

经进一步研究发现,蚂蚁会在其经过的路径上释放一种可以称之为“信息素”(phenomenon)的物质,蚁群内的蚂蚁对信息素具有感知能力,它们会沿着信息素浓度较高路径行走,而每只路过的蚂蚁都会在路上留下信息素。这样经过一段时间后,整个蚁群就会沿着最短路径到达食物源了。

微信图片_20220423093737.png

蚁群算法通过模仿蚂蚁“每次在经过的较短路径上留下信息素”的行为,通过信息素记录下较优结果,不断逼近最优解。


02


蚁群算法与VRPTW

VRPTW在之前的推文里已经提到过多次了,这里不再详细介绍。感兴趣的朋友可以看过去的推文:

禁忌搜索算法求解带时间窗的车辆路径规划问题详解(附Java代码)

通过上面的介绍,大家不难想到,蚁群算法的关键在于信息素的利用。在蚁群寻找食物时,每次都由一只蚂蚁从头开始寻找(不同于禁忌搜索或遗传算法的邻域动作);每次寻找的不同点在于信息素的改变:不断靠近信息素较浓的路径


用蚁群算法解决VRPTW的过程主要分为以下几步:


1.初始化蚂蚁信息(以下用agents表示);

2.为每位agents构造完整路径;

3.更新信息素;

4.迭代,保存最优解。

 

算法的关键在第二步:构造解时该如何查找下一个服务的客户。

我们用以下公式计算客户j被服务的概率:




微信图片_20220423093741.jpg微信图片_20220423093744.jpg微信图片_20220423093747.jpg微信图片_20220423093749.jpg




03


代码测试

这次代码是由小编亲自编写的,由于是第一次编写ACS的VRPTW代码,有不周之处还请多包涵。


因为小编太懒了,具体代码就不在此展示了,有兴趣的朋友可以在公众号内输入【ACSVRP】不带【】即可下载对应Java代码。




这里展示一下代码的运行情况。对Solomon Benchmark C101算例的测试效果如下:


25点(迭代次数1000,算例最优解191.3):

微信图片_20220423093947.jpg

50点(迭代次数1000,算例最优解362.4):

微信图片_20220423093951.jpg

100点(迭代次数1000,算例最优解827.3):

微信图片_20220423093953.jpg

从测试数据来看,结果似乎不是很好。。。不过,VRPTW仅是一个载体,目的是为了深入了解蚁群算法的运行机制。
小编在测试时发现,参数设置地不同对结果还是有一定影响的。算法偶尔会跑出单个点构成的路径,小编认为应该加大时间窗对应参数w_2,效果有一些提升。推荐的参数已经默认设置在代码中。

同时,蚁群算法也有其他仿生类算法的特点,比较容易早熟。这点在测试100点数据是尤为明显,全局最优解可能与前100次迭代的最优解相同。




04


笔记总结

大致了解了蚁群算法对VRPTW的求解过程后,我的第一感觉是,和禁忌搜索的思路其实很像:两者都是利用过去搜索的“记忆”指导下一步走向。禁忌禁止一些方向,信息素引导一些方向。但两者又有很大区别:禁忌搜索作为邻域搜索类算法,每次都在旧解里变换出新解;蚁群算法却需要重新派出蚂蚁走完全程。对比之下,每次迭代时蚁群算法可能需要跟更多花费时间。从测试结果来看,蚁群算法确实没有禁忌搜索高效。当然,这可能和小编个人编写代码的能力有关。


但不可否认的是,大自然的智慧确实不同寻常,在每一个领域都闪耀着光辉,如此美妙绝伦。


微信图片_20220423093956.jpg

(小小的蚂蚁,也蕴藏着让人意想不到的智慧呢!)


相关文章
|
18天前
|
算法
代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
20 3
|
18天前
|
算法
代码随想录算法训练营第五十七天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
代码随想录算法训练营第五十七天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
15 3
|
18天前
|
算法
代码随想录算法训练营第五十六天 | LeetCode 647. 回文子串、516. 最长回文子序列、动态规划总结
代码随想录算法训练营第五十六天 | LeetCode 647. 回文子串、516. 最长回文子序列、动态规划总结
34 1
|
18天前
|
算法
代码随想录算法训练营第五十五天 | LeetCode 583. 两个字符串的删除操作、72. 编辑距离、编辑距离总结
代码随想录算法训练营第五十五天 | LeetCode 583. 两个字符串的删除操作、72. 编辑距离、编辑距离总结
24 1
|
28天前
|
算法 安全 Java
java代码 实现AES_CMAC 算法测试
该代码实现了一个AES-CMAC算法的简单测试,使用Bouncy Castle作为安全提供者。静态变量K定义了固定密钥。`Aes_Cmac`函数接受密钥和消息,返回AES-CMAC生成的MAC值。在`main`方法中,程序对给定的消息进行AES-CMAC加密,然后模拟接收ECU的加密结果并进行比较。如果两者匹配,输出"验证成功",否则输出"验证失败"。辅助方法包括将字节转为16进制字符串和将16进制字符串转为字节。
|
16天前
|
机器学习/深度学习 人工智能 算法
基于DCT和扩频的音频水印嵌入提取算法matlab仿真
本文介绍了结合DCT和扩频技术的音频水印算法,用于在不降低音质的情况下嵌入版权信息。在matlab2022a中实现,算法利用DCT进行频域处理,通过扩频增强水印的隐蔽性和抗攻击性。核心程序展示了水印的嵌入与提取过程,包括DCT变换、水印扩频及反变换步骤。该方法有效且专业,未来研究将侧重于提高实用性和安全性。
|
3天前
|
存储 算法
m基于LDPC编译码的matlab误码率仿真,对比SP,MS,NMS以及OMS四种译码算法
MATLAB 2022a仿真实现了LDPC译码算法比较,包括Sum-Product (SP),Min-Sum (MS),Normalized Min-Sum (NMS)和Offset Min-Sum (OMS)。四种算法在不同通信场景有各自优势:SP最准确但计算复杂度高;MS计算复杂度最低但性能略逊;NMS通过归一化提升低SNR性能;OMS引入偏置优化高SNR表现。适用于资源有限或高性能需求的场景。提供的MATLAB代码用于仿真并绘制不同SNR下的误码率曲线。
138 3
|
6天前
|
算法 数据安全/隐私保护 计算机视觉
基于DCT变换的彩色图像双重水印嵌入和提取算法matlab仿真
**算法摘要:** - 图形展示:展示灰度与彩色图像水印应用,主辅水印嵌入。 - 软件环境:MATLAB 2022a。 - 算法原理:双重水印,转换至YCbCr/YIQ,仅影响亮度;图像分割为M×N块,DCT变换后嵌入水印。 - 流程概览:两步水印嵌入,每步对应不同图示表示。 - 核心代码未提供。
|
6天前
|
机器学习/深度学习 算法 数据可视化
Matlab决策树、模糊C-均值聚类算法分析高校教师职称学历评分可视化
Matlab决策树、模糊C-均值聚类算法分析高校教师职称学历评分可视化
|
7天前
|
算法 TensorFlow 算法框架/工具
基于直方图的图像阈值计算和分割算法FPGA实现,包含tb测试文件和MATLAB辅助验证
这是一个关于图像处理的算法实现摘要,主要包括四部分:展示了四张算法运行的效果图;提到了使用的软件版本为VIVADO 2019.2和matlab 2022a;介绍了算法理论,即基于直方图的图像阈值分割,通过灰度直方图分布选取阈值来区分图像区域;并提供了部分Verilog代码,该代码读取图像数据,进行处理,并输出结果到"result.txt"以供MATLAB显示图像分割效果。