交通|车辆路径启发式中的分解策略

news2025/1/23 3:16:01

在这里插入图片描述

推文作者:Amiee,研究方向:交通物流

编者按:

VRP问题由于其理论难度和实践价值,学者们设计了大量的精确或启发式求解算法。本文讨论了车辆路径启发式中分解技术的主要特征,强调了它们的优缺点,并推导出了一组理想的性质。

摘要

分解技术是用于求解车辆路径问题的大型实例的现代启发式算法的重要组成部分。当前的文献缺乏对分解策略的描述,也缺乏对其影响的系统研究,这些研究与最先进的启发式方法相结合。本文讨论了车辆路径启发式中分解技术的主要特征,强调了它们的优缺点,并推导出了一组理想的性质。通过数值实验,分析了在两种经典算法(自适应大邻域搜索算法和混合遗传搜索)中集成分解技术对CVRP求解的影响。结果表明,基于route的分解方法优于基于Path的分解方法。

引言

VRP问题的目标是为一组在空间上离散的节点确定一条最小成本的车辆路径。因为其理论难度和实践价值,学者们设计了大量的精确或启发式求解算法。特别地,启发式算法已经被证明是求解大规模问题的有效算法,而分解策略对启发式算法的性能具有明显的影响。因此,本文主要关注以下两个方面:

  • 讨论了VRP启发式分解技术的一些基本特征,其主体思路为:
    • 将实例重复分解为单独求解的较小子问题,并通过合并子问题的解,以获得原始问题的完整解。
    • 粗化聚合方法(Coarsening and aggregation):固定某些弧段的粗化和聚合方法,它会有效减少问题中的节点数量。
    • 破坏和重建方法(Ruin-and-recreate):暂时将一组客户和弧段保持固定,并试图重新排列其余的决策变量。
  • 通过计算实验讨论不同分解技术对CVRP解的影响,重点关注了Pisinger和Ropke (2007)的自适应大邻域搜索(ALNS), 和Vidal &Thibaut(2022)的混合遗传搜索(HGS),在集成分解技术后的性能表现。

分解技术的特征

启发式分解技术具有以下四个特征:第一是分解得到的子问题的特征,第二是定义子问题用到的信息,第三是子问题的解法,第四是子问题的解应用到主问题的方式。

子问题的特征

同质分解和异质分解
  • 所谓同质分解就是从原问题分解得到的子问题与原问题具有相同的结构,在这种分解模式下,通过递归地调用单一解法来求解。例如,基于顾客划分的分解带来的子问题通常是同质分解,这种分解导致了规模更小的车辆路径问题。
  • 所谓异质分解是指求解子问题的算法和求解主问题的算法是不同的算法。例如,将某个距离相近聚合为宏节点(macro-nodes)的方式,可能需要为子问题定制不同的求解方案。例如,有A,B,C,D四个节点,我们将节点A和节点B聚合为宏节点,那么优化问题就变为节点C和节点D在宏节点AB之前访问还是在AB之后访问更有利。
    在这里插入图片描述
子问题是独立的还是相互依赖的
  • 分解后会得到多个子问题。每个子问题的目标值和可行性,不依赖与其他子问题的目标值和可行性时,子问题间是相互独立的。大部分基于顾客划分的分解技术,产生的节点子集之间不存在交集,进而衍生出来的子问题就是相互独立的子问题。但是也有例外的情况。
  • 产生依赖子问题的一类分解方法是破坏和重建算法。这些算法通过迭代破坏解决方案的一部分而其余部分保持不变来改进解决方案,这可以理解为迭代地生成并解决较小子问题的分解方法。因为从一次迭代到下一次迭代,破坏的部分之间可能存在重叠,所以这些子问题的求解通常是按顺序进行的。
  • 总的来说,子问题之间相互独立的分解方式是我们希望看到的,因为它可以通过并行来减少计算时间,并且能够通过合并子问题的解来生成原问题的解。

子问题的信息

子问题的信息

