灾情巡视路线最优化的方案(刘) 下载本文

约束最优路线的模拟退火解法

说明:以98年全国大学生数模竞赛中的B题(即“灾情巡视路线”)为例,介绍能解一类较广泛的约束最优路线问题的方法??模拟退火法。该法对“灾情巡视路线”这类有约束以及“(一般)旅行推销员”、“中国邮递员”等无约束组合优化问题均能求得较好的近似解,具有适用范围广和可拓展的优点。

[1]

一、问题描述

对于最短路、最大流、中国邮递员、旅行推销员等最优路线问题,常采用各自不同的方法求解。若在这些问题中再加入一些约束条件,则原方法往往不再有效,如98年大学生数模竞赛中的B题就是如此。我们设计的方法较好地解决了这一问题。现以98年B题为例,介绍该法及其实现。下面为该题文字部分,并称其四问分别为问题1至问题4:

下图(略)为某县的乡(镇)、村公路网示意图,公路边的数字为该路段的公里数。

今年夏天该县遭受水灾。为考察灾情、组织自救,县领导决定,带领有关部门负责人到全县各乡(镇)、村巡视。巡视路线指从县政府所在地出发,走遍各乡(镇)、村,又回到县政府所在地的路线。 1.若分三组(路)巡视,试设计总路程最短且各组尽可能均衡的巡视路线。

2.假定巡视人员在各乡(镇)停留时间T=2小时,在各村停留时间t=1小时,汽车行驶速度V=35公里/小时。要在24小时内完成巡视,至少应分几组;给出这种分组下你认为最佳的巡视路线。

3.在上述关于T,t和V的假定下,如果巡视人员足够多,完成巡视的最短时间是多少;给出在这种最短时间完成巡视的要求下,你认为最佳的巡视路线。

4.若巡视组数已定(如三组),要求尽快完成巡视,讨论T,t和V改变对最佳巡视路线的影响。

二、问题分析及模型的建立

因为是分组巡视(不妨设分N 组),要直接确定一个组巡视哪些地点是困难的。由于将各组巡视的路线连接起来可看成一条N 次相继从县城出发又回到县城的路线,这样,多组巡视就化成了单组巡视。经分析,我们认为前3问及第4问计算部分都是组合规划中的约束优化问题,均属以模型

st.minf?x?hi?x??0,i?1,2,?,mgj?x??0,j?1,2,?,n (I)

为基础的约束最优路线模型。下面根据各问的要求,分别对4个问题进行具体讨论。

对于问题1,如果选取总路程最短的所有巡视路线中最均衡的,一般这一路线仍会很不均衡。故除了要总路程短,另需“均衡”提出一定的要求,即组间巡视路线的长度差不大于某给定值L。还有路线能够分成3次从县城O出发再回到O、各组经过地点的并集为所有顶点的集合只之约束。模型如下:

minF???fmax?fmin?

st.n?Nfmax?fmin?L1?i?n (II)

?Pi?A其中F为巡视总路程,N为要求的分组数(本问N=3),n是优化过程中路线的实际分组数,fmax和fmin分别为n组中最长和最短组的巡视路程,Pi 为第i组巡视地点的集合,A是所有顶点的集合。约束条件(fmax?fmin)?L用来保证各组路程基本均衡,

1

目标函数中加入?(fmax?fmin)是为了使各组的路程尽可能均衡,这是一个约束多目标规划。权重?的取值应远小于目标函数中F的权系数1,否则会因离散问题函数值的跳跃现象而导致优化困难。这里,我们取?=1/L。

对问题2和3,因在原图中不是任意两顶点间均有边,故在多组巡视时可能存在二组以上经过的公共点,从而使顶点赋权遇到如下困难:若先赋点权,则这些公共点的权会被重复计算;而若在优化过程中赋点权,则又有公共点究竟应该由哪次(组)巡视的问题。对此,我们采用Dijkstra法算出任意两点间的最短路程并除以速度V转化为时间,并用其作为两顶点间边的权构造一新图。第三个约束条件保证了每点至少经过一次,而这时若路线中含除县城外的重复地点将至少增加1个小时(除县城为0外,其它点权为1或2小时),因而能保证优化结果中不出现县城以外的重复点。经分析,我们认为这两问同属分组数和路线双重优化问题,具体模型如下:

st.minFn?N (III)

fmax?TMAX1?i?nUPi?A其中N、n 、A、Pi与模型(II)相同,F为各组巡视时间之和, fmax为n组中时间最长组的巡视时间,TMAX是巡视允许的最长时间。对问题2,TMAX=24;对问题3,因人员足够多,故每个地点可由一组单独巡视,因此完成巡视的最短时间是这些单点巡视的最佳路线中花时间最长的组对应的巡视时间,其值TMAX由程序计算确定。

