Aller au contenu

GMRES

Un article de Wikipédia, l'encyclopédie libre.

En mathématique, la généralisation de la méthode de minimisation du résidu (en anglais : Generalized minimal residual ou GMRES) est une méthode itérative pour déterminer une solution numérique d'un système d'équations linéaires. La méthode donne une approximation de la solution par un vecteur appartenant à un sous-espace de Krylov avec un résidu minimal. Pour déterminer ce vecteur, on utilise la méthode itérative d'Arnoldi.

La méthode GMRES fut développée par Yousef Saad et Martin H. Schultz en 1986[1].

Principe de la méthode

[modifier | modifier le code]

On cherche à résoudre le système d'équations linéaires suivant :

La matrice A est supposée inversible et de taille (m x m). De plus, on suppose que b est normé, i.e., (dans cet article, représente la norme euclidienne).

Le n-ième espace de Krylov pour ce problème est défini ainsi :

Vect signifie le sous-espace vectoriel engendré par les vecteurs.

La méthode GMRES donne une approximation de la solution exacte du système de départ par un vecteur qui minimise la norme du résidu : .

Pour garantir le caractère linéairement indépendant des vecteurs b, Ab, ..., An–1b, on utilise la méthode d'Arnoldi pour trouver des vecteurs orthonormaux

qui constituent une base de . Ainsi, le vecteur peut s'écrire xn = Qn yn avec , et Qn une matrice de taille (m x n) formée des q1, ..., qn.

La méthode d'Arnoldi produit aussi une matrice de Hessenberg supérieure de taille (n+1) x n avec

Comme Qn est orthogonale, on a

est le premier vecteur de la base canonique de , et

avec x0 vecteur d'initialisation (pour simplifier, on peut prendre zéro). Ainsi, xn peut être trouvé en minimisant la norme du résidu

On reconnait un problème linéaire de moindres carrés de taille n.

L'algorithme se résume donc en :

  • effectuer une étape de l'algorithme d'Arnoldi ;
  • trouver yn qui minimise |rn| ;
  • calculer xn = Qn yn ;
  • recommencer tant que le résidu est plus grand qu'une quantité choisie arbitrairement au début de l'algorithme (on appelle cette quantité tolérance).

À chaque itération, un produit matrice-vecteur A qn doit être effectué. Cela génère un coût en calcul de 2m2 opérations pour les matrices non creuses de taille m, mais le coût peut être ramené à O(m) pour les matrices creuses. En plus du produit matrice-vecteur, O(n m) opérations doivent être effectuées à la n-ième itération.

Extensions de la méthode

[modifier | modifier le code]

Comme d'autres méthodes itératives, GMRES est souvent combiné avec des méthodes de préconditionnement pour accroître la vitesse de convergence.

Le coût des itérations croît en O(n2), où n est le numéro de l'itération. De ce fait, la méthode est parfois relancée après un nombre k d'itérations, avec xk comme vecteur initial. Cette méthode est appelée GMRES(k).

Références

[modifier | modifier le code]
  1. Saad et Schultz 1986, p. 856-869

Bibliographie

[modifier | modifier le code]

Document utilisé pour la rédaction de l’article : document utilisé comme source pour la rédaction de cet article.

  • (en) Y. Saad et M.H. Schultz, « GMRES: A generalized minimal residual algorithm for solving nonsymmetric linear systems », SIAM J. Sci. Stat. Comput., vol. 7, no 3,‎ , p. 856-869 (ISSN 0196-5204, DOI 10.1137/0907058). Ouvrage utilisé pour la rédaction de l'article