Arnoldiho iterace - Arnoldi iteration
v numerické lineární algebra, Arnoldiho iterace je algoritmus vlastních čísel a důležitý příklad iterační metoda. Arnoldi najde přiblížení k vlastní čísla a vlastní vektory obecných (možná ne-Hermitian ) matice vytvořením ortonormálního základu Krylovský podprostor, což je zvláště užitečné při práci s velkými řídké matice.
Arnoldiho metoda patří do třídy algoritmů lineární algebry, které dávají částečný výsledek po malém počtu iterací, na rozdíl od tzv. přímé metody které musí vyplnit, aby poskytly užitečné výsledky (viz například Transformace domácnosti ). Částečným výsledkem je v tomto případě prvních několik vektorů základny, kterou algoritmus vytváří.
Při aplikaci na hermitovské matice se redukuje na Lanczosův algoritmus. Arnoldiho iteraci vynalezl W. E. Arnoldi v roce 1951.[1]
Krylovské podprostory a iterace výkonu
Intuitivní metoda pro nalezení největšího (v absolutní hodnotě) vlastního čísla dané m × m matice je iterace výkonu: počínaje libovolnou iniciálou vektor b, vypočítat Ab, A2b, A3b, ... normalizace výsledku po každé aplikaci matice A.
Tato posloupnost konverguje k vlastní vektor odpovídá vlastnímu číslu s největší absolutní hodnotou, . Mnoho potenciálně užitečných výpočtů je však promarněno použitím pouze konečného výsledku, . To naznačuje, že místo toho vytvoříme tzv Krylovova matice:
Sloupce této matice nejsou obecně ortogonální, ale můžeme extrahovat ortogonální základ pomocí metody, jako je Gram – Schmidtova ortogonalizace. Výsledná sada vektorů je tedy ortogonálním základem Krylovský podprostor, . Můžeme očekávat, že vektory tohoto základu budou rozpětí dobré aproximace vlastních vektorů odpovídajících největší vlastní čísla ze stejného důvodu přibližuje dominantní vlastní vektor.
Arnoldiho iterace
Arnoldiho iterace používá upravený Gram – Schmidtův proces produkovat posloupnost ortonormálních vektorů, q1, q2, q3,…, Zavolal Arnoldi vektory, tak, že pro každého n, vektory q1, …, qn překlenout Krylovský podprostor . Výslovně je algoritmus následující:
- Začněte s libovolným vektorem q1 s normou 1.
- Opakujte pro k = 2, 3, …
- pro j od 1 do k − 1
The j- smyčka promítá složku ve směrech . Tím je zajištěna ortogonalita všech generovaných vektorů.
Algoritmus se rozpadne, když qk je nulový vektor. To se stane, když minimální polynom z A je stupně k. Ve většině aplikací iterace Arnoldi, včetně algoritmu vlastních čísel níže a GMRES, algoritmus v tomto bodě konvergoval.
Každý krok k-loop vezme jeden produkt matice-vektor a přibližně 4mk operace s plovoucí desetinnou čárkou.
V programovacím jazyce python:
import numpy tak jako npdef arnoldi_iteration(A, b, n: int): "" "Vypočítá základ (n + 1) -Krylovova podprostoru A: prostor překlenuto {b, Ab, ..., A ^ n b}. Argumenty A: m × m pole b: počáteční vektor (délka m) n: rozměr krylovského podprostoru, musí být> = 1 Vrací se Q: m x (n + 1) pole, sloupce jsou ortonormálním základem Krylovský podprostor. h: (n + 1) x n pole, A na základě Q. Je to horní Hessenberg. """ m = A.tvar[0] h = np.nuly((n + 1, n)) Q = np.nuly((m, n + 1)) q = b / np.linalg.norma(b) # Normalizujte vstupní vektor Q[:, 0] = q # Použijte jej jako první Krylovův vektor pro k v rozsah(n): proti = A.tečka(q) # Vytvořte nový vektor kandidáta pro j v rozsah(k): # Odečtěte projekce na předchozích vektorech h[j, k] = np.tečka(Q[:, j].konj(), proti) proti = proti - h[j, k] * Q[:, j] h[k + 1, k] = np.linalg.norma(proti) eps = 1e-12 # Pokud je v kratší než tato prahová hodnota, jedná se o nulový vektor -li h[k + 1, k] > eps: # Přidejte vytvořený vektor do seznamu, pokud q = proti / h[k + 1, k] # je vytvořen nulový vektor. Q[:, k + 1] = q jiný: # Pokud k tomu dojde, přestaňte iterovat. vrátit se Q, h vrátit se Q, h
Vlastnosti iterace Arnoldi
Nechat Qn označit m-podle-n matice tvořená první n Arnoldi vektory q1, q2, …, qna nechte Hn být (horní Hessenberg ) matice tvořená čísly hj,k vypočítané algoritmem:
Metodu ortogonalizace je třeba specificky zvolit tak, aby byly nižší Arnoldi / Krylovovy složky odstraněny z vyšších Krylovových vektorů. Tak jako lze vyjádřit pomocí q1, …, qi + 1 podle konstrukce jsou kolmé na qi + 2, …, qn,
Pak máme
Matice Hn lze zobrazit jako A v podprostoru s Arnoldiho vektory jako ortogonální základnou; A je ortogonálně promítnuto na . Matice Hn lze charakterizovat následující podmínkou optimality. The charakteristický polynom z Hn minimalizuje ||p(A)q1||2 mezi všemi monické polynomy stupně n. Tento problém optimality má jedinečné řešení právě tehdy, když se Arnoldiho iterace nerozloží.
Vztah mezi Q matice v následných iteracích je dána
kde
je (n+1) -by-n matice vytvořená přidáním dalšího řádku do Hn.
Nalezení vlastních čísel s Arnoldiho iterací
Myšlenka Arnoldiho iterace jako algoritmus vlastních čísel je spočítat vlastní čísla v krylovském podprostoru. Vlastní čísla Hn se nazývají Ritzova vlastní čísla. Od té doby Hn je Hessenbergova matice skromné velikosti, její vlastní čísla lze vypočítat efektivně, například pomocí Algoritmus QR, nebo trochu příbuzný, Francisův algoritmus. Rovněž samotný Francisův algoritmus lze považovat za související s výkonovými iteracemi fungujícími na vnořeném krylovském podprostoru. Ve skutečnosti se zdá, že nejzákladnější formou Františkova algoritmu je volba b rovnat se Ae1a prodloužení n do plné dimenze A. Vylepšené verze zahrnují jeden nebo více směn a vyšší výkon A lze aplikovat v jednom kroku.[1]
Toto je příklad Rayleigh-Ritzova metoda.
V praxi se často pozoruje, že některé vlastní hodnoty Ritz konvergují k vlastním hodnotám A. Od té doby Hn je n-podle-n, má nanejvýš n vlastní čísla a ne všechna vlastní čísla A lze aproximovat. Vlastní hodnoty Ritz obvykle konvergují k největším vlastním hodnotám A. Chcete-li získat nejmenší vlastní čísla z A, inverzní (operace) A místo toho by měl být použit. To může souviset s charakterizací Hn jako matice, jejíž charakteristický polynom minimalizuje ||p(A)q1|| následujícím způsobem. Dobrý způsob, jak se dostat p(A) malý je výběr polynomu p takhle p(X) je kdykoli malý X je vlastní číslo z A. Proto jsou nuly p (a tedy vlastní čísla Ritz) budou blízká vlastním číslům A.
Podrobnosti však ještě nejsou plně pochopeny. To je na rozdíl od případu, kdy A je symetrický. V této situaci se Arnoldiho iterace stává Lanczosova iterace, pro které je teorie úplnější.
Implicitně restartovaná metoda Arnoldi (IRAM)
Kvůli praktickému zvážení úložiště se běžné implementace metod Arnoldi obvykle restartují po určitém počtu iterací. Jednou z hlavních inovací v restartu byla díky Lehoucqovi a Sorensenovi, kteří navrhli metodu implicitně restartovaného Arnoldiho.[2] Algoritmus také implementovali do volně dostupného softwarového balíčku s názvem ARPACK.[3] To podnítilo řadu dalších variant, včetně metody Implicitly Restarted Lanczos.[4][5][6] Také to ovlivnilo, jak jsou analyzovány další restartované metody.[7]Teoretické výsledky ukázaly, že konvergence se zlepšuje s nárůstem dimenze krylovského podprostoru n. A-a priori hodnota je n což by vedlo k optimální konvergenci není známo. Nedávno dynamická strategie přepínání[8] bylo navrženo, což mění rozměr n před každým restartem a vede tak ke zrychlení rychlosti konvergence.
Viz také
The zobecněná metoda minimálního rezidua (GMRES) je metoda řešení Sekera = b na základě Arnoldiho iterace.
Reference
- ^ W. E. Arnoldi, „Princip minimalizovaných iterací při řešení problému vlastní hodnoty matice,“ Quarterly of Applied Mathematics, svazek 9, strany 17–29, 1951
- ^ R. B. Lehoucq a D. C. Sorensen (1996). „Deflační techniky pro implicitně restartovanou Arnoldiho iteraci“. SIAM. doi:10.1137 / S0895479895281484. hdl:1911/101832.
- ^ R. B. Lehoucq; D. C. Sorensen a C. Yang (1998). „Uživatelská příručka ARPACK: Řešení velkých problémů s vlastním číslem pomocí implicitně restartovaných metod Arnoldi“. SIAM. Archivovány od originál dne 26.06.2007. Citováno 2007-06-30.
- ^ D. Calvetti; L. Reichel a DC Sorensen (1994). „Implicitně restartovaná metoda Lanczos pro velké problémy se symetrickým vlastním číslem“. ETNA.
- ^ E. Kokiopoulou; C. Bekas a E. Gallopoulos (2003). „Implicitně restartovaná metoda Lanczosovy bidiagonalizace pro výpočet nejmenších singulárních tripletů“ (PDF). SIAM.
- ^ Zhongxiao Jia (2002). „Vylepšená harmonická Arnoldiho metoda a implicitně restartovaný vylepšený algoritmus pro výpočet vnitřních vlastních párů velkých matic“. Appl. Číslo. Matematika. doi:10.1016 / S0168-9274 (01) 00132-5.
- ^ Andreas Stathopoulos a Yousef Saad a Kesheng Wu (1998). „Dynamic Thick Restarting of the Davidson, and the Implicitly Restarted Arnoldi Methods“. SIAM. doi:10.1137 / S1064827596304162.
- ^ K. Dookhitram, R. Boojhawon a M. Bhuruth (2009). „Nová metoda pro zrychlení Arnoldiho algoritmů pro velké problémy s vlastními problémy“. Matematika. Comput. Simulace. doi:10.1016 / j.matcom.2009.07.009.
- W. E. Arnoldi, „Princip minimalizovaných iterací při řešení problému vlastní hodnoty matice,“ Quarterly of Applied Mathematics, svazek 9, strany 17–29, 1951.
- Yousef Saad, Numerické metody pro velké problémy s vlastním číslem, Manchester University Press, 1992. ISBN 0-7190-3386-1.
- Lloyd N. Trefethen a David Bau, III, Numerická lineární algebra, Společnost pro průmyslovou a aplikovanou matematiku, 1997. ISBN 0-89871-361-7.
- Jaschke, Leonhard: Předpřipravené Arnoldiho metody pro systémy nelineárních rovnic. (2004). ISBN 2-84976-001-3
- Implementace: Matlab přichází s vestavěným ARPACK. Uložené i implicitní matice lze analyzovat prostřednictvím eigs () funkce.