מודל חישובי

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

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

דוגמות[עריכת קוד מקור | עריכה]

אוטומט סופי[עריכת קוד מקור | עריכה]

דוגמה לאוטומט סופי דטרמיניסטי מעל הא"ב , ששפתו היא כל המילים שמתחילות ונגמרות באותה ספרה.
Postscript-viewer-shaded.png ערך מורחב – אוטומט סופי

אוטומט סופי דטרמיניסטי הוא חמישייה כאשר:

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

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

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

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

אוטומט מחסנית[עריכת קוד מקור | עריכה]

דוגמה לאוטומט מחסנית מעל הא"ב , המקבלת את השפה .
Postscript-viewer-shaded.png ערך מורחב – אוטומט מחסנית

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

פורמלית, אוטומט מחסנית הוא השישייה כאשר:

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

ניתן להגדיר את שפת האוטומט בשני אופנים:

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

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

מכונת טיורינג[עריכת קוד מקור | עריכה]

מכונת טיורינג שקוראת מספר בינארי וכותבת את המספר הנגדי לו בשיטת המשלים ל-2.
Postscript-viewer-shaded.png ערך מורחב – מכונת טיורינג

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

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

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

זמן ריצה[עריכת קוד מקור | עריכה]

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

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

ראו גם[עריכת קוד מקור | עריכה]

קישורים חיצוניים[עריכת קוד מקור | עריכה]

ויקישיתוף מדיה וקבצים בנושא מודל חישובי בוויקישיתוף