הלמה של סטרבנץ

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

בערך זה
נעשה שימוש
בסימנים מוסכמים
מתחום המתמטיקה.
להבהרת הסימנים
ראו סימון מתמטי.

בחישובי נקודה צפה, הלֶמה של סטרבנץאנגלית: Sterbenz' lemma)‏[1] היא משפט שנותן את התנאים בהם חישוב הפרש של נקודה צפה מחושב באופן מדויק. היא נקראת על שם פט ה. סטרבנץ, שפרסם אותה כמשפט 4.3.1 בספרו Floating Point Computation בשנת 1974.[2]

הלמה של סטרבנץ טוענת שעבור מערכת מספרים של נקודה צפה עם מספרים תת-נורמליים, כגון IEEE 754 binary64, אם , הם מספרי נקודה צפה כך שמתקיים:

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

קשר לביטול הרסני[עריכת קוד מקור | עריכה]

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

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

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

שימוש באנליזה נומרית[עריכת קוד מקור | עריכה]

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

כאשר היא מחצית ההיקף. אם נשתמש בנוסחה הזאת בחישובי נקודה צפה, היא עשויה לתת תוצאות בעלות שגיאה גדולה עבור משולשים צרים. לעומת זאת, עבור הנוסחה החלופית:
נוכל להוכיח, בעזרת הלמה של סטרבנץ, שהיא בעלת שגיאה קדמית נמוכה לכל קלט אפשרי.[3][4][5]

הערות שוליים[עריכת קוד מקור | עריכה]

  1. ^ Muller, Jean-Michel; Brunie, Nicolas; de Dinechin, Florent; Jeannerod, Claude-Pierre; Joldes, Mioara; Lefèvre, Vincent; Melquiond, Guillaume; Revol, Nathalie; Torres, Serge (2018). Handbook of Floating-Point Arithmetic (2nd ed.). Gewerbestrasse 11, 6330 Cham, Switzerland: Birkhäuser. p. 101. doi:10.1007/978-3-319-76526-6. ISBN 978-3-319-76525-9.{{cite book}}: תחזוקה - ציטוט: location (link)
  2. ^ Sterbenz, Pat H. (1974). Floating-Point Computation. Englewood Cliffs, NJ, United States: Prentice-Hall. p. 138. ISBN 0-13-322495-3.
  3. ^ Kahan, W. (2014-09-04). "Miscalculating Area and Angles of a Needle-like Triangle" (PDF). Lecture Notes for Introductory Numerical Analysis Classes. נבדק ב-2020-09-17.
  4. ^ Goldberg, David (במרץ 1991). "What every computer scientist should know about floating-point arithmetic". ACM Computing Surveys. New York, NY, United States: Association for Computing Machinery. 23 (1): 5–48. doi:10.1145/103162.103163. ISSN 0360-0300. נבדק ב-2020-09-17. {{cite journal}}: (עזרה)
  5. ^ Boldo, Sylvie (באפריל 2013). Nannarelli, Alberto; Seidel, Peter-Michael; Tang, Ping Tak Peter (eds.). How to Compute the Area of a Triangle: a Formal Revisit. 21st IEEE Symposium on Computer Arithmetic. Computer Arithmetic, 2009. Arith 2009. 19Th IEEE Symposium on. IEEE Computer Society. pp. 91–98. doi:10.1109/ARITH.2013.29. ISBN 978-0-7695-4957-6. ISSN 1063-6889. {{cite conference}}: (עזרה)