Algorithme de Ford-Fulkerson

De testwiki
Version datée du 11 mars 2025 à 20:18 par imported>WikiCleanerBot (v2.05b - Bot T3 PCS#57 - Correction syntaxique (Titre de section terminé par deux-points))
(diff) ← Version précédente | Version actuelle (diff) | Version suivante → (diff)
Aller à la navigation Aller à la recherche

Modèle:ÉbaucheModèle:À sourcer Modèle:Voir paronyme

Exemple d'exécution de l'algorithme de Ford-Fulkerson. L'animation affiche le graphe résiduel correspondant à chaque itération.

En informatique, l'algorithme de Ford-Fulkerson est un algorithme pour le problème de flot maximum, un problème d'optimisation classique dans le domaine de la recherche opérationnelle. Il est dû à Lester Randolph Ford junior et D. R. Fulkerson[1] et c'est une variante de l'algorithme de Busacker et Gowen.

Problème du flot maximum

Modèle:Article détaillé

Définition du problème

Ce problème d'optimisation peut être représenté par un graphe comportant une entrée (à gauche) et une sortie (à droite). Le flot représente la circulation de l'entrée vers la sortie d'où l'utilisation de cet algorithme dans les problèmes de réseaux. Les applications sont multiples : problèmes informatiques, routiers, ferroviaires, etc. Il s'applique également à tous les autres problèmes de transferts comme les importations/exportations, les flux migratoires, démographiques mais aussi sur des flux purement numériques tels que les transferts financiers. Pour les données de très grande taille, il existe plusieurs algorithmes plus performants pour résoudre le problème de flot maximum.

Exemple d'application

Une société de fret dispose de trois centres : un à Paris, le deuxième à Lyon, le troisième à Marseille. Trois destinations sont possibles : la Pologne, la Suède, la Grèce. Chacun des centres de fret a un stock initial de marchandises (Paris : 100 ; Lyon : 80 ; Marseille : 150). De même, chaque pays d'arrivée a une demande maximale pour les importations (Pologne : 120 ; Suède : 140 ; Grèce : 50).

L'algorithme de Ford-Fulkerson va permettre d'optimiser ces flux à l'aide d'un outil de modélisation mathématique. La structure sous-jacente est représentée par un graphe orienté dont le sommet de gauche symbolise le stock initial. Trois arcs en partent, chacun menant à un sommet représentant un centre de fret. Le sommet final symbolise la fin de la livraison, auquel mènent trois arcs venant de sommets représentant une destination de livraison.

Dans l'exemple présent, la matrice d'adjacence porte donc dans sa première ligne les valeurs desdits stocks. Inversement, à l'extrémité de la chaîne, la matrice associée comprendra dans sa dernière colonne les demandes respectives des pays cités. Entre les sommets « centre de fret » et les sommets « destination » peuvent se trouver des sommets et des arcs intermédiaires, les capacités de ces arcs correspondant au fret maximal d'un point à l'autre.

             Paris                        Pologne
           /       \                     /       \
    100 ---         -------  ...  -------         ---- 120
       /   80               Nœuds               140   \
Départ ------- Lyon ------ intermé- ---- Suède -------- Fin
       \                   diaires                    /
    150 ---         -------  ...  -------         ---- 50
           \       /                     \       /
           Marseille                       Grèce

Le problème peut être généralisé à une circulation dans un réseau (véhicules, fluides, monnaie, etc.), les grandeurs mathématiques remplaçant indistinctement les faits réels qu'elles sont censées représenter.

Formalisation

Réseau

Soit un réseau G=(S,A,c,s,t) avec :

  • (S,A) un graphe orienté irréflexif ;
  • une capacité c:A avec pour convention : si l'arc (u,v) n'existe pas, c(u,v)=0 ;
  • un sommet source Modèle:Mvar sans arcs entrants ;
  • un sommet puits Modèle:Mvar sans arcs sortants.

On suppose qu'il n'y a pas d'arcs anti-parallèles, c'est-à-dire que l'existence d'un arc (u,v) exclut l'existence d'un arc (v,u).

Flot

Le flot d'un réseau est une fonction f:S2+ qui vérifie :

  • pour tous sommets (u,v)S×S, on a 0f(u,v)c(u,v) ;
  • pour tout sommet uS tel que us et ut : vSf(v,u)=wSf(u,w) (le flot entrant est égal au flot sortant : propriété de conservation).

La valeur d'un flot Modèle:Mvar est |f|=vSf(s,v).

Algorithme

Il s'agit d'un algorithme itératif. À chaque itération, la solution courante est un flot qui satisfait les contraintes de capacité (c'est donc un flot réalisable) et l'algorithme essaie d'augmenter la valeur de ce flot. Cela peut nécessiter d'annuler les mauvais choix. Pour ce faire, on définit le graphe résiduel de Modèle:Mvar et de Modèle:Mvar qui indique les modifications possibles (ajout ou annulation) : c'est un graphe pondéré Rf=(S,Af,rf) où on a

rf(u,v)={c(u,v)f(u,v)si (u,v)A(ajout)f(v,u)si (v,u)A(annulation)0sinon 

et Af={(u,v)S×S|rf(u,v)>0}.

Pseudo-code

  Entrée Un réseau G=(S,A,c,s,t)
  Sortie Un flot maximal Modèle:Mvar
  Fonction Ford_Fulkerson(G)
     f flot nul
     Tant que il y a un chemin simple γ de Modèle:Mvar à Modèle:Mvar dans le graphe résiduel Rf :
        Δ=min{rf(u,v):(u,v)γ}
        Pour toute arête (u,v)γ :
           Si (u,v)A :
              f(u,v):=f(u,v)+Δ
           Sinon :
              f(v,u):=f(v,u)Δ
     Renvoyer Modèle:Mvar

L'algorithme ne précise pas comment trouver chaque chemin γ. L'algorithme d'Edmonds-Karp, spécialisation de l'algorithme de Ford-Fulkerson, propose de faire un parcours en largeur.

Chaque chemin trouvé est garanti d’augmenter la valeur du flot, car il commence forcément par un arc sortant du sommet source et finit par un arc entrant dans le sommet puits.

Exemple d'exécution

On considère le réseau de flot G=(S,A,c,s,t), consistant du graphe (S,A) à quatre sommets S={s,t,u,v} et cinq arêtes A={(s,u),(u,t),(s,v),(v,t),(u,v)}, de la source sS, du puits tS et de la fonction de capacité c:A0.

On commence avec le flot vide f qui attribue la valeur 0 à chaque arête. Initialement, le graphe résiduel Gfet les capacités résiduelles rf correspondent alors exactement au réseau G avec les capacités c.

Graphe G (avec capacité c)
eA c(e)
(s,u) 4
(u,t) 1
(s,v) 2
(v,t) 6
(u,v) 3
Flot f
eA f(e)
(s,u) 0
(u,t) 0
(s,v) 0
(v,t) 0
(u,v) 0
Graphe résiduel Gf (avec capacité résiduelle rf)
eA rf(e) rf(e)
(s,u) 4 0
(u,t) 1 0
(s,v) 2 0
(v,t) 6 0
(u,v) 3 0
Supposons que l'algorithme choisisse d'abord le chemin γ=((s,u),(u,v),(v,t)) (bleu). Le long de ce chemin, on peut augmenter le débit au maximum de 3 puisque l'arête (u,v) est limitante (rf((u,v))=3). Il en résulte un nouveau flot (qu'on appellera toujours f) avec f((s,u))=f((u,v))=f((v,t))=3.

L'arête (s,u) a une capacité de c((s,u))=4. Elle est utilisée dans le flot : f((s,u))=3. Dans le graphe résiduel, sa capacité résiduelle sera donc rf((s,u))=c((s,u))f((s,u))=1. De même rf((u,v))=c((u,v))f((u,v))=33=0 et rf((v,t))=c((v,t))f((v,t))=63=3.

Les trois arêtes (s,u),(u,v),(v,t) sont strictement positives dans le flot. Ces poids dans le flot ne sont peut être pas les plus optimaux. Les nouvelles arêtes arrières (t,v),(v,u),(u,s) (en rouge) dans le graphe résiduel marquent alors le fait que l'on pourra toujours diminuer le flot sur ces arêtes.

Chemin améliorant γ (avec capacités résiduelles rf)
Flot f
eA f(e)
(s,u) 3
(u,t) 0
(s,v) 0
(v,t) 3
(u,v) 3
Graphe résiduel Gf résultant (avec les nouvelles capacités résiduelles rf)
eA rf(e) rf(e)
(s,u) 1 3
(u,t) 1 0
(s,v) 2 0
(v,t) 3 3
(u,v) 0 3
Supposons que l'algorithme sélectionne le chemin améliorant γ=((s,v),(v,u),(u,t)). L'augmentation maximale du débit est limitée par la capacité résiduelle rf((u,t))=c((u,t))f((u,t))=10=1. Pour la première fois, on passe par un arête arrière ((v,u)). Alors que le flot f augmente de 1 le long des arêtes (s,v) et (u,t), il diminue de 1 le long de (u,v).

On peut remarquer que les capacités résiduelles des arêtes arrières sont toujours égales aux poids dans le flot.

Chemin améliorant γ (avec capacités résiduelles rf)
Flot f
eA f(e)
(s,u) 3
(u,t) 1
(s,v) 1
(v,t) 3
(u,v) 2
Graphe résiduel Gf résultant (avec les nouvelles capacités résiduelles rf)
eA rf(e) rf(e)
(s,u) 1 3
(u,t) 0 1
(s,v) 1 1
(v,t) 3 3
(u,v) 1 2
Supposons que l'algorithme choisisse à nouveau le chemin γ=((s,u),(u,v),(v,t)). Cette fois, le débit le long du chemin ne peut être augmenté que de 1. Cela correspond justement au montant par lequel on a diminué (u,v) à l'étape précédente. En effet, l'algorithme peut faire beaucoup de va-et-vient. Chemin améliorant γ (avec capacités résiduelles rf)
Flot f
eA f(e)
(s,u) 4
(u,t) 1
(s,v) 1
(v,t) 4
(u,v) 3
Graphe résiduel Gf résultant (avec les nouvelles capacités résiduelles rf)
eA rf(e) rf(e)
(s,u) 0 4
(u,t) 0 1
(s,v) 1 1
(v,t) 2 4
(u,v) 0 3
Ici, seul le chemin γ=((s,v),(v,t)) est possible. Cela augmente alors le débit de 1. Le flot a alors une valeur de f((s,u))+f((s,v))=6. Les arêtes sortantes de la source sont pleinement utilisées donc ce flot est un flot maximal. La coupure au niveau de (s,u) et (s,v) est donc une coupe minimale. On respecte donc bien le Théorème flot-max/coupe-min qui affirme qu'un flot maximal a la même valeur qu'une coupe minimale.

L'algorithme se termine alors car aucun chemin de s à t n'existe dans le graphe résiduel obtenu. On a donc bien obtenu un flot maximal.

Chemin améliorant γ (avec capacités résiduelles rf)
Flot maximal f
eA f(e)
(s,u) 4
(u,t) 1
(s,v) 2
(v,t) 5
(u,v) 3
Graphe résiduel Gf résultant (avec les nouvelles capacités résiduelles rf)
eA rf(e) rf(e)
(s,u) 0 4
(u,t) 0 1
(s,v) 0 2
(v,t) 1 5
(u,v) 0 3

Propriétés de l'algorithme

Complexité

Le flot maximal est atteint quand plus aucun chemin améliorant ne peut être trouvé. Cependant, il n'y a aucune certitude que cette situation soit atteinte, mais la réponse sera correcte si l'algorithme se termine. Dans le cas où l'algorithme s'exécute indéfiniment, le flot peut même ne pas converger vers le flot maximum. Néanmoins, cette situation ne se produit qu'avec des valeurs de flot irrationnelles.Modèle:Référence nécessaire Lorsque les capacités sont des entiers, le temps d'exécution de l'algorithme de Ford-Fulkerson est borné par O(Af) (voir les notations de Landau), où A est le nombre d'arêtes dans le réseau de flot et f est la valeur du flot maximal. En effet, chaque chemin augmentant peut être trouvé en O(A) et augmente le débit d'une quantité entière d'au moins 1 avec f comme borne supérieure.

Une variante de l'algorithme de Ford-Fulkerson avec terminaison garantie et un temps d'exécution indépendant de la valeur de flot maximal est l' algorithme d'Edmonds-Karp, qui a une complexité temporelle en O(SA2).

Terminaison

Si les capacités des arêtes sont des entiers, l'algorithme se termine. En effet, la suite des flots calculés est à valeurs entières. strictement croissante, et majorée par la valeur du flot maximal. Elle ne peut donc pas être infinie, et l'algorithme se termine.

Exemple pour lequel l'algorithme ne termine pas

On s'intéresse au graphe suivant, qui a pour sommet source s, pour sommet puits t. Les arêtes e1, e2 et e3 ont pour capacités respectives 1, r=(51)/2 et 1. La capacité des autres arêtes est fixée à 10. On a choisi la constante r de sorte que r2=1r. On considère l'exécution de l'algorithme choisissant les chemins suivants, où on note p1={s,v4,v3,v2,v1,t}, p2={s,v2,v3,v4,t} et p3={s,v1,v2,v3,t}.

Étape Chemin choisi Augmentation du flot Capacité résiduelle
e1 e2 e3
0 r0=1 r 1
1 {s,v2,v3,t} 1 r0 r1 0
2 p1 r1 r2 0 r1
3 p2 r1 r2 r1 0
4 p1 r2 0 r3 r2
5 p3 r2 r2 r3 0

On remarque qu'après les étapes 1 et 5, les capacités résiduelles des arêtes e1, e2 et e3 sont respectivement de la forme rn, rn+1 et 0 et le flot ajouté est rnn. Ainsi, par récurrence on pourra toujours répéter la boucle de chemins p1, p2, p1 et p3 tout en ajoutant un flot strictement positif car les capacités résiduelles resteront toujours de la forme rn, rn+1 et 0 à la fin de l'exécution sur les chemins. L'algorithme ne termine donc pas sur cette entrée. Le fait que l'on ait une capacité irrationnelle par rapport aux autres capacités entières est cruciale car elle permet d'avoir une suite de taille de flot infinie strictement croissante et majorée[2].

Notes et références

Voir aussi

Article connexe

  • L'algorithme d'Edmonds-Karp est une spécialisation de l'algorithme de Ford-Fulkerson de résolution du problème de flot maximum dans un réseau.

Liens externes

Bibliographie

Modèle:Autres projets

  • A simple algorithm for finding maximal network flows and an application to the Hitchock problem (FORD L.R., FULKERSON D.R), Rand Report Rand Corporation, Santa Monica, Modèle:Date-.
  • Modèle:Article
  • The transhipment problem (ORDEN A.), Management Science 2, 1956.
  • Sur la déficience d'un réseau infini (BERGE C.), Comptes rendus de l'Académie des Sciences 245, 1957.
  • Invitation à la recherche opérationnelle (KAUFMANN A., FAURE R.) Dunod Entreprise, 1979.
  • Contribution de la théorie des graphes à l'étude des problèmes d'ordonnancement (ROY B.) Congrès international de recherche opérationnelle, 1960.
  • Modèle:Ouvrage
  • Modèle:Ouvrage
  • Modèle:Ouvrage
  • Modèle:Ouvrage

Modèle:Palette Modèle:Portail