شبكة بحوث وتقارير ومعلومات
تجربة هيدر2
اليوم: السبت 27 ابريل 2024 , الساعة: 2:19 م


اخر المشاهدات
الأكثر قراءة
اعلانات

مرحبا بكم في شبكة بحوث وتقارير ومعلومات


عزيزي زائر شبكة بحوث وتقارير ومعلومات.. تم إعداد وإختيار هذا الموضوع [ تعرٌف على ] أوتومات الدفع السفلي # اخر تحديث اليوم 2024-04-27 فإن كان لديك ملاحظة او توجيه يمكنك مراسلتنا من خلال الخيارات الموجودة بالموضوع.. وكذلك يمكنك زيارة القسم , وهنا نبذه عنها وتصفح المواضيع المتنوعه... آخر تحديث للمعلومات بتاريخ اليوم 24/03/2024

اعلانات

[ تعرٌف على ] أوتومات الدفع السفلي # اخر تحديث اليوم 2024-04-27

آخر تحديث منذ 1 شهر و 4 يوم
2 مشاهدة

تم النشر اليوم 2024-04-27 | أوتومات الدفع السفلي

تعريف

أوتومات الدفع السفلي هو السباعية: A
=
(
Q
,
Δ
,
Γ
,
δ
, q i
n
, A i
n
,
F
)
{\displaystyle {\mathcal {A}}=(Q,\Delta ,\Gamma ,\delta ,q_{in},A_{in},F)} حيث يتحقق:

Q
{\displaystyle Q} هي مجموعة منتهية من الحالات.
Δ
\Delta هي أبجدية المُدخل (أي من اية حروف يمكن أن تتركب سلسلة المُدخل)
Γ
{\displaystyle \Gamma } هي أبجدية المُكدس (يجب أن تحوي حروفا غير تلك التي نستخدمها للمُدخل)
δ

Q
×
(
Δ

{
λ
}
)
×
Γ
×
Q
× Γ ∗
{\displaystyle \delta \subseteq Q\times (\Delta \cup \{\lambda \})\times \Gamma \times Q\times \Gamma ^{*}} أي انها مجموعة جزئية منتهية ل- Q
×
(
Δ

{
λ
}
)
×
Γ
×
Q
× Γ ∗
{\displaystyle Q\times (\Delta \cup \{\lambda \})\times \Gamma \times Q\times \Gamma ^{*}} ، وتُسمى علاقة الانتقال (transition relation). وكل (
p
,
a
,
A
,
q
,
α
)

δ
{\displaystyle (p,a,A,q,\alpha )\in \delta } تُسمى أمر (أو نقلة) وهو يصف الانتقال من الحالة p
{\displaystyle p} للحالة q
{\displaystyle q} في حين أنَّ a
a هو الحرف التالي من المُدخل و- A
{\displaystyle A} هو الرمز الواقع في أعلى المُكدس. والتغيير يتحقق بقراءة الحرف a
a وإخراج A
{\displaystyle A} من المُكدس واحلال α
{\displaystyle \alpha } مكانه في المُكدس.
الحالة الابتدائية
q i
n

Q
{\displaystyle q_{in}\in Q}
رمز المُكدس الابتدائي
A i
n

Γ
{\displaystyle A_{in}\in \Gamma }
F

Q
{\displaystyle F\subseteq Q} مجموعة الحالات النهائية.
ملاحظات: يمكن اعتبار δ
{\displaystyle \delta } دالة من المجموعة Q
×
(
Δ

{
λ
}
)
×
Γ
{\displaystyle Q\times (\Delta \cup \{\lambda \})\times \Gamma } لمجموعة جزئية ل- Q
× Γ ∗
{\displaystyle Q\times \Gamma ^{*}} حينها يمكننا ان نكتب: (
q
,
α
)

