דקדוק חופשי-הקשר

מתוך המכלול, האנציקלופדיה היהודית
(הופנה מהדף דקדוק חסר הקשר)
קפיצה לניווט קפיצה לחיפוש

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

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

הגדרה

דקדוק חסר הקשר מוגדר על ידי הרביעייה , כאשר:

  1. - קבוצת משתנים
  2. - קבוצת אותיות סופיות (טרמינלים). קבוצה זו מהווה את האלפבית של השפה הנוצרת.
  3. - קבוצת כללי יצירה. כל כלל הופך משתנה למחרוזת של אותיות ומשתנים
  4. - סימן ההתחלה. משתנה מתוך .

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

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

צורה נורמלית

Postscript-viewer-blue.svg ערך מורחב – הצורה הנורמלית של חומסקי

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

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

דו-משמעות

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

ראו גם

לקריאה נוספת

  • John E. Hopcroft, Rajeev Motwani, and Jeffrey D. Ullman. Introduction to Automata Theory, Languages, and Computation, 3rd Edition, Addison-Wesley, 2006. מסת"ב 0-321-45536-3.
  • John E. Hopcroft and Jeffrey D. Ullman, Introduction to Automata Theory, Languages and Computation, Addison-Wesley Publishing, Reading Massachusetts, 1979. מסת"ב 0-201-02988-X.

קישורים חיצוניים

הערות שוליים

  1. ^ דוגמה לשפה דו-משמעית בצורה אינהרנטית היא השפה .
Logo hamichlol 3.png
הערך באדיבות ויקיפדיה העברית, קרדיט,
רשימת התורמים
רישיון cc-by-sa 3.0