פירוק לערכים סינגולריים (Singular value decomposition - SVD) היא שיטת פירוק באלגברה ליניארית של מטריצהמרוכבת או ממשית. לשיטה זו שימושים רבים באלגברה ליניארית חישובית, בחשבון מטריצות, בעיבוד אותות ובסטטיסטיקה.
פורמלית, פירוק לערכים סינגולריים של מטריצה ממשית או מרוכבת בעלת ממדים הוא פירוק מהצורה:
כאשר U היא מטריצה אוניטרית ממשית או מרוכבת מממד , היא מטריצה אלכסונית מלבנית מממד עם ערכים ממשיים לא-שליליים על האלכסון, ו- (הצמודה ההרמיטית של ) היא מטריצה אוניטרית ממשית או מרוכבת מממד . ערכי האלכסון של , , נקראים הערכים הסינגולריים של והם מסודרים מהגדול לקטן. כמו כן, m העמודות של ו-n העמודות של נקראות הווקטורים הסינגולריים השמאליים והווקטורים הסינגולריים הימניים של , בהתאמה.
הפירוק מקיים את התכונות הבאות:
הווקטורים הסינגולריים השמאליים של הם וקטורים עצמיים של .
הווקטורים הסינגולריים הימניים של הם וקטורים עצמיים של .
הערכים הסינגולריים השונים מאפס של (שעל האלכסון של ) הם שורשים ריבועיים של הערכים עצמיים השונים מאפס הן של והן של .
מטריצת הערכים הסינגולריים , שמבצעת מתיחה ושינוי סקלה, מורכבת רק מ-0ים מחוץ לאלכסון הראשי (כאשר העמודה שמחוץ לבלוק הריבועי המקסימלי מסומנת בכתב אפור נטוי) ואילו באלכסון הראשי רק אחד הערכים הסינגולריים הוא 0 (צבוע באדום). מכאן אפשר להסיק שדרגת המטריצה היא 3 (מספר הערכים הסינגולריים שאינם 0). המטריצות ו- הן אוניטריות, ומכיוון שהן ממשיות (כלומר: כל איבריהן הן מספרים ממשיים) הן גם אורתוגונליות. פירוש העובדה שהן אוניטריות היא:
שימושים
ל-SVD שימושים רבים בדיסציפלינות רבות. השימושים הקלאסיים במתמטיקה כוללים:
מציאת הדרגה (rank) של מטריצה. הדרגה שווה למספר הערכים הסינגולריים הגדולים מאפס.
מציאת מרחב האפס (null space) ימני או שמאלי, בפתרון מערכת משוואות ליניאריות הומוגנית. מרחב האפס נפרס על ידי הווקטורים הסינגולריים המתאימים לערכים הסינגולרים שהם אפס.
חישוב פסאודו-הופכי (Pseudo-Inverse) של מטריצה שלא בהכרח הפיכה ואף לא בהכרח ריבועית.
מציאת קירוב על ידי מטריצה מדרגה נמוכה למטריצה כלשהי (Low Rank Approximation). הקירוב מתבצע על ידי איפוס של הערכים הסינגולרים הקטנים ושמירה של k הערכים הסינגולרים הגדולים ביותר. קירוב זה אופטימלי הן במובן הנורמה הספקטרלית והן במובן נורמת Frobenius.
הקירוב הטוב ביותר למטריצה כלשהי בעזרת מטריצה אורתוגנלית תחת נורמת Frobenius. ידועה גם כבעיית "מיטת סדום". הפתרון נתון על ידי הביטוי , כאשר ו- מתקבלים מחישוב ה-SVD של . שיטה זו משמשת למשל על-מנת למצוא את מטריצת הסיבוב (שהיא כמובן אורתוגונלית) בין שני סטים של נקודות דו-ממדיות.
Condition number של מטריצה - מספר שאינו קטן מ-1, הקובע את יציבות הבעיה המתמטית ואת שגיאת החישוב המקסימלית העשויה להתקבל במחשב הפועל באריתמטיקה של נקודה צפה. מוגדר כ- . ערך גדול משמעותו שהבעיה היא ill-conditioned. חשוב לציין שלמרות שה- condition number מהווה מדד לשגיאת חישוב אפשרית, זוהי תכונה של המטריצה ולא של האלגוריתם או הייצוג האריתמטי בו משתמשים.
חישוב Pseudo-Inverse
פירוק SVD יכול לשמש כדי לחשב את ה-Pseudo-Inverse של מטריצה, כאשר עבור M שהפירוק שלה הוא ניתן למצוא את ה-Pseudo-Inverse:
כאשר Σ+ היא מטריצת ה-Pseudo-Inverse של Σ, המתקבלת על ידי החלפה של כל ערך שאינו אפס על גבי האלכסון בהופכי שלו ושחלוף המטריצה המתקבלת. אחד השימושים למטריצה זו הוא לפתרון בעיות בשיטת הריבועים הפחותים.
נורמות
בעזרת הערכים הסינגולרים ניתן לחשב בקלות מספר נורמות של מטריצות ואף להגדיר נורמות חדשות:
הערך הסינגולרי הגדול ביותר הוא נורמה. נורמה זו נקראת הנורמה הספקטרלית והיא שווה לנורמה p המושרית עבור p=2. באופן פורמלי:
נורמת Frobenius, השווה לשורש סכום ריבועי איברי המטריצה, שווה גם לשורש סכום ריבועי הערכים הסינגולריים:
נורמת Ky-Fan, השווה לסכום k הערכים הסינגולרים הגדולים ביותר: . כאשר סוכמים את כל הערכים הסינגולריים, הנורמה נקראת גם Nuclear Norm. נורמה זו, משמשת לעיתים (בעיקר בבעיות אופטימיזציה) כתחליף ל- rank, כיוון שהיא קמורה (convex) ורציפה. סימון מקובל עבור נורמת ה Nuclear הוא: .
נורמת Schatten, שהיא בעצם נורמת p הרגילה לווקטורים מופעלת על הערכים הסינגולריים: . עבור p=2 מתקבלת נורמת Frobenius ועבור p=1 מתקבלת ה Nuclear norm.
לקריאה נוספת
Golub, Gene H.; Van Loan, Charles F. (2013), Matrix Computations (4th ed.), Johns Hopkins, ISBN 978-1421407944.