Lanczos algoritması - Lanczos algorithm

Lanczos algoritması bir doğrudan algoritma tarafından tasarlanmış Cornelius Lanczos bu bir uyarlamadır güç yöntemleri bulmak için "en kullanışlı" (aşırı en yüksek / en alçağa doğru eğilim) Özdeğerler ve özvektörler bir Hermit matrisi, nerede genellikle, ancak çok da küçük değildir .[1] Prensip olarak hesaplama açısından verimli olmasına rağmen, başlangıçta formüle edildiği şekliyle yöntem, sayısal kararsızlık.

1970 yılında Ojalvo ve Newman, yöntemin sayısal olarak kararlı hale nasıl getirileceğini gösterdiler ve bunu dinamik yüklemeye maruz kalan çok büyük mühendislik yapılarının çözümüne uyguladılar.[2] Bu, Lanczos vektörlerini saflaştırmak için bir yöntem kullanılarak elde edildi (yani, yeni oluşturulan her vektör ile tekrar tekrar ortogonalize edilerek) herşey önceden oluşturulmuş olanlar)[2] gerçekleştirilmediğinde, en düşük doğal frekanslarla ilişkili olanlar tarafından oldukça kirlenmiş bir dizi vektör üreten herhangi bir doğruluk derecesine.

Orijinal çalışmalarında, bu yazarlar bir başlangıç ​​vektörünün nasıl seçileceğini de önerdiler (yani, başlangıç ​​vektörünün her bir elemanını seçmek için bir rastgele sayı üreteci kullanın) ve belirlemek için deneysel olarak belirlenmiş bir yöntem önerdiler. , azaltılmış vektör sayısı (yani istenen doğru özdeğer sayısının yaklaşık 1,5 katı seçilmelidir). Kısa süre sonra çalışmalarını, bir hata analizi de sağlayan Paige takip etti.[3][4] 1988'de Ojalvo, bu algoritmanın daha ayrıntılı bir tarihçesini ve verimli bir özdeğer hata testi üretti.[5]

Algoritma

Giriş a Hermit matrisi boyut ve isteğe bağlı olarak bir dizi yineleme (varsayılan olarak ).
  • Açıkçası, algoritmanın açık matrise erişime ihtiyacı yoktur, sadece bir fonksiyon matrisin çarpımını rastgele bir vektörle hesaplayan. Bu işlev en çok zamanlar.
Çıktı bir matris ile ortonormal sütunlar ve bir üç köşeli gerçek simetrik matris boyut . Eğer , sonra dır-dir üniter, ve .
Uyarı Lanczos yinelemesi sayısal kararsızlığa meyillidir. Kesin olmayan aritmetikte yürütüldüğünde, sonuçların geçerliliğini sağlamak için ek önlemler (sonraki bölümlerde özetlendiği gibi) alınmalıdır.
  1. İzin Vermek ile keyfi bir vektör olmak Öklid normu .
  2. Kısaltılmış ilk yineleme adımı:
    1. İzin Vermek .
    2. İzin Vermek .
    3. İzin Vermek .
  3. İçin yapmak:
    1. İzin Vermek (Ayrıca Öklid normu ).
    2. Eğer o zaman izin ver ,
      başka türlü seç Öklid normuna sahip keyfi bir vektör bu hepsine ortogonaldir .
    3. İzin Vermek .
    4. İzin Vermek .
    5. İzin Vermek .
  4. İzin Vermek sütunlu matris olun . İzin Vermek .
Not için .

Prensipte yineleme prosedürünü yazmanın dört yolu vardır. Paige ve diğer çalışmalar, yukarıdaki işlem sırasının sayısal olarak en kararlı olduğunu gösteriyor.[6][7]Uygulamada ilk vektör prosedürün başka bir argümanı olarak alınabilir. ve sayısal belirsizlik göstergeleri ek döngü sonlandırma koşulları olarak dahil edilmiştir.

Matris vektör çarpımını saymazsak, her yineleme aritmetik işlemler. Matris vektör çarpımı şu şekilde yapılabilir: aritmetik işlemler nerede bir satırdaki sıfır olmayan ortalama öğe sayısıdır. Toplam karmaşıklık bu nedenle veya Eğer ; Lanczos algoritması seyrek matrisler için çok hızlı olabilir. Sayısal kararlılığı geliştirmeye yönelik şemalar tipik olarak bu yüksek performansa göre değerlendirilir.

