《数学建模提高班第六讲-网络优化模型及案例分析.ppt》由会员分享,可在线阅读,更多相关《数学建模提高班第六讲-网络优化模型及案例分析.ppt(94页珍藏版)》请在三一办公上搜索。
1、网络优化模型及案例分析,梦想点燃激情,激情成就未来,赵承业 2011/4/24,本专题学习目的,掌握把实际问题转化为图或网络问题的方法了解图的基本概念和矩阵表示方法掌握最短路问题、最小生成树问题的算法了解旅行商问题,一种表示工具图,最小生成树,主要内容,一个时间安排问题,图论的起源,人、狼、羊、菜渡河问题,最短路问题,图的矩阵表示方法,练习题,主要内容,旅行商问题,图论的起源:七桥问题,图论的起源:七桥问题,图1,图2,欧拉图论之父 定理1:一个图存在通过每边正好一次回到出发点的路线的充要条件是:1)图要是连通的2)与图中每一顶点相连的边必须是偶数条。于是得出结论:七桥问题无解。,图论的起源:
2、七桥问题,返 回,无向图,一般用大写字母G,H表示。,一种表示工具图,图3,无向图:G=(V,E),顶点集:V;边集:E。e与顶点u,v相关联。u与v相邻。两边相邻。重边,一种表示工具图,图4,两种特殊图:简单图 完全图,记为Kn,一种表示工具图,图6,图5,有向图:,你能给出一个可用有向图描述的实际例子吗?,一种表示工具图,图7,网络,这些数字可以代表距离,费用,可靠性或其他的相关参数。,一种表示工具图,图8,(G)和(G)分别表示图G的顶点数和边数在无向图中,v的度数,记为d(v);在有向图中,v的出度,记为d+(v);v的入度,记为d-(v)。,一种表示工具图,返 回,一个时间安排问题,
3、学校要为一年级的研究生开设六门基础数学课:统计(S),数值分析(N),图论(G),矩阵论(M),随机过程(R)和数理方程(P)。按培养计划,注册的学生必须选修其中的一门以上,你作为教务管理人员,要设法安排一个课表,使每个学生所选的课程,在时间上不会发生冲突。,一个时间安排问题,表1,完成上述表示课程冲突关系的图,直观、清晰地表达已知信息的方式,一个时间安排问题,返 回,图9,人狼羊菜渡河问题,摆渡人F狼W羊G菜C,图10,南岸状态:16种,其中WG,GC,WGC,从而FC,FW,F为不允许状态,,10个允许状态:,人狼羊菜渡河问题,寻求图中从顶点“FWGC”到顶点“O”的最短路径,这样的路径有
4、几条?求出最优的渡河方案。,语言描述时未显示的关系跃然纸上,人狼羊菜渡河问题,图11,人狼羊菜渡河问题,返 回,图12,图的矩阵表示方法,邻接矩阵,关联矩阵,边矩阵,邻接顺序表,返 回,邻接矩阵,图13,无向图的邻接矩阵:A=(aij)nn,其中,无向图的邻接矩阵有何特点?由邻接矩阵是否能作出原图?,邻接矩阵,返 回,关联矩阵,图13,无向图的关联矩阵:M=(mij)nm,其中,无向图的关联矩阵有哪些特征?由关联矩阵能否作出原图?,关联矩阵,返 回,边矩阵,返 回,图13,最短路问题及算法,最短路问题是图论应用的基本问题,很多实际,问题,如线路的布设、运输安排、运输网络最小费,用流等问题,都可
5、通过建立最短路问题模型来求解.,最短路的定义,最短路问题的两种方法:Dijkstra和Floyd算法.,1)求赋权图中从给定点到其余顶点的最短路.,2)求赋权图中任意两点间的最短路.,2)在赋权图G中,从顶点u到顶点v的具有最小权,定义1 1)若H是赋权图G的一个子图,则称H的各,边的权和 为H的权.类似地,若,称为路P的权,若P(u,v)是赋权图G中从u到v的路,称,的路P*(u,v),称为u到v的最短路,3)把赋权图G中一条路的权称为它的长,把(u,v),路的最小权称为u和v之间的距离,并记作 d(u,v).,1)赋权图中从给定点到其余顶点的最短路,假设G为赋权有向图或无向图,G边上的权均
6、非,负若,则规定,最短路是一条路,且最短路的任一节也是最短路,例 求下面赋权图中顶点u0到其余顶点的最短路,图14,Dijkstra算法:求G中从顶点u0到其余顶点的最短路.,1)置,对,且.,2)对每个,用,代替,计算,并把达到这个最小值的,一个顶点记为,置,3)若,则停止;若,则用 i+1 代,替i,并转2).,Dijkstra算法:求G中从顶点u0到其余顶点的最短路.,1)置,对,且.,2)对每个,用,代替,计算,并把达到这个最小值的,一个顶点记为,置,3)若,则停止;若,则用 i+1 代,替i,并转2).,Dijkstra算法:求G中从顶点u0到其余顶点的最短路.,1)置,对,且.,2
7、)对每个,用,代替,计算,并把达到这个最小值的,一个顶点记为,置,3)若,则停止;若,则用 i+1 代,替i,并转2).,Dijkstra算法:求G中从顶点u0到其余顶点的最短路.,1)置,对,且.,2)对每个,用,代替,计算,并把达到这个最小值的,一个顶点记为,置,3)若,则停止;若,则用 i+1 代,替i,并转2).,定义2 根据顶点v的标号l(v)的取值途径,使 到v,的最短路中与v相邻的前一个顶点w,称为v的先驱,点,记为z(v),即z(v)=w.,先驱点可用于追踪最短路径.例5的标号过程也,可按如下方式进行:,首先写出左图带权邻接矩阵,因G是无向图,故W是对称阵,表2,续表2,图8,
8、2)求赋权图中任意两顶点间的最短路,算法的基本思想,(I)求距离矩阵的方法.,(II)求路径矩阵的方法.,(III)查找最短路路径的方法.,Floyd算法:求任意两顶点间的最短路.,举例说明,算法的基本思想,(I)求距离矩阵的方法.,(II)求路径矩阵的方法.,在建立距离矩阵的同时可建立路径矩阵R,(III)查找最短路路径的方法.,然后用同样的方法再分头查找若:,图16,(IV)Floyd算法:求任意两顶点间的最短路.,例 2求下图中加权图的任意两点间的距离与路径.,图17,插入点 v1,得:,矩阵中带“=”的项为经迭代比较以后有变化的元素.,插入点 v2,得:,矩阵中带“=”的项为经迭代比较
9、以后有变化的元素.,插入点 v3,得:,插入点 v4,得:,插入点 v5,得:,插入点 v6,得:,故从v5到v2的最短路为8,由v6向v5追溯:,由v6向v2追溯:,所以从到的最短路径为:,返 回,最小生成树及算法,许多应用问题都是一个求无向连通图的最小生成树问题。例如:要在n个城市之间铺设光缆,主要目标是要使这 n 个城市的任意两个之间都可以通信,但铺设光缆的费用很高,且各个城市之间铺设光缆的费用不同;另一个目标是要使铺设光缆的总费用最低。这就需要找到带权的最小生成树。,1)树的定义与树的特征,定义3 连通且不含圈的无向图称为树常用T表示.,树中的边称为树枝.树中度为1的顶点称为树叶.,孤
10、立顶点称为平凡树.,平凡树,图18,定理2 设G是具有n个顶点的图,则下述命题等价:,1)G是树(G无圈且连通);,2)G无圈,且有n-1条边;,3)G连通,且有n-1条边;,4)G无圈,但添加任一条新边恰好产生一个圈;,5)G连通,且删去一条边就不连通了(即G为最,最小连通图);,6)G中任意两顶点间有唯一一条路.,2)图的生成树,定义4 若T是包含图G的全部顶点的子图,它又是树,则称T是G的生成树.图G中不在生成树的边叫做弦.,定理3 图G=(V,E)有生成树的充要条件是图G是连,通的.,证明 必要性是显然的.,(II)找图中生成树的方法,可分为两种:避圈法和破圈法,A 避圈法:深探法和广
11、探法,B 破圈法,A 避圈法,定理3的充分性的证明提供了一种构造图的生,成树的方法.,这种方法就是在已给的图G中,每步选出一条边使它与已选边不构成圈,直到选够n-1条边为止.这种方法可称为“避圈法”或“加边法”,在避圈法中,按照边的选法不同,找图中生成树的方法可分为两种:深探法和广探法.,a)深探法,若这样的边的另一端均已有标号,就退到标号为,步骤如下:,i)在点集V中任取一点u,ii)若某点v已得标号,检,端是否均已标号.,若有边vw之w未标号,则给,w代v,重复ii).,i-1的r点,以r代v,重复ii),直到全部点得到标号为止.,给以标号0.,查一端点为v的各边,另一,w以标号i+1,记
12、下边vw.令,例3用深探法求出下图10的一棵生成树,0,1,2,3,4,5,6,7,8,9,10,11,12,13,图20,3,b)广探法,步骤如下:,i)在点集V中任取一点u,ii)令所有标号i的点集为,是否均已标号.对所有未标,号之点均标以i+1,记下这些,iii)对标号i+1的点重复步,步骤ii),直到全部点得到,给u以标号0.,Vi,检查Vi,VVi中的边端点,边.,例4用广探法求出下图10的一棵生成树,1,0,1,2,2,1,3,2,1,2,2,3,4,标号为止.,B 破圈法,相对于避圈法,还有一种求生成树的方法叫做“破圈法”.这种方法就是在图G中任取一个圈,任意舍弃一条边,将这个圈
13、破掉,重复这个步骤直到图G中没有圈为止.,例5 用破圈法求出,下图的一棵生成树.,图22,B 破圈法,例6 用破圈法求出下图的另一棵生成树.,不难发现,图的生成树不是唯一的.,图23,3)最小生成树与算法,介绍最小树的两种算法:Kruskal算法(或避圈法)和破圈法.,5,A Kruskal算法(或避圈法),步骤如下:,1)选择边e1,使得w(e1)尽可能小;,2)若已选定边,则从,中选取,使得:,i)为无圈图,,ii)是满足i)的尽可能小的权,,3)当第2)步不能继续执行时,则停止.,定理4 由Kruskal算法构作的任何生成树,都是最小树.,例7用Kruskal算法求下图的最小树.,在左图
14、中 权值,最小的边有 任取一条,在 中选取权值,最小的边,中权值最小边有,从中选,任取一条边,会与已选边构成圈,故停止,得,中选取在中选取,中选取.但 与 都,图24,B破圈法,算法2 步骤如下:,1)从图G中任选一棵树T1.,2)加上一条弦e1,T1+e1中,立即生成一个圈.去掉此,圈中最大权边,得到新,树T2,以T2代T1,重复2)再,检查剩余的弦,直到全,部弦检查完毕为止.,例8 用破圈法求下图的最小树.,先求出上图的一棵生成树.,加以弦 e2,得到的圈v1v3v2v1,去掉最大的权边e2,得到一棵新,树仍是原来的树;,再加上弦e7,得到圈 v4v5v2v4,去掉最大的权边e6,得到一棵
15、,新树;如此重复进行,直到全,全部的弦均已试过,得最小树.,返 回,图25,旅行售货员问题,定义6设G=(V,E)是连通无向图,包含图G的每个,顶点的路称为G的哈密尔顿路(Hamilton路或H路).,包含图G的每个顶点的圈,称为G的哈密尔顿圈,(或Hamilton圈或H圈).,含Hamilton圈的图称为哈密尔顿图(或Hamilton,图或H图).,旅行售货员问题或货郎担问题,一个旅行售货员想去访问若干城镇,然后回,到出发地.给定各城镇之间的距离后,应怎样计划,他的旅行路线,使他能对每个城镇恰好经过一次,而总距离最小?,它可归结为这样的图论问题:在一个赋权完,全图中,找出一个最小权的H圈,称
16、这种圈为最优圈.,但这个问题是NP-hard问题,即不存在多项式,时间算法.也就是说,对于大型网络(赋权图),目前还,没有一个求解旅行售货员问题的有效算法,因此,只能找一种求出相当好(不一定最优)的解.,一个可行的办法:,是先求一个H圈,然后适当,修改,以得到具有较小权的另,一个H圈.,图26,定义7 若对于某一对i和j,有,则圈Cij将是圈C的一个改进.,定义8 二边逐次修正法:,在接连进行一系列修改之后,最后得一个圈,不能,再用此方法改进了,这个最后的圈可能不是最优的,但是它是比较好的,为了得到更高的精度,这个,程序可以重复几次,每次都以不同的圈开始.这种,方法叫做二边逐次修正法.,例9
17、对下图,用二边逐次修正法求较优H圈.,较优H圈:,其权为W(C3)=192,图27,分析:找出的这个解的好坏可用最优H圈的权,的下界与其比较而得出.即利用最小生成树可得最,优H圈的一个下界,方法如下:,设C是G的一个最优H圈,则对G的任一顶点v,C-v是G-v的路,也G-v是的生成树.如果T是G-v的,最小生成树,且e1是e2与v关联的边中权最小的两条,边,则w(T)+w(e1)+w(e2)将是w(C)的一个下界.,取v=v3,得G-v3的一,最小生成树(实线),其,权w(T)=122,与v3关联,的权最小的两条边为,w(T)+w(v1v3)+w(v2v3),=178.故最优H圈的权,v1v3
18、和v2v3,故w(C),应满足178 w(C)192.,返 回,1.设某校的田径选拔赛共设六个项目的比赛,即跳高,跳远,标枪,铅球,100米和200米短跑,规定每个选手至多参加三个项目的比赛。现有七名选手报名,选手所选项目如表1所示。现在要求设计一个比赛日程安排表,使得在尽可能短的时间内完成比赛。,田径赛的时间安排,练习题,表1 参赛选手比赛项目表,附录:图论算法的matlab实现,最短路问题,例 某公司在六个城市中有分公司,从ci到cj的直接航程票价记在下述矩阵的位置上。(表示无直接航路),请帮助该公司设计一张城市c1到其它城市间的票价最便宜的路线图。,用矩阵(为顶点个数)存放各边权的邻接矩
19、阵,行向量pb、index1、index2、d分别用来存放标号信息、标号顶点顺序、标号顶点索引、最短通路的值。其中分量 index2(i)存放始点到第点最短通路中第顶点前一顶点的序号;d(i)存放由始点到第点最短通路的值。,Dijkstra 的Matlab程序如下:M=10000;a(1,:)=0,50,M,40,25,10;a(2,:)=zeros(1,2),15,20,M,25;a(3,:)=zeros(1,3),10,20,M;a(4,:)=zeros(1,4),10,25;a(5,:)=zeros(1,5),55;a(6,:)=zeros(1,6);a=a+a;,pb(1:length
20、(a)=0;pb(1)=1;index1=1;index2=ones(1,length(a);d(1:length(a)=M;d(1)=0;temp=1;while sum(pb)length(a)tb=find(pb=0);d(tb)=min(d(tb),d(temp)+a(temp,tb);tmpb=find(d(tb)=min(d(tb);temp=tb(tmpb(1);pb(temp)=1;,index1=index1,temp;index=index1(find(d(index1)=d(temp)-a(temp,index1);if length(index)=2 index=ind
21、ex(1);end index2(temp)=index;endd,index1,index2,Floyd算法的Matlab程序如下:clear;clc;M=10000;a(1,:)=0,50,M,40,25,10;a(2,:)=zeros(1,2),15,20,M,25;a(3,:)=zeros(1,3),10,20,M;a(4,:)=zeros(1,4),10,25;a(5,:)=zeros(1,5),55;a(6,:)=zeros(1,6);b=a+a;path=zeros(length(b);,for k=1:6 for i=1:6 for j=1:6 if b(i,j)b(i,k)+
22、b(k,j)b(i,j)=b(i,k)+b(k,j);path(i,j)=k;end end endendb,path,最小生成树问题,prim算法如下:clc;clear;M=1000;a(1,2)=50;a(1,3)=60;a(2,4)=65;a(2,5)=40;a(3,4)=52;a(3,7)=45;a(4,5)=50;a(4,6)=30;a(4,7)=42;a(5,6)=70;a=a;zeros(2,7);a=a+a;a(find(a=0)=M;result=;p=1;tb=2:length(a);while length(result)=length(a)-1 temp=a(p,tb
23、);temp=temp(:);d=min(temp);jb,kb=find(a(p,tb)=d);j=p(jb(1);k=tb(kb(1);result=result,j;k;d;p=p,k;tb(find(tb=k)=;endresult,Kruskal算法如下:clc;clear;M=1000;a(1,2)=50;a(1,3)=60;a(2,4)=65;a(2,5)=40;a(3,4)=52;a(3,7)=45;a(4,5)=50;a(4,6)=30;a(4,7)=42;a(5,6)=70;i,j=find(a=0),用 存放各边端点的信息,当选中某一边之后,就将此边对应的顶点序号中较大序号改记为此边的另一序号,同时把后面边中所有序号为的改记为。此方法的几何意义是:将序号的这个顶点收缩到顶点,顶点不复存在。后面继续寻查时,发现某边的两个顶点序号相同时,认为已被收缩掉,失去了被选取的资格。,while length(result)v2 index(find(index=v1)=v2;else index(find(index=v2)=v1;end data(:,flag)=;index(:,flag)=;endresult,