Iterace výkonu - Power iteration

v matematika, iterace výkonu (také známý jako metoda napájení) je algoritmus vlastních čísel: daný a úhlopříčně matice , algoritmus vytvoří číslo , což je největší (v absolutní hodnotě) vlastní číslo z a nenulový vektor , což je odpovídající vlastní vektor z , to znamená, Algoritmus je také známý jako Von Misesova iterace.[1]

Power iterace je velmi jednoduchý algoritmus, ale může konvergovat pomalu. Časově nejnáročnější operací algoritmu je násobení matice vektorem, takže je efektivní pro velmi velké řídká matice s vhodnou implementací.

Metoda

Animace, která vizualizuje algoritmus iterace výkonu na matici 2x2. Matice je znázorněna svými dvěma vlastními vektory. Chyba se počítá jako

Algoritmus iterace výkonu začíná vektorem , což může být aproximace dominantního vlastního vektoru nebo náhodný vektor. Metodu popisuje relace opakování

Takže při každé iteraci vektor se vynásobí maticí a normalizováno.

Pokud předpokládáme má vlastní číslo, které je přísně větší než jeho ostatní vlastní čísla a počáteční vektor má nenulovou složku ve směru vlastního vektoru spojeného s dominantní vlastní hodnotou, pak subsekvenci konverguje na vlastní vektor spojený s dominantní vlastní hodnotou.

Bez dvou výše uvedených předpokladů sekvence nemusí nutně konvergovat. V tomto pořadí

,

kde je vlastní vektor spojený s dominantní vlastní hodnotou a . Přítomnost termínu to naznačuje nekonverguje, pokud . Podle dvou výše uvedených předpokladů sekvence definován

konverguje k dominantní vlastní hodnotě.[je zapotřebí objasnění ]

Jeden to může vypočítat pomocí následujícího algoritmu (zobrazeného v Pythonu s NumPy):

#! / usr / bin / env python3import numpy tak jako npdef power_iteration(A, počet simulací: int):    # Ideálně vyberte náhodný vektor    # Snížení šance, že náš vektor    # Je kolmý k vlastnímu vektoru    b_k = np.náhodný.rand(A.tvar[1])    pro _ v rozsah(počet simulací):        # vypočítat součin matice po vektoru Ab        b_k1 = np.tečka(A, b_k)        # vypočítat normu        b_k1_norm = np.linalg.norma(b_k1)        # re normalizovat vektor        b_k = b_k1 / b_k1_norm    vrátit se b_kpower_iteration(np.pole([[0.5, 0.5], [0.2, 0.8]]), 10)

Vektor k přidruženému vlastnímu vektoru. V ideálním případě byste měli použít Rayleighův kvocient za účelem získání přidruženého vlastního čísla.

Tento algoritmus se používá k výpočtu Google PageRank.

Tuto metodu lze také použít k výpočtu spektrální poloměr (vlastní hodnota s největší velikostí, pro čtvercovou matici) výpočtem Rayleighova kvocientu

Analýza

Nechat být rozložen na jeho Jordan kanonická forma: , kde je první sloupec je vlastní vektor odpovídající dominantní vlastní hodnotě . Vzhledem k tomu, že dominantní vlastní číslo je jedinečný, první jordánský blok je matice kde je největší vlastní hodnota z A ve velikosti. Výchozí vektor lze psát jako lineární kombinaci sloupců PROTI:

Podle předpokladu má nenulovou složku ve směru dominantní vlastní hodnoty, takže .

Výpočtově užitečné relace opakování pro lze přepsat jako:

kde výraz: je vhodnější pro následující analýzu.

Výše uvedený výraz zjednodušuje jako

Limita vyplývá ze skutečnosti, že vlastní hodnota je menší než 1, takže

Z toho vyplývá, že:

Pomocí této skutečnosti lze psát ve formě, která zdůrazňuje jeho vztah s když k je velký:

kde a tak jako

Sekvence je ohraničený, takže obsahuje konvergentní subsekvenci. Všimněte si, že vlastní vektor odpovídající dominantnímu vlastnímu číslu je jedinečný pouze po skalární, takže i když posloupnost nemusí konvergovat, je téměř vlastním vektorem A pro velké k.

Alternativně, pokud A je úhlopříčně, pak následující důkaz přináší stejný výsledek

Nechť λ1, λ2, ..., λm být m vlastní hodnoty (počítané s multiplicitou) z A a nechte proti1, proti2, ..., protim být odpovídajícími vlastními vektory. Předpokládejme to je dominantní vlastní číslo, takže pro .

Počáteční vektor lze napsat:

Li je vybrán náhodně (s jednotnou pravděpodobností), poté C1 ≠ 0 s pravděpodobnost 1. Nyní,

Na druhou stranu:

Proto, konverguje k (násobku) vlastního vektoru . Konvergence je geometrický, s poměrem

kde označuje druhou dominantní vlastní hodnotu. Metoda tedy konverguje pomalu, pokud existuje vlastní číslo blízké velikosti dominantnímu vlastnímu číslu.

Aplikace

Ačkoli metoda iterace výkonu aproximuje pouze jedno vlastní číslo matice, zůstává pro jistotu užitečné výpočetní problémy. Například, Google používá jej k výpočtu PageRank dokumentů ve svém vyhledávači,[2] a Cvrlikání používá jej k tomu, aby uživatelům ukázal doporučení, koho mají následovat.[3] Metoda iterace výkonu je zvláště vhodná pro řídké matice, například webová matice nebo jako bezmaticová metoda to nevyžaduje ukládání matice koeficientů explicitně, ale místo toho může přistupovat k funkci hodnotící produkty matice-vektor . Pro nesymetrické matice, které jsou dobře podmíněný metoda iterace výkonu může překonat složitější Arnoldiho iterace. U symetrických matic se metoda iterace výkonu používá jen zřídka, protože její rychlost konvergence může být snadno zvýšena, aniž by byla obětována malá cena za iteraci; viz např. Lanczosova iterace a LOBPCG.

Některé z pokročilejších algoritmů vlastních čísel lze chápat jako variace iterace výkonu. Například inverzní iterace metoda aplikuje na matici iteraci výkonu . Jiné algoritmy sledují celý podprostor generovaný vektory . Tento podprostor je známý jako Krylovský podprostor. Může být vypočítán pomocí Arnoldiho iterace nebo Lanczosova iterace.

Viz také

Reference

  1. ^ Richard von Mises a H. Pollaczek-Geiringer,Praktische Verfahren der Gleichungsauflösung, ZAMM - Zeitschrift für Angewandte Mathematik und Mechanik 9, 152-164 (1929).
  2. ^ Ipsen, Ilse a Rebecca M. Wills (5. – 8. května 2005). „7. mezinárodní sympozium IMACS o iteračních metodách ve vědeckých výpočtech“ (PDF). Fields Institute, Toronto, Kanada.CS1 maint: více jmen: seznam autorů (odkaz)
  3. ^ Pankaj Gupta, Ashish Goel, Jimmy Lin, Aneesh Sharma, Dong Wang a Reza Bosagh Zadeh WTF: Systém koho sledovat na Twitteru Sborník z 22. mezinárodní konference o World Wide Web