Определение неоднозначности грамматики и языка

Этапы жизненного цикла программного продукта

· Анализ: цель – определение требований к будущему программному продукту

· Проектирование: результат – архитектура системного программного продукта (алгоритмы + декомпозиция, функции + интерфейс)

· Реализация: кодирование + тестирование + отладка

· Сопровождение: эволюция программного продукта при его эксплуатации

Состав и схема функционирования классической системы программирования

Транслятор – программа, кот позволяет писать программу на языке высокого уровня и обеспечивает ее выполнение (позволяет писать не в машинных кодах)

Компилятор - программа, которая осуществляет перевод исходной программы на ЯП в объектную программу (одна из разновидностей транслятора)

Интерпретатор – так же 1 из разновидностей трансляторов, выход – результат обработки исходных данных

Схема:

Редактор текстов -> (исходная программа на некотором языке программирования) -> компилятор (+макрогенератор) -> (объектная программа – машинно-ориентированное представление программы, где есть информация в машинном коде + инф о внешних связях + таблицы констант…) -> редактор связей –> (исполняемый модуль – программа в машинных кодах как единое целое, относительно некоторого условного начального адреса)

Типы трансляторов, особенности интерпретаторов и компиляторов

Схема работы «чистого» компилятора: (исходная программа на ЯП) -> ЛА + СА + КУ + генерация кода -> (объектный модуль)

Схема работы чистого интерпретатора: (исх. программа на ЯП + входные данные) -> интерпретатор -> (результат работы исх. программы на водных данных)

Смешанная стратегия: (исх. программа на ЯП) -> ЛА + СА + КУ -> (промежуточное представление программы + вх. данные) -> интерпретатор промежуточного представления -> результат работы исх. программы на входных данных

Общая схема работы компилятора

Фаза анализа: (исходная программа на ЯП) -> лексический анализатор -> (последовательность лексем) -> синтаксический анализатор -> (промежуточное представление) -> семантический анализатор

Фаза синтеза: подготовка к генерации -> генерация кода -> (объектный модуль)

Определение порождающей грамматики

Порождающая грамматика – это четверка (VT, VN, P, S), где

VT – алфавит терминальных символов (терминалов)

VN – алфавит нетерминальных символов (нетерминалов, не пересекающийся с VT)

P – конечное подмножество множества (VN U VN)+ X (VT U VN)*; элемент (a, b) называется правилом вывода и записывается в виде a -> b; в а есть хотя бы один нетерминал

S – начальный символ (цель) грамматики, S из VN

Определение языка, порождаемого грамматикой

Язык, порождаемый грамматикой G = (VT. VN, P, S), L(G) – это множество цепочек {a} из VT: каждая a выводима из S.

7. Определение эквивалентности грамматик
Грамматики G1 и G2 называются эквивалентными, если L(G1) = L(G2).

Грамматики G1 и G2 почти эквивалентны, если языки, ими порождаемые, отличаются на более чем на эпсилон.

Определение типов грамматики и языков по Хомскому

Тип 0: на правила 0 не накладывается никаких ограничений, кроме огр. по определению(в а есть хотя бы 1 нетерминал)

Тип 1: а) неукорачивающие грамматики: |a| <= |b|; a из +, b из *

b) КЗ a -> b: a = w1 A w2; b = w1 B w2; w1, w2 из *

Тип 2: a) КС a -> b: a – отдельный нетерминал, b – непустая цепочка

b) УКС: a -> b: a – нетерминал, b – любая цепочка

Тип 3: a) праволинейные: A -> tB || A -> t, A, B из VN, t из VT

b) леволинейные: A -> Bt|| A -> t, …

Соотношения между типами грамматик

· Любая регулярная грамматика = КС

· Любая КС = КЗ, неукорачивающая

· Любая КЗ, любая неукорачивающая = типа 0

· Любая регулярная = УКС

· Любая КС = УКС

· УКС с эпсилон не явл. типа 1.

Соотношения между типами языков

Язык типа К, если его можно описать грамматикой типа К и нельзя грамматикой типа К + 1

· Любой регулярный язык = КС язык, но КС-языки не явл. регулярными

· Любой КС = язык типа 1, но есть типа 1 не КС

· Любой язык типа 1 = язык типа 0

Определение неоднозначности грамматики и языка

Дерево вывода: помеченное упорядоченное дерево, явл. деревом разбора в грамматике G = (VT, VN, P, S), если:

· Корень дерева помечен S, листья – символы из VT, либо эпсилон (для укорачивающих грамматик), все вершины – VN

· Если вершины помечены A из VN и пометки при непосредственных потомках, выписанные слева направо, образуют цепочку a1, …, an, где ai из (VT U VN), то A -> a1…an из P – правило вывода грамматики

· Если вершины помечены A из VN и при непосредственных потомках, помеченных эпсилон, то этот потомок единственный.

Грамматика G является неоднозначной, если существует w из L(G), для которой существует более одного дерева вывода.

Наши рекомендации