第八章线性规划与网络流.ppt

上传人:得****1 文档编号:76368419 上传时间:2023-03-09 格式:PPT 页数:59 大小:1.90MB
返回 下载 相关 举报
第八章线性规划与网络流.ppt_第1页
第1页 / 共59页
第八章线性规划与网络流.ppt_第2页
第2页 / 共59页
点击查看更多>>
资源描述

《第八章线性规划与网络流.ppt》由会员分享,可在线阅读,更多相关《第八章线性规划与网络流.ppt(59页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、1学习要点学习要点理解线性规划算法模型掌握解线性规划问题的单纯形算法 理解网络与网络流的基本概念掌握网络最大流的增广路算法掌握网络最大流的预流推进算法掌握网络最小费用流的消圈算法掌握网络最小费用流的最小费用路算法掌握网络最小费用流的网络单纯形算法第第8 8章章 线性规划与网络流线性规划与网络流2问题与建模模型:对真实系统的结构与行为用图、解析式或方程来描述的合称为模型。数学模型:通过抽象和简化,使用数学语言对实际对象的一个刻画,以便于人们更简明更深刻地认识所研究的对象数学建模:根据要求,针对实际问题,组建数学模型的全过程(包括建立、求解、分析、检验等)线性规划模型应用最广泛的方法之一。是最基本

2、的方法之一。网络规划,整数规划,目标规划和多目标规划都是以线性规划为基础的。是解决稀缺资源最优分配的有效方法,使付出的费用最小或获得的收益最大3仓库租赁问题仓库租赁问题 某企业计划为流通的货物租赁一批仓库。必须保证在时间段i=1,2,n,有bi的仓库容量可用。现有若干仓库源可供选择。设cij是从时间段i到时间段j租用1个单位仓库容量的价格,1ijn。应如何安排仓库租赁计划才能满足各时间段的仓库需求,且使租赁费用最少。在现实生活中利用现有资源来安排生产以取得最大经济效益的问题,经常表述为线性规划问题。48.1 8.1 线性规划问题和单纯形算法线性规划问题和单纯形算法5线性规划问题及其表示线性规划

3、问题及其表示线性规划问题可表示为如下形式:s.t.目标函数约束条件目标函数和约束条件都为线性函数,所以称为线性规划问题。线性规划问题是在一组线性约束条件的限制下,求一线性目标函数最大或最小的问题6变量满足约束条件(8.2)-(8.5)式的一组值称为线性规划问题的一个可行解可行解。所有可行解构成的集合称为线性规划问题的可行区域可行区域。使目标函数取得极值的可行解称为最优解最优解。在最优解处目标函数的值称为最优值最优值。有些情况下可能不存在最优解。通常有两种情况:(1)根本没有可行解,即给定的约束条件之间是相互排斥的,可行区域为空集;(2)目标函数没有极值,也就是说在n 维空间中的某个方向上,目标

4、函数值可以无限增大,而仍满足约束条件,此时目标函数值无界。7一个可行解:1,5,1,2这个问题的最优解为(x1,x2,x3,x4)=(0,3.5,4.5,1);最优值为16。仓库租赁问题仓库租赁问题 8某企业计划为流通的货物租赁一批仓库。必须保证在时间段i=1,2,n,有bi的仓库容量可用。现有若干仓库源可供选择。设cij是从时间段i到时间段j租用1个单位仓库容量的价格,1ijn。应如何安排仓库租赁计划才能满足各时间段的仓库需求,且使租赁费用最少。设租用时间段i到时间段j的仓库容量为yij,1ijn。则租用仓库的总费用为:在时间段k可用的仓库容量为:仓库租赁问题可表述为下面的线性规划问题:线性

5、规划基本定理线性规划基本定理 9约束条件(8.2)-(8.5)中n个约束以等号满足的可行解称为线性规划问题的基本可行解基本可行解。基:矩阵中的最大线性无关组基本解:满足Ax=b,且非基变量为0的解基本可行解:满足非负条件的基本解。线性规划基本定理:线性规划基本定理:如果线性规划问题有最优解,则必有一基本可行最优解。Dantzig于1948年提出了线性规划问题的单纯形算法。单纯形法迭代的基本思路是:先找出一个基本可行解,判断其是否为最优解,如为否,则转换到相邻的基本可行解,并使目标函数值不断增大,一直找到最优解为止。(即在凸集的各个顶点进行测试,判断是否为最优)单纯形算法的特点是:(1)只对约束

6、条件的若干组合进行测试,测试的每一步都使目标函数的值增加;(2)一般经过不大于m或n次迭代就可求得最优解。max (1-17)在约束条件(1-18)式的变量的系数矩阵中总会存在一个单位矩阵,不妨设为 (1-20)基本可行解理解例子基本可行解理解例子式中 称为基向量,同其对应的决策变量 称为基变量,模型中的其它变量 称为非基变量。在(1-18)式中令所有非基变量等于零,即可找到一个解 X=(,)T=(b1,bm,0,0)T因有b0,故X满足约束(1-19),是一个基本可行解记为 又称初始基本可行解。例3 求解非齐次线性方程组 (5/4,1/4,0,0)是一个基本可行解约束标准型线性规划问题的单纯

7、形算法约束标准型线性规划问题的单纯形算法 12当线性规划问题中没有不等式约束(8.2)和(8.4)式,而只有等式约束(8.3)和变量非负约束(8.5)时,称该线性规划问题具有标准形式标准形式。再考察一类更特殊的标准形式线性规划问题。这一类线性规划问题中,每一个等式约束中,至少有一个变量的系数为正,且这个变量只在该约束中出现。在每一约束方程中选择一个这样的变量,并以它作为变量求解该约束方程。这样选出来的变量称为左端变量或基本变量基本变量,其总数为m个。剩下的n-m个变量称为右端变量或非基本变量非基本变量。这一类特殊的标准形式线性规划问题称为约束标准型线性规划问题约束标准型线性规划问题。任意一个线

8、性规划问题可以转换为约束标准型线性规划问题。13x2x3x5z0-13-2x173-12x412-240 x610-438将所有非基本变量都置为0,从约束方程式中解出满足约束的基本变量的值,可求得一个基本可行解。基本可行解x=(7,0,0,12,0,10)。每次变换将一个非基本变量与一个基本变量互调位置,且保持当前的线性规划问题是一个与原问题完全等价的标准线性规划问题。14单纯形算法的第单纯形算法的第1步:步:选出使目标函数增加的非基本变量作为入基变量入基变量。查看单纯形表的第1行(也称之为z行)中标有非基本变量的各列中的值。选出使目标函数增加的非基本变量作为入基变量。z行中的正系数非基本变量

9、都满足要求。在上面单纯形表的z行中只有1列为正,即非基本变量相应的列,其值为3。选取非基本变量x3作为入基变量。x2x3x5z0-13-2x173-12x412-240 x610-43815单纯形算法的第单纯形算法的第2步:步:选取离基变量离基变量。在单纯形表中考察由第1步选出的入基变量所相应的列。在一个基本变量变为负值之前,入基变量可以增到多大。如果入基变量所在的列与基本变量所在行交叉处的表元素为负数,那么该元素将不受任何限制,相应的基本变量只会越变越大。如果入基变量所在列的所有元素都是负值,则目标函数无界,已经得到了问题的无界解。如果选出的列中有一个或多个元素为正数,受限的增加量可以用入基

10、变量所在列的元素(称为主元素)来除主元素所在行的“常数列”(最左边的列)中元素而得到。所得到数值越小说明受到限制越多。选取受到限制最多的基本变量作为离基变量,才能保证将入基变量与离基变量互调位置后,仍满足约束条件。上例中,惟一的一个值为正的z行元素是3,它所在列中有2个正元素,即4和3。min12/4,10/3=3,应该选取x4为离基变量;入基变量x3取值为3。x2x3x5z0-13-2x173-12x412-240 x610-43816单纯形算法的第单纯形算法的第3步:转轴变换步:转轴变换。转轴变换的目的是将入基变量与离基变量互调位置。解离基变量所相应的方程,将入基变量x3用离基变量x4表示

11、为再将其代入其他基本变量和所在的行中消去x3,代入目标函数得到形成新单纯形表x2x4x5z91/2-3/4-2x1105/21/42x33-1/21/40 x61-5/2-3/4817单纯形算法的第单纯形算法的第4步:步:转回并重复第1步,进一步改进目标函数值。不断重复上述过程,直到z行的所有非基本变量系数都变成负值为止。这表明目标函数不可能再增加了。在上面的单纯形表中,惟一的值为正的z行元素是非基本变量x2相应的列,其值为1/2。因此,选取非基本变量x2作为入基变量。它所在列中有惟一的正元素5/2,即基本变量x1相应行的元素。因此,选取x1为离基变量。再经步骤3的转轴变换得到新单纯形表。新单

12、纯形表z行的所有非基本变量系数都变成负值,求解过程结束。整个问题的解可以从最后一张单纯形表的常数列中读出。目标函数的最大值为11;最优解为:x*=(0,4,5,0,0,11)。x1x4x5z11-1/5-4/5-12/5x245/21/104/5x351/53/102/5x6111-1/210单纯形算法计算步骤单纯形算法计算步骤 18单纯形算法的计算过程可以用单纯形表的形式归纳为一系列基本矩阵运算。主要运算为转轴变换,该变换类似解线性方程组的高斯消去法中的消元变换。单纯形表:单纯形表:为基本变量,为非基本变量。基本变量下标集为B=1,2,m;非基本变量下标集为N=m+1,m+2,n;当前基本可

13、行解为()。xm+1xm+2xnzc0cm+1cm+2cnx1b1a1m+1a1m+2a1nx2b2a2m+1a2m+2a2n xmbmamm+1amm+2amn19单纯形算法计算步骤单纯形算法计算步骤如下:步骤步骤1:选入基变量选入基变量。如果所有cj0,则当前基本可行解为最优解,计算结束。否则取ce0相应的非基本变量xe为入基变量。步骤步骤2:选离基变量选离基变量。对于步骤1选出的入基变量xe,如果所有aie0,则最优解无界,计算结束。否则计算选取基本变量xk为离基变量。新的基本变量下标集为新的非基本变量下标集为步骤步骤3:作转轴变换作转轴变换。新单纯形表中各元素变换如下。20 (8.10

14、)(8.11)(8.12)(8.13)步骤步骤4:转步骤1。xm+1xm+2xnzc0cm+1cm+2cnx1b1a1m+1a1m+2a1nx2b2a2m+1a2m+2a2n xmbmamm+1amm+2amn将一般问题转化为约束标准型将一般问题转化为约束标准型 21有几种巧妙的办法可以将一般的线性规划问题转换为约束标准型线性规划问题。首先,需要把(8.2)或(8.4)形式的不等式约束转换为等式约束。具体做法是,引入松弛变量松弛变量,利用松弛变量的非负性,将不等式转化为等式。松驰变量记为yi,共有m1+m3个。在求解过程中,应当将松弛变量与原来变量同样对待。求解结束后,抛弃松弛变量。注意松弛变

15、量前的符号由相应的原不等式的方向所确定。22为了进一步构造标准型约束,还需要引入m个人工变量人工变量,记为zi。对极小化线性规划问题,只要将目标函数乘以-1即可化为等价的极大化线性规划问题。一般线性规划问题的一般线性规划问题的2 2阶段单纯形算法阶段单纯形算法 引入人工变量后的线性规划问题与原问题并不等价,除非所有zi都是0。在求解时必须分2个阶段进行。第一阶段用一个辅助目标函数 替代原来的目标函数。这个线性规划问题称为原线性规划问题所相应的辅助线性规划问题。如果原线性规划问题有可行解,则辅助线性规划问题就有最优解,且其最优值为0,即所有zi都为0。在辅助线性规划问题最后的单纯形表中,所有zi

16、均为非基本变量。划掉所有zi相应的列,剩下的就是只含xi和yi的约束标准型线性规划问题了。单纯形算法第一阶段的任务就是构造一个初始基本可行解。232 2阶段单纯形算法阶段单纯形算法单纯形算法第二阶段的目标是求解由第一阶段导出的问题。此时要用原来的目标函数进行求解。如果在辅助线性规划问题最后的单纯形表中,zi不全为0,则原线性规划问题没有可行解,从而原线性规划问题无解。24退化情形的处理退化情形的处理 25用单纯形算法解一般的线性规划问题时,可能会遇到退化的情形,即在迭代计算的某一步中,常数列中的某个元素的值变成0,使得相应的基本变量取值为0。如果选取退化的基本变量为离基变量,则作转轴变换前后的

17、目标函数值不变。在这种情况下,算法不能保证目标函数值严格递增,因此,可能出现无限循环。考察下面的由Beale在1955年提出的退化问题的例子。按照2阶段单纯形算法求解该问题将出现无限循环。ixBiCBix1x2x3x4x5x6x7b(i)比值Cj3/4-201/2-60000 x501/4-8-1910000/(1/4)x601/2-12-1/2301000/(1/2)x7000100011/j(0)3/4-201/2-6000z(x(0)=01x13/41-32-4364000/x60043/2-15-21000 x7000100011/j(1)047/2-33-300z(x(1)=02x1

18、3/4108-84-128000 x2-20013/8-15/4-1/21/4000 x70001000111j(2)002-18-1-10z(x(2)=03x31/21/801-21/2-3/2100/x2-20-3/64103/161/16-1/8000 x70-1/80021/23/2-1112/21j(3)-1/40032-30z(x(3)=04x31/2-5/256102-6000 x4-6-1/416/3011/3-2/3000 x705/2-5600-2611/j(4)1/2-16001-10z(x(4)=05x50-5/4281/201-300/x4-61/6-4-1/6101

19、/3000 x7000100011/j(5)7/4-44-1/20020z(x(5)=06x501/4-8-1910000/(1/4)x601/2-12-1/2301000/(1/2)x7000100011/j(6)3/4-201/2-6000z(x(6)=0循循环环27Bland提出避免循环的一个简单易行的方法。Bland提出在单纯形算法迭代中,按照下面的2个简单规则就可以避免循环。规则1:设 ,取xe为入基变量。规则2:设 取xk为离基变量。算法leave(col)已经按照规则2选取离基变量。选取入基变量的算法enter(objrow)中只要加一个break语句即可。仓库租赁问题仓库租赁问

20、题 28某企业计划为流通的货物租赁一批仓库。必须保证在时间段i=1,2,n,有bi的仓库容量可用。现有若干仓库源可供选择。设cij是从时间段i到时间段j租用1个单位仓库容量的价格,1ijn。应如何安排仓库租赁计划才能满足各时间段的仓库需求,且使租赁费用最少。设租用时间段i到时间段j的仓库容量为yij,1ijn。则租用仓库的总费用为:在时间段k可用的仓库容量为:仓库租赁问题可表述为下面的线性规划问题:29设 m=n(n+1)/2;()=();()=();上述线性规划问题可表述为n个约束和m个变量的标准线性规划问题如下。练习:生产计划决策例2.某工厂在计划内要安排、两种产品的生产,已知生产单位产品

21、所需的设备台时及A,B两种原材料的消耗,以及资源的限制,如下表所示。两种产品各该生产多少件,才能得到最大利润?产品资源产品产品资源限制设备(台时)11300台时原材料A(千克)21400千克原材料B(千克)01250千克单位产品利润(元)50100解max z=50 x1+100 x2,xj生产产品j的数量最优解(50,250),最优值为27500310100200300200100300400 x1+x2=3002x1+x2=400 x2=250B(50,250)C(100,200)D3233)(iBx)(iBC1x2x1s2s3s)(ib)()(ilKilab1s2s3s0jz)0()0(

22、jjjzC-=s1s2s2x1jz25000)()1(=xz)1()1(jjjzC-=s1x2s2x2jz27500)()2(=xz)2()2(jjjzC-=s迭代次数基变量501000000011100300300/1021010400400/1001001250250/100000z(x)=0/50100000101010-15050/102001-1150150/210001001250/010000100/50000-1002501010-150/000-21150100010012505010050050/00-500-508.2 8.2 最大网络流问题最大网络流问题341 基本概念

23、和术语基本概念和术语 (1)网络网络G是一个简单有向图,G=(V,E),V=1,2,n。在V中指定一个顶点s,称为源源和另一个顶点t,称为汇汇。有向图G的每一条边(v,w)E,对应有一个值cap(v,w)0,称为边的容量容量。这样的有向图G称作一个网络网络。(2)网络流网络流网络上的流流是定义在网络的边集合E上的一个非负函数flow=flow(v,w),并称flow(v,w)为边(v,w)上的流量流量。35(3)可行流可行流满足下述条件的流flow称为可行流可行流:(3.1)容量约束:容量约束:对每一条边(v,w)E,0flow(v,w)cap(v,w)。(3.2)平衡约束:平衡约束:对于中间

24、顶点:流出量=流入量。即对每个vV(vs,t)有:顶点v的流出量顶点v的流入量=0,即对于源s:s的流出量s的流入量=源的净输出量f,即对于汇t:t的流入量t的流出量的=汇的净输入量f,即式中f 称为这个可行流的流量,即源的净输出量(或汇的净输入量)。可行流总是存在的。例如,让所有边的流量flow(v,w)=0,就得到一个其流量f=0的可行流(称为0流)。36(4)边流边流对于网络G的一个给定的可行流flow,将网络中满足flow(v,w)=cap(v,w)的边称为饱和边饱和边;flow(v,w)0的边称为非零非零流边流边。当边(v,w)既不是一条零流边也不是一条饱和边时,称为弱流边弱流边。(

25、5)最大流最大流最大流问题即求网络G的一个可行流flow,使其流量f达到最大。即flow满足:0flow(v,w)cap(v,w),(v,w)E;且(6)流的费用流的费用在实际应用中,与网络流有关的问题,不仅涉及流量,而且还有费用的因素。此时网络的每一条边(v,w)除了给定容量cap(v,w)外,还定义了一个单位流量费用cost(v,w)。对于网络中一个给定的流flow,其费用定义为:37(7)残流网络残流网络对于给定的一个流网络G及其上的一个流flow,网络G关于流flow的残流网络G*与G有相同的顶点集V,而网络G中的每一条边对应于G*中的1条边或2条边。设(v,w)是G的一条边。当flo

26、w(v,w)0时,(w,v)是G*中的一条边,该边的容量为cap*(w,v)=flow(v,w);当flow(v,w)cap(v,w)时,(v,w)是G*中的一条边,该边的容量为cap*(v,w)=cap(v,w)-flow(v,w)。按照残流网络的定义,当原网络G中的边(v,w)是一条零流边时,残流网络G*中有唯一的一条边(v,w)与之对应,且该边的容量为cap(v,w)。当原网络G中的边(v,w)是一条饱和边时,残流网络G*中有唯一的一条边(w,v)与之对应,且该边的容量为cap(v,w)。当原网络G中的边(v,w)是一条弱流边时,残流网络G*中有2条边(v,w)和(w,v)与之对应,这2

27、条边的容量分别为cap(v,w)-flow(v,w)和flow(v,w)。残流网络是设计与网络流有关算法的重要工具。增广路算法增广路算法 381 算法基本思想算法基本思想设P是网络G中联结源s和汇t的一条路。定义路的方向是从s到t。将路P上的边分成2类:一类边的方向与路的方向一致,称为向前边向前边。向前边的全体记为P+。另一类边的方向与路的方向相反,称为向后边向后边。向后边的全体记为P-。设flow是一个可行流,P是从s到t的一条路,若P满足下列条件:(1)在P的所有向前边(v,w)上,flow(v,w)0,即P-中的每一条边都是非零流边。则称P为关于可行流flow的一条可增广路。可增广路是残

28、流网络中一条容量大于0的路。将具有上述特征的路P称为可增广路是因为可以通过修正路P上所有边流量flow(v,w)将当前可行流改进成一个流值更大的可行流。39增流的具体做法是:(1)不属于可增广路P的边(v,w)上的流量保持不变;(2)可增广路P上的所有边(v,w)上的流量按下述规则变化:在向前边(v,w)上,flow(v,w)+d;在向后边(v,w)上,flow(v,w)-d。按下面的公式修改当前的流。其中d称为可增广量,可按下述原则确定:d取得尽量大,又要使变化后的流仍为可行流。按照这个原则,d既不能超过每条向前边(v,w)的cap(v,w)-flow(v,w),也不能超过每条向后边(v,w

29、)的flow(v,w)。因此d应该等于向前边上的cap(v,w)-flow(v,w)与向后边上的flow(v,w)的最小值。也就是残流网络中P的最大容量。增广路定理:增广路定理:设flow是网络G的一个可行流,如果不存在从s到t关于flow的可增广路P,则flow是G的一个最大流。402 算法描述算法描述最大流的增广路算法如下。该算法也常称作Ford Fulkerson算法。template class MAXFLOW const Graph&G;int s,t,maxf;vector wt;vector st;int ST(int v)const return stv-other(v);vo

30、id augment(int s,int t)int d=stt-capRto(t);for(int v=ST(t);v!=s;v=ST(v)if(stv-capRto(v)capRto(v);stt-addflowRto(t,d);maxf+=d;for(v=ST(t);v!=s;v=ST(v)stv-addflowRto(v,d);bool pfs();public:MAXFLOW(const Graph&G,int s,int t,int&maxflow):G(G),s(s),t(t),st(G.V(),wt(G.V(),maxf(0)while(pfs()augment(s,t);ma

31、xflow+=maxf;413 算法的计算复杂性算法的计算复杂性增广路算法的效率由下面2个因素所确定。(1)整个算法找增广路的次数;(2)每次找增广路所需的时间。给定的网络中有n个顶点和m条边,且每条边的容量不超过M。可以证明,在一般情况下,增广路算法中找增广路的次数不超过nM次。最短增广路算法在最坏情况下找增广路的次数不超过nm/2次。找1次增广路最多需要O(m)计算时间。因此,在最坏情况下最短增广路算法所需的计算时间为O(nm2)。当给定的网络是稀疏网络,即m=O(n)时,最短增广路算法所需的计算时间为O(n3)。最大容量增广路算法在最坏情况下找增广路的次数不超过2mlogM次。由于使用堆

32、来存储优先队列,找1次增广路最多需要O(nlogn)计算时间。因此,在最坏情况下最大容量增广路算法所需的计算时间为当给定的网络是稀疏网络时,最大容量增广路算法所需的计算时间为预流推进算法预流推进算法 421 算法基本思想算法基本思想增广路算法的特点是找到增广路后,立即沿增广路对网络流进行增广。每一次增广可能需要对最多n-1条边进行操作。最坏情况下,每一次增广需要O(n)计算时间。有些情况下,这个代价是很高的。下面是一个极端的例子。43无论用哪种增广路算法,都会找到10条增广路,每条路长为10,容量为1。共需要10次增广,每次增广需要对10条边进行操作,每条边增广1个单位流量。10条增广路中的前

33、9个顶点(前8条边)是完全一样的。如果直接将前8条边的流量增广10个单位,而只对后面长为2的不同的有向路单独操作,就可以节省许多计算时间。这就是预流推进(preflow push)算法的基本思想。预流推进算法注重对每一条边的增流,而不必每次一定对一条增广路增流。通常将沿一条边增流的运算称为一次推进(push)。在算法的推进过程中,网络流满足容量约束,但一般不满足流量平衡约束。从每个顶点(除s和t外)流出的流量之和总是小于等于流入该顶点的流量之和。这种流称为预流(preflow)。这也是这类算法被称为预流推进算法的原因。下面先给出预流的严格定义。给定网络G=(V,E)一个预流预流是定义在G的边集

34、E上的一个正边流函数。该函数满足容量约束,即对G的每一条边(v,w)E,满足0flow(v,w)cap(v,w)。44G的每一中间顶点满足流出量小于或等于流入量。即对每个vV(vs,t)有满足条件 的中间顶点v称为活顶点活顶点。量 称为顶点v的存流。按此定义,源s和汇t不可能成为活顶点。对网络G上的一个预流,如果存在活顶点,则说明该预流不是可行流。预流推进算法就是要选择活顶点,并通过把一定的流量推进到它的邻点,尽可能地将当前活顶点处正的存流减少为0,直至网络中不再有活顶点,从而使预流成为可行流。如果当前活顶点有多个邻点,那么首先推进到哪个邻点呢?由于算法最后的目的是尽可能将流推进到汇点t,因此

35、算法应寻求把流量推进到它的邻点中距顶点t最近的顶点。预流推进算法中用到一个高度函数h来确定推流边。对于给定网络G=(V,E)的一个流,其高度函数h是定义在G的顶点集V上的一个非负函数。该函数满足:(1)对于G的残流网络中的每一条边(u,v)有,h(u)h(v)+1;(2)h(t)=0。G的残流网络中满足h(u)=h(v)+1的边(u,v)称为G的可推流边可推流边。一般的预流推进算法一般的预流推进算法45一般的预流推进算法的每次迭代是一次推进运算或者一次高度重新标号运算。如果推进的流量等于推流边上的残留容量,则称为饱和推进,否则称为非饱和推进。算法终止时,网络中不含有活顶点。此时只有顶点s和t的

36、存流非零。此时的预流实际上已经是一个可行流。算法预处理阶段已经令h(s)=n,而高度函数在计算过程中不会减少,因此算法在计算过程中可以保证网络中不存在增广路。根据增广路定理,算法终止时的可行流是一个最大流。步骤步骤0:构造初始预流flow:对源顶点s的每条出边(s,v)令flow(s,v)=cap(s,v);对其余边(u,v)令flow(u,v)=0。构造一有效的高度函数h。步骤步骤1:如果残量网络中不存在活顶点,则计算结束,已经得到最大流;否则转步骤2。步骤步骤2:在网络中选取活顶点v。如果存在顶点v的出边为可推流边,则选取一条这样的可推流边,并沿此边推流。否则令h(v)=minh(w)+1

37、|(v,w)是当前残流网络中的边,并转步骤1。46一般的预流推进算法并未给出如何选择活顶点和可推流边。不同的选择策略导致不同的预流推进算法。在基于顶点的预流推进算法中,选定一个活顶点后,算法沿该活顶点的所有推流边进行推流运算,直至无可推流边或该顶点的存变成0时为止。3 算法的计算复杂性算法的计算复杂性基于顶点的预流推进算法用一个广义队列gQ存储当前活顶点集合。广义队列可以是通常的FIFO队列,LIFO栈,随机化队列,随机化栈,或按各种优先级定义的优先队列。算法的效率与广义优先队列的选择密切相关。如果选用通常的FIFO队列,则在最坏情况下,预流推进算法求最大流所需的计算时间为O(mn2),其中m

38、和n分别为图G的边数和顶点数。如果以顶点高度值为优先级,选用优先队列实现预流推进算法,则在最坏情况下,求最大流所需的计算时间为这个算法也称为最高顶点标号预流推进算法。近来已提出许多其它预流推进算法的实现策略,在最坏情况下算法所需的计算时间已接近O(mn)。8.3 8.3 最小费用流问题最小费用流问题471 网络流的费用网络流的费用在实际应用中,与网络流有关的问题,不仅涉及流量,而且还有费用的因素。网络的每一条边(v,w)除了给定容量cap(v,w)外,还定义了一个单位流量费用cost(v,w)。对于网络中一个给定的流flow,其费用定义为:2 最小费用流问题最小费用流问题给定网络G,要求G的一

39、个最大用流flow,使流的总费用最小。3 最小费用可行流问题最小费用可行流问题给定多源多汇网络G,要求G的一个可行流flow,使可行流的总费用最小。可行流问题等价于最大流问题。最小费用可行流问题也等价于最小费用流问题。消圈算法消圈算法 481 算法基本思想算法基本思想最小费用流问题有关的算法中,仍然沿用残流网络的概念。此时,残流网络中边的费用定义为:int costRto(int v)return from(v)?-pcost:pcost;当残流网络中的边是向前边时,其费用不变。当残流网络中的边是向后边时,其费用为原费用的负值。由于残流网络中存在负费用边,因此残流网络中就不可避免地会产生负费用

40、圈。在与最小费用流问题有关的算法中,负费用圈是一个重要概念。最小费用流问题的最优性条件最小费用流问题的最优性条件网络G的最大流flow是G的一个最小费用流的充分且必要条件是flow所相应的残流网络中没有负费用圈。49最小费用流的消圈算法最小费用流的消圈算法 步骤步骤0:用最大流算法构造最大流flow。步骤步骤1:如果残量网络中不存在负费用圈,则计算结束,已经找到最小费用流;否则转步骤2。步骤步骤2:沿找到的负费用圈增流,并转步骤1。503 算法的计算复杂性算法的计算复杂性给定网络中有n个顶点和m条边,且每条边的容量不超过M,每条边的费用不超过C。最大流的费用不超过mCM,而每次消去负费用圈至少

41、使得费用下降1个单位,因此最多执行mCM次找负费用圈和增流运算。用Bellman-Ford算法找1次负费用圈需要O(mn)计算时间。最小费用流的消圈算法在最坏情况下需要计算时间最小费用路算法最小费用路算法511 算法基本思想算法基本思想消圈算法首先找到网络中的一个最大流,然后通过消去负费用圈使费用降低。最小费用路算法不用先找最大流,而是用类似于求最大流的增广路算法的思想,不断在残流网络中寻找从源s到汇t的最小费用路,然后沿最小费用路增流,直至找到最小费用流。残流网络中从源s到汇t的最小费用路是残流网络中从s到t的以费用为权的最短路。残流网络中边的费用定义为:当残流网络中边(v,w)是向前边时,

42、其费用为cost(v,w);当(v,w)是向后边时,其费用为-cost(w,v)。52最小费用流的最小费用路算法最小费用流的最小费用路算法步骤步骤0:初始可行0流。步骤步骤1:如果不存在最小费用路,则计算结束,已经找到最小费用流;否则用最短路算法在残流网络中找从s到t的最小费用可增广路,转步骤2。步骤步骤2:沿找到的最小费用可增广路增流,并转步骤1。533 算法的计算复杂性算法的计算复杂性算法的主要计算量在于连续寻找最小费用路并增流。给定网络中有n个顶点和m条边,且每条边的容量不超过M,每条边的费用不超过C。每次增流至少使得流值增加1个单位,因此最多执行M次找最小费用路算法。如果找1次最小费用

43、路需要s(m,n,C)计算时间,则求最小费用流的最小费用路算法需要O(Ms(m,n,C)计算时间。网络单纯形算法网络单纯形算法 541 算法基本思想算法基本思想消圈算法的计算复杂度不仅与算法找到的负费用圈有关,而且与每次找负费用圈所需的时间有关。网络单纯形算法是从解线性规划问题的单纯形算法演变而来,但从算法的运行机制来看,可以将网络单纯形算法看作另一类消圈算法。其基本思想是用一个可行支撑树结构来加速找负费用圈的过程。对于给定的网络G和一个可行流,相应的可行支撑树可行支撑树定义为G的一棵包含所有弱流边的支撑树。网络单纯形算法的第一步是构造可行支撑树。从一个可行流出发,不断找由弱流边组成的圈,然后

44、沿找到的弱流圈增流,消除所有弱流圈。在剩下的所有弱流边中加入零流边或饱和边构成一棵可行支撑树。在可行支撑树结构的基础上,网络单纯形算法通过顶点的势函数,巧妙地选择非树边,使它与可行支撑树中的边构成负费用圈。然后,沿找到的负费用圈增流。55定义了顶点的势函数后,残流网络中各边(v,w)的势费用定义为:c*(v,w)=c(v,w)-(v)-(w)。其中,c(v,w)是(v,w)在残流网络中的费用。如果对可行支撑树中所有边(v,w)有c*(v,w)=0,则相应的势函数是一个有效势函数。对于一棵可行支撑树,如果将一条非树边加入可行支撑树,产生残流网络中的一个负费用圈,则称该非树边为一条可用边。可可用用

45、边边定定理理:给定一棵可行支撑树及其上的一个有效势函数,非树边e是一条可用边的充分必要条件是,e是一条有正势费用的饱和边,或e是一条有负势费用的零流边。事实上,设e=(v,w)。边e与树边t1,t2,td构成一个圈cycle:t1,t2,td,t1,其中v=t1,w=td。按照边的势费用的定义有:c(w,v)=c*(w,v)+(td)-(t1)c(t1,t2)=(t1)-(t2)c(t2,t3)=(t2)-(t3)c(td-1,td)=(td-1)-(td)56各式相加得:cost(cycle)=c*(w,v)。由此可见,e是一条可用边当且仅当cost(cycle)0;当且仅当c*(w,v)0

46、;当且仅当e是一条有正势费用的饱和边或e是一条有负势费用的零流边。最最优优性性条条件件:给定网络G的可行流flow及相应的可行支撑树T,如果不存在T的可用边,则flow是一个最小费用流。事实上,如果不存在T的可用边,则由可用边的定义知残流网络中没有负费用圈。又由最小费用流问题的最优性条件知flow是一个最小费用流。最小费用流的网络单纯形算法最小费用流的网络单纯形算法步骤步骤0:构造flow为初始可行0流。构造相应的可行支撑树T和有效的顶点势函数。步骤步骤1:如果不存在T的可用边,则计算结束,已经找到最小费用流;否则转步骤2。步骤步骤2:选取T的一条可用边与T的树边构成负费用圈,沿找到的负费用圈增流,从T中删去一条饱和边或零流边,重构可行支撑树,并转步骤1。573 算法的计算复杂性算法的计算复杂性给定网络中有n个顶点和m条边,且每条边的容量不超过M,每条边的费用不超过C。最大流的费用不超过mCM,而每次消去负费用圈至少使得费用下降1个单位,因此最多执行mCM次找负费用圈和增流运算。用网络单纯形算法找1次负费用圈需要O(m)计算时间。因此,求最小费用流的网络单纯形算法在最坏情况下需要计算时间课后作业课后作业58习题 8-3,8-10,8-19,8-25,8-2859

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 应用文书 > 工作报告

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