各位读者大家好,今天小编给大家分享如何用遗传算法求解带时间窗的车辆路径规划问题。算法的主要思想来自于论文:A simple and effective evolutionary algorithm for the vehicle routing problem。在实现用遗传算法解VRPTW的过程中,小编一直在被生成了很多不可行解修复很困难而困扰,而这篇论文中所提出的算法恰好就避免了不可行解的处理,那么究竟是如何实现避免讨论不可行解的呢?接着读完这篇推文就能明白了~
1.遗传算法
1
遗传算法简介
遗传算法(Genetic Algorithm,简称GA)是一类借鉴生物界的进化规律(适者生存,优胜劣汰遗传机制)演化而来的基于种群的随机化搜索方法。它是由美国的J.Holland教授1975年首先提出,其主要特点是直接对结构对象进行操作,不存在求导和函数连续性的限定;具有内在的隐并行性和更好的全局寻优能力;采用概率化的寻优方法,能自动获取和指导优化的搜索空间,自适应地调整搜索方向,不需要确定的规则。遗传算法的这些性质,已被人们广泛地应用于组合优化、机器学习、信号处理、自适应控制和人工生命等领域。遗传算法是现代智能计算中的关键技术之一。
2
遗传算法基本思想
在现实生活中,生物的染色体通过基因控制了生物的性状,而生物的性状决定了生物在环境中的适应度,适应度高的生物,其基因更容易流传下来,随着时间的不断流逝,整个种群的适应度随之提高。
遗传算法和现实非常类似,首先将问题的解通过一定的方法,编码到染色体中,通过适应度函数,得到每个个体的适应度,通过选择,将适应度高的个体保留到下一代中,不断迭代,即可获得满意解。
3
遗传算法流程
对遗传算法的详细介绍见:
干货 | 嘿!你和遗传算法的距离也许只差这一文(附C++代码和详细代码注释)
遗传算法求解混合流水车间调度问题(附C++代码)
2.带时间窗的车辆路径规划问题介绍
1
车辆路径规划问题介绍
车辆路径规划问题,经过60年来的研究与发展,研究的目标对象,限制条件等均有所变化,已经从最初的简单车辆安排调度问题转变为复杂的系统问题。最