分解方法通常遵循以下三个主要原则:第一,分解产生的固定变量应支持高质量的求解方法,第二子问题的自由变量不能太多或太少,第三是自由变量应该是相关的。

  • 第一是分解是否支持精英解决方案。也就是说,我们是通过高质量的解决方案来定义子问题。如下图,左侧的图中,分解之后的子问题不会破坏精英解决方案,此时分解策略支持精英解决方案;而在右侧图中,分解后的子问题会破坏精英解决方案,此时分解策略不支持精英解决方案。

  • 第二是子问题的规模,它是控制子问题难度和改进潜力的重要参数,子问题规模的大小取决于算法的性能(包括计算时间和解决方案的质量)。子问题的规模可以是固定的,也可以是随机的,还可以是根据算法的某些指标在搜索过程中动态变化。当可以精确地知道算法求解子问题的能力时,可以选择固定大小模式。但是如果不知道这样的信息,或者子问题规模的细微变化会对算法的性能产生重大影响时,自适应地确定子问题的规模则是一个更好地选择。

  • 第三是关联信息。子问题的创建可能用到一些关联信息,如节点间的空间关联、时间关联、历史关联和解的模式关联等。空间和时间相关性度量直接源自问题的特征,并测量两个节点在空间或时间上的接近程度。相比之下,历史关联和解的模式关联,则考察了在历史搜索中,在得到的较好的解决方案中,某些决策被同时做出的频率。

子问题的求解技术

不同的子问题求解技术,在运行时间和解决方案质量上可能有很大差异。子问题的求解技术的范畴包括从简单的贪婪启发式到复杂的元启发式的启发式谱系,和从隐式枚举到分支定价技术的精确算法谱系。
求解算法的运行时间和解的质量是密切相关的,在破坏重建型算法中,使用贪婪启发式方法的好处在于很快能得到一个新的解,但产生良好解决方案的概率随着子问题的大小而迅速降低。同时,随着基于分支定价技术的精确算法在获取精确解的能力方面的改善,在子问题的求解中,探索使用基于精确算法处理子问题的新型分解算法,展现出了很好的前景。

子问题解的用处

当定义的子问题支持精英解时,直接替换或改进精英解即可。因此,推荐使用具有独立特征和同质分解结构,且支持精英解决方案的启发式分解技术;在这种情形下,可充分的利用子问题的解。

分解技术的设计

基于此思路,重点考虑了两种启发式分解技术,第一是基于Route的分解,这种模式是基于精英路径来定义子问题;第二是基于Path的分解,迭代地规定某些节点序列。

基于Route的分解

基于Route的分解方法创建一组独立的子问题S={S_{1},…,S_{k}},然后通过递归地求解每一个子问题,之后合并子问题的解即可重建出原始问题的解。每个子问题可以定义为S_{j}={V_{j},p_{j}},其中V_{j}表示构成子问题的节点集合,p_{j}表示该子问题中包含的车辆数目。

对于CVRP,它的解可表示为一个路径集,每条路径包含一组节点,如果车辆没有被使用,则对应子问题包含的节点集合为空,车辆数目为0。

基于Path的分解

基于Path的分解的思路是将一组节点T=(v_{1},…,v_{r})合并为一个宏节点v_{T},从而来定义子问题。宏节点内部将对应一个访问序列,假设为(v_{1},…,v_{r}),也即Path。基于Path,则有:

  • 宏节点的需求量等于组成宏节点的所有节点的需求量之和
  • 宏节点与不在宏节点内的其他节点u\in V-T之间的行驶成本为c_{u,v_{T}}=c_{u,v_{1}}和c_{v_{T},u}=c_{v_{r},u}。
  • 宏节点处的服务时间为内部节点的行驶时间之和。

在这种分解方式下,利用宏节点定义削减的子问题(reduced subproblem),在求解完子问题后,将子问题的解替换到原问题解的对应部分。这种分解其实可以理解为,从精英解中抽取一部分节点,来定义子问题。如果每个宏节点只包含一个节点,则相当于是抽取了单个弧段。

集成分解技术的ALNS设计

ALNS算法通过迭代地调用破坏和修复算子来快速求解大规模的路径问题,其中破坏算子移除了解的一部分节点,而修复算子重建了破坏算子产生的部分解。在ALNS集成分解技术的一个简单实现为,每隔固定的次数,对当前最优解执行一次分解。

基于分解技术的混合遗传搜索(HGS)

HGS是一种为各种VRP设计的遗传算法,它与经典遗传算法的区别是,对种群多样性进行了更高层级的管理。该算法允许可行解和不可行解在种群中共存。解决方案的适应度是根据其成本、对可能不可行的惩罚以及对其对种群多样性贡献的奖励来计算的。类似地,集成分解策略的HGS的一个简单实现为,每隔固定的次数,对当前最优解执行一次分解。

