Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Скачиваний:
57
Добавлен:
16.04.2015
Размер:
790.89 Кб
Скачать

Магазинный преобразователь

Вчастности:

если a = , то выбор действия не зависит от текущего входного символа и, как уже отмечалось, входная головка неподвижна;

если i = , то верхний символ магазина стирается, а вершина магазина опускается;

если yi = , то на выходную ленту ничего не пишется, и её головка остается на прежнем месте.

31

Магазинный преобразователь

В начальный момент q = q0, в магазине находится единственный символ Z0, входная головка сканирует первую ячейку на входной ленте, а выходная лента пуста, причём её головка находится на первой ячейке.

Работу магазинного преобразователя опишем в терминах конфигураций.

32

Магазинный преобразователь

Определение 1.8. Конфигурацией магазинного преобразователя P назовем четверку (q, x, , y), где q Q текущее состояние, x * — часть входной цепочки от текущего символа до её последнего символа,

называемая непросмотренной частью входной цепочки, * содержимое магазина (будем считать, что первый символ цепочки есть верхний символ магазина), y * вся выходная цепочка.

33

Магазинный преобразователь

Таким образом, начальная конфигурация

есть (q0 , x, Z0, ), где x обозначает всю входную цепочку.

Пусть (q, ax, Z , y) — текущая конфигура-

ция, и (p, , z) (q, a, Z).

Тогда один такт работы pdt P записывается как отношение между двумя последовательными конфигурациями:

(q, ax, Z , y) (p, x, , yz).

Здесь q Q, a { }, x *, Z ,, *, y, z *.

34

Трансляция, реализуемая магазинным преобразователем

Как обычно, определяются степень ( ), транзитивное замыкание ( ) и рефлексивнотранзитивное замыкание () этого отношения.

35

Трансляция, реализуемая магазинным преобразователем

Определение 1.9. Говорят, что y * есть

выход для x * при конечном состоянии,

если

(q0, x, Z0, ) (q, , , y)

для некоторых q F и *.

Трансляция, определяемая магазинным пре-

образователем P при конечном состоянии,

есть

 

(P) = {(x, y) (q0, x, Z0, )

(q, , , y)

для некоторых q F и *}.

 

36

Трансляция, реализуемая магазинным преобразователем

Говорят, что y * есть выход для x * при пустом магазине, если

(q0, x, Z0, ) (q, , , y)

для некоторого q Q.

Трансляция, определяемая магазинным преобразователем P при пустом магазине,

есть

e(P) = {(x, y) (q0, x, Z0, ) (q, , , y)

для некоторого q Q}.

37

Пример 1.3. Пусть pdt P = ({q}, {a, +, *}, {E, +, *}, {a, +, *}, , q, E, {q}), где

1)

(q, a, E) = {( q, , a)},

 

2) (q, +, E) = {( q, EE+, )},

Входной символ

используется

 

(q, *, E) = {( q, EE*, )},

3)

 

4) (q, , +) = {( q, , +)},

Входной символ

 

 

5)

(q, , *) = {( q, , *)}.

не используется

Ret 66

38

Пример 1.3.

Рассмотрим действия pdt P на входе +*aaa:

(q, +*aaa, E, )

(q, *aaa, EE+, )

(q, aaa, EE*E+, ) (q, aa, E*E+, a)

(q, a, *E+, aa)

(q, a, E+, aa*)

(q, , +, aa*a)

(q, , , aa*a+).

Очевидно, что он преобразует префиксные арифметические выражения в постфиксные.

Данный магазинный преобразователь является примером детерминированного

магазинного преобразователя (см. определение 1.10 далее).

39

Детерминированный магазинный преобразователь

Определение 1.10. Магазинный преобразова-

тель P = (Q, , , , , q0, Z0, F) называется

детерминированным (dpdt), если

1) # (q, a, Z) 1

для всех q Q, a { } и Z ;

2) если (q, , Z) для данных q Q и Z , то (q, a, Z) = для всех a .

40

Соседние файлы в папке lectures