Algorithme des directions alternées

From Wikipedia, the free encyclopedia

L'algorithme des directions alternées (l'ADA ou l'algorithme des DA) est un algorithme de résolution de problèmes d'optimisation décomposables, qui cherche à adapter l'algorithme du lagrangien augmenté à ce contexte, alors que cet algorithme détruit cette décomposabilité. Il est typiquement utilisé pour minimiser la somme de deux fonctions (souvent convexes) dépendant de variables différentes couplées par une contrainte affine :

et , , et . L’algorithme suppose implicitement que minimiser ou seul est facile.

C'est un algorithme trouvant rapidement une solution avec peu de précision, mais qui demande beaucoup d'itérations pour déterminer une solution avec précision.

L'algorithme est utilisé dans des domaines très variés dans lesquels la précision de la solution importe peu : technique d'apprentissage statistique, machine à vecteurs de support, régularisation des problèmes de moindres-carrés, régression logistique creuse, etc.

On se place dans le contexte donné en introduction, à savoir celui où l'on cherche à minimiser la somme de deux fonctions dépendant de variables différentes couplées par une contrainte affine :

et , , et .

Exemple 1. On peut utiliser l'algorithme des DA pour minimiser la somme de deux fonctions convexes par duplication des variables :

Exemple 2, qui tire parti du fait que les fonctions peuvent prendre des valeurs infinies. On cherche à minimiser une fonction sur un ensemble . Comme ce problème revient à minimiser , où est la fonction indicatrice de , on se ramène au problème de l'exemple 1, traitant de la minimisation d'une somme de deux fonctions.

L'algorithme

L'algorithme se présente le mieux en le voyant comme une modification de l'algorithme du lagrangien augmenté, cherchant à préserver la décomposabilité supposée des fonctions et . Nous commençons donc par rappeler celui-ci.

L'algorithme du lagrangien augmenté

Le lagrangien augmenté, associé au problème ci-dessus, est la fonction

dont la valeur en s'écrit

est le paramètre d'augmentation. Si on retrouve le lagrangien du problème.

Une itération de l'algorithme du lagrangien augmenté fait passer d'une estimation d'un multiplicateur optimal à l'estimation suivante en deux étapes :

L'inconvénient de la première étape est de devoir minimiser le lagrangien augmenté simultanément en et , alors que le terme de pénalisation quadratique de la contrainte couple ces variables (il n'est pas possible de faire la minimisation séparément en et en ). C'est à cet inconvénient que remédie l'algorithme des DA.

L'algorithme des directions alternées

Algorithme des directions alternées  Une itération passe d'un quadruplet au suivant comme suit.

  1. Minimisation en  : .
  2. Minimisation en  : .
  3. Nouvelle variable duale : .
  4. Test d'arrêt : .
  5. Nouveau paramètre d'augmentation : .

Remarques.

  • C'est la minimisation séparée en et qui permet de faire de la décomposition lorsque et sont séparables.
  • Si l'on minimisait d'abord en puis en avant de mettre à jour , on obtiendrait des itérés différents.
  • L'algorithme des DA est un algorithme lent, si l'on veut une solution précise (il vaut mieux alors utiliser des algorithmes tenant compte des dérivées secondes ou d'une approximation de celles-ci), mais rapide si l'on se contente d'une précision modérée.
  • On attribue généralement cet algorithme à Glowinski et Marocco (1975), ainsi qu'à Gabay et Mercier (1976).

Interprétations

L'algorithme peut se voir comme une méthode de Gauss-Seidel par bloc, tronquée à une seule passe, pour minimiser le lagrangien augmenté, avant de modifier le multiplicateur[1]. Cependant aucun résultat de convergence n'utilise cette interprétation, si bien qu'elle est contestée par certains[2].

L'algorithme peut être vu comme réalisant une composition d'opérateurs contractants[3].

L'algorithme peut aussi être vu comme un cas particulier de l'algorithme de Douglas-Rachford[4], qui est lui-même un cas particulier de l'algorithme proximal[5].

Convergence

Exemples d'utilisation

Annexes

Related Articles

Wikiwand AI