أوتومات الدفع السفلي

في علم الحاسوب، الأوتومات الدفع السفلي أو باختصار "PDA" هو نموذج حاسوبي بسيط يقوم على فكرة بنية البيانات المكدس (stack)، حيث أنه يستخدمه بأنه ذاكرة اضافية يُخزن فيها النتائج غير نهائية ليُعيد استخدامها لاحقا ضمن العمليات المُتاحة لهذا النموذج.[1][2][3] هنالك نوعان من أوتوماتات الدفع السفلي: أوتومات الدفع السفلي القطعي (DPA)، أوتومات الدفع السفلي غير القطعي (PDA). على خلاف النماذج الابسط أوتومات الدفع السفلي غير القطعي «اقوى» من قرينه القطعي، أي يوجد لغات التي يمكن تقريرها بواسطة PDA ولكن ليس بواسطة DPA . أوتومات الدفع السفلي عمليا هو أوتومات حالات محدودة مُزود بمكدس LIFO أي من يدخل اخرا يخرج أولا، أول من أنتج الPDA's هو Anthony Oettinger في عام 1963 وقد كان المُكَّدس مستخدماً منذ زمن طويل، إلا أن أبحاثه نَظَّمت دمجه في أوتومات منتهي.ولعل أحد أهم المبرهنات في هذا المجال هي: لكل PDA يمكن بناء قواعد حرة السياق تنتج نفس اللغة. أهمية هذا الأوتومات تتبين من حقيقة انه يُستخدم كثيرا في عملية التجزئة (parsing) وخاصة انه أسهل للبرمجة من القواعد حرة السياق وقد تبين انهما ذوي قوة مضارعة.

تعريف

عدل

أوتومات الدفع السفلي هو السباعية:   حيث يتحقق:

 
  1.   هي مجموعة منتهية من الحالات.
  2.   هي أبجدية المُدخل (أي من اية حروف يمكن أن تتركب سلسلة المُدخل)
  3.   هي أبجدية المُكدس (يجب أن تحوي حروفا غير تلك التي نستخدمها للمُدخل)
  4.   أي انها مجموعة جزئية منتهية ل-   ، وتُسمى علاقة الانتقال (transition relation). وكل   تُسمى أمر (أو نقلة) وهو يصف الانتقال من الحالة   للحالة   في حين أنَّ   هو الحرف التالي من المُدخل و-   هو الرمز الواقع في أعلى المُكدس. والتغيير يتحقق بقراءة الحرف   وإخراج   من المُكدس واحلال   مكانه في المُكدس.
  5. الحالة الابتدائية  
  6. رمز المُكدس الابتدائي  
  7.   مجموعة الحالات النهائية.

ملاحظات :

  1. يمكن اعتبار   دالة من المجموعة   لمجموعة جزئية ل-   حينها يمكننا ان نكتب:   .
  2. نرمز ب-   مجموعة كل السلاسل (أو الكلمات) التي تتركب من المجموعة   وكذا الأمر ل-   .

صورة فورية

عدل

صورة فورية (configuration) لأوتومات الدفع السفلي   مُكونة من حروف المُدخل التي لم يتم قراءتها بعد والحالة الحالية والمحتوى الحالي للمُكَّدس أي انه مجموعة الصور الفورية هي مجموعة جزئية ل-  .

علاقة الخطوة

عدل

دالة الانتقال   يمكننا بواسطتها تعريف علاقة الخطوة،   ، والعلاقة مُعرفة على مجموعة الصور الفورية:

 

من تبعيات هذا التعريف انَّ الأوتومات لا يمكنه المتابعة إذا ما فرغ المُكَدس لانه بكل خطوة عليه إخراج حرف أو رمز من المكدس.

حساب

عدل

حساب أوتومات ذو مكدس هو متتالية خطوات متلاحقة، وعلاقة الحساب هي المنغلق الانعكاسي والمتعدي، ، لعلاقة الخطوة.

لغة الأوتومات

عدل

