Algorithme de Stoer-Wagner

Page d’aide sur l’homonymie

Pour les articles homonymes, voir Wagner.

Une coupe minimale (de poids 4) d'un graphe pondéré[1]

En théorie des graphes, l'algorithme de Stoer-Wagner est un algorithme récursif déterministe pour trouver la coupe minimale dans des graphes non orientés pondérés, avec des poids positifs. Autrement dit, il s'agit de séparer le graphe en deux morceaux non vides, de telle sorte que la somme des poids attribués aux arêtes reliant un sommet d'un des morceaux à un sommet de l'autre soit la plus petite possible. L'algorithme a été proposé en 1994 par Mechthild Stoer et Frank Wagner lors d'un symposium européen à Utrecht[2],[3]. L'idée essentielle est de réduire progressivement la taille du graphe à considérer, en fusionnant des sommets par paire, jusqu'à ce que le graphe ne contienne que deux ensembles de sommets combinés[4]. À chaque étape, l'algorithme choisit deux sommets s {\displaystyle s} et t {\displaystyle t} , calcule la coupe minimale qui les sépare, puis (récursivement) la coupe minimale du graphe obtenu en les fusionnant, et renvoie le minimum des deux.

Principe de l'algorithme de Stoer – Wagner

On considère un graphe non orienté pondéré G = ( V , E , w ) {\displaystyle G=(V,E,w)}  : V {\displaystyle V} est l'ensemble des sommets, E {\displaystyle E} celui des arêtes entre les sommets et w {\displaystyle w} la fonction de valuation qui associe des nombres (les « poids ») aux arêtes. Une coupe est une partition des sommets du graphe en deux parties, deux sous-ensembles non-vides A {\displaystyle A} et B {\displaystyle B} . Le poids de cette coupe est alors la somme des poids des arêtes qui relient un sommet de A {\displaystyle A} à un sommet de B {\displaystyle B} . Une coupe minimale est une coupe de poids minimum ; elle n'est pas unique en général.

Considérons alors deux sommets quelconques, s {\displaystyle s} et t {\displaystyle t} , de V {\displaystyle V} . L'algorithme repose sur l'alternative suivante : soit une coupe minimale sépare s {\displaystyle s} et t {\displaystyle t} (c'est-à-dire que les deux sommets ne sont pas dans la même partie de la coupe), soit on peut l'obtenir à partir d'une coupe minimale d'un graphe ayant moins de sommets que le graphe initial.

Si en effet s {\displaystyle s} et t {\displaystyle t} sont dans la même partie, alors on peut construire un graphe G ~ ( V { s , t } s t , E ~ , w ~ ) {\displaystyle {\tilde {G}}(V\backslash \{s,t\}\cup st,{\tilde {E}},{\tilde {w}})} dans lequel on a fusionné les sommets s {\displaystyle s} et t {\displaystyle t} en un seul sommet s t {\displaystyle st} . S'il y avait une arête ( s , t ) {\displaystyle (s,t)} entre s {\displaystyle s} et t {\displaystyle t} dans le graphe initial, elle est retirée ; pour tout autre sommet u {\displaystyle u} , on crée une arête du nouveau graphe, ( u , s t ) {\displaystyle (u,st)} , entre le sommet u {\displaystyle u} et le nouveau sommet s t {\displaystyle st}  ; on attribue à cette arête un poids qui est la somme des poids des arêtes ( u , s ) {\displaystyle (u,s)} et de ( u , t ) {\displaystyle (u,t)} entre les sommets u {\displaystyle u} et s {\displaystyle s} , ou u {\displaystyle u} et t {\displaystyle t} , du graphe initial (on utilise 0 lorsqu'il n'existait pas d'arête entre ces sommets). La coupe minimale de G ~ {\displaystyle {\tilde {G}}} a alors exactement le même poids que la coupe minimale du graphe initial G {\displaystyle G} , et on peut repasser de l'une à l'autre (en remplaçant le sommet s t {\displaystyle st} par les deux sommets s {\displaystyle s} et t {\displaystyle t} )[4].

On note également que, dans le cas général, la coupe minimale de G ~ {\displaystyle {\tilde {G}}} a le même poids qu'une certaine coupe de G {\displaystyle G}  ; ce poids est donc supérieur ou égal au poids d'une coupe minimale de G {\displaystyle G} . Le graphe G ~ {\displaystyle {\tilde {G}}} possède un sommet de moins que le graphe G {\displaystyle G} . Par ailleurs, si G ~ {\displaystyle {\tilde {G}}} ne possède que deux sommets, alors sa coupe minimale est obtenue trivialement en séparant ces deux sommets.