Vektörler arandı Lanczos vektörleri. Vektör sonra kullanılmaz hesaplanır ve vektör sonra kullanılmaz hesaplanır. Bu nedenle, üçü için de aynı depolama alanı kullanılabilir. Aynı şekilde, sadece üç köşeli matris aranırsa, ham yinelemenin hesapladıktan sonra Sayısal kararlılığı iyileştirmek için bazı planlar daha sonra buna ihtiyaç duyacak olsa da. Bazen sonraki Lanczos vektörleri yeniden hesaplanır. ihtiyaç duyulduğunda.

Özsoruna uygulama

Lanczos algoritması, çoğunlukla özdeğerler ve özvektörler bir matris, ancak sıradan bir matrisin köşegenleştirilmesi özvektörleri ve özdeğerleri incelemeden anlaşılır kılacaksa, aynı şey Lanczos algoritması tarafından gerçekleştirilen üç diyagonalleştirme için geçerli değildir; Tek bir özdeğer veya özvektörü bile hesaplamak için önemsiz olmayan ek adımlara ihtiyaç vardır. Bununla birlikte, Lanczos algoritmasını uygulamak, özdeşleşmeyi hesaplamada genellikle ileriye doğru önemli bir adımdır. Eğer bir özdeğerdir , ve eğer ( özvektördür ) sonra karşılık gelen özvektördür (dan beri ). Böylelikle Lanczos algoritması, eigendecomposition problemini eigendecomposition problemine .

  1. Üçgen matrisler için, genellikle genel amaçlı algoritmalardan daha iyi hesaplama karmaşıklığına sahip bir dizi özel algoritma vardır. Örneğin, eğer bir üç köşeli simetrik matris sonra:
    • sürekli özyineleme hesaplamaya izin verir karakteristik polinom içinde operasyonlar ve bir noktada değerlendirme operasyonlar.
    • bölün ve yönet özdeğer algoritması tüm eigende bileşimini hesaplamak için kullanılabilir içinde operasyonlar.
    • Hızlı Çok Kutuplu Yöntem[8] tüm özdeğerleri sadece operasyonlar.
  2. Bazı genel özbirleştirme algoritmaları, özellikle QR algoritması, tridiagonal matrisler için genel matrislerden daha hızlı yakınsadıkları bilinmektedir. Üçgen QR'nin asimptotik karmaşıklığı aynen böl ve yönet algoritmasında olduğu gibi (sabit faktör farklı olsa da); çünkü özvektörler birlikte elemanlar, bu asimptotik olarak optimaldir.
  3. Yakınsama oranları üniter dönüşümlerden etkilenmeyen algoritmalar bile, örneğin güç yöntemi ve ters yineleme, üç köşeli matrise uygulanmasından düşük seviye performans avantajlarından yararlanabilir orijinal matris yerine . Dan beri yüksek öngörülebilir konumlarda sıfır olmayan tüm öğelerle çok seyrek olup, karşılaştırmalı olarak mükemmel performansla kompakt depolamaya izin verir Önbelleğe almak. Aynı şekilde, bir gerçek tüm özvektörler ve özdeğerler gerçek olan matris, oysa genel olarak karmaşık elemanlara ve özvektörlere sahip olabilir, bu nedenle gerçek aritmetik, özvektörlerini ve özdeğerlerini bulmak için yeterlidir. .
  4. Eğer çok büyük, sonra küçülüyor Böylece yönetilebilir bir boyutta olması, yine de daha uç özdeğerlerin ve özvektörlerin bulunmasına izin verecektir. ; içinde bölgesinde, Lanczos algoritması bir kayıplı sıkıştırma Aşırı özdeğerlerin korunmasını vurgulayan Hermit matrisleri şeması.

Seyrek matrisler için iyi performansın ve birkaç (tümünü hesaplamadan) özdeğer hesaplama becerisinin kombinasyonu, Lanczos algoritmasını kullanmayı seçmenin ana nedenleridir.

Üçgenleştirme uygulaması