对最少分组数的优化,模型中没有体现,我们是通过主程序与辅助控制函数协同工作来实现该目的的,即在优化过程中,若路线调整发现最短与次短组的时间之和不大于TMAX,且满足约束,则记录该路线后返回,并由主程序将分组数减1后重新优化,如果重新优化找不到满足约束的可行路线,则认为找到了最优解;而若优化函数没有找到满足约束的可行路线,主程序则将分组数加1后进行下一轮优化。我们用m和M分别表示求解时尝试的最小和最大分组数,对问题2,取m=4,M=8,而对问题3,m=20,M=35。

对于问题4,其最佳路线是指在分组数N已确定的情况下,巡视时间最长的组所对应的时间尽量短的路线。下面给出其模型,各参数的含义同模型(III),关于T、t和V对路线的影响,我们将在结果与分析部分给出。

st. (IV) n?NUPi?Aminfmax1?i?n三、模型的求解

(一)算法选择

由以上分析可知,本题的所有问题都可视为“在一定约束下,从一点出发再回到该点的最优路线寻求问题”。如问题1可看成有约束的“一般旅行推销员”问题,但即使是无约束的“旅行推销员”问题,也尚未找到解这类问题最优解的多项式算法,对本题n=53这种情形,无论是“分枝与界限法”还是动态规划等方法,想得到最优解一般是不可能的,只能用近似算法。选择模拟退火法,是因为它不同于一般的单纯下降法,它具有一定条件下的随机上升过程,有可能从一极小区域跃过波峰到过另一极小区域,因而具有解更接近全局最优解的优点。 (二)计算方法与步骤

1.方法概述 下面介绍模拟退火法函数,主函数部分略。模拟退火法是一种较新的算法,尚无固定的计算步骤。我们设计的基本操作包括路线调整、约束条件判断、调整许可预测、内部优化、与已有最佳路线的比较和最佳路线及相关数据的记录等。路线调整在给定的工作点集序列上进行,其前部分为当前路线,后部分为剩余点集。如此设计是

[1]

[3]

[4]

[5]

2

因为在许多问题中某些点在路线中可能出现多次,如“田”字型图的“一般旅行推销员”问题,此时可将每一可能重复的点或所有点以最大可能重复出现的次数置于工作点集中。路线的调整有5种(所有操作对象都是随机选取的):交换?路线内两路段(含点)互换;反转?路线中选取一路段反向;删除?路线内一路段移至路线外;插入?路线外一路段插入到路线中;替换?路线内外各取一路段互换。约束条件判断由用户函数完成;调整允许预测由内部函数完成,它决定是否接受一上升过程;内部优化是仅有交换和反转操作的优化过程,与上层模拟退火法函数基本相同。

2.基本步骤

(1) 由主程序传送工作点集、初始路线终点、记录器数目、温度初值t0、温度下降率FT、温度循环上限maxtk、每个温度的最大循环次数maxk和最多成功次操作次数max_suc、连续温度无改进时结束优化参数K等,并设置寻找可行路线的不成功次数n_suc:=0、最优路线条数rec_n:=0、优化值fx0:=maxfx、温度循环变量tk:=1,优化连续无改进温度次数same_tn:=0等内部变量初值;

(2) 计算初始路线的目标函数值fx、优化控制函数值fx1。若fx1

(5) 若fx20或rec_n==0且fx2>fx1,转步(4);

(6) 执行100次内部优化并更改路线,若某次内部优化后fx230时,转步(15);其它情况转步(4);

(7)计算路线的辅助控制函数值fx3,若fx3<=-maxfx,则路线及相关数据记入记录器第一个位置,转步(15);否则,用dfx12和t为参数调用预测函数,若返回值为0,即不允许更改路线时转步(4);

(8)进行若干次内部优化(次数动态调整),更新路线和目标函数值fx,重算优化控制函数值fx2,sucn:=sucn+1; (9)若fx+fx2>fx0,即比已有的最佳路线差,转步(4);否则检查是否与记录的路线重复,若重复则转步(4); (10)若fx+fx2

(11) rec_n:=rec_n+1,并计算记录器中最后一条最优路线的辅助控制函数值fx4;

(12)若fx3

(13)若记录器没满,则路线及相关参数记在已有最优路线之后;转步(4);

(14)若tk

(15)算法终止。此时若rec_n>0,则找到了最优路线,可从记录器中获取最优和次优路线及相关数据。 3.编程提示

对分组的处理及模型中的变量n、Pi、fmax、fmin、F和下面用到的次短组巡视时间fmin1均由分组处理函数完成,因此它是解决分组问题的关键,分组方法是:当自然分组数不大于N时,取自然分组;否则将最短两组合并,直到组数等于N为止。与总的设计思想相对应,程序设计应考虑多功能与通用性,以适应起点与终点相同和不同、单组和多组等各种要求。由于有上升过程,故需一组变量存放当前最佳路线、最优值和路线终点位置等。记录器参数组可满足人们想获取多条最优路线的要求。参数maxfx之值为“无穷大”,也是判断约束是否满足的依据,即满足约束时优化控制函数值

3