- 1、本文档共23页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
最小费用最大流的求解方法-20131212
最小费用最大流的求解方法
一、基本概念
1、什么是最小费用最大流问题?
对每一条弧都给出单位流量费用的容量网络D=(V, A, C) (称为费用容量网络)中,求取最大流f,使输送流量的总费用 b(f) =∑bijfij 为最小的一类优化问题。
其中,cij表示弧(vi, vj)上的容量,bij表示弧(vi, vj)上通过单位流量所花费的费用,fij表示弧(vi, vj)上的流量。
2、最小费用流
对于一个费用容量网络,具有相同流量 v(f) 的可行流中,总费用b(f)最小的可行流称为该费用容量网络关于流量 v(f) 的最小费用流,简称流量为 v(f) 的最小费用流
3、增广链的费用
当沿着一条关于可行流 f 的增广链(流量修正路线)μ,以修正量ε=1进行调整,得到新的可行流 ,则称 为增广链μ的费用。
②增广链μ的费用定义为:以单位调整量调整可行流时所付出的费用;
③当修正量ε=1时,
二、求解最小费用最大流问题的对偶法
1、求解思路:
(1)始终保持网络中的可行流是最小费用
流,然后不断调整,使流量逐步增大,
最终成为最小费用的最大流;
(2)始终保持可行流是最大流,通过不断
调整使费用逐步减小,最终成为最大流
量的最小费用流。
主要学习按思路(1)的求解方法始终保持网络中的可行流是最小费用流,然后不断调整,使流量逐步增大,最终成为最小费用的最大流。
v(f)
b(f)
应该如何实现“始终保持网络中的可行流是最小费用流” 呢?
(2)实现思路
基于第一种求解途径,根据上述定理,从流量为v(f) 的最小费用流f 开始,只要找到其上的最小费用增广链,在该链上调整流量,就得到增加流量后的最小费用流。循环往复就可以求出最小费用最大流。
实施中的关键——寻找最小费用增广链
具体方法:构造增广费用网络图,借助最短路算法寻找最小费用增广链。
增广费用网络图的构造方法
将流量网络中的每一条弧(vi,vj)用一对方向相反的弧替代,并定义弧的权数如下:
对于零流弧(fij=0),在其对应位置构造与其方向相同且权数为bij的弧;
对于非饱和且非零流弧( cijfij0),在其对应位置构造与其方向相同且边权为bij的弧,以及与其方向相反且边权为-bij的弧。
处理完所有的弧,即形成增广费用网络图。
对于饱和弧(fij=cij),在其对应位置构造与其方向相反且权数为-bij的弧;
对弧的三种处理结果:
(1) 零流弧上(fij=0) ,保持原弧不变,将单位费用作为权数,即wij= bij:
bij
(2) 饱和弧上(fij=cij):去掉原有弧,添加以单位费用的负数作为权数后向弧(虚线弧):
(3) 非饱和且非零流弧上( cijfij0) ,原有弧以单位费用作权数,并添加以单位费用的负数作为权数后向弧(虚线弧):
3、整个过程的求解步骤:
第一步---取初始可行流为零流 ,它必为流量=0的最小费用流。
第二步 --- 对该可行流f(0)构造增广费用网络图W(f(0)),用最短路算法求出从发点到收点的最短路。(寻找f(0)的最小费用增广链)
若不存在最短路,则该可行流即为最小费用最大流,停止迭代;否则,转下一步。
第三步--- 将最短路还原成流量网络图(cij,fij)中的最小费用增广链μ,在μ上对可行流f(0)进行调整(采用最大流问题中的增广链流量调整方法),得到新的可行流图。返回第二步,将f(0)替换为新的可行流即可。
4、举例:以下图为例,求最小费用最大流,弧旁的数字为(cij,bij)。
解:(1)以零流弧为初始可行流f(0),则初始可行流的流量v(f(0))=0。
4
1
1
3
2
2
6
第 1 次 迭 代
① f(0)中全部是零流弧,则保持原边不变,单位费用为权;
②所有的权均大于零,可用D氏标号法求出最短路:
即是f(0)的最小费用增广链。
①流量调整量
ε1=min{8-0,5-0,7-0}=5
总流量v(f(1))=5
②最小费用增广链的费用∑bij=1+2+1=4
③新的可行流为f(1),总费用b1=4×5=20
第 2 次 迭 代
1
-2
6
4
-1
3
2
1
-1
①零流弧保持原边,非饱和非零流弧(vs,v2)和(v1,vt)增添后向弧,饱和弧(v2,v1)去掉原弧增添后向弧;
②用列表法求出最短路:
即是f(1)的最小费用增广链。
①流量调整量
ε2=min{10-0,7-5}=2,
总流量v(f(2))=原流量+新增
流量=5+
您可能关注的文档
- 《齿轮机械原理》大全概要1.ppt
- 一、客观实际是人生选择的前提和基础概要1.pptx
- 暨南大学蓝海战略.ppt
- 更新版本自检报告.doc
- 一、职业礼仪塑形象概要1.ppt
- 一、静力载荷试验概要1.docx
- 一 苹果优良品种.ppt概要1.ppt
- 普通生物学第二章生命的化学基础.ppt
- 曲棍球运动员膝关节损伤.pptx
- 一、声现象复习概要1.ppt
- 数据仓库:Redshift:Redshift与BI工具集成.docx
- 数据仓库:Redshift:数据仓库原理与设计.docx
- 数据仓库:Snowflake:数据仓库成本控制与Snowflake定价策略.docx
- 大数据基础:大数据概述:大数据处理框架MapReduce.docx
- 实时计算:GoogleDataflow服务架构解析.docx
- 分布式存储系统:HDFS与MapReduce集成教程.docx
- 实时计算:Azure Stream Analytics:数据流窗口与聚合操作.docx
- 实时计算:Kafka Streams:Kafka Streams架构与原理.docx
- 实时计算:Kafka Streams:Kafka Streams连接器开发与使用.docx
- 数据仓库:BigQuery:BigQuery数据分区与索引优化.docx
文档评论(0)