Öz problem genellikle Lanczos algoritmasını uygulamak için motivasyon kaynağı olsa da, algoritmanın esas olarak gerçekleştirdiği işlem, sayısal olarak kararlı olan bir matrisin üç köşegenleştirilmesidir. Hane halkı dönüşümleri 1950'lerden beri tercih edilmektedir. 1960'larda Lanczos algoritması göz ardı edildi. Kaniel-Paige yakınsama teorisi ve sayısal istikrarsızlığı önlemek için yöntemlerin geliştirilmesi, buna olan ilgi yeniden canlandı, ancak Lanczos algoritması, yalnızca Householder tatmin edici değilse denenecek alternatif algoritma olmaya devam ediyor.[9]

İki algoritmanın farklı olduğu yönler şunları içerir:

  • Lanczos şunlardan yararlanır: Seyrek bir matris olmak, oysa Householder değildir ve oluşturacaktır doldurun.
  • Lanczos, orijinal matrisle baştan sona çalışır (ve sadece örtük olarak bilinmesi sorunu yoktur), oysa ham Householder matrisi hesaplama sırasında değiştirmek ister (ancak bundan kaçınılabilir).
  • Lanczos algoritmasının her yinelemesi, son dönüşüm matrisinin başka bir sütununu üretir Householder'ın bir yinelemesi, üniter bir faktörleştirmede başka bir faktör üretirken nın-nin . Ancak her faktör tek bir vektör tarafından belirlenir, bu nedenle depolama gereksinimleri her iki algoritma için de aynıdır ve hesaplanabilir zaman.
  • Ev sahibi sayısal olarak kararlıdır, oysa ham Lanczos değildir.
  • Lanczos, yalnızca noktaları senkronizasyon (hesaplamaları ve ). Ev sahibi daha az paraleldir, bir dizi her biri dizideki önceki miktara bağlı olarak hesaplanan skaler büyüklükler.

Algoritmanın türetilmesi

Lanczos algoritmasına götüren birkaç mantık satırı vardır.

Daha tasarruflu bir güç yöntemi

En büyük büyüklükteki özdeğer ve bir matrisin karşılık gelen özvektörünü bulmak için güç yöntemi kabaca

  1. Rastgele bir vektör seçin .
  2. İçin (yönüne kadar yakınsadı) şunu yapın:
    1. İzin Vermek
    2. İzin Vermek
  • Geniş limit en büyük büyüklük özdeğerine karşılık gelen normlu özvektöre yaklaşır.

