BPP (מחלקת סיבוכיות)
בעיות פתוחות במדעי המחשב: |
BPP (ראשי תיבות: Bounded-Error, Probabilistic, Polynomial Time) היא מחלקת הבעיות הפתירות על ידי אלגוריתם אקראי בעל זמן ריצה פולינומי, אשר צודק בהסתברות "טובה". (כלומר, ההסתברות (על פני המטבעות שמטיל האלגוריתם) שהאלגוריתם עונה את התשובה הנכונה היא לפחות ).
מקובל לראות בבעיות הנמצאות במחלקה זו בעיות "הניתנות לפתרון סביר".
הגדרה
עריכהקיימות מספר הגדרות שקולות למחלקה זו, נציין אחת מהן.
מחלקת BPP מאגדת את כל השפות להן קיים אלגוריתם אקראי , הרץ בזמן פולינומי, ומקיים:
- לכל , מתקיים בהסתברות לפחות .
- לכל , מתקיים בהסתברות לפחות .
ניתן לציין כי השימוש בקבוע שרירותי ונבחר מטעמי פשטות, וכל קבוע אחר, או ביטוי מהצורה היה נותן מחלקה זהה. הסיבה לכך, היא שניתן להעצים את הסתברות ההצלחה של האלגוריתם על ידי הרצתו מספר (פולינומי) של פעמים באופן בלתי תלוי ובחירת תוצאת הרוב. כך ניתן להקטין את סיכויי הכישלון באופן מעריכי עם מספר החזרות, כפי שניתן לנתח באמצעות אי-שוויון צ'רנוף.
יחס למחלקות אחרות
עריכההמחלקה BPP מכילה את מחלקות הסיבוכיות RP ו-co-RP, אשר מאפשרות טעות חד-צדדית בלבד, ואת מחלקת הסיבוכיות P, אשר אינה מאפשרת אקראיות בכלל (ולכן, ממילא, האלגוריתם חייב לצדוק תמיד). המחלקה מוכלת במחלקת הסיבוכיות PP.
עם זאת, לא ידוע האם BPP מכילה ממש את P, וכן לא ידוע היחס בין BPP למחלקה NP (דהיינו, כלל לא ידוע האם אחת מהן מוכלת בשנייה). סוגיה זו היא אחת הסוגיות הבסיסיות של מדעי המחשב בכלל, ותורת הסיבוכיות בפרט. ידוע ש BPP מוכלת במחלקת הסיבוכיות P/Poly, הכוללת את כל הפונקציות הניתנות לחישוב על ידי מעגלים בגודל פולינומי.
לאור הידוע אודות "דה-רנדומיזציה", ההשערה המקובלת היא ש-BPP שווה למחלקה P[1].
משפט סיפסר לאוטמן
עריכהמשפט סיפסר לאוטמן קובע כי
אינטואיציה
עריכההמחלקה BPP היא המחלקה אשר מתירה טעות דו צדדית קטנה, כלומר טעות קטנה בתשובה "כן", וטעות קטנה בתשובה "לא". הכוונה בטעות קטנה היא שניתן בזמן פולינומי באורך הקלט להקטין אותה לטעות זניחה. מכיוון שיש מספר זניח של טעויות, אז "רוב" המחרוזות הראנדומיות[2] הן מחרוזות שגורמות למכונה שמכריעה שפה ב-BPP להוציא תשובה נכונה (מחרוזות "נכונות"). לכן ניקח מספר פולינומי של פונקציות הפיכות שלאחר שנפעיל אותן על קבוצת המחרוזות הראנדומיות הנכונות נקבל את כל המחרוזות הרנדומיות הקיימות. מאחר שיש לנו קבוצת פונקציות כזאת, אז הנוסחה שתתאים ל היא . כלומר לכל קלט ראנדומי קיימת פונקציה שממפה אותו לקלט מהקבוצה של הקלטים הנכונים. הפועל הפונקציות ההפיכות תהיינה פעולות xor עם ערך קבוע.
הוכחה
עריכהנרצה להוכיח עבור שפה שמתקיים . מכיוון ש-BPP סגורה למשלים אז מתקיים גם , ולכן . בלי הגבלת הכלליות ניקח מכונה הסתברותית M המכריעה את L עם הסתברות טעות לכל היותר [3]. נגדיר . עכשיו נמצא מספר קטן של פונקציות שיקיימו , כאשר R הוא מרחב מרחב המחרוזות הרנדומיות (נגדיר הפעלה של פונקציה על קבוצה בתור הפעלה איבר איבר, כלומר ). אנחנו נתייחס למרחב קלטים ראנדומי באורך r.
למה 1
עריכהנרצה להראות שקבוצה גדולה יכולה לכסות את כל R עם פונקציות מתאימות, או בשפה מתמטית
- אם אז קיימות מחרוזות תרגום כך ש . הפעולה תוגדר כמו מקודם - .
הוכחה. נבחר באקראי . נגדיר .
אז, לכל ,
- [4].
לכן ההסתברות שקיים לפחות איבר אחד ב-R שאינו נמצא ב-S היא
ולכן
ומכיוון שההסתברות לא 0 קיימות מחרוזות תרגום עבורן הקבוצות S ו-R שוות.
למה 2
עריכהנרצה להראות שקבוצה קטנה לא יכולה לכסות את כל R עם כל מספר פולינומי של פונקציות, או בשפה מתמטית אם אז אין קבוצה קטנה של מחרוזות תרגום שמכסה את R.
ההוכחה טריוויאלית - , ופולינום כפול מספר זניח הוא מספר זניח, ולכן לא קיים כיסוי עם אף סט קטן של מחרוזות תרגום.
מסקנה
עריכהראינו שקיימות מחרוזות תרגום עבורן . לכן ניתן לכתוב
ובגלל ההפיכות של xor, כלומר , אז אנחנו יודעים מלמה 1 שלכל r תהיה מחרוזת כך ש- , ולכן המכונה תקבל כל מילה בשפה. לעומת זאת, עבור מילים שאינן בשפה קיים r שאין עבורו שום תרגום ל- , ולכן ההגדרה שלמעלה תקינה. היא גם הגדרה מהצורה של , ומכאן נובע ש- , שהרי BPP סגורה למשלים.
הערות שוליים
עריכה- ^ P = BPP if E requires exponential circuits: derandomizing the XOR lemma
- ^ מחרוזת ראנדומית מחרוזת של אחדות ואפסים שמייצגות את הטלות המטבע של המכונה הראנדומית, ובעזרת מחרוזת ראנדומית אפשר להריץ מכונה ראנדומית בעזרת מכונה דטרמיניסטית
- ^ מכיוון שניתן להריץ את המכונות ב-BPP הרבה פעמים אז לכל שפה ב-BPP יש מכונה עם טעות כזו
- ^ מכיוון שהבחירה של המחרוזות תרגום נעשתה באקראי ההסתברויות בלתי תלויות