δ
(
p
,
a
,
A
)
{\displaystyle (q,\alpha )\in \delta (p,a,A)} .
نرمز ب-
Γ ∗
{\displaystyle \Gamma ^{*}} مجموعة كل السلاسل (أو الكلمات) التي تتركب من المجموعة Γ
{\displaystyle \Gamma } وكذا الأمر ل-
Δ ∗
{\displaystyle \Delta ^{*}} .
صورة فورية
صورة فورية (configuration) لأوتومات الدفع السفلي A
{\displaystyle {\mathcal {A}}} مُكونة من حروف المُدخل التي لم يتم قراءتها بعد والحالة الحالية والمحتوى الحالي للمُكَّدس أي انه مجموعة الصور الفورية هي مجموعة جزئية ل-
Δ ∗
×
Q
×
Γ
{\displaystyle \Delta ^{*}\times Q\times \Gamma } . علاقة الخطوة
دالة الانتقال δ
\delta يمكننا بواسطتها تعريف علاقة الخطوة،

A {\displaystyle \vdash _{\mathcal {A}}} ، والعلاقة مُعرفة على مجموعة الصور الفورية: (
a
x
,
p
,
A
γ
) ⊢
A (
x
,
q
,
α
γ
) ⟺ (
p
,
a
,
A
,
q
,
α
)

δ
,
x
∈ Δ ∗
,
γ
∈ Γ ∗
{\displaystyle (ax,p,A\gamma )\vdash _{\mathcal {A}}(x,q,\alpha \gamma )\iff (p,a,A,q,\alpha )\in \delta ,x\in \Delta ^{*},\gamma \in \Gamma ^{*}} من تبعيات هذا التعريف انَّ الأوتومات لا يمكنه المتابعة إذا ما فرغ المُكَدس لانه بكل خطوة عليه إخراج حرف أو رمز من المكدس. حساب
حساب أوتومات ذو مكدس هو متتالية خطوات متلاحقة، وعلاقة الحساب هي المنغلق الانعكاسي والمتعدي،

A ∗
{\displaystyle \vdash _{\mathcal {A}}^{*}} ، لعلاقة الخطوة.

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


من وجهة نظر عملية أوتومات الدفع السفلي بصورته هذه لا يُعتبر مفيدا لتمييز اللغات أو حتى للتحليل النحوي (parsing)، وذلك لانه ليس قطعيا أي انه في كل خطوة عليه ان يتحزر الصواب ويسلك طريقه. وخلافا لاتومات الحالات المنتهية فان أوتومات الدفع السفلي القطعي لا ينتج كل لغة حرة السياق أي انه ليس موديل لهذه اللغات كما هو الحال مع القواعد حرة السياق وكذا أوتومات الدفع السفلي غير القطعي. تعريف
أوتومات الدفع السفلي A
=
(
Q
,
Δ
,
Γ
,
δ
, q i
n
, A i
n
,
F
)
{\displaystyle {\mathcal {A}}=(Q,\Delta ,\Gamma ,\delta ,q_{in},A_{in},F)} قطعي إذا تحقق التالي: لكل p

Q
{\displaystyle p\in Q} ، كل a

Δ
{\displaystyle a\in \Delta } وايضا كل A

Γ
{\displaystyle A\in \Gamma } , δ
\delta لا تحوي التعليم (instruction) (
p
,
λ
,
A
,
q
,
α
)
{\displaystyle (p,\lambda ,A,q,\alpha )} وكذلك التعليم (
p
,
a
,
A
, q
′ , α
′ )
{\displaystyle (p,a,A,q',\alpha ')}
لكل p

Q
{\displaystyle p\in Q} ، ولكل a

Δ

{
λ
}
{\displaystyle a\in \Delta \cup \{\lambda \}} ولكل A

Γ
{\displaystyle A\in \Gamma } يوجد في δ
\delta على الأكثر تعليم واحد (
p
,
a
,
A
,
q
,
α
)
{\displaystyle (p,a,A,q,\alpha )} .
ملاحظة: لاحظ انه مسموح تواجد التعليمين (
p
,
λ
,
A
,
q
,
α
)

