En mathématique, la généralisation de la méthode de minimisation du résidu (ou GMRES, pour Generalized minimal residual) 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

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).

Coûts modifier

À 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

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

  1. (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)

Bibliographie modifier