多旅行商问题模型

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

以点0表示旅行商的出发城市,称为源点,点1,2,,l表示m个旅行商需访问的城市。MTSP问题的数学模型可以表示为:令10ijx弧(i,j)在线路上弧(i,j)不在线路上模型表示如下:0000min10,1,,10,1,,()01,0,1,,RRijijijRijiRijjijijzdxxjRxiRXxSxijR或式中:1;ijRmld为增广费用。若用(,1,,)ijcijl表示旅行商经过对应弧度(,)ij所花的费用,如时间、距离、花费等,那么给ijc增加(1)m行和(1)m列,每一新的行或列是ijc的最后一行或列的复制,增广矩阵的其他元素为无穷大,由此构成了增广费用ijd。一般MTSP中,旅行商访问l个城市必须满足以下2个条件。条件1:从指定城市出发,对其他所有城市严格访问一次后返回原出发城市。条件2:一条有效路径严格由m条非平凡子路径(NontrivialSubtours)组成。所谓非平凡子路径是指该路径中除出发城市外,至少访问一个其他城市。用遗传算法求解MTSP,可通过附加虚拟城市的方法把MTSP转化为TSP。将另外(1)m个旅行商理解为(1)m个虚拟城市,这(1)m个虚拟城市标号分别为1,2,,1,lllm,它们与城市0具有相同的坐标(即相同位置)。在旅行商访问路径中出现的每一个虚拟城市均表示旅行商返回出发城市,从而组成一个回路。每个回路表示MTSP中一个旅行商的旅行路径。需注意的是,为了避免出现平凡子路径,必须假设(1)m个虚拟城市到原点的距离为00(,0,1,,1),ijcMijllmM为一无穷大的正数(即永远不能达到),到其他各点距离与原点一致,这样遗传算法就不会出现0-0-0的途径。将源点0复制(1)m个,m个源点编号为0,1,1,llm每一个同源点0一样与其他点相连,而m个源点互相不连接,这样在结点集0,1,,,1,,1lllm上,可得到TSP线路,然后各源点合并成一个点。这样MTSP线路就分解成m个分线路。初始化路径矩阵D确定实际问题参数对参数进行编码(0)X初始化群体适应度评估满足停止准则结束遗传操作(选择、交叉、变异)是否进行代数加1

1 / 2
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功