基于混合遗传算法车辆路径问题

基于混合遗传算法车辆路径问题

ID:5941897

大小:27.50 KB

页数:6页

时间:2017-12-29

基于混合遗传算法车辆路径问题_第1页
基于混合遗传算法车辆路径问题_第2页
基于混合遗传算法车辆路径问题_第3页
基于混合遗传算法车辆路径问题_第4页
基于混合遗传算法车辆路径问题_第5页
资源描述:

《基于混合遗传算法车辆路径问题》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、基于混合遗传算法车辆路径问题  摘要:遗传算法可以很好的解决路径选择问题,但简单的遗传算法存在过早收敛问题。在自然界中远亲交配具有更好的遗传优势,本文据此理论改进车辆路径选择问题中的遗传算法,提高求解性能。关键词:混合遗传算法;车辆路径选择,远亲交叉策略中图分类号:U27文献标识码:A遗传算法简称GA(GeneticAlgorithm)是一种模拟自然界中遗传和选择机制的寻找最优解的方法。他的基本原理源自达尔文的生物进化论和盂德尔的基因学说。遗传算法模拟自然界的遗传,变异和进化法则,逐步修订解决问题的方案使之接近完美。遗传算法的优势在于将搜索过程作用在编码后的字符串上.不直接作用

2、在优化问题的具体变量上,这样可以绕过复杂的数学推演而采用最直接的方式在有限的结果集中搜索更优的结果。遗传算法通过设定一个初始种群,即一个预设的结果。并对这个初始种群进行基因突变和杂交,留下好的基因,改变不好的基因,使种群不停的进化,最后得到一组最优的或趋进于最优的结果,给人更大的选择余地。遗传算法有很好的易修改性和可并行性,在处理大规模复杂问题上更有优势。6但普通的遗传算法存在“早熟”问题,即容易收敛于局部最优解,在自然界中远亲交配具有更好的遗传优势,本文据此理论改进车辆路径选择问题中的遗传算法,并以有车载限制单配中心VRP的求解加以说明。这种交叉策略虽然使遗传算法的收敛速度稍

3、有减缓,但使算法具有很好的求解性能。具体步骤如下:(1)混合遗传算法的编码规则应用遗传算法求解的首要问题是对所求问题解的编码。一个解的编码称为一个染色体,组成编码的元素称为基因。混合遗传算法采用路径编码方法。每个染色体由区间「1,m+n-1」中互不相同的自然数序列构成,其中n为客户数目,m为运输车数量,前面1~n为客户编号,n+1~n+m-1表示配送中心。例如,若有3辆运输车和12个客户,则一个染色体为{2,1,3,13,5,4,6,10,14,8,7,9,11,12},其中13,14表示配送中心以区分开3辆车所运输的客户编组。三辆车的配送路径分别为:第一辆车:配送中心→2→1

4、→3→配送中心;第二辆车:配送中心→5→4→6→10一配送中心;第三辆车:配送中心→8→7→9→11→12→配送中心。(2)客户编号6由于车辆行驶路径的迂回将大大增加目标函数式的值,为减少迂回造成行驶路径的增加,混合遗传算法将根据客户的位置对客户按方向编号:首先任意取一个客户并将其编号为1,然后以配送中心为极点、以配送中心和该客户的连线为极轴将所有客户的平面坐标转化成极坐标,最后以各客户的极角大小对客户依次进行编号。基于客户的编号,混合遗传算法将对车辆的行驶方向进行优化,从而尽量使车辆按一定的方向行驶。(3)构造个体产生初始种群由于初始种群的多样性将影响遗传算法的求解性能,因此

5、,为了使初始种群具有较好的多样性,混合遗传算法采用以下3种方式依次产生一部分个体来构成初始种群(其中K为种群大小)。它们之间没有任何联系,可以看作是远亲关系。首先分别以每个客户为起始点,按客户编号顺序即极角顺序遍历一周,在遍历所得的客户序列中,按约束条件把表示配送中心的基因(即n+1,n+m-1)插入到序列中,构成一个个体。这样可以产生n个个体,为子种群一。然后重复(K-n)/2次以下操作,产生(K-n)/2个个体组成子种群二:随机产生n个区间[[1,n]上互不重复的自然数序列,然后按约束式把n+1,-n+m-1插入到序列中,构成一个个体。若该个体满足所有约束,则该个体为有效个

6、体,否则为无效个体,重新产生该个体。6最后使用贪心算法产生剩下的(K-n)/2个个体,为子种群三。即以配送中心为起点,选择一个距其近、没有车辆提供服务且将其加入路径后约束式能满足的客户加入路径,然后以该客户为起点继续以上操作。若以上客户不存在,且还有未加个体的客户,则插入配送中心,并以配送中心为起点重复以上操作。若所有客户均已加入个体,则一个个体构造完成。(4)适应度函数。本文研究的单配送中心VRP问题的目标函数是关于最短路径的,一般来说,若目标函数为最小问题,适应度函数可以建立为:(1-1)式中Cmax为f(x)的最大估值。(5)交叉、选择与变异。6在交叉个体的选择上,简单遗

7、传算法通常直接采用随机选择两个个体进行交叉操作。这种交叉操作很大程度上导致了早熟现象的发生。混合遗传算法基本思想是:在选择交叉个体时,要求两个个体之间有一定的距离以保持种群的多样性,本例中以上述3个子种群相互交叉。选定两个交叉位置将每个个体分成三个部分,首先交换两个个体的中间部分;然后分别在第一部分和第三部分删除己经在中间部分出现的基因;最后,从另一个个体的第一个基因位置开始,依次选取未在该个体中出现的基因插入到该个体的第一部分末尾和第三部分的开头,以保持个体的第一部分和第二部分长度不变且每

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。