Méthode de Gauss-Seidel

De testwiki
Aller à la navigation Aller à la recherche

La méthode de Gauss-Seidel est une méthode itérative de résolution d'un système linéaire (de dimension finie) de la forme Ax=b, ce qui signifie qu'elle génère une suite qui converge vers une solution de cette équation, lorsque celle-ci en a une et lorsque des conditions de convergence sont satisfaites (par exemple lorsque A est symétrique définie positive). L'algorithme suppose que la diagonale de A est formée d'éléments non nuls.

La méthode se décline en une version « par blocs ».

Le principe de la méthode peut s'étendre à la résolution de systèmes d'équations non linéaires et à l'optimisation, mais avec des conditions d'efficacité moins claires. En optimisation, l'utilité de cette approche dépendra beaucoup de la structure du problème. Le principe gauss-seidelien permet aussi d'interpréter d'autres algorithmes.

Il est nommé d'après Carl Friedrich Gauss et Philipp Ludwig von Seidel, qui l'ont développé et appliqué pour le calcul d'angles en géodésie[1]Modèle:,[2].

L'algorithme

Principe

Soit

Ax=b

le système linéaire à résoudre, que l'on suppose écrit sous forme matricielle avec An×n et bn, ce qui signifie que l'on cherche xn tel que le produit matriciel Ax soit égal à b.

On note aij les éléments de A et bi ceux de b :

A=(a11a12a1na21a22a2nan1an2ann)etb=(b1b2bn).

La méthode de Gauss-Seidel résout le système linéaire Ax=b de manière itérative, ce qui veut dire qu'elle génère une suite de vecteurs xkn, pour k=0,1,2,. On interrompt le calcul de la suite lorsque l'itéré courant, disons xk, est jugé suffisamment proche d'une solution, par exemple parce que le résidu Axkb est petit.

Soit xk=(x1k,,xnk)n l'itéré courant. L'itéré suivant xk+1=(x1k+1,,xnk+1)n se calcule en n étapes, comme suit.

  • Modèle:Souligner. Si l'on suppose que a110 et connaissant (x2k,,xnk), on peut calculer x1k+1 au moyen de la première équation du système linéaire Ax=b. De manière plus précise, x1k+1 est pris comme solution de
    Modèle:Sauta11x1k+1_+a12x2k++a1nxnk=b1,Modèle:Saut
    ce qui est possible si a110.
  • Modèle:Souligner. Si l'on suppose que a220 et connaissant (x1k+1,x3k,,xnk), on peut calculer x2k+1 au moyen de la deuxième équation du système linéaire Ax=b. De manière plus précise, x2k+1 est pris comme solution de
    Modèle:Sauta21x1k+1+a22x2k+1_+a23x3k++a2nxnk=b2,Modèle:Saut
    ce qui est possible si a220.
  • Modèle:Souligner (cas général). Si l'on suppose que aii0 et connaissant (x1k+1,,xi1k+1,xi+1k,,xnk), on peut calculer xik+1 au moyen de la i-ième équation du système linéaire Ax=b. De manière plus précise, xik+1 est pris comme solution de
    Modèle:Sautai1x1k+1++ai,i1xi1k+1+aiixik+1_+ai,i+1xi+1k++ainxnk=bi,Modèle:Saut
    ce qui est possible si aii0.

En résumé, pourvu que les éléments diagonaux de A soient non nuls, on calcule les composantes xik+1 de xk+1 de manière séquentielle pour i=1,,n par

Modèle:Bloc emphase

La formule fait intervenir les éléments xjk+1 (j=1,,i1) calculés dans les étapes précédentes.

Expression matricielle

L'expression matricielle de l'algorithme suppose que la matrice A se sépare comme suit

A=L+D+U,

D est la partie diagonale de A, L (pour lower) sa partie triangulaire inférieure stricte et U (pour upper) sa partie triangulaire supérieure stricte.

Une itération de la méthode de Gauss-Seidel, celle passant de xk à xk+1, consiste alors à résoudre le système triangulaire inférieur

Modèle:Bloc emphase

de « haut en bas », c'est-à-dire en déterminant successivement x1k+1, x2k+1, ..., xnk+1.

Convergence

La formule de mise à jour des itérés dans la méthode de Gauss-Seidel montre que ceux-ci sont des approximations successives pour le calcul d'un point fixe de l'application

