Jacobi-eigenwaarde algoritme
Het Jacobi-eigenwaarde algoritme 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.
Inhoud |
Algoritme [bewerken]
Aangezien het uitgangspunt is dat de matrix
symmetrisch is, is deze matrix orthogonaal gelijksoortig aan een diagonaalmatrix 
waarbij de diagonalen van
de eigenwaarden
van
bevat en
kolomsgewijs de bijbehorende eigenvectoren
Het achterliggende idee bij het Jacobi-eigenwaarde algoritme bestaat eruit om steeds het grootste element buiten de diagonaal 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
met 
waarbij
en
steeds voor de
-de en
-de
rij en kolom staan en
het grootste buitendiagonaalelement van
voorstelt. De componenten van
lenen zich nu tot de volgende overweging:
De transformatie
zorgt speciaal in de kruislementen voor de volgende veranderingen:
- Aangezien
moet zijn, volgt uit 
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
naar een diagonaalmatrix convergeert. Deze matrix moet op grond van de gelijksoortigheid dezelfde eigenwaarden bezitten.
Over het algemeen volstaan 5n bewerkingen voor een n x n matrix
Klassiek en cyclisch Jacobi-eigenwaarde algoritme [bewerken]
Bij het klassieke Jacobi-eigenwaarde algoritme wordt bij elke iteratie het op dat moment grootste element op nul gezet. Aangezien het cyclische Jacobi-eigenwaarde algoritme 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 [bewerken]
- (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 inachteming van de numerieke aspecten) VDF Hochschulverlag AG 2002, ISBN 978-3-7281-2818-8. Abschnitt 10.2 (S. 222-228) ((de) beperkte online-version (Google Books))




moet zijn, volgt uit 

![A^{(k)} \xrightarrow[k\rightarrow\infty]{}\,diag(\lambda_1, \ldots, \lambda_n)](http://upload.wikimedia.org/math/8/0/2/802cd7cf1def36dc0313ba7cf4feedba.png)