结论

经过测试,基于Route的分解方法通常优于基于Path分解方法。这样的结论为未来的研究工作带来许多新的潜能,例如可以使用复杂的学习机制和稀疏化( sparsification)技术来更好的定义子问题;并且随着CVRP及其子问题的数学规划的重大进展,利用精确技术处理分解子问题,也可能在未来表现出更大的潜力。

参考文献

Santini, A., Schneider, M., Vidal, T., & Vigo, D. (2023). Decomposition strategies for vehicle routing heuristics. INFORMS Journal on Computing. doi:https://doi.org/10.1287/ijoc.2023.1288

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1298038.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

唱响主旋律——建行江门市分行推动服务实体经济高质量发展

建行江门市分行主动对接当地战略部署,在侨乡热土踏歌而行,全力当好服务实体经济的主力军和维护金融稳定的压舱石,在助力再造一个现代化新江门上贡献建行力量。 输血实体 为实体经济服务是金融的天职。建行江门市分行积极发挥在重大基建领域…

爱智EdgerOS之深入解析如何应用爱智的视频流模块完成拉流

一、ONVIF 规范和常见视频流传输协议 ① ONVIF 规范 随着视频监控产业链的成熟,市面上陆陆续续出现了各式各样的网络摄像设备,这些设备都需要通讯协议才能进行数据传输。早期厂商都采用私有协议,但是现在厂商分工明确,有的负责生…

用Rust刷LeetCode之26 删除有序数组中的重复项

