ביטול הרסני

באנליזה נומרית, ביטול הרסני[1][2] היא תופעה בה הדיוק של חיסור של שני מספרים עם שגיאה קטנה גוררת שגיאה גדולה. דבר זה עלול לקרות גם אם החיסור הוא מדויק.

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

אבל אם נחשב את ההפרש בין הערכים המשוערים, נקבל: , לעומת הפרש אמיתי של . השגיאה היחסית היא כעת 100%.

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

ניתוח פורמלי

עריכה

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

 

וכך אנו נוכחים שהשגיאה היחסית של החיסור המדויק   של המספרים המשוערכים היא:

 

והיא עלולה להיות גדולה מאוד אם הערכים האמיתיים   ,  קרובים.

באלגוריתמים נומריים

עריכה

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

 

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

וכעת, אם נחשב את החיסור בנקודה צפה:

 

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

 

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

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

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

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

ראו גם

עריכה

הערות שוליים

עריכה
  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. 102. doi:10.1007/978-3-319-76526-6. ISBN 978-3-319-76525-9.{{cite book}}: תחזוקה - ציטוט: location (link)
  2. ^ 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}}: (עזרה)