אלגוריתם לנצוש
אלגוריתם לָנְצוֹשׁ (Lanczos) הוא אלגוריתם שפיתח קורנליוס לנצוש ב-1950[1]. האלגוריתם מוצא חלק (או את כל) הערכים עצמיים והווקטורים העצמיים של מטריצה הרמיטית (או סימטרית) בגודל במספר מוגבל של פעולות. כמות הפעולות הנדרשת למציאת כל הערכים העצמיים והווקטורים העצמיים של מטריצה היא , אבל בעזרת אלגוריתם לנצוש ניתן למצוא חלק מהערכים העצמיים בפחות פעולות.[2]
למרות שהאלגוריתם יעיל חישובית, השיטה בהצגה המקורית שלה הייתה לא מועילה, מאחר שסבלה מחוסר יציבות נומרית. ב-1970 הראו איביו וניומן איך לייצב את השיטה ויישמו זאת כדי לפתור מערכות הנדסיות גדולות מאוד. בעבודה המקורית שלהם, הם הציעו שיטה לבחירת וקטור התחלתי. מעט אחר כך ביצע כריסטופר פייג' אנליזה לשגיאה.
האלגוריתם
קלט: מטריצה הרמיטית בגודל , ומספר איטרציות (בשביל לקבל את כל הערכים העצמיים והווקטורים העצמיים מבדויק, יש לבחור ). למעשה, האלגוריתם לא צריך לקבל את המטריצה, אלא את היכולת להפעיל אותה על וקטורים.
פלט: מטריצה בגודל עם עמודות אורתונורמליות ומטריצה תלת-אלכסונית בגודל . הערכים העצמיים של המטריצה "קרובים" לחלק מהערכים העצמיים של המטריצה המקורית . בשביל לקבל את הערכים העצמיים של אפשר להשתמש למשל באלגוריתם QR. מכיוון שהמטריצה היא מטריצה תלת-אלכסונית, הערכים העצמיים שלה מחושבים ב פעולות.
אלגוריתם:
- יהי וקטור שרירותי עם נורמה אוקלידית .
- צעד התחלתי:
- יהי .
- יהי .
- יהי .
- עבור בצע:
- יהי (נורמה אוקלידית).
- אם אז ,
- אחרת בחר את להיות וקטור שרירותי עם נורמה אוקלידית שיהיה אורתוגונלי לכל .
- יהי .
- יהי .
- יהי .
- תהי המטריצה עם עמודות . תהי .
- הערה הפענוח נכשל (שגיאת המרה. השרת ("https://wikimedia.org/api/rest_") השיב: "Cannot get mml. Server problem."): {\displaystyle Av_{j}=w_{j}'=\beta _{j+1}v_{j+1}+\alpha _{j}v_{j}+\beta _{j}v_{j-1}} עבור .
מימוש
אחד המימושים המקובלים לאלגוריתם נמצא בחבילה ARPACK[3]. לדוגמה, המימוש באוקטבה (Octave) מתבסס על מימוש זה[4].
לקריאה נוספת
- Trefethen, Lloyd N., and David Bau III. Numerical linear algebra. Vol. 50. Siam, 1997.
- Stewart, Gilbert W. Matrix Algorithms: Volume II: Eigensystems. Society for Industrial and Applied Mathematics, 2001.
הערות שוליים
- ^ Lanczos, C. "An iteration method for the solution of the eigenvalue problem of linear differential and integral operators", J. Res. Nat’l Bur. Std. 45, 255-282 (1950).
- ^ קיים אנלוג לאלגוריתם עבור מטריצות שאינן סימטריות בשם אלגוריתם ארנולדי
- ^ http://www.caam.rice.edu/software/ARPACK/
- ^ https://www.gnu.org/software/octave/doc/interpreter/Sparse-Linear-Algebra.html#doc_002deigs
22075542אלגוריתם לנצוש