26. 删除排序数组中的重复项[1] 难度: 简单 老的描述: 新的描述: 注意是 排序数组,非严格递增排列,即已经是排好序的,只不过有重复元素 func removeDuplicates(nums []int) int { if len(nums) 0 { return 0 } i : 0 for j : 1; j < len(nums); j { …

电源小白入门学习3——电源系统常见元件选型MOS管、二极管、电感篇

电源小白入门学习3——电源系统常见元件选型MOS管、二极管、电感篇 MOS管二极管电感 书接上文&#xff0c;上一期我们讲了电阻、电容选型中需要注意的事项&#xff0c;下面我们接着来介绍MOS管和二极管。 MOS管 关于MOS管的基本原理和内部的一些结构&#xff0c;PN结、半导体的…

uniapp切换页面时报错问题

我们来看如下错误&#xff1a; 该错误的意思是不能切换到 tabbar 页面。tabbar页面通常是公共页面或者底部导航栏&#xff0c;如果我们用 navigateTo 或者 redirectTo 都不能实现页面切换。 我们有两种方式&#xff1a; 第一种是用 switchTab 来进行切换&#xff0c;但注意切…

Kettle 安装配置

文章目录 Kettle 安装配置Kettle 安装Kettle 配置连接 Hive Kettle 安装配置 Kettle 安装 在安装Kettle之前&#xff0c;需要确定已经安装Java运行环境。Kettle需要Java的支持才能运行&#xff0c;JDK的版本最好是8.x的太新的也会出现bug。Kettle的7.1版本的太旧了&#xff0…

【PWN】学习笔记(一)【二进制基础】

目录 课程教学一次简单的Hack程序的编译与链接Linux下的可执行文件格式ELF进程虚拟地址空间程序的编译与链接程序的装载与进程的执行x86&amd64汇编简述 课程教学 课程链接&#xff1a;https://www.bilibili.com/video/BV1854y1y7Ro/?vd_source7b06bd7a9dd90c45c5c9c44d12…

【Gradle】mac环境安装Gradle及配置

官网安装说明&#xff1a;Gradle | Installation 由于Gradle运行依赖jvm&#xff0c;所以事先需要安装jdk&#xff0c;并确认你的jdk版本和gradle版本要求的对应关系&#xff0c;这个官网上有说明&#xff0c;但是我试了一下不太准确&#xff0c;供参考&#xff0c;链接如下&a…

自动化测试Allure报告

这一节主要是记录allure的内容以及用法&#xff0c;怎么让他生成一个完整的想要的报告。 allure生成的报告和其他五花八门的报告对比了一下&#xff0c;它的可读性是最好、最直观的。这不仅仅是我想要的效果&#xff0c;也是很多小伙伴想要的结果&#xff0c;毕竟这是给领导看…

kettle完成mysql表与表之间的更新和插入

版本&#xff1a;20231209 kettle完成数据库表与表之间的转换非常的简单&#xff0c;只需要在输入模块选择&#xff1a;输入表&#xff1b;在输出模块选择&#xff1a;插入和更新表模块 实例展示&#xff1a;将表stu1的数据同步到stu2&#xff0c;并覆盖掉stu2原本的数据。 cr…

情深不必纠缠

那一年&#xff0c;男孩女孩在万千人中相遇了。多年后女人的一封邮件&#xff0c;让男人与女人的灵魂相遇了。他们无缘夫妻&#xff0c;却发现彼此是灵魂的陪伴。不能携手相守&#xff0c;却懂得彼此的心灵。 有一天&#xff0c;女人告诉男人要回家了&#xff0c;问男人心里会不…

JOSEF约瑟 接触式中间继电器 JZC1-53 AC220V 导轨安装

系列型号 JZC1-22中间继电器&#xff1b;JZC1-44中间继电器&#xff1b; JZC1-62中间继电器&#xff1b;JZC1-80中间继电器&#xff1b; JZC1-71中间继电器&#xff1b;JZC1-53中间继电器&#xff1b; JZC1-32中间继电器&#xff1b;JZC1-40中间继电器&#xff1b; JZC1-31中间…

Laya2.13.3接入第三方库Socket.io

服务端&#xff1a; 1.新建一个文件夹&#xff0c;使用npm.init -y创建node工程 2.在控制台使用以下代码下载Socket.io npm install socket.io 3.创建一个app.js的文件&#xff0c;将以下代码填入 import { Server } from "socket.io"; import { createServer }…

nginx配置正向代理支持https

操作系统版本&#xff1a; Alibaba Cloud Linux 3.2104 LTS 64位 nginx版本&#xff1a; nginx-1.25.3 1. 下载软件 切换目录 cd /server wget http://nginx.org/download/nginx-1.25.3.tar.gz 1.1解压 tar -zxvf nginx-1.25.3.tar.gz 1.2切换到源码所在目录…

作为CSS开发人员你不能错过的15个节省时间的网站

本文翻译自 15 Time-Saving Websites You Should Know As A CSS Developer&#xff0c;作者&#xff1a;Shefali&#xff0c; 略有删改。 在这篇文章中&#xff0c;我将向您介绍15个网站&#xff0c;它们可以为您节省大量时间&#xff0c;并增强您的CSS开发体验。 CSS Buttons…

安装dhg

python版本&#xff1a;3.9 离线安装pytorch&#xff1a;download.pytorch.org/whl/torch_stable.html 问题1&#xff1a; 离线安装时没办法安装依赖包导致的&#xff0c;但是在线安装很蛋疼&#xff0c;最后按下面这个老哥的搞了解决pytorch指令安装时Could not find a versi…

简单实现Spring容器(三) 初始化单例池并完成getBean() createBean()方法

阶段3: (仍需打磨,静态处有小瑕疵) // 1.编写自己的Spring容器,实现扫描包,得到bean的class对象. // 2.扫描将 bean 信息封装到 BeanDefinition对象,并放入到Map.3.初始化单例池并完成getBean() createBean()方法思路: 初始化单例池,也就是如果Bean是单例的就实例化,并放入到…

Numpy矩阵(第16讲)

Numpy矩阵(第16讲)         🍹博主 侯小啾 感谢您的支持与信赖。☀️ 🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹…

接口测试-Jmeter使用

一、线程组 1.1 作用 线程组就是控制Jmeter用于执行测试的一组用户 1.2 位置 右键点击‘测试计划’-->添加-->线程(用户)-->线程组 1.3 特点 模拟多人操作线程组可以添加多个&#xff0c;多个线程组可以并行或者串行取样器(请求)和逻辑控制器必须依赖线程组才能…

将一维数组转变成二维数组

说在前面 &#x1f388; 算法并不一定都是很难的题目&#xff0c;也有很多只是一些代码技巧&#xff0c;多进行一些算法题目的练习&#xff0c;可以帮助我们开阔解题思路&#xff0c;提升我们的逻辑思维能力&#xff0c;也可以将一些算法思维结合到业务代码的编写思考中。简而言…