
- •Автор: старший преподаватель кафедры Прикладной Математики и Информатики им. Ю.В.Кожевникова Сергей Викторович Сотников.
- •2.3. Общие методы синтаксического анализа 81
- •1. Класс контекстно-свободных языков (V-3.0 28.02.2009)
- •1.1. Свойства кс-языков
- •1.1.1. Теорема Огдена. Лемма о разрастании кс-языков
- •1.2. Приведение кс-грамматик
- •Удаление недостижимых символов;
- •Удаление бесплодных (бесполезных) символов;
- •Удаление цепных правил;
- •1.2.5. Удаление цепных правил
- •1.2.5.1. Алгоритм удаления цепных правил
- •1.3. Нормализация грамматик (Приведение кс-грамматик к нормальной форме)
- •1.3.1.1. Алгоритм преобразования к нормальной форме Хомского
- •1.3.2.1. Устранение левой (правой) рекурсии
- •1.3.2.1.1. Алгоритм устранения левой рекурсии
- •1.3.2.2. Преобразование нелеворекурсивной приведенной кс-грамматики к нормальной форме Грейбах
- •1.3.2.2.1. Алгоритм преобразования нелеворекурсивной приведенной кс-грамматики к нормальной форме Грейбах
- •1.3.2.3. Другой способ преобразования кс-грамматики к нормальной форме Грейбах (Метод Розенкранца)
- •1.3.2.3.1. Алгоритм метода Розенкранца
- •1.4. Автоматы с магазинной памятью (mп-автоматы)
- •1.5. Соотношения между различными мп-автоматами
- •1.5.1. Алгоритм построения мп-автомата по расширенному мп-автомату
- •1.5.2. Алгоритм построения расширенного мп-автомата по мп-автомату
- •1.5.3.1. Алгоритм построения по мп-автомату мп-автомата, допускающего цепочки опустошением магазина
- •1.5.3.1. Алгоритм построения мп-автомата по мп-автомату, допускающего цепочки опустошением магазина
- •1.6. Эквивалентность мп-автоматов и кс-грамматик
- •1.6.1. Алгоритм построения мп-автомата по произвольной кс-грамматике
- •1.6.2. Алгоритм построения расширенного мп-автомата по произвольной кс-грамматике
- •1.6.3. Алгоритм построения кс-грамматики для произвольного мп-автомата
- •1.6.4. Алгоритм построения кс-грамматики для произвольного расширенного мп-автомата
- •2. Методы трансляции
- •2.1. Теория перевода
- •2.1.1. Формализмы, используемые для определения перевода
- •2.1.1.1. Перевод и семантика
- •2.1.1.2. Схемы синтаксически управляемого перевода ( су-схемы)
- •2.1.1.3. Конечные преобразователи
- •2.1.1.4. Преобразователь с магазинной памятью
- •2.1.1.5. Эквивалентность простых су-схем и преобразователей с магазинной памятью
- •2.1.1.5.1. Алгоритм построения мп-преобразователя для простой су-схемы
- •2.1.1.5.2. Алгоритм построения простой су-схемы по мп-преобразователю
- •2.1.2. Лексический анализ
- •2.1.2.1. Непрямой лексический анализ
- •2.1.2.2. Прямой лексический анализ
- •2.1.2.3. Программное моделирование конечных преобразователей
- •2.1.3. Синтаксический анализ
- •2.1.3.1. Определение разбора
- •2.2. Общие методы синтаксического анализа
- •2.2.1. Синтаксический анализ с возвратами
- •2.2.1.1. Алгоритм нисходящего разбора с возвратами
- •2.2.1.2. Проблемы алгоритм нисходящего разбора с возвратами
- •2.2.1.3. Алгоритм восходящего разбора с возвратами
- •Синтаксический анализ с возвратами
- •2.3. Общие методы синтаксического анализа универсальные методы синтаксического анализа. Табличные методы синтаксического анализа Алгоритм Кока-Янгера-Касами
- •Алгоритм разбора Кока-Янгера-Касами
- •Алгоритм нахождения левого разбора по таблице разбора
- •Алгоритм Эрли
- •Алгоритм разбора Эрли
- •Алгоритм построения правого разбора по списку разбора
1.2.5.1. Алгоритм удаления цепных правил
Вход: КС-грамматика .
Выход: Грамматика без цепных правил.
Метод:
Шаги 1,2,3,4 повторяются для каждого нетерминала.
1.
;
2.
;
3. Если
,
то заканчиваем построение множества
для текущего нетерминала
;
если
,
то
и
переходим к шагу 2;
4.
;
5. ;
;
;
Во множество - заносятся все правила из , кроме цепных.
6. Для всех правил
вида
,
из множества
,
если нетерминал
принадлежит одному из построенных
множеств (например
),
то во множество правил
добавляются правила вида
.
1.3. Нормализация грамматик (Приведение кс-грамматик к нормальной форме)
1.3.1. КС-грамматика в нормальной форме Хомского
Определение: КС-грамматика называется грамматикой в нормальной форме Хомского (бинарной нормальной форме), если на множество правил данной грамматики накладываются следующие ограничения
1.
,
;
2.
,
;
, если - цель и не встречается в правых частях других правил.
1.3.1.1. Алгоритм преобразования к нормальной форме Хомского
Вход: Приведенная КC-грамматика .
Выход: - грамматика в нормальной форме Хомского.
Метод:
1. , ;
2. Если во множестве правил встречается правило вида
,
где
.
Тогда данное правило добавляется во множество правил без изменений;
3. Если во множестве правил встречается правило вида
,
где
,
.
Тогда данное правило добавляется во множество правил без изменений;
4. Если во множестве правил встречается правило вида
,
где
- целевой символ грамматики и не встречается в правых частях других правил.
Тогда данное правило добавляется во множество правил без изменений;
5. Если во множестве правил встречается правило вида
,
где
,
.
Тогда во множество правил добавляются правила вида
;
.
Во множество
нетерминалов
добавляется новый нетерминал вида
,
т.е.
;
6. Если во множестве правил встречается правило вида
,
где
, .
Тогда во множество правил добавляются правила вида
;
.
Во множество
нетерминалов
добавляется новый нетерминал вида
,
т.е.
;
7. Если во множестве правил встречается правило вида
,
где
,
.
Тогда во множество правил добавляются правила вида
;
;
.
Во множество
нетерминалов
добавляются новые нетерминалы вида
,
,
т.е.
;
8. Если во множестве правил встречаются правила вида
,
где
,
.
Тогда во множество правил добавляются правила вида
;
;
.
Во множество
нетерминалов
добавляются новые нетерминалы вида
,
т.е.
.
Если
,
то
в правых частях добавляемых правил
заменяется на новый нетерминал
,
который добавляется в
,
а во множество правил
добавляются правила вида
.
Если
,
то не производим никаких замен, все
остается без изменений;
9. , грамматика является грамматикой в нормальной форме Хомского.
Пример :
.
Решение:
1.
;
2. Правила вида переносятся в без изменений.
;
;
3. Правила вида переносятся в без изменений.
;
;
;
4. Правила вида переносятся без изменений. Правила такого вида отсутствуют;
5.
заменяем на правила вида
;
.
И множество
.
заменяем на правила вида
;
.
И множество
;
6.
заменяем на правила вида
;
;
И множество
;
7.
заменяем на правила вида
;
;
;
И множество
;
заменяем на правила вида
;
;
;
;
;
И множество
.
заменяем на правила вида
;
;
И множество
.
В результате получаем грамматику со следующими правилами
.
1.3.2. КС-грамматика в нормальной форме Грейбах