L'algorithme consiste alors à déterminer deux sommets s {\displaystyle s} et t {\displaystyle t} et une coupe minimale séparant s {\displaystyle s} et t {\displaystyle t} , et à stocker le minimum entre cette coupe et la coupe minimale de G ~ {\displaystyle {\tilde {G}}} , calculée récursivement[4].

Détermination de s et t

Comme cette méthode fonctionne pour tout couple ( s , t ) {\displaystyle (s,t)} , l'algorithme de Stoer-Wagner choisit un couple ( s , t ) {\displaystyle (s,t)} tel que la coupe minimale séparant s {\displaystyle s} et t {\displaystyle t} soit rapide à déterminer.

Stoer et Wagner proposent d'initialiser le processus avec un ensemble A {\displaystyle A} composé d'un seul sommet quelconque a {\displaystyle a} , par exemple de plus grand poids total, puis d'ajouter à A {\displaystyle A} le sommet le plus relié à a {\displaystyle a} (autrement dit, tel que la somme des poids des arêtes de ce sommet à a {\displaystyle a} soit maximale), puis le sommet le plus relié aux sommets déjà dans A {\displaystyle A} , et ainsi de suite. Ils montrent que si on appelle les deux derniers sommets ajoutés s {\displaystyle s} et t {\displaystyle t} , alors une coupe minimale séparant s {\displaystyle s} et t {\displaystyle t} est celle formée de tous les sommets sauf t {\displaystyle t} d'un côté et de t {\displaystyle t} de l'autre[4].

Pseudo-code

On peut présenter le procédé ainsi[4] :

CoupeMinEtape
  
    
      
        (
        G
        ,
        w
        ,
        a
        )
      
    
    {\displaystyle (G,w,a)}
  

  
  
    
      
        A
        
        
          {
          a
          }
        
      
    
    {\displaystyle A\gets \left\{a\right\}}
  

  Tant que 
  
    
      
         
        A
        
        V
      
    
    {\displaystyle \ A\neq V}
  

    Ajouter à 
  
    
      
        A
      
    
    {\displaystyle A}
  
 le sommet le plus connecté à 
  
    
      
        A
      
    
    {\displaystyle A}
  

  Fin
  Stocker les deux derniers sommets s et t ajoutés à A.
  Stocker le poids de la coupe obtenue en plaçant tous les sommets sauf t dans un ensemble de la partition, et t tout seul dans l'autre. Ce poids est la valeur d'une coupe minimale séparant s et t. 
  Remplacer 
  
    
      
        G
      
    
    {\displaystyle G}
  
 par 
  
    
      
        
          
            
              G
              ~
            
          
        
      
    
    {\displaystyle {\tilde {G}}}
  
 obtenu en fusionnant les deux sommets (s, t).

Coupe minimale 
  
    
      
        (
        G
        ,
        w
        ,
        a
        )
      
    
    {\displaystyle (G,w,a)}
  

  Tant que 
  
    
      
        
          |
        
        V
        
          |
        
        >
        1
      
    
    {\displaystyle |V|>1}
  

    Calculer CoupeMinEtape
  
    
      
        (
        G
        ,
        w
        ,
        a
        )
      
    
    {\displaystyle (G,w,a)}
  

    Si le poids obtenu est moindre  que celui de la coupe minimale stockée
      alors remplacer cette coupe minimale stockée par celle de poids moindre.

Complexité

Si n {\displaystyle n} est le nombre de sommets du graphe et m {\displaystyle m} le nombre d'arêtes, le temps de calcul[3] est de l'ordre de O ( n m + n 2 log n ) {\displaystyle O(nm+n^{2}\log n)} .

Références

  1. Daniel Trebbien, « Boost Graph Library: Stoer–Wagner Min-Cut - 1.46.1 », www.boost.org, (consulté le ).
  2. (en) Mechthild Stoer et Frank Wagner, « A simple min-cut algorithm », dans Jan Leeuwen (ed.), Algorithms-ESA'94, Springer, coll. « Lecture Notes in Computer Science » (no 855), , p. 141-147.
  3. a et b (en) Kurt Melhorn et Christian Uhrig, « The minimum cut algorithm of Stoer and Wagner », .
  4. a b c d et e (en) Mechthild Stoer et Frank Wagner, « A simple min-cut algorithm », Journal of the ACM, vol. 44, no 4,‎ , p. 585–591 (lire en ligne).

Liens externes

  • Daniel Trebbien, « Boost Graph Library: Stoer–Wagner Min-Cut - 1.46.1 », www.boost.org, (consulté le ).
  • StoerWagnerMinCut.java : Implémentation en Java de l'algorithme de Stoer–Wagner.
  • icône décorative Portail des mathématiques
  • icône décorative Portail de l'informatique théorique