Méthode de la puissance inverse — Wikipédia

En analyse numérique, la méthode de puissance inverse est un algorithme de recherche de valeur propre itératif de valeurs propres. Il permet de trouver un vecteur propre approché lorsqu'une approximation d'une valeur propre correspondante est déjà connue. La méthode est conceptuellement similaire à la méthode de la puissance itérée. Il semble avoir été initialement développé pour calculer les fréquences de résonance dans le domaine de la mécanique des structures[1].

La méthode de la puissance inverse commence par une approximation pour la valeur propre correspondant au vecteur propre souhaité et un vecteur , soit un vecteur sélectionné au hasard, soit une approximation du vecteur propre. La méthode est décrite par la récurrence :où les sont des constantes habituellement choisies telles que Puisque les vecteurs propres sont définis à une constante multiplicative près, le choix de peut être arbitraire en théorie ; les aspects pratiques du choix de sont discutés ci-dessous.

À chaque itération, le vecteur est multiplié par la matrice et normalisé. On retrouve la même formule que dans la méthode de la puissance itérée, mais en remplaçant la matrice par Plus la valeur choisie est proche de la valeur propre réelle, plus l'algorithme converge rapidement ; cependant, un choix incorrect de peut conduire à une convergence lente ou à la convergence vers un vecteur propre différent de celui souhaité. En pratique, la méthode est utilisée lorsqu’une bonne approximation de la valeur propre est connue et qu’il suffit donc de quelques itérations (souvent une seule).

Théorie et convergence

[modifier | modifier le code]

L'idée de base de la puissance itérée est de choisir un vecteur initial (soit une approximation de vecteur propre, soit un vecteur aléatoire) et de calculer itérativement . Sauf pour un ensemble de mesure nulle, pour tout vecteur initial, le résultat convergera vers un vecteur propre correspondant à la valeur propre dominante de la matrice.

La puissance inverse fait de même pour la matrice , donc il converge vers le vecteur propre correspondant à la valeur propre dominante de la matrice . Les valeurs propres de cette matrice sont sont les valeurs propres de . Le plus grand de ces nombres correspond au plus petit nombre parmi Les vecteurs propres de et de sont les mêmes, puisqueAinsi, la méthode converge vers le vecteur propre de la matrice correspondant à la valeur propre la plus proche de

En particulier, en prenant on voit que converge vers le vecteur propre correspondant à la valeur propre de avec la plus grande valeur absolue et peut donc être utilisé pour déterminer la plus petite valeur propre de grandeur de puisqu'ils sont inversement liés.

Vitesse de convergence

[modifier | modifier le code]

On détermine ici le taux de convergence de la méthode.

