אלגוריתם לויד-מקס

מתוך ויקיפדיה, האנציקלופדיה החופשית
קפיצה לניווט קפיצה לחיפוש

אלגוריתם לויד-מקס הוא אלגוריתם הקרוי על שמו של סטוארט לויד למציאת חלוקה לקבוצות של נקודות במרחב אוקלידי לתאים קמורים. בדומה לאלגוריתם k-מרכזים, האלגוריתם מוצא נקודות מרכז לכל קבוצה בחלוקה, ואחר כך מחלק את הנקודות בהתאם לקרבתן למרכזים. בהקשר זה פעולת המיצוע על הנקודות מוחלפת באינטגרל על שטח המרחב, ופעולת מציאת המרכזים הקרובים יוצרת דיאגרמת וורונוי.

את האלגוריתם ניתן להפעיל במרחב אוקלידי, אך אלגוריתמים דומים יכולים להיות מופעלים על מרחבים מממד גבוה יותר או למרחבים לא אוקלידים.

בקוונטיזציה, האלגוריתם מאפשר למזער את השגיאה הריבועית הממוצעת.

הדגמה של אלגוריתם לויד-מקס. דיאגרמת וורונוי מוצגת עבור הנקודות בכל שלב. סימני הפלוס מסמנים את המרכזים של תאי וורונוי.
איטרציה 1
איטרציה 2
איטרציה 3
איטרציה 15
בתרשים האחרון, הנקודות סמוכות למרכזים של תאי וורונוי.

קוונטיזציה אחידה ושגיאת קוונטיזציה

בקוונטיזציה אחידה, בהינתן N, מספר הרמות שאליהן אנו מחלקים את הטווח, מספיק לקבוע את רמת הקוונטיזציה הראשונה ואת ההפרש בין הרמות, וכך הקוונטיזציה נקבעת חד-חד-ערכית. אולם, הדבר מגביל אותנו מבחינת שגיאת הקוונטיזציה שאותה ניתן להשיג. נרצה להשיג חופש גדול יותר בבחירת מדרגות הקוונטיזציה וערכיהן בשביל לקבל שגיאה נמוכה יותר.

MSE=a1(xx1)2fx(x)dx+i=2Nai1ai(xxi)2fx(x)dx+aN1(xxN)2fx(x)dx+

נחשב את xi ו- ai האופטימליים:

עבור ai, נגזור ונשווה ל-0:

dMSEdai=fx(ai)[(aixi)2(aixi+1)2]=0

(שכן, ddbabg(x)dx=g(b),ddaabg(x)dx=g(a) )

ואזי, נקבל ai האופטימלי:

ai=xi+xi+22

עבור xi, נגזור ונשווה ל-0:

dMSEdai=2ai1ai(xix)fx(x)dx=0

xiai1aif(x)dx=ai1aixf(x)dx

ואזי, נקבל xi האופטימלי:

xi=Rixf(x)dxRif(x)dx

כאשר: Ri{ai1,ai}

אלגוריתם לויד-מקס

- קבע בצורה שרירותית ואחידה את Ri עבור i=1,...,N.

- בצע בצורה איטרטיבית עד התכנסות:

  1. xi=Rixf(x)dx/Rif(x)dx,i=1,...,N
  2. ai=xi+xi+22,i=1,...,N
  • לא בהכרח מתכנס למינימום מוחלט (יכולים להיתקע במינימום מקומי)
  • כאמור, אלגוריתם זה נותן קוונטיזציה (ai,xi)
  • ישנן טבלאות עבור התפלגות גאוסית N(0,1) עבור ערכי N שונים.
    • במקרים שהתוחלת היא μ, אזי: ai^=ai+μxi^=xi+μ
    • ובמקרים שהשונות היא σ2, אזי: ai^=aiσxi^=xiσ
    • ובמקרה הכללי: ai^=aiσ+μxi^=xiσ+μMSE^=σ2MSE

דוגמאות

הפונקציה הראשונה

דוגמה להתכנסות אלגוריתם לויד- מקס למינימום מקומי:

נניח N=2. בתמונה משמאל ניתן לראות את fx(x).

a1=x1+x22

, וכן מתקיימים התנאים לLloyd Max.

הפונקציה השנייה

למרות שקיימנו את תנאי Lloyd Max, קיבלנו מינימום מקומי.

פתרון טוב יותר היה הפונקציה התחתונה:

לפי תנאי 1 באלגוריתם, מקבלים את הערך של x2 והוא יהיה יותר קרוב למלבן הרחב בציור הראשון.

ראו גם

לקריאה נוספת

שגיאת לואה ביחידה יחידה:Citation/CS1/Configuration בשורה 1739<includeonly></includeonly>: attempt to index field '?' (a nil value).

קישורים חיצוניים

ויקישיתוף מדיה וקבצים בנושא אלגוריתם לויד-מקס בוויקישיתוף   המזהה לא מולא ולא נמצא בוויקינתונים, נא למלא את הפרמטר.