Bu yönteme karşı ileri sürülebilecek bir eleştiri, savurgan olmasıdır: matristen bilgi çıkarmak için çok fazla iş (adım 2.1'deki matris-vektör ürünleri) harcar. , ancak yalnızca son sonuca dikkat eder; uygulamalar genellikle tüm vektörler için aynı değişkeni kullanır , her yeni yinelemenin bir öncekinin sonuçlarının üzerine yazması. Ya bunun yerine tüm ara sonuçları saklasak ve verilerini düzenleseydik?

Vektörlerden önemsiz bir şekilde elde edilebilen bir bilgi parçası bir zincir Krylov alt uzayları. Algoritmaya kümeler eklemeden bunu belirtmenin bir yolu, hesaplama yaptığını iddia etmektir.

bir alt küme temelinde öyle ki her biri için ve tüm

bu önemsiz bir şekilde tatmin oluyor olduğu sürece doğrusal olarak bağımsızdır (ve böyle bir bağımlılık olması durumunda, kişi aşağıdaki gibi seçerek diziye devam edebilir doğrusal olarak bağımsız olan keyfi bir vektör ). İçeren bir temel Ancak vektörler muhtemelen sayısal olarak kötü şartlandırılmış, çünkü bu vektör dizisi tasarım gereği, bir özvektörüne yakınsamak anlamına gelir. . Bundan kaçınmak için, güç yinelemesini bir Gram-Schmidt süreci yerine bu Krylov alt uzaylarının ortonormal bir temelini üretmek için.

  1. Rastgele bir vektör seçin Öklid normunun . İzin Vermek .
  2. İçin yapmak:
    1. İzin Vermek .
    2. Hepsi için İzin Vermek . (Bunlar koordinatlarıdır temel vektörlere göre .)
    3. İzin Vermek . (Bileşenini iptal edin içinde .)
    4. Eğer o zaman izin ver ve ,
      aksi takdirde olarak seç Öklid normunun keyfi bir vektörü bu hepsine ortogonaldir .

Güç yineleme vektörleri arasındaki ilişki ve ortogonal vektörler bu mu

.

Burada gerçekten ihtiyacımız olmadığı gözlemlenebilir. bunları hesaplamak için vektörler , Çünkü ve bu nedenle arasındaki fark ve içinde , ortogonalleştirme işlemi tarafından iptal edilir. Böylece, Krylov alt uzaylarının zinciri için aynı temel şu şekilde hesaplanır:

  1. Rastgele bir vektör seçin Öklid normunun .
  2. İçin yapmak:
    1. İzin Vermek .
    2. Hepsi için İzin Vermek .
    3. İzin Vermek .
    4. İzin Vermek .
    5. Eğer o zaman izin ver ,
      aksi takdirde olarak seç Öklid normunun keyfi bir vektörü bu hepsine ortogonaldir .

A priori katsayıları tatmin etmek

hepsi için ;

tanım biraz tuhaf görünebilir, ancak genel kalıba uyuyor dan beri

Çünkü güç yineleme vektörleri bu özyinelemeden çıkarılmış olanlar tatmin edici vektörler ve katsayılar yeterince bilgi içerir hepsi bu hesaplanabilir, böylece vektörleri değiştirerek hiçbir şey kaybolmaz. (Gerçekten de, burada toplanan verilerin, güç yönteminde eşit sayıda yinelemeden elde edilenden en büyük özdeğer için önemli ölçüde daha iyi tahminler verdiği ortaya çıkıyor, ancak bu noktada bu çok açık olmasa da.)

Bu son prosedür, Arnoldi yinelemesi. Lanczos algoritması daha sonra basitleştirme olarak ortaya çıkar, hesaplama adımlarının ortadan kaldırılmasıyla Hermiteseldir - özellikle de çoğu katsayılar sıfır olur.

Temel olarak, eğer o zaman Hermitian

İçin Biz biliyoruz ki , dan beri yapım gereği bu altuzaya ortogonaldir, bu iç çarpım sıfır olmalıdır. (Bu, esasen aynı zamanda, dik polinom dizilerine her zaman bir verilebilmesinin nedenidir. üç dönemli tekrarlama ilişkisi.) İçin biri alır

çünkü ikincisi, bir vektörün normu olması nedeniyle gerçektir. İçin biri alır

yani bu da gerçek.

Daha soyut olarak, eğer sütunlu matristir sonra sayılar matrisin elemanları olarak tanımlanabilir , ve için matris dır-dir Yukarı Hessenberg. Dan beri

matris Hermitian. Bu şu anlama gelir Hessenberg de daha düşüktür, bu yüzden aslında üç bölgeli olmalıdır. Hermitian olduğu için, ana köşegeni gerçektir ve ilk alt köşegeni yapım gereği gerçek olduğundan, aynı şey ilk süper diyagonal için de geçerlidir. Bu nedenle, gerçek, simetrik bir matristir — matristir Lanczos algoritması spesifikasyonunun.

Aşırı özdeğerlerin eşzamanlı yaklaşımı

Hermit matrisinin özvektörlerini karakterize etmenin bir yolu olduğu gibi sabit noktalar of Rayleigh bölümü

Özellikle en büyük özdeğer küresel maksimumdur ve en küçük özdeğer küresel minimumdur .

Düşük boyutlu bir alt uzay içinde nın-nin maksimum noktayı bulmak mümkün olabilir ve minimum nın-nin . Artan bir zincir için bunu tekrar ediyorum iki vektör dizisi üretir: ve öyle ki ve

Daha sonra soru, bu dizilerin optimum oranda yakınsaması için alt uzayların nasıl seçileceğini ortaya çıkarır.

Nereden , daha büyük değerlerin aranacağı en uygun yön bu mu gradyan ve aynı şekilde daha küçük değerlerin aranacağı en uygun yön negatif gradyan mı . Genel olarak

,

bu nedenle ilgi yönleri matris aritmetiğinde hesaplanacak kadar kolaydır, ancak her ikisini de geliştirmek istenirse ve o zaman dikkate alınması gereken iki yeni yön vardır: ve dan beri ve doğrusal olarak bağımsız vektörler olabilir (aslında ortogonale yakın), genel olarak kimse beklenemez ve paralel olmak. Bu nedenle boyutunu artırmak gerekli mi? tarafından her adımda Değilse Krylov alt uzayları olarak kabul edilir, çünkü o zaman hepsi için dolayısıyla özellikle her ikisi için ve .

Başka bir deyişle, gelişigüzel bir başlangıç ​​vektörüyle başlayabiliriz vektör uzaylarını inşa et

ve sonra ara öyle ki

Beri inci güç yöntemi yinelemesi ait olmak bunu üretmek için bir yineleme olduğunu izler ve iktidar yönteminden daha yavaş birleşemez ve her iki özdeğer aşırısına yaklaşarak daha fazlasını elde eder. Optimizasyon alt problemi için bazı ortonormal bir temele sahip olmak uygundur bu vektör uzayı için. Böylelikle, Krylov alt uzaylarının dizisi için böyle bir temeli yinelemeli olarak hesaplama sorununa tekrar yönlendiriliyoruz.

Yakınsama ve diğer dinamikler

Algoritmanın dinamiklerini analiz ederken, özdeğerlerini ve özvektörlerini almak uygundur. Kullanıcı tarafından açıkça bilinmese bile, verildiği gibi. Gösterimi düzeltmek için özdeğerler olsun (bunların hepsi gerçek olarak bilinir ve dolayısıyla sıralanması mümkündür) ve ortonormal bir özvektör kümesi olabilir, öyle ki hepsi için .

İlk Lanczos vektörünün katsayıları için bir gösterim sabitlemek de uygundur. bu özbaz ile ilgili olarak; İzin Vermek hepsi için , Böylece . Başlangıç ​​vektörü Bazı özdeğerlerin tükenmesi, karşılık gelen öz değere yakınsamayı geciktirecektir ve bu, hata sınırlarında sabit bir faktör olarak ortaya çıksa bile, tükenme arzu edilmez. Sürekli olarak vurulmaktan kaçınmanın yaygın bir tekniği, ilk önce elemanları aynı şekilde rastgele çizerek normal dağılım ortalama ile ve sonra vektörü norm olarak yeniden ölçeklendirin . Yeniden ölçeklendirmeden önce bu, katsayılara neden olur aynı normal dağılımdan bağımsız normal dağılımlı stokastik değişkenler olmak (çünkü koordinatların değişimi üniterdir) ve vektörü yeniden ölçeklendirdikten sonra sahip olacak üniforma dağıtımı birim küre üzerinde . Bu, örneğin olasılığın sınırlandırılmasını mümkün kılar .

Lanczos algoritmasının koordinattan bağımsız olması - işlemler sadece vektörlerin iç çarpımlarına bakar, asla vektörlerin tek tek elemanlarına bakmaz - algoritmayı çalıştırmak için bilinen özyapı ile örnekler oluşturmayı kolaylaştırır: make köşegen üzerinde istenen özdeğerleri olan bir köşegen matrisi; başlangıç ​​vektörü olduğu sürece Yeterli sıfır olmayan öğeye sahipse, algoritma genel bir üçgensel simetrik matris çıkaracaktır. .

Kaniel-Paige yakınsama teorisi

Sonra Lanczos algoritmasının yineleme adımları, bir gerçek simetrik matris, yukarıdakine benzer şekilde özdeğerler Yakınsama ile öncelikle -e (ve simetrik yakınsama -e ) gibi büyür ve ikincil olarak bir aralığın yakınsaması Özdeğerlerinin meslektaşlarına nın-nin . Lanczos algoritması için yakınsama, genellikle güç yineleme algoritması için olandan daha hızlı büyüklük sıralarıdır.[9]:477

İçin sınırları Rayleigh bölümünün aşırı değerleri olarak özdeğerlerin yukarıdaki yorumundan gelir . Dan beri bir önsel maksimumdur bütününde buna karşılık sadece bir boyutlu Krylov alt uzayı, önemsiz olarak . Tersine, herhangi bir nokta Krylov alt uzayının bir alt sınır sağladığı için , yani bir nokta sergilenebilirse küçükse bu sıkı bir sınır sağlar .

Boyut Krylov alt uzayı

yani herhangi bir unsuru şu şekilde ifade edilebilir: bazı polinomlar için en fazla derece ; bu polinomun katsayıları, basitçe vektörlerin doğrusal kombinasyonundaki katsayılardır . İstediğimiz polinomun gerçek katsayılara sahip olduğu ortaya çıkacak, ancak şimdilik karmaşık katsayılara da izin vermeliyiz ve yazacağız tüm katsayılarının karmaşık konjuge edilmesiyle elde edilen polinom için . Krylov alt uzayının bu parametrizasyonunda,

Şimdi için ifadeyi kullanarak özvektörlerin doğrusal bir kombinasyonu olarak,

ve daha genel olarak

herhangi bir polinom için .

Böylece

Buradaki pay ve payda arasındaki temel fark, terim payda kaybolur, ancak paydada kaybolmaz. Böylece biri seçebilirse geniş olmak ancak diğer tüm özdeğerlerde küçük, hata konusunda sıkı bir sınır elde edilecektir. .

Dan beri şundan çok daha fazla öz değeri vardır katsayıları var, bu uzun bir sıra gibi görünebilir, ancak bunu karşılamanın bir yolu, Chebyshev polinomları. yazı derece için Birinci türden Chebyshev polinomu (tatmin eden hepsi için ), aralıkta kalan bir polinomumuz var bilinen aralıkta ama onun dışında hızla büyüyor. Argümanın biraz ölçeklendirilmesiyle, onun dışındaki tüm özdeğerleri eşleştirmesini sağlayabiliriz: içine . İzin Vermek

(durumunda bunun yerine en büyük özdeğerini kesinlikle küçük olanı kullanın ), ardından maksimum değeri için dır-dir ve minimum değer , yani

Ayrıca

miktar

(yani, ilkinin oranı eigengap geri kalanının çapına spektrum ) bu nedenle buradaki yakınsama oranı için kilit öneme sahiptir. Ayrıca yazıyor

şu sonuca varabiliriz

Yakınsama oranı bu nedenle esas olarak , çünkü bu sınır bir faktör kadar küçülür her fazladan yineleme için.

Karşılaştırma için, güç yönteminin yakınsama oranının nasıl bağlı olduğu düşünülebilir. , ancak güç yöntemi öncelikle özdeğerlerin mutlak değerleri arasındaki bölüme duyarlı olduğundan, ihtiyacımız var eigengap için ve baskın olan olmak. Bu kısıtlama altında, güç yöntemini en çok destekleyen durum şudur: , bunu bir düşünün. Güç yönteminin sonlarında, iterasyon vektörü:

[not 1]

her yeni yinelemenin etkili bir şekilde -genlik tarafından

En büyük özdeğerin tahmini o zaman

bu nedenle, Lanczos algoritması yakınsama oranı için yukarıdaki sınır ile karşılaştırılmalıdır

hangi faktör küçülür her yineleme için. Böylece aradaki fark, ve . İçinde bölge, ikincisi daha çok ve iki kat daha büyük bir eigengap ile güç yönteminin yapacağı gibi çalışır; dikkate değer bir gelişme. Ancak daha zorlu durum, içinde eigengap üzerinde daha da büyük bir gelişmedir; bölge, Lanczos algoritmasının yakınsama açısından en küçük güç yönteminde iyileştirme.

Sayısal kararlılık

Kararlılık, ortaya çıkan ve biriken küçük sayısal hatalar varsa, algoritmanın ne kadar etkileneceği anlamına gelir (yani, orijinal sonuca yakın yaklaşık sonucu üretecek mi). Sayısal kararlılık, yuvarlama ile bir bilgisayarda bir algoritma uygulamanın yararlılığını değerlendirmek için temel kriterdir.

Lanczos algoritması için, bununla kanıtlanabilir tam aritmetikvektörler kümesi inşa eder ortonormal temel ve çözülen özdeğerler / vektörler, orijinal matrisinkilere iyi yaklaşımlardır. Bununla birlikte, pratikte (hesaplamalar, hatanın kaçınılmaz olduğu kayan nokta aritmetiğinde yapıldığı için), ortogonalite hızla kaybolur ve bazı durumlarda yeni vektör, halihazırda inşa edilmiş olan kümeye doğrusal olarak bağlı bile olabilir. Sonuç olarak, elde edilen üç köşeli matrisin bazı özdeğerleri, orijinal matrise yaklaşık değerler olmayabilir. Bu nedenle, Lanczos algoritması çok kararlı değildir.

Bu algoritmanın kullanıcıları, bu "sahte" özdeğerleri bulabilmeli ve kaldırabilmelidir. Lanczos algoritmasının pratik uygulamaları, bu kararlılık sorunuyla mücadele etmek için üç yöne gider:[6][7]

  1. Ortogonalite kaybını önlemek,
  2. Temel oluşturulduktan sonra ortogonalliği kurtarın.
  3. İyi ve "sahte" özdeğerlerin tümü belirlendikten sonra, sahte olanları kaldırın.

Varyasyonlar

Lanczos algoritmasındaki varyasyonlar, ilgili vektörlerin uzun, vektörler yerine dar matrisler ve normalleştirme sabitlerinin küçük kare matrisler olduğu durumlarda mevcuttur. Bunlar "blok" Lanczos algoritmaları olarak adlandırılır ve çok sayıda yazmaç ve uzun bellek getirme sürelerine sahip bilgisayarlarda çok daha hızlı olabilir.

Lanczos algoritmasının birçok uygulaması, belirli sayıda yinelemeden sonra yeniden başlar. Yeniden başlatılan en etkili varyasyonlardan biri, dolaylı olarak yeniden başlatılan Lanczos yöntemidir,[10] hangi uygulamada ARPACK.[11] Bu, yeniden başlatılan Lanczos bidiagonalization gibi bir dizi başka yeniden başlatılan varyasyona yol açtı.[12] Yeniden başlatılan başka bir başarılı varyasyon, Kalın Yeniden Başlatma Lanczos yöntemidir,[13] TRLan adlı bir yazılım paketinde uygulanmıştır.[14]

Sonlu bir alan üzerinde nullspace

1995'te, Peter Montgomery Lanczos algoritmasına dayalı bir algoritma yayınladı. nullspace büyük bir seyrek matrisin GF (2); Sonlu alanlar üzerinde büyük seyrek matrislerle ilgilenen insanlar kümesi ve büyük özdeğer problemleriyle ilgilenen insan kümesi pek örtüşmediğinden, buna genellikle Lanczos algoritmasını engelle mantıksız bir kafa karışıklığına neden olmadan.[kaynak belirtilmeli ]

Başvurular

Lanczos algoritmaları çok çekicidir çünkü çarpma işlemi tek büyük ölçekli doğrusal işlemdir. Ağırlıklı terimli metin alma motorları yalnızca bu işlemi uyguladığından, Lanczos algoritması metin belgelerine verimli bir şekilde uygulanabilir (bkz. Gizli Anlamsal İndeksleme ). Özvektörler aynı zamanda büyük ölçekli sıralama yöntemleri için de önemlidir. HITS algoritması tarafından geliştirilmiş Jon Kleinberg, ya da PageRank Google tarafından kullanılan algoritma.

Lanczos algoritmaları ayrıca Yoğun Madde Fiziği çözme yöntemi olarak Hamiltonyanlar nın-nin kuvvetle ilişkili elektron sistemleri,[15] yanı sıra kabuk modeli kodlar nükleer Fizik.[16]

Uygulamalar

NAG Kitaplığı birkaç rutin içerir[17] for the solution of large scale linear systems and eigenproblems which use the Lanczos algorithm.

MATLAB ve GNU Oktav come with ARPACK built-in. Both stored and implicit matrices can be analyzed through the eigs() işlev (Matlab /Oktav ).

A Matlab implementation of the Lanczos algorithm (note precision issues) is available as a part of the Gaussian Belief Propagation Matlab Package. GraphLab[18] collaborative filtering library incorporates a large scale parallel implementation of the Lanczos algorithm (in C++) for multicore.

PRIMME library also implements a Lanczos like algorithm.

Notlar

  1. ^ The coefficients need not both be real, but the phase is of little importance. Nor need the composants for other eigenvectors have completely disappeared, but they shrink at least as fast as that for , yani describes the worst case.

Referanslar

  1. ^ Lanczos, C. (1950). "An iteration method for the solution of the eigenvalue problem of linear differential and integral operators" (PDF). Ulusal Standartlar Bürosu Araştırma Dergisi. 45 (4): 255–282. doi:10.6028/jres.045.026.
  2. ^ a b Ojalvo, I. U.; Newman, M. (1970). "Vibration modes of large structures by an automatic matrix-reduction method". AIAA Dergisi. 8 (7): 1234–1239. Bibcode:1970AIAAJ...8.1234N. doi:10.2514/3.5878.
  3. ^ Paige, C. C. (1971). The computation of eigenvalues and eigenvectors of very large sparse matrices (Doktora tezi). U. of London. OCLC  654214109.
  4. ^ Paige, C. C. (1972). "Computational Variants of the Lanczos Method for the Eigenproblem". J. Inst. Maths Applics. 10 (3): 373–381. doi:10.1093/imamat/10.3.373.
  5. ^ Ojalvo, I. U. (1988). "Origins and advantages of Lanczos vectors for large dynamic systems". Proc. 6th Modal Analysis Conference (IMAC), Kissimmee, FL. sayfa 489–494.
  6. ^ a b Cullum; Willoughby. Büyük Simetrik Özdeğer Hesaplamaları için Lanczos Algoritmaları. 1. ISBN  0-8176-3058-9.
  7. ^ a b Yousef Saad (1992-06-22). Numerical Methods for Large Eigenvalue Problems. ISBN  0-470-21820-7.
  8. ^ Coakley, Ed S.; Rokhlin, Vladimir (2013). "A fast divide-and-conquer algorithm for computing the spectra of real symmetric tridiagonal matrices". Uygulamalı ve Hesaplamalı Harmonik Analiz. 34 (3): 379–414. doi:10.1016/j.acha.2012.06.003.
  9. ^ a b Golub, Gene H .; Van Loan, Charles F. (1996). Matris hesaplamaları (3. baskı). Baltimore: Johns Hopkins Üniv. Basın. ISBN  0-8018-5413-X.
  10. ^ D. Calvetti; L. Reichel; D.C. Sorensen (1994). "An Implicitly Restarted Lanczos Method for Large Symmetric Eigenvalue Problems". Sayısal Analiz Üzerine Elektronik İşlemler. 2: 1–21.
  11. ^ R. B. Lehoucq; D. C. Sorensen; C. Yang (1998). ARPACK Users Guide: Solution of Large-Scale Eigenvalue Problems with Implicitly Restarted Arnoldi Methods. SIAM. doi:10.1137/1.9780898719628. ISBN  978-0-89871-407-4.
  12. ^ E. Kokiopoulou; C. Bekas; E. Gallopoulos (2004). "Computing smallest singular triplets with implicitly restarted Lanczos bidiagonalization" (PDF). Appl. Numer. Matematik. 49: 39–61. doi:10.1016/j.apnum.2003.11.011.
  13. ^ Kesheng Wu; Horst Simon (2000). "Thick-Restart Lanczos Method for Large Symmetric Eigenvalue Problems". Matris Analizi ve Uygulamaları Üzerine SIAM Dergisi. SIAM. 22 (2): 602–616. doi:10.1137/S0895479898334605.
  14. ^ Kesheng Wu; Horst Simon (2001). "TRLan software package". Arşivlenen orijinal 2007-07-01 tarihinde. Alındı 2007-06-30.
  15. ^ Chen, HY; Atkinson, W.A.; Wortis, R. (July 2011). "Disorder-induced zero-bias anomaly in the Anderson-Hubbard model: Numerical and analytical calculations". Fiziksel İnceleme B. 84 (4): 045113. arXiv:1012.1031. Bibcode:2011PhRvB..84d5113C. doi:10.1103/PhysRevB.84.045113.
  16. ^ Shimizu, Noritaka (21 October 2013). "Nuclear shell-model code for massive parallel computation, "KSHELL"". arXiv:1310.5431 [nucl-th ].
  17. ^ Sayısal Algoritmalar Grubu. "Keyword Index: Lanczos". NAG Kitaplığı Kılavuzu, Mark 23. Alındı 2012-02-09.
  18. ^ GraphLab Arşivlendi 2011-03-14 de Wayback Makinesi

daha fazla okuma