[go: up one dir, main page]

Vés al contingut

Algorisme de Lanczos

De la Viquipèdia, l'enciclopèdia lliure

L'algorisme de Lanczos és un mètode iteratiu ideat per Cornelius Lanczos que és una adaptació de mètodes de potència per trobar el "més útils" (tenent cap a l'extrem més alt/mínim) valors propis i vectors propis d'un matriu hermitiana, on sovint, però no necessàriament, és molt més petit que .[1] Encara que en principi computacionalment eficient, el mètode tal com es va formular inicialment no va ser útil, a causa de la seva inestabilitat numèrica.

El 1970, Ojalvo i Newman van mostrar com fer el mètode numèricament estable i el van aplicar a la solució d'estructures d'enginyeria molt grans sotmeses a càrrega dinàmica.[2] Això es va aconseguir mitjançant un mètode per purificar els vectors de Lanczos (és a dir, reortogonalitzant repetidament cada nou vector generat amb tots els generats anteriorment) [2] amb qualsevol grau de precisió, que quan no es realitzava, produïa una sèrie de vectors que estaven molt contaminats per els associats a les freqüències naturals més baixes.

En el seu treball original, aquests autors també van suggerir com seleccionar un vector inicial (és a dir, utilitzar un generador de nombres aleatoris per seleccionar cada element del vector inicial) i van suggerir un mètode determinat empíricament per determinar , el nombre reduït de vectors (és a dir, s'hauria de seleccionar per ser aproximadament 1,5 vegades el nombre de valors propis precisos desitjat). Poc després el seu treball va ser seguit per Paige, que també va proporcionar una anàlisi d'errors.[3][4] L'any 1988, Ojalvo va produir un historial més detallat d'aquest algorisme i una prova d'error de valors propis eficient.[5]

L'algorisme

[modifica]
Introduir una matriu hermitiana de mida , i opcionalment una sèrie d'iteracions (per defecte, sigui ).
  • En sentit estricte, l'algorisme no necessita accés a la matriu explícita, sinó només una funció que calcula el producte de la matriu per un vector arbitrari. Aquesta funció s'anomena com a màxim vegades.
Sortida an matriu amb columnes ortonormals i una matriu simètrica real tridiagonal de mida . Si , llavors V és unitari, i .
Advertència La iteració de Lanczos és propensa a la inestabilitat numèrica. Quan s'executa en aritmètica no exacta, s'han de prendre mesures addicionals (tal com es descriu en seccions posteriors) per garantir la validesa dels resultats.
  1. Sigui ser un vector arbitrari amb norma euclidiana 1.
  2. Pas d'iteració inicial abreujat:
    1. Sigui .
    2. Sigui .
    3. Sigui .
  3. Per fer :
    1. Sigui (també norma euclidiana).
    2. Si , llavors fer ,
      altrament escolliu com un vector arbitrari amb norma euclidiana que és ortogonal a tots .
    3. Sigui .
    4. Sigui .
    5. Sigui .
  4. Sigui V la matriu amb columnes . Sigui .
Nota per per .

En principi hi ha quatre maneres d'escriure el procediment d'iteració. Paige i altres treballs mostren que l'ordre d'operacions anterior és el més estable numèricament.[6][7] A la pràctica el vector inicial es pot prendre com un altre argument del procediment, amb i s'inclouen indicadors d'imprecisió numèrica com a condicions addicionals de terminació del bucle.

Sense comptar la multiplicació matriu-vector, cada iteració ho fa operacions aritmètiques. La multiplicació matriu-vector es pot fer en operacions aritmètiques on és el nombre mitjà d'elements diferents de zero en una fila. La complexitat total és així , o si ; l'algorisme de Lanczos pot ser molt ràpid per a matrius escasses. Els esquemes per millorar l'estabilitat numèrica es jutgen normalment en funció d'aquest alt rendiment.

Aplicacions

[modifica]

Els algorismes de Lanczos són molt atractius perquè la multiplicació per és l'única operació lineal a gran escala. Com que els motors de recuperació de text amb termes ponderats implementen només aquesta operació, l'algoritme de Lanczos es pot aplicar de manera eficient als documents de text (vegeu indexació semàntica latent). Els vectors propis també són importants per als mètodes de classificació a gran escala com l' algoritme HITS desenvolupat per Jon Kleinberg o l'algoritme PageRank utilitzat per Google.

Els algorismes de Lanczos també s'utilitzen en la física de la matèria condensada com a mètode per resoldre els hamiltonians de sistemes electrònics fortament correlacionats,[8] així com en els codis de models de capa en física nuclear.

Implementacions

[modifica]

La biblioteca NAG conté diverses rutines [9] per a la solució de sistemes lineals a gran escala i problemes propis que utilitzen l'algorisme de Lanczos.

MATLAB i GNU Octave inclouen ARPACK integrat. Tant les matrius emmagatzemades com les implícites es poden analitzar mitjançant la funció eigs() (Matlab / Octave ).

De la mateixa manera, a Python, el paquet SciPyscipy.sparse.linalg.eigsh que també és un embolcall per a les funcions de les funcions SSEUPD i DSEUPD d' ARPACK que utilitzen el mètode Lanczos reiniciat implícitament.

Una implementació de Matlab de l'algoritme Lanczos (anoteu problemes de precisió) està disponible com a part del paquet Gaussian Belief Propagation Matlab . La biblioteca de filtratge col·laboratiu GraphLab incorpora una implementació paral·lela a gran escala de l'algorisme Lanczos (en C++) per a multinucli.

La biblioteca PRIMME també implementa un algorisme semblant a Lanczos.


Referències

[modifica]
  1. Lanczos, C. Journal of Research of the National Bureau of Standards, 45, 4, 1950, pàg. 255–282. DOI: 10.6028/jres.045.026 [Consulta: lliure].
  2. 2,0 2,1 Ojalvo, I. U.; Newman, M. AIAA Journal, 8, 7, 1970, pàg. 1234–1239. Bibcode: 1970AIAAJ...8.1234N. DOI: 10.2514/3.5878.
  3. Paige, C. C. The computation of eigenvalues and eigenvectors of very large sparse matrices (Tesi) (en anglès). U. of London., 1971. OCLC 654214109. 
  4. Paige, C. C. J. Inst. Maths Applics, 10, 3, 1972, pàg. 373–381. DOI: 10.1093/imamat/10.3.373.
  5. Ojalvo, I. U.. «Origins and advantages of Lanczos vectors for large dynamic systems». A: Proc. 6th Modal Analysis Conference (IMAC), Kissimmee, FL (en anglès), 1988, p. 489–494. 
  6. Cullum. Lanczos Algorithms for Large Symmetric Eigenvalue Computations (en anglès). 1, 1985. ISBN 0-8176-3058-9. 
  7. Yousef Saad. Numerical Methods for Large Eigenvalue Problems (en anglès), 1992-06-22. ISBN 0-470-21820-7. 
  8. Chen, HY; Atkinson, W.A.; Wortis, R. Physical Review B, 84, 4, 7-2011, pàg. 045113. arXiv: 1012.1031. Bibcode: 2011PhRvB..84d5113C. DOI: 10.1103/PhysRevB.84.045113.
  9. The Numerical Algorithms Group. «Keyword Index: Lanczos». NAG Library Manual, Mark 23. [Consulta: 9 febrer 2012].