,

(
p
,
a
, A
′ , q
′ , α
′ )
{\displaystyle (p,\lambda ,A,q,\alpha )\ ,\ (p,a,A',q',\alpha ')} في δ
\delta في حين أن a

λ
{\displaystyle a\neq \lambda } وكذلك A
≠ A
′ {\displaystyle A\neq A'} أي أن الاختيار يكون حسب رأس المكدس العلوي وخلاف هذا الصورتين الفوريتين متساويتين.
لغات الأوتومات القطعي
كما هو الحال مع الأوتومات الدفع السفلي الغير قطعي عندنا طريقتين لتعريف لغة الأوتومات: اما عن طريق الوصول إلى حالة نهائية مع انتهاء المُدخل أو بفراغ المُكدس مع انتهاء المُدخل. اما اللغات من الطريقة الثانية فهي لغات حرة البدايات (prefix free) أي: انَّ هذه اللغات لا تحوي الكلمة أو ايا من بدايتها في نفس الوقت. ولهذا السبب فإن هذه العائلة لا يمكن مقارنتها بعائلة اللغات المنتظمة (regular). وكما كان الحال مع اللغات حرة السياق وعلاقتها بأوتومات الدفع السفلي يمكن أيضا هنا في هذه الحالة قول نفس الشيء بالنسبة لعلاقة اللغات حرة البدايات مع الأوتومات القطعي. أي انه: لغة تُقبل بواسطة أوتومات دفع سفلي قطعي عن طريق فراغ المُكدس فقط إذا هي حرة السياق ويمكن أن تُقبل عن طريق أوتومات دفع سفلي قطعي (ربما اخر) عن طريق الوصول لحالة نهائية (وهذا يعني انه ليس كل لغة تُقبل عن الحالة النهائية يمكن أيضا أن تقبل عن طريق فراغ المُكدس لذا فالشرط أن اللغة حرة البدايات ضروري). قواعد حرة السياق قطعية
وهي مجموعة اللغات التي تُقبل بواسطة أوتومات دفع سفلي قطعي عن طريق الوصول لحالة نهائية. ولها يُرمز DCF . وهذه المجموعة تحوي مجموعة اللغات النظامية (regular languages) على أنها مجموعة جزئية فعلية أي R
E
G

D
C
F
{\displaystyle REG\subset DCF} ، وهذا لان الأوتومات ذو الحالات النهائية القطعي يمكن النظر إليه على أنه أوتومات دفع سفلي قطعي يتجاهل المُكدس، وكذلك يمكن بناء أوتومات دفع سفلي قطعي بسهولة للغة غير النظامية { a n
b a n | n
>
1
}
{\displaystyle \{a^{n}ba^{n}|n>1\}} . مجموعة اللغات حرة السياق (يُرمز لها CF) تحوي هذه المجموعة فعليا أي: D
C
F

C
F
{\displaystyle DCF\subset CF} .

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


PDA يقبل المدخل إذا حسابه على المُدخل بداية من الحالة الابتدائية مع وجود رمز المُكدس الابتدائي وتمام قراءة المُدخل واحد الامرين التاليين يتحقق: ينتهي الأمر بحالةٍ نهائية.
أو ينتهي الأمر بمُكدس فارغ.
بشكل عام هاتان اللغتان، لأوتومات مُعين، ليستا بالضرورة متساويان. لاحظ انه في الحالة الثانية لا يهم أية حالة وقفنا عليها (سواء كانت نهائية أو لا). بناء على ما تقدم سالفا نُعرف اللغتين بالشكل التالي: فليكن A
{\displaystyle {\mathcal {A}}} أوتومات دفع سفلي، نعرف اللغتين التاليتين: لغة الحالة النهائية للأوتومات A
{\displaystyle {\mathcal {A}}} هي: L
(
A
)
=
{
x
∈ Δ ∗ | (
x
, q i
n
, A i
n
) ⊢
A ∗
(
λ
,
q
,
γ
)

for some

q

F
,
γ
∈ Γ ∗
}
{\displaystyle L({\mathcal {A}})=\{x\in \Delta ^{*}|(x,q_{in},A_{in})\vdash _{\mathcal {A}}^{*}(\lambda ,q,\gamma )\ {\mbox{for some}}\ q\in F,\gamma \in \Gamma ^{*}\}}
لغة المُكدس الفارغ للاتومات A
{\displaystyle {\mathcal {A}}} هي: N
(
A
)
=
{
x
∈ Δ ∗ | (
x
, q i
n
, A i
n
) ⊢
A ∗
(
λ
,
q
,
λ
)

for some

q

Q
}
{\displaystyle N({\mathcal {A}})=\{x\in \Delta ^{*}|(x,q_{in},A_{in})\vdash _{\mathcal {A}}^{*}(\lambda ,q,\lambda )\ {\mbox{for some}}\ q\in Q\}}
بشكل عام لا يتحقق التساوي بين اللغتين لكل أوتومات، ولكن يمكن بناء أوتومات اخر بحيث يتحقق التساوي، أي انه يتحقق التالي: فليكن A
{\displaystyle {\mathcal {A}}} أوتومات دفع سفلي حينها يمكننا بناء أوتومات
A
′ {\displaystyle {\mathcal {A}}'} بحيث يتحقق: N
(
A
)
=
L
( A
′ )
{\displaystyle N({\mathcal {A}})=L({\mathcal {A}}')} . وكذا العكس.

صفات انغلاق


فلتكن A , B لغتين اللتين تُمَيَّزَان (recognized) بواسطة اوتماتي الدفع السفلي
M A
, M B
{\displaystyle M_{A},M_{B}} على التوالي. 1. الاتحاد: اللغة A

B
{\displaystyle A\cup B} يمكن أن تُمَيَّز بواسطة أوتومات دفع سفلي
M A

B
{\displaystyle M_{A\cup B}} . بحيث أن
M A

B
{\displaystyle M_{A\cup B}} مركب من الأوتوماتين
M A
, M B
{\displaystyle M_{A},M_{B}} مع إضافة حالة جديدة وفي دالة العبور نضيف لهذه الحالة عبور بواسطة λ
{\displaystyle \lambda } ، كما هو مبين في الصورة.
2. التسلسل: اللغة A

B
{\displaystyle A\circ B} يمكن أن تُمَيَّز بواسطة أوتومات دفع سفلي
M A

B
{\displaystyle M_{A\circ B}} . بحيث أن
M A

B
{\displaystyle M_{A\circ B}} مركب من الأوتوماتين
M A
, M B
{\displaystyle M_{A},M_{B}} ، وفي دالة العبور نضيف عبور بواسطة λ
{\displaystyle \lambda } من مجموعة الحالات النهائية التي في A لبداية B . 3. فلتكن R لغة منظمة (regular language) حينها اللغة A

R
{\displaystyle A\cap R} يمكن تميزها بواسطة أوتومات دفع سفلي. 4. نجمة كليين: اللغة
A ∗
{\displaystyle A^{*}} يمكن أن تُمَيَّز بواسطة أوتومات دفع سفلي
M
A ∗
{\displaystyle M_{A^{*}}} . هذا يُبرهن بواسطة القواعد حرة السياق. 5. مورفزم عكسي: فليكن h
:
Σ
→ Δ ∗
{\displaystyle h:\Sigma \to \Delta ^{*}} مورفزم حينها اللغة:
h −
1
(
A
)
⊆ Σ ∗
{\displaystyle h^{-1}(A)\subseteq \Sigma ^{*}} يمكن أيضا ان تُميز بواسطة أوتومات دفع سفلي.

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


كل قواعد حر السياق الذي ينتج لغة يمكن تحويله بسهولة إلى أوتومات دفع سفلي يتعرف (recognize) على اللغة عينها. فليكن G
=
(
N
,
T
,
S
,
P
)
{\displaystyle G=(N,T,S,P)} نعرف الأوتومات التالي ذي الحالة الواحدة: A
=
( q ,
T
,
N

T
,
δ
,
q
,
S
,

)
{\displaystyle {\mathcal {A}}=({q},T,N\cup T,\delta ,q,S,\emptyset )} بحيث أنَّ δ
\delta قوانينها كالتالي: (
q
,
λ
,
A
,
q
,
α
)
{\displaystyle (q,\lambda ,A,q,\alpha )} لكل A

α

P
{\displaystyle A\to \alpha \in P} . «توسيع»
(
q
,
a
,
a
,
q
,
λ
)
{\displaystyle (q,a,a,q,\lambda )} لكل a

T
{\displaystyle a\in T} . «تطابق»
حسابات A
{\displaystyle {\mathcal {A}}} تقابل الاشتقاقات الأكثر يسارا (leftmost derivations)
⇒ G
,
l

{\displaystyle \Rightarrow _{G,l}^{*}} ل- G ، رسميا: فليكن x
∈ T ∗
{\displaystyle x\in T^{*}} وليكن α

(
N

T ) ∗
{\displaystyle \alpha \in (N\cup T)^{*}} إذا (
x
,
q
,
S
) ⊢
A ∗
(
λ
,
q
,
α
)
{\displaystyle (x,q,S)\vdash _{\mathcal {A}}^{*}(\lambda ,q,\alpha )} حينها يتحقق: S ⇒ G
,
l

x
α
{\displaystyle S\Rightarrow _{G,l}^{*}x\alpha } . كما أن العكس يتحقق لكل α

N
(
N

T ) ∗

{
λ
}
{\displaystyle \alpha \in N(N\cup T)^{*}\cup \{\lambda \}} . حينما نأخذ α
=
λ
{\displaystyle \alpha =\lambda } نجد أن: S ⇒ G
,
l

x
{\displaystyle S\Rightarrow _{G,l}^{*}x} فقط إذا (
x
,
q
,
S
) ⊢
A ∗
(
λ
,
q
,
λ
{\displaystyle (x,q,S)\vdash _{\mathcal {A}}^{*}(\lambda ,q,\lambda } لكل x
∈ T ∗
{\displaystyle x\in T^{*}} ، وهذا يعني أنَّ L
(
G
)
=
N
(
A
)
{\displaystyle L(G)=N({\mathcal {A}})} ، هذا التوافق يُظهر أنَّ الأوتومات ذي الحالة الواحدة (حين الاخذ بالاعتبار لغة المُكدس الفارغ كما سبق تعريفها) مكافئ
للقواعد
حرة
السياق. التكافؤ لا يقف عند هذا الحد إذ أنَّ التكافؤ الكامل بين أوتومات الدفع السفلي وبين القواعد حرة السياق هو تكافؤ شامل وهذه النتيجة توصل إليها كل من نعوم تشومسكي ومارسيل-بوول شوتزنبرجر، وإيفي. والمبرهنة تنص على أن كل لغة تُقبل بواسطة اتومات دفع سفلي سواء اكان ذلك بفراغ المُكدس ام بالوصول إلى حالة نهائية من مجموعة الحالات النهائية، فقط إذا كانت هذه اللغة هي لغة حرة السياق.

شرح مبسط


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

 
التعليقات

لم يعلق احد حتى الآن .. كن اول من يعلق بالضغط هنا

أقسام شبكة بحوث وتقارير ومعلومات عملت لخدمة الزائر ليسهل عليه تصفح الموقع بسلاسة وأخذ المعلومات تصفح هذا الموضوع [ تعرٌف على ] أوتومات الدفع السفلي # اخر تحديث اليوم 2024-04-27 ويمكنك مراسلتنا في حال الملاحظات او التعديل او الإضافة او طلب حذف الموضوع ...آخر تعديل اليوم 24/03/2024


اعلانات العرب الآن