קואינדוקציה

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

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

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

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

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

תיאור

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

הקדמות

תהי קבוצה ותהי פונקציה מונוטונית , כלומר:

אלא אם צוין אחרת, ההנחה היא כי מונוטונית.

X נקראת F-סגורה אם
X נקראת F-עקבית אם
X נקראת נקודת שבת אם

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

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

הגדרה

עקרון האינדוקציה : אם היא F-סגורה, אז
עקרון הקואינדוקציה : אם היא F-עקבית, אז

דיון

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

דוגמאות

הגדרת קבוצה של טיפוסי נתונים

הבה נתבונן בדקדוק הבא של טיפוסי נתונים:

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

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

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

כל טיפוסי הנתונים ב- הם סופיים

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

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

הטיפוס שייך ל-

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

הקבוצה הזו מתבררת כ-F-עקבית, ולכן . קביעה זו תלויה בקביעה החשודה ש-

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

טיפוסי נתונים קואינדוקטיביים בשפות תכנות

נתבונן בהגדרה הבאה של זרם:[דרוש מקור]

data Stream a = S a (Stream a)

-- Stream "destructors"
head (S a astream) = a
tail (S a astream) = astream

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

קשר עם קואלגברות-F[2]

ראו תורת הקטגוריות

נבחן את האנדופונקטור בקטגוריית הקבוצות:

לקואלגברת-F הסופית מיוחס המורפיזם הבא:

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

כך ש-

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

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

זרם כקואלגברה סופית

נראה כי

Stream A

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

out astream = (head astream, tail astream)
out' (a, astream) = S a astream

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

קשר עם אינדוקציה מתמטית

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

כעת נבחן את הפונקציה :

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

כלומר,

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

הערות שוליים

  1. ^ Benjamin Pierce. "Types and Programming Languages". The MIT Press.
  2. ^ Ralf Hinze (2012). "Generic Programming with Adjunctions". Generic and Indexed Programming. Lecture Notes in Computer Science. Vol. 7470. Springer. pp. 47–129. doi:10.1007/978-3-642-32202-0_2. ISBN 978-3-642-32201-3.

לקריאה נוספת

ספרי לימוד
  • Davide Sangiorgi (אנ') (2012). Introduction to Bisimulation and Coinduction. Cambridge University Press.
  • Davide Sangiorgi (אנ') and Jan Rutten (אנ') (2011). Advanced Topics in Bisimulation and Coinduction. Cambridge University Press.
כתבי מבוא
הערך באדיבות ויקיפדיה העברית, קרדיט,
רשימת התורמים
רישיון cc-by-sa 3.0

קואינדוקציה37641347Q4227156