Algorithme le plus rapide pour calculer le numéro de condition d'une grande matrice dans Matlab / Octave


9

D'après la définition du numéro de condition, il semble qu'une inversion de matrice est nécessaire pour le calculer, je me demande si pour une matrice carrée générique (ou mieux si symétrique positive définie) est possible d'exploiter une décomposition de matrice pour calculer le numéro de condition dans un manière plus rapide.

Réponses:


7

Le calcul du nombre de conditions (même en l'approximant dans un facteur 2) semble avoir la même complexité que le calcul d'une factorisation, bien qu'il n'y ait pas de théorèmes dans cette direction.

A partir d'un facteur de Cholesky clairsemé d'une matrice définie positive symétrique, ou d'une factorisation clairsemée (avec implicite ) d'une matrice carrée générale, on peut obtenir le nombre de conditions dans la norme Frobenius en calculant le sous-ensemble inverse clairsemé de , ce qui est beaucoup plus rapide que le calcul de l'inverse complet. (Lié à ceci est mon article: Normes et limites hybrides pour les systèmes linéaires surdéterminés, Linear Algebra Appl. 216 (1995), 257-266. Http://www.mat.univie.ac.at/~neum/scan/74 .pdf )Q R Q ( R T R ) - 1RQRQ(RTR)1

Edit: Si alors par rapport à tout norn unitairement invariant,Pour le calcul des factorisations QR éparses, voir, par exemple, http://dl.acm.org/citation.cfm?id=174408 . Pour le calcul de l'inverse clairsemé, voir, par exemple, mon article: Estimation du maximum de vraisemblance restreint des covariances dans les modèles linéaires clairsemés, Genetics Selection Evolution 30 (1998), 1-24. https://www.mat.univie.ac.at/~neum/ms/reml.pdf Le coût est environ 3 fois le coût de la factorisation.c o n d ( A ) = c o n d ( R ) = A=QR

cond(A)=cond(R)=cond(RTR).




Vous proposez donc ce qui suit: Étant donné une matrice calculez son QR de la forme où est une matrice triangulaire supérieure et est une matrice orthogonale puis le numéro de condition est donné par Le point ici est de savoir comment trouver une méthode rapide pour calculer une factorisation QR. Ai-je raison? AA=QRRQcond(A)=||A||||A1||(RTR)1
linello

@linello: pas tout à fait; voir mon montage.
Arnold Neumaier

Merci! Je vais vérifier, btw quel est le coût de cette étape?
linello

@linello: Pour une matrice complète, ; pour une matrice clairsemée, cela dépend beaucoup de la structure clairsemée. O(n3)
Arnold Neumaier

4

Il est certainement facile d'utiliser la décomposition valeur propre / vecteur propre d'une matrice symétrique ou la SVD d'une matrice générale pour calculer le numéro de condition, mais ce ne sont pas des moyens particulièrement rapides de procéder.

A1condest


Mais l'estimation est parfois nettement trop petite. Le calcul du nombre de conditions (même en l'approximant dans un facteur 2) semble avoir la même complexité que le calcul d'une factorisation, bien qu'il n'y ait pas de théorèmes dans cette direction.
Arnold Neumaier

1

HHHTH

Étant donné que les valeurs propres / valeurs singulières les plus grandes et les plus petites peuvent être trouvées très rapidement (bien avant la fin de la tridiagonalisation), la méthode de Lanczos est particulièrement utile pour calculer le nombre de conditions.


Je me suis toujours demandé où trouver un code matlab lisible pour l'itération lanczos qui clarifie comment obtenir la valeur propre la plus petite ou la plus grande. Pouvez-vous m'en suggérer un?
linello

Je n'ai pas les codes MATLAB pour l'algorithme de Lanczos.
chaohuang
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.