领域搜索算法java_干货|自适应大邻域搜索(ALNS)算法求解带时间窗的车辆路径规划问题(附JAVA代码)...

转眼距离开学又过去一个多月了,不知道大家在家里学习的怎么样?这段时间小编在家里也没闲着,时隔多日,再次为大家带来干货内容!

ebf3b17c2a4104e1f1c2c7cc6f023911.gif

邻域搜索类启发式算法有很多种,比如禁忌搜索啦,模拟退火啦,变邻域搜索啦等等。这次带来的自适应大邻域搜索代码,相对上述几种会更复杂,内容相对全面。

小编在编写代码时,主要采用git-hub上一位作者de.markusziller的代码,参考他的ALNS框架下写出了解决带时间窗的车辆路径规划问题的代码,今天文章的主要内容将围绕代码实现展开。下面就开始今天的内容吧!

7842679164a2419ff3199308bc7d4511.png

算法介绍

有关ALNS概念的介绍,公众号内已经有相关内容了,这里稍提一下,有疑惑的同学可以参考往期内容:

简单的讲,ALNS主要有两个特点:1.先用destroy方法破坏当前解,再用repair方法组合成新解。2.设计一组destroy,repair方法,动态评估每种方法的效果,在搜索中选用效果较好的方法。

ALNS算法是脱胎于大邻域搜索算法(Large Neighborhood Serach,LNS)的,第一个特点就是LNS的关键。通过带有随机性的destroy、repair方法构造新解,从而对解空间进行启发式搜索。

第二个特点是ALNS的自适应部分。类似于蚁群算法中的信息素,或禁忌搜索算法重点的禁忌表,由于ALNS算法的解空间是有destroy和repair方法定义的,因此这里记忆的主要是算子的使用情况。

下面针对这次的VRPTW代码进行一些讲解。当然,这里只是挑选部分重点内容进行讲解,代码总量有2000多行,想要认真研究还需要下载代码亲自查阅哦!

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值