x(L+D)1(bUx).

Les propriétés de convergence de la méthode vont donc dépendre du spectre de la matrice (L+D)1U.

On sait que la méthode de Gauss-Seidel converge, quels que soient le vecteur b et le point initial x0, dans les situations suivantes :

Discussion

Un seul vecteur vn suffit pour mémoriser les itérés successifs : à l'étape i, il suffit de mémoriser les éléments déjà calculés de xk+1, à savoir xjk+1 pour j=1,,i1, dans v1:i1 et les éléments de xk encore utiles, à savoir xjk pour j=i+1,,n, dans vi+1:n. Cette faible exigence en espace mémoire peut être un atout dans certaines circonstances.

Contrairement à la méthode de Jacobi, l'algorithme est essentiellement séquentiel et n'est donc pas adapté au calcul parallèle.

Généralisations

Méthode par blocs

La version par blocs de la méthode de Gauss-Seidel procède de manière similaire à la méthode élément par élément, mais en remplaçant l'utilisation des éléments de A par des sous-matrices de A, appelées ici des blocs.

On suppose que l'ensemble des indices [[1,n]] est partitionné en p sous-intervalles (non vides et deux-à-deux disjoints) :

[[1,n]]=I1I2Ip.

La matrice A et le vecteur b sont alors dissocié comme suit

A=(AI1I1AI1I2AI1IpAI2I1AI2I2AI2IpAIpI1AIpI2AIpIp)etb=(bI1bI2bIp),

AIJ est la sous-matrice de A obtenue en sélectionnant les éléments avec indices de ligne dans I et indices de colonnes dans J, tandis que bI est le sous-vecteur de b obtenu en sélectionnant les éléments avec indices dans I.

La méthode de Gauss-Seidel par blocs suppose que les sous-matrices principales AIiIi, avec i[[1,p]], sont inversibles.

Une itération de la méthode de Gauss-Seidel par blocs, celle passant de xk à xk+1, s'écrit de la même manière que la méthode élément par élément, à savoir

Modèle:Bloc emphase

mais avec des définitions différentes de L, D et U :

L=(00AI2I1AIpI1AIpIp10),D=(AI1I1000AI2I2000AIpIp)etU=ALD.

La résolution du système triangulaire par blocs ci-dessus, se fait également de « haut en bas », c'est-à-dire en déterminant successivement xI1k+1, xI2k+1, ..., xIpk+1.

Systèmes d'équations non linéaires

Le principe de la méthode de Gauss-Seidel peut également s'appliquer à la résolution d'un système d'équations non linéaires F(x)=0, où F:nn. Ce système s'écrit donc sous la forme de n équations non linéaires à n inconnues :