PDA يقبل المدخل إذا حسابه على المُدخل بداية من الحالة الابتدائية مع وجود رمز المُكدس الابتدائي وتمام قراءة المُدخل واحد الامرين التاليين يتحقق:

  1. ينتهي الأمر بحالةٍ نهائية.
  2. أو ينتهي الأمر بمُكدس فارغ.

بشكل عام هاتان اللغتان، لأوتومات مُعين، ليستا بالضرورة متساويان. لاحظ انه في الحالة الثانية لا يهم أية حالة وقفنا عليها (سواء كانت نهائية أو لا).

بناء على ما تقدم سالفا نُعرف اللغتين بالشكل التالي:

فليكن   أوتومات دفع سفلي، نعرف اللغتين التاليتين:

  1. لغة الحالة النهائية للأوتومات   هي:  
  2. لغة المُكدس الفارغ للاتومات   هي:  

بشكل عام لا يتحقق التساوي بين اللغتين لكل أوتومات، ولكن يمكن بناء أوتومات اخر بحيث يتحقق التساوي، أي انه يتحقق التالي:

فليكن   أوتومات دفع سفلي حينها يمكننا بناء أوتومات   بحيث يتحقق:   . وكذا العكس.

لغات حرة السياق

عدل

كل قواعد حر السياق الذي ينتج لغة يمكن تحويله بسهولة إلى أوتومات دفع سفلي يتعرف (recognize) على اللغة عينها. فليكن   نعرف الأوتومات التالي ذي الحالة الواحدة:  بحيث أنَّ   قوانينها كالتالي:

  •   لكل   . «توسيع»
  •   لكل   . «تطابق»

حسابات   تقابل الاشتقاقات الأكثر يسارا (leftmost derivations)   ل- G ، رسميا: فليكن   وليكن   إذا   حينها يتحقق:   . كما أن العكس يتحقق لكل   .

حينما نأخذ   نجد أن:   فقط إذا   لكل   ، وهذا يعني أنَّ   ، هذا التوافق يُظهر أنَّ الأوتومات ذي الحالة الواحدة (حين الاخذ بالاعتبار لغة المُكدس الفارغ كما سبق تعريفها) مكافئ للقواعد حرة السياق. التكافؤ لا يقف عند هذا الحد إذ أنَّ التكافؤ الكامل بين أوتومات الدفع السفلي وبين القواعد حرة السياق هو تكافؤ شامل وهذه النتيجة توصل إليها كل من نعوم تشومسكي ومارسيل-بوول شوتزنبرجر، وإيفي. والمبرهنة تنص على أن كل لغة تُقبل بواسطة اتومات دفع سفلي سواء اكان ذلك بفراغ المُكدس ام بالوصول إلى حالة نهائية من مجموعة الحالات النهائية، فقط إذا كانت هذه اللغة هي لغة حرة السياق.

صفات انغلاق

عدل

فلتكن A , B لغتين اللتين تُمَيَّزَان (recognized) بواسطة اوتماتي الدفع السفلي   على التوالي.

1. الاتحاد: اللغة   يمكن أن تُمَيَّز بواسطة أوتومات دفع سفلي   . بحيث أن   مركب من الأوتوماتين   مع إضافة حالة جديدة وفي دالة العبور نضيف لهذه الحالة عبور بواسطة   ، كما هو مبين في الصورة.

 

2. التسلسل: اللغة   يمكن أن تُمَيَّز بواسطة أوتومات دفع سفلي   . بحيث أن   مركب من الأوتوماتين   ، وفي دالة العبور نضيف عبور بواسطة   من مجموعة الحالات النهائية التي في A لبداية B .

3. فلتكن R لغة منظمة (regular language) حينها اللغة   يمكن تميزها بواسطة أوتومات دفع سفلي.

4. نجمة كليين: اللغة   يمكن أن تُمَيَّز بواسطة أوتومات دفع سفلي   . هذا يُبرهن بواسطة القواعد حرة السياق.

5. مورفزم عكسي: فليكن   مورفزم حينها اللغة:   يمكن أيضا ان تُميز بواسطة أوتومات دفع سفلي.

