Ahuja-Orlin: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
		
	
| Line 11: | Line 11: | ||
| # The flow <math>f</math> is a fleasible flow. | # The flow <math>f</math> is a fleasible flow. | ||
| # If all upper bounds are integral, <math>f</math> is integral as well. | # If all upper bounds are integral, <math>f</math> is integral as well. | ||
| # There is a [[Basic flow definitions|valid distance labeling]] <math>d</math> with respect to <math></math>. | # There is a [[Basic flow definitions|valid distance labeling]] <math>d</math> with respect to <math>f</math>. | ||
| # Each node <,ath>v\in V\setminus\{t\}</math> has a '''current arc'', which is either void or one of the outgoing arcs of <math>v</math>. | # Each node <,ath>v\in V\setminus\{t\}</math> has a '''current arc'', which is either void or one of the outgoing arcs of <math>v</math>. | ||
| # There is a '''current flow-augmenting path''' with respect to <math>f</math>. This path starts wit <math>s</math> and ends at an arbitrary node of <math>G</math>. Each arc on this path is the curren tarc of its tail. | # There is a '''current flow-augmenting path''' with respect to <math>f</math>. This path starts wit <math>s</math> and ends at an arbitrary node of <math>G</math>. Each arc on this path is the curren tarc of its tail. | ||
| '''Variant:''' | '''Variant:''' | ||
| If no arc is appended to tha path in the current iteration, the distance label of some node (the endnode of the pat , in fact) is increased. | |||
| '''Break condition:'''  | '''Break condition:''' <math>d(s)\geq n</math>. | ||
| == Remark == | == Remark == | ||
| This algorithm may be seen as a "lazy" variant on [[Edmonds-Karp]]. In fact, the most expensive step there is the computation of a flow-augmenting <math>(s,t)</math>-path. This task amounts to computing the true distance from every node to <math>t</math>. A valid distance labeling may be seen as "lazily evaluated" true distances. | This algorithm may be seen as a "lazy" variant on [[Edmonds-Karp]]. In fact, the most expensive step there is the computation of a flow-augmenting <math>(s,t)</math>-path. This task amounts to computing the true distance from every node to <math>t</math>. A valid distance labeling may be seen as "lazily evaluated" true distances. | ||
Revision as of 06:41, 13 October 2014
General Information
Algorithmic problem: Max-Flow Problems
Type of algorithm: loop
Abstract View
Invariant: After [math]\displaystyle{ i \ge 0 }[/math] iterations:
- The flow [math]\displaystyle{ f }[/math] is a fleasible flow.
- If all upper bounds are integral, [math]\displaystyle{ f }[/math] is integral as well.
- There is a valid distance labeling [math]\displaystyle{ d }[/math] with respect to [math]\displaystyle{ f }[/math].
- Each node <,ath>v\in V\setminus\{t\}</math> has a 'current arc, which is either void or one of the outgoing arcs of [math]\displaystyle{ v }[/math].
- There is a current flow-augmenting path with respect to [math]\displaystyle{ f }[/math]. This path starts wit [math]\displaystyle{ s }[/math] and ends at an arbitrary node of [math]\displaystyle{ G }[/math]. Each arc on this path is the curren tarc of its tail.
Variant: If no arc is appended to tha path in the current iteration, the distance label of some node (the endnode of the pat , in fact) is increased.
Break condition: [math]\displaystyle{ d(s)\geq n }[/math].
Remark
This algorithm may be seen as a "lazy" variant on Edmonds-Karp. In fact, the most expensive step there is the computation of a flow-augmenting [math]\displaystyle{ (s,t) }[/math]-path. This task amounts to computing the true distance from every node to [math]\displaystyle{ t }[/math]. A valid distance labeling may be seen as "lazily evaluated" true distances.