Algorithme de Lanczos

De testwiki
Aller à la navigation Aller à la recherche

Modèle:À sourcer En algèbre linéaire, l’algorithme de Lanczos (ou méthode de Lanczos) est un algorithme itératif pour déterminer les valeurs et vecteurs propres d'une matrice carrée, ou la décomposition en valeurs singulières d'une matrice rectangulaire.

Cet algorithme n'a pas de lien avec le fenêtrage de Lanczos (utilisé par exemple pour le redimensionnement d'images), si ce n'est que tous les deux tirent leur nom du même inventeur, le physicien et mathématicien hongrois Cornelius Lanczos.

Description de l'algorithme

Méthode de la puissance itérée

La méthode de la puissance itérée pour trouver la plus grande valeur propre d'une matrice carrée symétrique A d'ordre p est la suivante.

Si x0 est un vecteur et xn+1=Axn, alors xn=Anx0.

On sait qu'une matrice symétrique est diagonalisable[1]Modèle:,[2], et les termes σi,i=1,,p de la matrice diagonale sont les valeurs propres de la matrice. Soit donc

A=U(σ10σi0σp)U=Udiag(σi)U

la décomposition en valeurs propres de A, où U est une matrice orthogonale ; alors

An=Udiag(σin)U

Pour des valeurs de n très grandes, la matrice diagonale des valeurs propres sera dominée par la plus grande d'entre elles — à l'exception du cas où il y a deux plus grandes valeurs égales : en effet, soit σmax la valeur propre de plus grand module.

limnAn=limn|σmax|nUdiag(σin|σmax|n)U=Udiag(0...0,(σmax|σmax|)n,0...0)U

Alors, |xn+1|/|xn| converge vers la plus grande valeur propre et xn/|xn| au vecteur propre correspondant.

Dans le cas où il y a plusieurs valeurs propres maximales, xn converge vers un vecteur dans le sous-espace engendré par les vecteurs propres associés à ces valeurs. Après avoir déterminé le premier, on peut successivement restreindre l'algorithme au noyau des vecteurs propres connus pour déterminer les autres.

En pratique, cet algorithme possède deux inconvénients : une vulnérabilité aux erreurs d'arrondi, et une vitesse de convergence parfois trop faible.

Algorithme de Lanczos

L'algorithme de Lanczos améliore la méthode précédente, dans laquelle chaque u est restreint à l'orthogonal de toutes les valeurs précédentes. Lors de la construction de ces vecteurs, les constantes de normalisation sont regroupées dans une matrice tridiagonale dont les valeurs propres les plus significatives convergent, rapidement, vers les valeurs propres de la matrice de départ.

La multiplication par A est alors la seule opération de grande ampleur, ce qui fait l'intérêt de la méthode.

Applications, variantes et généralisations

L'algorithme de Lanczos est particulièrement pratique pour déterminer la décomposition de très grandes matrices, en météorologie ou en traitement des langues naturelles, où ces matrices peuvent compter des centaines de milliers de termes.

Il se généralise en l'algorithme d'Arnoldi pour les matrices non symétriques.

Une variante de cet algorithme est utilisée pour la résolution de systèmes linéaires (en particulier pour les systèmes linéaires creux) et la recherche d'éléments du noyau d'une matrice. Sous cette forme, il est fréquemment utilisé dans le cadre d'algorithmes comme le crible quadratique ou le crible algébrique pour la factorisation d'entiers ou la méthode de l'index pour le problème du logarithme discret. Il est apparenté à la méthode du gradient conjugué.

Notes et références

  1. Pour la démonstration, cf. Modèle:Ouvrage, chap. 1, théorème 1.2.1
  2. Modèle:Ouvrage

Voir aussi

Articles connexes

Références

Modèle:Traduction/Référence

Liens externes

Modèle:Portail