Совпадение множества языков МП-автоматов и контекстно-свободных языков — различия между версиями
Bochkarev (обсуждение | вклад) (→Пример) |
Bochkarev (обсуждение | вклад) (→Построение КС-грамматики по МП-автомату) |
||
Строка 38: | Строка 38: | ||
*a) продукции <tex> S \rightarrow [q_0,Z_0,p] </tex> для всех <tex> p </tex>, таким образом <tex> (q,w,Z_0)\vdash^* (q,\epsilon,\epsilon)</tex> | *a) продукции <tex> S \rightarrow [q_0,Z_0,p] </tex> для всех <tex> p </tex>, таким образом <tex> (q,w,Z_0)\vdash^* (q,\epsilon,\epsilon)</tex> | ||
*b) пусть <tex> \delta(q,a,X) </tex> содержит <tex> (r,Y_1,Y_2,...,Y_k)</tex>. Тогда для всех списков состояний <tex> r_1,r_2,...,r_k</tex> в грамматике <tex> G </tex> есть продукция <tex> [qXr_k]\rightarrow a[r Y_1 r_1][r_1 Y_1 r_2]...[r_{k-1} Y_k r_k]</tex>. | *b) пусть <tex> \delta(q,a,X) </tex> содержит <tex> (r,Y_1,Y_2,...,Y_k)</tex>. Тогда для всех списков состояний <tex> r_1,r_2,...,r_k</tex> в грамматике <tex> G </tex> есть продукция <tex> [qXr_k]\rightarrow a[r Y_1 r_1][r_1 Y_1 r_2]...[r_{k-1} Y_k r_k]</tex>. | ||
+ | ==== Пример ==== | ||
+ | Пусть у нас имеется <tex> P=({q},{i,e},{Z},\delta,q,Z)</tex>, функция <tex> \delta </tex> задана следующим образом: | ||
+ | *<tex> \delta(q,i,Z)=\{(q,ZZ)\}</tex> | ||
+ | *<tex> \delta(q,e,Z)=\{(q,\epsilon)\}</tex> | ||
+ | Так как <tex> P </tex> имеет один магазинный символ и одно состояние, то грамматика строится просто. У нас будет всего две переменные: | ||
+ | *a) <tex> S </tex> — стартовый символ. | ||
+ | *b) <tex> [qZq] </tex> — единственная тройка, которую можно собрать из наших состояний и магазинный символов. | ||
+ | Также грамматика имеет следующие продукции: | ||
+ | *1. Единственной продукцией для <tex> S </tex> является <tex> S \rightarrow [qZq] </tex>. Но если бы у автомата было <tex> n </tex> состояний, то тут бы имелось и <tex> n </tex> продукций. | ||
+ | *2. | ||
==== Корректность построения ==== | ==== Корректность построения ==== | ||
Докажем, что если <tex> (q,w,X) \vdash^* (p,\epsilon,\epsilon)</tex>, то <tex> [q,X,p] \Rightarrow^* w </tex>. | Докажем, что если <tex> (q,w,X) \vdash^* (p,\epsilon,\epsilon)</tex>, то <tex> [q,X,p] \Rightarrow^* w </tex>. |
Версия 08:55, 15 января 2011
Далее будут приведены конструкции для построения МП-автомата по заданной КС-грамматике, и наоборот. Также будет приведена теорема об эквивалентности языков.
Содержание
Построение МП-автомата по заданной КС-грамматике
Пусть
— КС-грамматика. Построим МП-автомат , который допускает по пустому магазину. Функция переходов будет определена по следующим правилам:- 1. — продукция — для каждой переменной .
- 2. для каждого терминала .
Пример
Преобразуем грамматику выражений в МП-автомат. Пусть дана грамматика:
Множеством входных символов является
. Эти символы, вместе с переменными , образуют магазинный алфавит. Функция переходов определена следующим образом:- a)
- b)
- c) ; ;... ; если входной символ совпадает с вершиной стека, то вершина удаляется.
Пункты a,b образованы по первому правилу построения функции переходов, пункт c по второму правилу.
Корректность построения
Пусть
, тогда имеет следующее левое порождение: . Покажем индукцией по , что :- База. Очевидно, что
- Переход. Предположим, что . Заметим, что шаг порождения включает замену некоторой переменной ее продукцией . Правило 1 построения МП-автомата позволяет на заменить на вершине стека на цепочку , а правило 2 позволяет затем сравнить любые терминалы на вершине со входными символами. В результате достигается МО .
- Также заметим, что . Таким образом , т.е допускает по пустому стеку.
Утверждение (1): |
Если МП-автомат построен по грамматике , с использованием указанной выше конструкции, то |
Выше доказана корректность построения МП-автомата по любой КС-грамматике. Значит множество языков КС-грамматик является подмножеством языков допускаемых МП-автоматами. |
Построение КС-грамматики по МП-автомату
Наша конструкция эквивалентной грамматики использует переменные вида:
Следует отметить, что удаление может являться результатом множества переходов.
Пусть — МП-автомат. Построим , где состоит из:
- 1 Специальный стартовый символ
- 2 Все символы вида , где и — состояния из , а — магазинный символ из .
Грамматика
имеет следующие продукции:- a) продукции для всех , таким образом
- b) пусть содержит . Тогда для всех списков состояний в грамматике есть продукция .
Пример
Пусть у нас имеется
, функция задана следующим образом:Так как
имеет один магазинный символ и одно состояние, то грамматика строится просто. У нас будет всего две переменные:- a) — стартовый символ.
- b) — единственная тройка, которую можно собрать из наших состояний и магазинный символов.
Также грамматика имеет следующие продукции:
- 1. Единственной продукцией для является . Но если бы у автомата было состояний, то тут бы имелось и продукций.
- 2.
Корректность построения
Докажем, что если
, то .- База. Пара должна быть в и есть одиночный символ, или . Из построения следует, что является продукцией, поэтому .
- Переход. Предположим, что последовательность состоит из переходов, и . Первый переход должен иметь вид:
.
Утверждение (2): |
Если КС-грамматика построена по МП-автомату , с использованием указанной выше конструкции, то |
Выше доказана корректность построения КС-грамматики по МП-автомату. Значит языки допускаемые МП-автоматами являются подмножеством языков, заданных КС-грамматикой. |
Эквивалентность языков МП-автоматов и КС-языков
Теорема (Об эквивалентности языков МП-автоматов и КС-языков): |
Множество языков, допускаемых МП-автоматами совпадает с множеством языков, задаваемых с помощью контекстно-свободных грамматик. |
Доказательство: |
Из утверждения 1 следует, что | , в свою очередь из утверждения 2 следует, что . Отсюда .