חרטה (תורת ההחלטות)

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

חרטה של סדרות תוצאות והחלטות

עריכה

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

החרטה של סדרת ההחלטות   יחסית לסדרת החלטות אפשרית אחרת  , מוגדרת כהפרש

 

.

דוגמאות

עריכה

השקעה בתיק מניות

עריכה

בשוק המניות יש   מניות. הווקטור   מציין את העלייה בערכי המניות ביום ה-  (למשל   אם המניה ה-  הכפילה את ערכה ביום  , ואילו   אם המניה ה-  אבדה את כל ערכה).

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

חיזוי תוצאת תנאי תוכנה

עריכה

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

כל תוצאת תנאי היא  . אלגוריתם חוזה את התוצאה הבאה  .

במקרה זה, נגדיר את תועלת הנחוש כ- , כלומר 1 אם הניחוש הצליח, ו-0 אם לא.

החרטה בהשוואה לסדרת ניחושים   היא  .

הגדרות נוספות

עריכה

חרטה אפשר למדוד בהשוואה לתוחלת של סדרת התוצאות (אם לתהליך   יש התפלגות המייצרת את סדרת התוצאות, החרטה היא  ). אפשרות אחרת היא מדידה של התוצאה בהשוואה לסדרת התוצאות הגרועה ביותר:  .

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

חרטה פנימית וחיצונית

עריכה

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

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

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

דוגמה: חרטה פנימית במירוץ סוסים

עריכה

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

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

החרטה הפנימית היא   כאשר הסדרה   מושגת על ידי החלפת כל הימור על סוס   בהימור על סוס  .

חרטה חיצונית

עריכה

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

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

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

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

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

מזעור חרטה חיצונית

עריכה

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

מודל

עריכה

נניח מודל מקוון בו   פעולות אפשריות: {X = {1,…,N. בכל מקטע זמן   אלגוריתם מקוון   בוחר התפלגות   מעל   הפעולות, לאחר-מכן היריב בוחר וקטור הפסד   כאשר   הוא ההפסד בפעולה ה- -ית במקטע ה- . במודל האינפורמציה המלאה האלגוריתם   מקבל את וקטור ההפסד   ומחשב את  . במודל האינפורמציה החלקית האלגוריתם המקון מקבל   כאשר   מפולג לפי   ו-  הוא ההפסד. ההפסד של הפעולה ה- -ית במקטע הזמן   הוא   וההפסד של האלגוריתם ה-  הוא  . נגדיר את החרטה החיצונית באופן שתהיה האפשרות לבחור מבין אוסף אלגוריתמים  , הנקראת קבוצת הכיווץ, את האלגוריתם עם הביצועים הטובים ביותר כך שההפסד יהיה:   כאשר  .


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

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

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

בהינתן אוסף התפלגויות הסתברותיות   (בהן נעשה שימוש באלגוריתם המקוון  ) וחוק ההתאמה   נגדיר סדרה חדשה של התפלגויות הסתברותיות   כאשר   כאשר  . ההפסד של הסדרה המתואמת הוא  . חוק ההתאמה   מניב התפלגויות שונות.

בהינתן קבוצת חוקים סופית וחסרת זיכרון (=שאינה תלויה בהיסטוריה) Ғ ואוסף וקטורי הפסד, החרטה של האלגוריתם המקוון   היא:   כאשר Ғ .

ראו גם

עריכה

הערות שוליים

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