تجزیه قطعی تجزیهای است که در آن بتوان به صورت قطعی و در زمان چند جملهای تجزیه پذیر بودن یا نبودن یک عبارت توسط گرامر را تشخیص داد. این نوع رفتار همان رفتار مورد نیاز در کامپایلرهاست.این نوع تجزیه معمولاً براساس ماشین پشتهای قطعی است.
گرامر قطعی مستقل از متن [۱] [۲]
گرامرهای قطعی مستقل از متن در زمینه کامپایلر و بهطور کل هرجا که قرار است زبانی به زبان دیگر ترجمه شود کاربرد فراوان دارد.
یک گرامر را زمانی گرامر مستقل ازمتن قطعی می نامیم ، بهطوریکه تمام رشتههای تولید شده توسط این گرامر توسط یک ماشین پشتهای قطعی قابل تولید باشد و یک زبان مستقل از متن قطعی تولید کند. این نوع گرامرها خالی از هرنوع ابهام هستند.
زبان *L ⊆ Σ یک زبان مستقل از متن قطعی است اگر (L$ = L(M برای ماشین پشتهای قطعی M ، درحالی که $ یک علامت جدید میباشد که در Σ نیست.
یک ماشین پشتهای قطعی است زمانی که به ازای هر ساخت در آن ماشین حداکثر یک انتقال ممکن باشد.
- این مساله با ماشین تعیین پذیر حالت متناهی متفاوت است چرا که امکان دارد که هیچ گونه انتقالی ممکن نباشد و ماشین پشتهای در وسط ورودی گیر کند.
- مساله تشخیص این که یک ماشین پشتهای قطعی است یا نه مساله ساده و مشخصی نیست.در زیر بعضی از مواردی که در آن قطعیت ماشین پشتهای از بین میرود آورده شده است:
- ساختهای ((p, a, ϵ), (q, γ)) و (('p, ϵ, A), (q′, γ)) وجود داشته باشند: اگر در حالت p بوده و در حال خواندن a از ورودی باشیم و A در بالای پشته باشد آن گاه هر دو انتقال قابل انجام هستند.
- ساختهای ((p, a, A), (q, γ)) و (('p, a, AB), (q′, γ)) وجود داشته باشند: اگر در حالت p بوده و در حال خواندن a از ورودی باشیم و AB در بالای پشته باشد آن گاه هر دو انتقال قابل انجام هستند.
- ساختهای ((p, a, A), (q, γ))و (('p, ϵ, AB), (q′, γ)) وجود داشته باشد: اگر در حالت p بوده و در حال خواندن a از ورودی باشیم و AB در بالای پشته باشد آن گاه هر دو انتقال قابل انجام هستند.
و ... .
برای این که یک ماشین پشتهای قطعی باشد برای هرجفت از انتقالها باید حداقل یکی از موارد زیر بر قرار باشد:
- انتقالها ((pi, ai, βi), (qi, γi))، pi متفاوتی داشته باشند.
- انتفالها ai متفاوتی داشته باشند که هیچکدام از آنها ϵ نیستند.
- انتقالها βi متفاوتی داشته باشند که هیچکدام پیشوند دیگری هم نباشد.
گذری بر تجزیه در تاریخ
- در سال 1965 کنوث(knuth) تجزیه گر چپ به راست(LR parser) را توسعه داد که میتوانست با استفاده از پیشبینی در زمان قطعی هر گرامر قطعی مستقل از متنی را بازسازی کند.
- در سال 1969 دی رمر (DeRemer) تجزیه گرهای LALR را معرفی کرد که در واقع نسخهای ساده شده از LR بودند.این تجزیه گرهای به حافظه کمتری نسبت به LR نیاز داشتند اما ضعیف تر بودند.
تجزیه بالا به پایین و پایین به بالا [۱] [۳]
تجزیه بالا به پایین
ایده اصلی تجزیه بالا به پایین ساخت یک ماشین پشتهای از یک گرامرو پس از آن قطعی کردن آن ماشین پشتهای است. بعضی از راههای قطعی کردن ماشین پشتهای عبارت اند از:
- پیشبینی کردن یک علامت
- فاکتورگیری از چپ
- حذف بازگشت چپ
گرامرهایی که پیشبینی یک علامت برای آنها برای تجزیه بالا به پایین چپ به راست کفایت میکند گرامرهای (LL(1 می گویند.
تجزیه پایین به بالا
تجزیه پایین به بالا براساس کلاس (LR(K گرامرها به وجود آمدهاست."L" به معنای خواندن ورودی از چپ به راست است."R" به معنای این است که راستترین تجزیه انجام خواهد شد. در تجزیه پایین به بالا مانند تجزیه بالا به پایین ماشین پشتهای به وجود می آوریم با این تفاوت که در تجزیه پایین به بالا ماشین پشتهای به وجود آمده راستترین استخراج پایین به بالا از یک پایانه ورودی انجام می دهیم تا به علامت شروع S برسیم.
بیشتر بخوانید
- LL Parser
- تجزیه پایین به بالا
- تجزیه بالا به پایین
منابع