Problème de flot maximum

Un article de Wikipédia, l'encyclopédie libre.
Un exemple de graphe de flot avec un flot maximum. la source est , et le puits . Les nombres indiquent le flot et la capacité.

Le problème de flot maximum consiste à trouver, dans un réseau de flot, un flot réalisable depuis une source unique et vers un puits unique qui soit maximum[1]. Quelquefois[Quand ?], on ne s'intéresse qu'à la valeur de ce flot. Le s-t flot maximum (depuis la source s vers le puits t) est égal à la s-t coupe minimum du graphe, comme l'indique le théorème flot-max/coupe-min.

Applications[modifier | modifier le code]

Ce type de problème est proche de ce qui est rencontré dans le remplissage optimisé de boîtes. On peut également utiliser des approches de flot maximum pour résoudre des problèmes de gestion d'écoulements dans des réseaux (égouts, conduites d'eau, trafic routier...).

Algorithmes[modifier | modifier le code]

Étant donné un graphe orienté , où chaque arc a une capacité , on cherche un flot maximum depuis la source vers le puits , sous contrainte de capacité. Différents algorithmes ont été développés pour résoudre ce problème de complexités différentes. On utilise, dans la description des complexités, la notation simplifiée qui remplace le cardinal d'un ensemble par l'ensemble lui-même : on écrit au lieu de .

Algorithme Complexité Description
Programmation linéaire Les contraintes sont données par flot admissible, où on considère comme admissible un flot qui n'excède pas la capacité d'un arc. On maximise
Algorithme de Ford-Fulkerson
dans le cas entier
Tant qu'il existe un chemin entre la source et le puits dans le graphe résiduel, envoyer le minimum des capacités résiduelles sur ce chemin.
Algorithme d'Edmonds-Karp Spécialisation de l'algorithme de Ford-Fulkerson, où les chemins augmentants sont des plus courts chemins (en nombre d'arcs) dans le graphe résiduel (on utilise un parcours en largeur)
Algorithme de flot bloquant de Dinitz À chaque phase l'algorithme construit un graphe en couches avec une recherche en profondeur d'abord sur le graphe résiduel. Le flot maximum dans le graphe en couche peut être calcule en temps , et le nombre maximum de phase est de .
Algorithme de flot maximum par poussage/réétiquetage Cet algorithme maintient un préflot, i.e. une fonction de flot avec une possibilité d'excès dans les sommets. L'algorithme fonctionne tant qu'il existe un sommet avec un excès strictement positif, appelé sommet actif du graphe. L'opération de poussage augmente le flot sur une arête résiduelle, et une fonction de hauteur contrôle sur les sommets contrôle quelles arêtes résiduelles doivent être poussées. Cette fonction est changée avec la fonction d'étiquetage. Les définitions de ces opérations garantissent que le flot résultant est un flot maximum.
Poussage/réétiquetage avec règle de sélection des sommets par FIFO Variante qui sélectionne toujours le sommet le plus actif formellement, et fait les opérations jusqu'à ce que l'excès soit positif ou qu'il existe des arêtes résiduelles admissibles depuis ce sommet.
Algorithme de flot bloquant de Dinitz avec arbre dynamique[2] La structure d'arbre dynamique accélère le calcul de flot maximum dans le graphe en couche pour obtenir par phase.
Poussage/re-étiquetage avec usage des arbres dynamiques[3] L'algorithme construit des arbres de taille limitée sur le graphe résiduel en considérant la fonction de hauteur, ces arbres fournissent des opérations de poussage multi-niveau.
Algorithme de flot bloquant binaire[4] La valeur correspond à la capacité maximum du réseau.
KRT : Algorithme de King, Rao et Tarjan[5]
Algorithme de James B Orlin + KRT[6] L'algorithme d'Orlin calcule le flot maximum en temps O(VE) pour et KRT résout le problème en O(VE) pour .
Algorithme de Chen, Kyng, Liu, Peng, Gutenberg et Sachdeva [7] L'algorithme de Chen, Kyng, Liu, Peng, Gutenberg et Sachdeva' résout le problème de flot maximum et cout minimum en temps presque linéaire en construisant le flot par une série de cycles non-orientés de ratios minimums approchés, chacun calculé et utilisé en temps amorti avec une structure de donnée dynamique.

Une liste plus complète figure dans le livre de Cormen, Leiserson, Rivest et Stein[1]. Le problème du flot maximal est complet pour la classe P[8].

Extensions[modifier | modifier le code]

Le problème du flot maximum peut être vu comme un cas particulier de plusieurs autres problèmes de flots dans les réseaux, comme le flot multi-commodités.

Références bibliographiques[modifier | modifier le code]

  1. a et b (en) Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest and Clifford Stein, Introduction to Algorithms, Cambridge, MIT Press and McGraw-Hill, , 2e éd., 1180 p., relié (ISBN 978-0-262-53196-2, LCCN 2001031277), « Chap. 26. Maximum Flow », p. 643–700.
  2. (en) Daniel D. Sleator and Robert E. Tarjan, « A data structure for dynamic trees », Journal of Computer and System Sciences, vol. 26, no 3,‎ , p. 362–391 (ISSN 0022-0000, DOI 10.1016/0022-0000(83)90006-5, lire en ligne).
  3. (en) Andrew V. Goldberg and Robert E. Tarjan, « A new approach to the maximum-flow problem », Journal of the ACM, New York, NY, USA, ACM Press, vol. 35, no 4,‎ , p. 921–940 (ISSN 0004-5411, DOI 10.1145/48014.61051).
  4. (en) Andrew V. Goldberg and S. Rao, « Beyond the flow decomposition barrier », J. Assoc. Comput. Mach., vol. 45,‎ , p. 753–782 (DOI 10.1145/290179.290181).
  5. V. King, S. Rao et R. Tarjan, « A Faster Deterministic Maximum Flow Algorithm », Journal of Algorithms, vol. 17, no 3,‎ , p. 447–474 (DOI 10.1006/jagm.1994.1044)
  6. James B. Orlin, « Max flows in O(nm) time, or better », STOC '13 Proceedings of the forty-fifth annual ACM symposium on Theory of computing,‎ , p. 765–774 (DOI 10.1145/2488608.2488705)
  7. L. Chen, R. Kyng, Y.P. Liu, M.P. Gutenberg et S. Sachdeva, « Maximum Flow and Minimum-Cost Flow in Almost-Linear Time », preprint ArXiv,‎
  8. (en) « The maximum flow problem is log space complete for P », Theoretical Computer Science, vol. 21, no 1,‎ , p. 105–111 (ISSN 0304-3975, DOI 10.1016/0304-3975(82)90092-5, lire en ligne, consulté le )

Articles connexes[modifier | modifier le code]

Lien externe[modifier | modifier le code]