On sait que l'algorithme de la puissance itérée converge linéairement vers la limite, plus précisément : par conséquent, pour la méthode de la puissance inverse, un résultat similaire ressemble à : Il s'agit d'une formule clé pour comprendre la convergence de la méthode. Cela montre que si est choisi suffisamment proche d'une valeur propre , Par exemple chaque itération améliorera la précision fois. (on l'utilise pour des choses assez petites "le plus proche de " et " le plus proche de " est la même chose.) Pour assez petit c'est à peu près la même chose que . Donc si l'on parvient à trouver , de telle sorte que le sera suffisamment petit, alors très peu d'itérations peuvent être satisfaisantes.

Complexité

[modifier | modifier le code]

L'algorithme d'itération inverse nécessite la résolution d'un système linéaire ou le calcul de la matrice inverse. Pour les matrices non structurées (ni creuses, ni de Toeplitz,...) cela nécessite opérations.

Options de mise en œuvre

[modifier | modifier le code]

La méthode est définie par la formule :Il existe cependant plusieurs options pour sa mise en œuvre.

Calculer une matrice inverse ou résoudre un système d'équations linéaires

[modifier | modifier le code]

On peut réécrire la formule de la manière suivante :soulignant que pour trouver l'approximation suivante on peut résoudre un système d'équations linéaires. Il existe deux options : on peut choisir un algorithme qui résout un système linéaire, ou on peut calculer l'inverse puis l'appliquer au vecteur. Les deux options ont une complexité O( n3), le nombre exact dépend de la méthode choisie.

Le choix dépend également du nombre d'itérations. Naïvement, si à chaque itération on résout un système linéaire, la complexité sera k O( n3), où k est le nombre d'itérations ; de même, calculer la matrice inverse et l'appliquer à chaque itération est de complexité k O( n3). Notons cependant que si l’estimation des valeurs propres reste constant, alors on peut réduire la complexité à O( n3) + k O(n 2) avec l'une ou l'autre méthode. Calculer la matrice inverse une fois et la stocker pour l'appliquer à chaque itération est de complexité O( n3) + k O(n 2). Stocker une décomposition LU de et utiliser l'algorithme de montée et descente pour résoudre le système d'équations à chaque itération est également de complexité O( n3) + k O(n 2).

L'inversion de la matrice aura généralement un coût initial plus élevé, mais un coût inférieur à chaque itération. À l’inverse, la résolution de systèmes d’équations linéaires aura généralement un coût initial moindre, mais nécessitera plus d’opérations pour chaque itération.

Tridiagonalisation, forme de Hessenberg

[modifier | modifier le code]

S'il est nécessaire d'effectuer de nombreuses itérations (ou peu d'itérations, mais pour de nombreux vecteurs propres), alors il pourrait être judicieux de mettre d'abord la matrice sous forme de Hessenberg supérieure (pour une matrice symétrique, ce sera une forme tridiagonale), qui a un coût en opérations arithmétiques utilisant une technique basée sur la transformation de Householder, avec une suite finie de transformations de similarité orthogonales, un peu comme une décomposition QR bilatérale[2],[3]. (Pour la décomposition QR, les rotations de Householder sont multipliées uniquement à gauche, mais pour le cas de Hessenberg, elles sont multipliées à gauche et à droite). Pour les matrices symétriques, cette procédure coûte opérations arithmétiques utilisant une technique basée sur la réduction de Householder[2],[3].

La solution du système d'équations linéaires pour les matrices tridiagonales est en opérations, donc la complexité augmente en , où est le numéro d'itération, ce qui est meilleur que pour l'inversion directe. Cependant, pour quelques itérations, une telle transformation peut ne pas être pratique.

La transformation vers une forme de Hessenberg implique également des racines carrées et l'opération de division, qui ne sont pas universellement prises en charge par le matériel.

Choix de la constante de normalisation Ck

[modifier | modifier le code]

Sur les processeurs à usage général (produits par exemple par Intel), le temps d'exécution de l'addition, de la multiplication et de la division est approximativement égal. Mais sur le matériel embarqué et/ou à faible consommation d'énergie (processeurs de signaux numériques, FPGA, ASIC), la division peut ne pas être prise en charge par le matériel et doit donc être évitée. Choisir permet une division rapide sans prise en charge matérielle explicite, car la division par une puissance de 2 peut être implémentée soit sous la forme d'un décalage de bits (pour l'arithmétique à virgule fixe), soit sous la forme d'une soustraction de de l'exposant (pour l'arithmétique à virgule flottante).

Lors de la mise en œuvre de l'algorithme utilisant l'arithmétique à virgule fixe, le choix de la constante est particulièrement important. De petites valeurs entraîneront une croissance rapide de la norme de et dépasser ; de grandes valeurs de va faire tendre le vecteur vers zéro.

Utilisation

[modifier | modifier le code]

La principale application de la méthode est la situation dans laquelle une approximation d’une valeur propre est trouvée et où il faut trouver le vecteur propre approché correspondant. Dans une telle situation, l’itération inverse est la méthode principale et probablement la seule à utiliser.

Méthodes pour trouver des valeurs propres approximatives

[modifier | modifier le code]

Généralement, la méthode est utilisée en combinaison avec une autre méthode qui trouve des valeurs propres approchées : l'exemple standard est l'algorithme de bissection pour les valeurs propres, un autre exemple est l'itération du quotient de Rayleigh, qui est en fait la même itération inverse avec le choix de la valeur propre approchée comme valeur propre, le quotient de Rayleigh correspondant au vecteur obtenu à l'étape précédente de l'itération.

Il existe certaines situations où la méthode peut être utilisée seule, mais elles sont assez marginales.

Norme de matrice comme approximation de la valeur propre dominante

[modifier | modifier le code]

La valeur propre dominante peut être facilement estimée pour n’importe quelle matrice. Pour toute norme matricielle induite, il est vrai que pour toute valeur propre . Ainsi, en prenant la norme de la matrice comme valeur propre approximative, on peut voir que la méthode convergera vers le vecteur propre dominant.

Estimations basées sur des statistiques

[modifier | modifier le code]

Dans certaines applications en temps réel, il faut trouver des vecteurs propres pour des matrices à une vitesse de plusieurs millions de matrices par seconde. Dans de telles applications, les statistiques des matrices sont généralement connues à l’avance et on peut prendre comme valeur propre approximative la valeur propre moyenne d’un grand échantillon matriciel. On peut aller plus loin et calculer le rapport moyen des valeurs propres à la trace ou à la norme de la matrice et estimer la valeur propre moyenne comme la trace ou la norme multipliée par la valeur moyenne de ce rapport. Il est clair qu’une telle méthode ne peut être utilisée qu’avec parcimonie et uniquement lorsqu’une grande précision n’est pas critique. Cette approche d'estimation d'une valeur propre moyenne peut être combinée avec d'autres méthodes pour éviter une erreur trop importante.

Voir également

[modifier | modifier le code]

Références

[modifier | modifier le code]
  1. (de) Ernst Pohlhausen, « Berechnung der Eigenschwingungen statisch-bestimmter Fachwerke », Zeitschrift für Angewandte Mathematik und Mechanik, vol. 1, no 1,‎ , p. 28-42 (DOI 10.1002/zamm.19210010104)
  2. a et b (en) James W. Demmel, Applied Numerical Linear Algebra, Philadelphia, PA, Society for Industrial and Applied Mathematics, (ISBN 0-89871-389-7, MR 1463942).
  3. a et b (en) Lloyd N. Trefethen et David Bau, Numerical Linear Algebra, SIAM, (lire en ligne).