Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
ТЕОРІЯ ЦИФРОВИХ АВТОМАТІВ ТА ФОРМАЛЬНИХ МОВ..doc
Скачиваний:
1
Добавлен:
01.05.2025
Размер:
4.72 Mб
Скачать

11.2. Виключення ліворекурсивних правил

Ряд граматик потребують виключення ліворекурсивних та ланцюгових правил.

Правило вигляду A A, де A Va, та (Vт Va), називається праворекурсивним, а правило вигляду A A ліворекурсивним.

Для кожної КВ-граматики Г, що містить ліворекурсивні правила, можна побудувати еквівалентну граматику Г′, що не містить ліворекурсивних правил.

Щоб показати техніку перетворення, розглянемо приклад.

Приклад. Маємо граматику

Г11.3: R = {E E + T | T (1)

T T *F | F (2)

F (E ) | a}. (3)

Правила E E + T | T перетворимо в правила E T | TE' і E' +T | +TE, а правила T T * F | F перетворимо в правила T F | FT' і T' F | * FT'.

У результаті одержимо граматику Г, що має схему:

R' = { E T (1) T FT' (6)

E TE' (2) T' *F (7)

E' + T (3) T' * FT' (8)

E' + TE' (4) F a (9)

T F (5) F (E)}. (10)

11.3. Виключення ланцюгових правил

Правило граматики вигляду A B, де A, B Va, називається ланцюговим. Для КВ-граматики Г, яка містить ланцюгові правила, можна побудувати еквівалентну їй граматику Г′, яка не містить ланцюгових правил.

Ідея доведення полягає в наступному. Якщо схема граматики має вигляд

R = {..., A B, ..., B C, ..., C aX},

то така граматика еквівалентна граматиці зі схемою

R' = {..., A aX, ...},

оскільки виведення у граматиці зі схемою R ланцюжка aX

A B C 

може бути отримано у граматиці зі схемою R' за допомогою правила A aX.

11.4. Магазинні автомати

КВ-граматика визначає структуру ланцюжків і дозволяє будувати ланцюжки визначеної мови. Магазинні автомати (МА) дозволяють розв’язувати для контекстно-вільних мов задачу розпізнавання, яка полягає в тому, що за заданим ланцюжком необхідно визначити, чи належить він заданій мові. У роботах, пов'язаних з формальними мовами і граматиками, використовується модель магазинного автомата (рис 11.1), що складається з вхідної стрічки, управляючого пристрою і допоміжної стрічки, названої магазином або стеком. Вхідна стрічка розділяється на клітини (позиції), у кожній з яких може бути записаний символ вхідного алфавіту. При цьому передбачається, що у вільних клітинах вхідної стрічки розташовані порожні символи . Допоміжна стрічка також розділена на клітини, у яких можуть розташовуватися символи магазинного алфавіту. Початок допоміжної стрічки називається дном магазина та позначається – hо. Зв'язок пристрою керування зі стрічками здійснюється двома головками, що можуть переміщатися уздовж стрічок.

читаюча

головка

управляючий пристрій

читаюча/записуюча

головка

допоміжна стрічка

(магазин)

вершина

магазина

вхідна стрічка

дно

Рисунок 11.1 – Магазинний автомат

Головка вхідної стрічки може переміщатися тільки в один бік – вправо чи залишатися на місці. Вона може виконувати тільки операцію читання. Головка допоміжної стрічки здатна виконувати як читання, так і записування, але ці операції пов'язані з переміщенням головки певним чином:

- при записуванні головка попередньо зрушується на одну позицію вгору, а потім символ заноситься на стрічку;

- при читанні символ, що знаходиться під головкою, зчитується зі стрічки, а потім головка зрушується на одну позицію вниз, так що головка завжди встановлена напроти останнього записаного символу. Позицію, що знаходиться в розглянутий момент часу під головкою, називають вершиною магазина.

Магазинний автомат М визначається такою сукупністю семи об'єктів:

M = {P, S, sо, f, F, H, hо}, де P вхідний алфавіт; S – алфавіт станів; sо початковий стан, sо S; F множина кінцевих станів, F є підмножиною S; H алфавіт магазинних символів, які записуються на допоміжну стрічку; hо маркер дна, він завжди записується на дно магазина, hо H; f функція переходів.

Робота МА зводиться до зміни конфігурацій. Конфігурацією автомата називають трійку об'єктів (s, , ), де s – поточний стан автомата;  – вхідний ланцюжок, самий лівий символ a якого знаходиться під головкою, – магазинний ланцюжок, самий верхній символ якого hH. Якщо a = , то вважається, що вхідний ланцюжок прочитаний, якщо $ – то магазин порожній.

Робота автомата може бути подана як зміна конфігурацій. Один такт роботи автомата полягає у визначенні нової конфігурації за заданою. Це записується так:

(s, a, h) |-- (s', , ).

При цьому передбачається, що автомат читає символ a, який знаходиться під головкою, і символ h, що знаходиться у вершині магазина, визначає новий стан s' і записує ланцюжок у магазин замість символу h.

Якщо = $, то верхній символ виявляється вилученим з магазина. Така зміна конфігурацій можлива, якщо функція f(s, a, h) визначена і їй належить значення (s', ). Описаний такт роботи виконується з переміщенням головки. Для опису роботи автомата також буде потрібен інший вид такту, що припускає зміну стану магазина без переміщення вхідної головки. Якщо f 0(s, , h) визначена і їй належить значення (s', ), то зміна конфігурацій визначається так:

(s, a, h) |-- (s', a, ).

У загальному вигляді дії, що задаються функцією переходів і виконуються автоматом, демонструє така форма запису:

f(s, <вхідний символ>, <магазинний символ>) = (s1, < ланцюжок, що заноситься до магазина>).

При цьому варто мати на увазі, що при виконанні такту спочатку читається символ у вершині, а потім на його місце заноситься новий символ чи ланцюжок.

Початковою конфігурацією називається конфігурація (sо, , hо), де sо – початковий стан і hо – маркер дна магазина, а заключною – конфігурація (s, $, $), де s належить до множини кінцевих станів F.

Для позначення послідовності змінюючих одна одну конфігурацій умовимося використовувати знак ├. У такий спосіб послідовність

(s1, 1, 1) (s2, 2, 2) ... ├ (sn, n, n)

записується в скороченому вигляді так:

(s1, 1, 1) * (sn, n, n).

Для спрощення далі будемо використовувати єдиний стан s.

Контрольні запитання

1. Яка граматика називається приведеною?

2. Які символи граматики називаються непродуктивними?

3. Які символи граматики називаються недосяжними?

4. Які символи граматики називаються зайвими?

5. Які правила називаються ліворекурсивними?

6. Як можна виключити рекурсію?

7. Що таке магазинний автомат? Яка його структура?

8. Яка мова вважається допустимою для магазинного автомата?

9. Який автомат називається детермінованим, а який – недетермінованим?