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

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

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

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

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

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

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

(שכן, )

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

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

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

כאשר:

אלגוריתם Lloyd- Max

- קבע בצורה שרירותית ואחידה את עבור .

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

  • לא בהכרח מתכנס למינימום מוחלט (יכולים להיתקע במינימום מקומי)
  • כאמור, אלגוריתם זה נותן קוונטיזציה
  • ישנן טבלאות עבור התפלגות גאוסית עבור ערכי N שונים.
    • במקרים שהתוחלת היא , אזי:
    • ובמקרים שהשונות היא , אזי:
    • ובמקרה הכללי:

דוגמאות

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

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

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

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

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

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

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

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

ראו גם

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

הערך באדיבות ויקיפדיה העברית, קרדיט,
רשימת התורמים
רישיון cc-by-sa 3.0

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