أوتومات دفع سفلي قطعي

عدل

من وجهة نظر عملية أوتومات الدفع السفلي بصورته هذه لا يُعتبر مفيدا لتمييز اللغات أو حتى للتحليل النحوي (parsing)، وذلك لانه ليس قطعيا أي انه في كل خطوة عليه ان يتحزر الصواب ويسلك طريقه. وخلافا لاتومات الحالات المنتهية فان أوتومات الدفع السفلي القطعي لا ينتج كل لغة حرة السياق أي انه ليس موديل لهذه اللغات كما هو الحال مع القواعد حرة السياق وكذا أوتومات الدفع السفلي غير القطعي.

تعريف

عدل

أوتومات الدفع السفلي   قطعي إذا تحقق التالي:

  • لكل   ، كل   وايضا كل   ,   لا تحوي التعليم (instruction)   وكذلك التعليم  
  • لكل   ، ولكل   ولكل   يوجد في   على الأكثر تعليم واحد   .

ملاحظة:

  • لاحظ انه مسموح تواجد التعليمين   في   في حين أن   وكذلك   أي أن الاختيار يكون حسب رأس المكدس العلوي وخلاف هذا الصورتين الفوريتين متساويتين.

لغات الأوتومات القطعي

عدل

كما هو الحال مع الأوتومات الدفع السفلي الغير قطعي عندنا طريقتين لتعريف لغة الأوتومات: اما عن طريق الوصول إلى حالة نهائية مع انتهاء المُدخل أو بفراغ المُكدس مع انتهاء المُدخل. اما اللغات من الطريقة الثانية فهي لغات حرة البدايات (prefix free) أي: انَّ هذه اللغات لا تحوي الكلمة أو ايا من بدايتها في نفس الوقت. ولهذا السبب فإن هذه العائلة لا يمكن مقارنتها بعائلة اللغات المنتظمة (regular).

وكما كان الحال مع اللغات حرة السياق وعلاقتها بأوتومات الدفع السفلي يمكن أيضا هنا في هذه الحالة قول نفس الشيء بالنسبة لعلاقة اللغات حرة البدايات مع الأوتومات القطعي. أي انه: لغة تُقبل بواسطة أوتومات دفع سفلي قطعي عن طريق فراغ المُكدس فقط إذا هي حرة السياق ويمكن أن تُقبل عن طريق أوتومات دفع سفلي قطعي (ربما اخر) عن طريق الوصول لحالة نهائية (وهذا يعني انه ليس كل لغة تُقبل عن الحالة النهائية يمكن أيضا أن تقبل عن طريق فراغ المُكدس لذا فالشرط أن اللغة حرة البدايات ضروري).

قواعد حرة السياق قطعية

عدل

وهي مجموعة اللغات التي تُقبل بواسطة أوتومات دفع سفلي قطعي عن طريق الوصول لحالة نهائية. ولها يُرمز DCF . وهذه المجموعة تحوي مجموعة اللغات النظامية (regular languages) على أنها مجموعة جزئية فعلية أي   ، وهذا لان الأوتومات ذو الحالات النهائية القطعي يمكن النظر إليه على أنه أوتومات دفع سفلي قطعي يتجاهل المُكدس، وكذلك يمكن بناء أوتومات دفع سفلي قطعي بسهولة للغة غير النظامية   . مجموعة اللغات حرة السياق (يُرمز لها CF) تحوي هذه المجموعة فعليا أي:   .

انظر أيضا

عدل

مصادر

عدل
  1. ^ "معلومات عن أوتومات الدفع السفلي على موقع psh.techlib.cz". psh.techlib.cz. مؤرشف من الأصل في 2021-03-01.
  2. ^ "معلومات عن أوتومات الدفع السفلي على موقع xlinux.nist.gov". xlinux.nist.gov. مؤرشف من الأصل في 2020-10-28.
  3. ^ "معلومات عن أوتومات الدفع السفلي على موقع omegawiki.org". omegawiki.org. مؤرشف من الأصل في 2020-10-28.