网络流
此条目没有列出任何参考或来源。 (2020年10月22日) |
在图论中,网络流(英语:Network flow)是指在一个每条边都有容量(Capacity)的有向图分配流,使一条边的流量不会超过它的容量。通常在运筹学中,有向图称为网络。顶点称为节点(Node)而边称为弧(Arc)。一道流必须符合一个结点的进出的流量相同的限制,除非这是一个源点(Source)──有较多向外的流,或是一个汇点(Sink)──有较多向内的流。一个网络可以用来模拟道路系统的交通量、管中的液体、电路中的电流或类似一些东西在一个结点的网络中游动的任何事物。
定义
编辑网络流图
编辑如果带权有限的有向图 满足如下条件,则称之为网络流图(或容量网络):
- 有且仅有一个结点 入度为0.称为源点。
- 有且仅有一个结点 出度为0.称为汇点。
- , 称为这条弧的容量。特别地,如果 ,可以假定 .
净流
编辑通过容量网络中的一条弧 的流量(或净流)记为 .
弧
编辑弧是网络流图中的一条带权边 .
特殊的弧有:
- 零流弧满足 .
- 非零流弧满足 .
- 饱和弧满足 .
- 非饱和弧满足 .
网络流
编辑一个流量的集合 包含所有弧上的流,则称为这个容量网络的一个网络流。
可行流
编辑- 容量限制(Capacity Constraints): .
- 流守恒(Flow Conservation): 除非 或 ,否则 一结点的净流是零,除了“制造”流的源点和“消耗”流的汇点。
伪流
编辑伪流是一种与可行流相对的概念,如果一个网络流只满足容量限制条件,不满足流守恒条件,那么这个网络流就是一个伪流。
剩余容量
编辑边的剩余容量(Residual Capacity)简称为残量,是 .
残量网络
编辑由所有边均为其残量的 称为残量网络(Residual Network)或剩余网络.它显示可用的容量的多少。留意就算在原网络中由 到 没有边,在剩余网络仍可能有由 到 的边。因为相反方向的流抵消,减少由 到 的流等于增加由 到 的流。
最大流
编辑增广路
编辑增广路(Augmenting Path)是一条路径 ,而 、 及 ,这表示沿这条路径传送更多流是可能的。当且仅当剩余网络 没有增广路时处于最大流。
性质
编辑在任意时刻, 的网络流都满足如下性质。
容量限制
编辑通过一条弧的流量不能超过这条弧的容量上限。
反对称性
编辑从一个结点 到另一个结点 的净流量一定是从 到 净流量的相反数。
流守恒
编辑对于 中任意一个结点 ,如果它既不是源点也不是汇点,那么它到相邻结点的所有流量之和为0.
例子
编辑在右边可以看到一个有以 标示的源点、以 标示的汇点及4个额外结点的流网络。流及容量以 显示。注意网络怎样保证斜对称、容量限制及流守恒。由 到 的总流量为5,由此可简单地观察到源于 的所有向外流是5,也就是汇于 的向内流。我们知道在其它结点中没有任何流出现或消失。
在下面你可以看到对既定的流的剩余网络。注意某些边的剩余容量是正数而原来的容量是零,如边 。这道流不是一道最大流。沿路径 、 及 还有可用的容量,也就是扩张路径。第一条路径的剩余容量是 。注意扩张路径 在原来的网络中并不存在,但你可以沿它发送流,因此仍是一道正当的流。
假如这是一个真实的网络,由 到 的2单位的流及由 到 的1单位的流事实上可能存在,但我们只维持净流。
应用
编辑将一连串的水管绘画成一个网络。每条水管有一特定的阔度,因此只可以保持一特定的水流量。当任何水管汇合,流入汇流点的总水量必须等于流出的水量,否则我们会很快地缺水,或者我们会团积水。我们有一个作为源点的入水口,和一个作为汇点的出水口。一道流便是一条由源点到汇点而使从出水口流出的总水量一致的可能路径。直观地,一个网络的总流量是水从出口流出的速率。
流可以适用于交通网络上的人或材料,或配电系统上的电力。对于任何这样的实物网络,进入任何中途结点的流需要等于离开那个结点的流。这个守恒限制相当于基尔霍夫电流定律。
在生态学中也可找到网络流的应用:当考虑在食物网中不同组织之间养料及能量的流,网络流便自然地产生。与这些网络有联系的数学问题和那些液体流或交通流网络中所产生的难题有很大分别。由Robert Ulanowicz及其他人发展的生态系统网络分析领域包含使用信息论及热力学的概念去研究这些网络随时间的演变。
普遍化及专门化
编辑利用网络流去找出最大流是最简单及最普通的问题,它提供了在一指定的图中由源点到汇点的最大可能总流量。还有很多其它问题可以利用最大流算法去解决,假设它们可以适当地塑造成流网络的模样,例如二分图匹配(Bipartite Matching)、任务分配问题(Assignment Problem)和运输问题(Transportation Problem)。
在多物网络流问题(Multi-commodity Flow Problem)中,可以有多个源点和汇点,和各种各样的由指定源点发送到指定汇点的“物品(Commodities)”。例如这可能是不同的工厂生产的各种各样的货物经由“同一”运输网络运送到不同的消费者手上。
在最小费用最大流问题(Minimum Cost Flow Problem)中,每条边 都有特定费用 。沿这条边发送 的费用是 。目标是要用最低的成本由源点发送一特定数量的流到汇点。
在环流问题(Circulation Problem)中,每条边除了有上限 外,还有下限 。每条边亦有一个费用。很多时,流守恒适用于环流问题中所有结点,由汇点到源点亦有一条链接。这样便能利用 和 支配总流量。这问题因流环绕网络流动而得名。
在有增益网络或普遍化网络中,每条边都有增益,一个实数(非零)使如果这条边有一增益g而有一流量x的流在尾部流入,便有一流量gx的流从头部流出。
参见
编辑延伸阅读
编辑- George T. Heineman, Gary Pollice, and Stanley Selkow. Chapter 8:Network Flow Algorithms. Algorithms in a Nutshell. Oreilly Media. 2008: 226–250. ISBN 978-0-596-51624-6.
- Ravindra K. Ahuja, Thomas L. Magnanti, and James B. Orlin. Network Flows: Theory, Algorithms and Applications. Prentice Hall. 1993. ISBN 0-13-617549-X.
- Bollobás, Béla. Graph Theory: An Introductory Course. Heidelberg: Springer-Verlag. 1979. ISBN 3-540-90399-2.
- Chartrand, Gary & Oellermann, Ortrud R. Applied and Algorithmic Graph Theory. New York: McGraw-Hill. 1993. ISBN 0-07-557101-3.
- Even, Shimon. Graph Algorithms. Rockville, Maryland: Computer Science Press. 1979. ISBN 0-914894-21-8.
- Gibbons, Alan. Algorithmic Graph Theory. Cambridge: Cambridge University Press. 1985. ISBN 0-521-28881-9.
- Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, and Clifford Stein. 26. Introduction to Algorithms 2nd. MIT Press and McGraw-Hill. 2001: 696–697 [1990]. ISBN 0-262-03293-7.
外部链接
编辑- Maximum Flow Problem
- Real graph instances (页面存档备份,存于互联网档案馆)
- Lemon C++ library with several maximum flow and minimum cost circulation algorithms (页面存档备份,存于互联网档案馆)
- QuickGraph (页面存档备份,存于互联网档案馆), graph data structures and algorithms for .Net