{F1(x1,x2,,xn)=0F2(x1,x2,,xn)=0Fn(x1,x2,,xn)=0.

La méthode de Gauss-Seidel résout ce système de manière itérative, en générant donc une suite de vecteurs xkn, pour k=0,1,2,. On interrompt le calcul de la suite lorsque l'itéré courant, disons xk, est jugé suffisamment proche d'une solution, par exemple parce que le résidu F(xk) est petit.

Soit xk=(x1k,,xnk)n l'itéré courant. L'itéré suivant xk+1=(x1k+1,,xnk+1)n se calcule en n étapes, comme suit.

  • Modèle:Souligner (cas général). Connaissant (x1k+1,,xi1k+1,xi+1k,,xnk), on calcule xik+1 comme solution de l'équation non linéaire (elle est supposée exister) :
    Modèle:SautFi(x1k+1,,xi1k+1,xik+1_,xi+1k,,xnk)=0.Modèle:Saut

La version par blocs se définit facilement en considérant des groupes d'équations et d'inconnues, au lieu de considérer, comme ci-dessus, équation et inconnue une par une.

Optimisation

Le principe de la méthode de Gauss-Seidel décrit dans la section précédente s'applique naturellement au problème d'optimisation non linéaire

infxXf(x),

dans lequel on minimise une fonction f:n sur un sous-ensemble X de n. Nous présentons directement ci-dessous la version « par blocs », qui est la plus utile lorsque le nombre p de blocs est faible (souvent p=2). La méthode de Gauss-Seidel perd en effet de sa pertinence lorsque p est grand, par manque d'efficacité dans ce cas. La version « élément par élément » peut être vue comme un cas particulier de la version par blocs, obtenue en prenant n blocs de cardinal 1.

On suppose donc que l'ensemble des indices est partitionné en p blocs,

[[1,n]]=I1I2Ip,

et que l'ensemble admissible est un produit cartésien de p ensembles,

X=X1×X2××Xp,

où chaque Xi est un convexe de |Ii|. La variable xn se décomposera comme suit

x=(xI1,xI2,,xIp).

Lorsque f est différentiable et que X=n, on pourrait obtenir une méthode de Gauss-Seidel en appliquant la méthode de la section précédente à la condition d'optimalité du premier ordre de ce problème d'optimisation sans contrainte, à savoir

f(x)=0,

qui est un système de n équations non linéaires à n inconnues x=(x1,,xn). Mais on peut préférer, comme ci-dessous, rester dans le domaine de l'optimisation en minimisant f séquentiellement, bloc par bloc. Cette option a l'avantage de pouvoir prendre en compte des contraintes, c'est-à-dire de restreindre les variables à l'ensemble admissible X.

La méthode de Gauss-Seidel[4] résout le problème d'optimisation ci-dessus de manière itérative, en générant donc une suite {xk}n. L'algorithme passe d'un itéré xk au suivant xk+1 en minimisant f un bloc de variables à la fois, en séquence. On interrompt le calcul de la suite lorsque l'itéré courant, disons xk, est jugé suffisamment proche d'une solution, par exemple parce que la norme du gradient projeté gP(xk) est jugée suffisamment petite.

Modèle:Théorème

La version élément par élément se définit facilement en considérant des blocs Ii de cardinal 1 et en minimisant f composante par composante.

Le résultat suivant montre la convergence de la méthode de Gauss-Seidel lorsque f est de classe C1, coercive et strictement convexe[5].

Modèle:Théorème

Remarques
  1. Si l'on applique ce résultat au cas où X=n et f est la fonction quadratique x12xAxbx, on retrouve le résultat affirmant que la méthode de Gauss-Seidel par blocs pour résoudre le système linéaire Ax=b converge, quels que soient le vecteur b et le point initial, pourvu que A soit définie positive.
  2. La méthode de Gauss-Seidel est un algorithme lent (il requiert beaucoup d'itérations), dont la mise en œuvre est coûteuse (chaque itération peut demander beaucoup de temps de calcul, selon les cas). Tel qu'il est présenté, il requiert en effet la minimisation exacte de f dans chaque problème intermédiaire et ces p minimisations doivent être réalisées à chaque itération. Son application est donc restreinte au cas où le nombre de blocs est petit.
  3. L'algorithme de Gauss-Seidel ne s'étend pas aisément à des ensembles admissibles plus complexes qu'un produit cartésien d'ensembles convexes. Par exemple si l'on cherche à minimiser composante par composante la fonction linéaire f:2:(x1,x2)x1+x2 sur l'ensemble X:={x+2:x1x21}, qui n'est pas le produit cartésien de deux intervalles, tout point de la frontière de X est bloquant (c'est-à-dire que l'algorithme ne peut y progresser), alors que seul le point x¯=(1,1) est solution.
  4. En l'absence de convexité, la méthode de Gauss-Seidel ne converge pas nécessairement, même pour des fonctions de classe C. Powell (1973) a en effet construit plusieurs fonctions conduisant à la non-convergence de la méthode de Gauss-Seidel composante par composante, notamment une fonction C de trois variables pour laquelle les itérés générés ont un cycle limite formé de 6 points auxquels le gradient n'est pas nul.
  5. D'autres résultats de convergence sont donnés par Luo et Tseng (1992).
  6. La méthode est vraiment peu élégante[6].

Annexes

Notes

Modèle:Références

Articles connexes

Liens externes

Références

Modèle:Palette Modèle:Portail

  1. Modèle:Article
  2. Modèle:Ouvrage Réédité par Georg Olms Verlag, Hildesheim, 436-447.
  3. Voir par exemple, P. G. Ciarlet (1982), théorème 5.3.2.
  4. Cette méthode est appelée méthode de relaxation par Glowinski, Lions et Trémolières (1976), mais cette appellation est utilisée pour beaucoup trop d'algorithmes pour qu'elle soit suffisamment discriminante.
  5. Résultat qui semble dû à Glowinski, Lions et Trémolières (1976), théorème 1.2, page 66.
  6. Modèle:Article