Jacobi-eigenwaardealgoritme

Uit testwiki
Naar navigatie springen Naar zoeken springen

Het jacobi-eigenwaardealgoritme is een iteratief algoritme uit de numerieke wiskunde, dat gebruikt wordt om alle eigenwaarden en eigenvectoren van kleine symmetrische matrices te berekenen. Het algoritme werd in het midden van de 19e eeuw door de Duitse wiskundig Carl Jacobi ontwikkeld.

Algoritme

Voor een reële, symmetrische n×n-matrix A geldt:

D=STAS,

waarin D=diag(λ1,,λn) de diagonaalmatrix van eigenwaarden van A is en S kolomsgewijs de bijbehorende eigenvectoren van A bevat.

Het achterliggende idee bij het jacobi-eigenwaardealgoritme bestaat eruit om steeds het grootste element buiten de diagonaal van A met behulp van een Givens-rotatie naar 0 te brengen, om op die manier meer en meer de diagonaalmatrix te benaderen.

Er geldt het volgende iteratievoorschrift

A(0)=AA(k+1)=RkTA(k)Rk=RkTRk1TR0TSkTA(0)R0Rk1RkSk

met Rk=[10000cosφsinφ00sinφcosφ00001],

waarbij cosφ en sinφ steeds in de p-de en q-de (p<q) rij en kolom staan en apq(k) het absoluut grootste buitendiagonaalelement van A(k) voorstelt, dus is voor alle 1i,jn,ij

|apq(k)||aij(k)|

De elementen van Rk volgen dan uit de volgende overweging:

De transformatie RkTA(k)Rk zorgt speciaal voor de elementen op de kruising van de p-de en q-de rij en kolom voor de volgende veranderingen:

app(k+1)=app(k)cos2φ2apq(k)cosφsinφ+aqq(k)sin2φaqq(k+1)=app(k)sin2φ+2apq(k)cosφsinφ+aqq(k)cos2φapq(k+1)=aqp(k+1)=(app(k)aqq(k))cosφsinφ+apq(k)(cos2φsin2φ)

Aangezien apq(k+1)=0 moet zijn, volgt hieruit voor

Θ=aqq(k)app(k)2apq(k)=cot2φ=1tan2φ2tanφ

dat

tanφ={1Θ+sgnΘ1+Θ2Θ=01Θ=0

en dus

cosφ=11+tan2φ,sinφ=tanφcosφ

Aangezien de rotatiematrices orthogonaal zijn en producten van orthogonale matrices ook weer orthogonaal zijn, wordt op deze wijze een orthogonale gelijksoortigheidstransformatie beschreven. Men kan aantonen dat de rij van matrices A(k) naar een diagonaalmatrix convergeert. Deze matrix moet op grond van de gelijksoortigheid dezelfde eigenwaarden bezitten.

A(k) kdiag(λ1,,λn)

Over het algemeen volstaan 5n bewerkingen voor een n×n-matrix.

Klassiek en cyclisch jacobi-eigenwaardealgoritme

Bij het klassieke jacobi-eigenwaardealgoritme wordt bij elke iteratie het op dat moment grootste element op nul gezet. Aangezien het cyclische jacobi-eigenwaardealgoritme daarentegen juist naar dit grootste element zoekt, wordt daar bij iedere iteratie steeds een Givens-rotatie op elk element binnen de strikte bovendriehoek uitgevoerd.

Referenties

  • Sjabloon:De Kaspar Nipp, Daniel Stoffer: Lineare Algebra: Eine Einführung für Ingenieure unter besonderer Berücksichtigung numerischer Aspekte (Lineaire algebra: een introductie voor ingenieurs met bijzondere inachtneming van de numerieke aspecten) VDF Hochschulverlag AG 2002, ISBN 978-3-7281-2818-8. Abschnitt 10.2 (S. 222-228) (Sjabloon:De beperkte online-version (Google Books))