Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:

Лекция 10. Контекстно-зависимые грамматики

.pdf
Скачиваний:
0
Добавлен:
28.02.2026
Размер:
568.48 Кб
Скачать

Порождающие грамматики Хомского

Контекстно-свободная грамматика (тип 2)

грамматика, в которой правила имеют вид:

A → , где — цепочка, состоящая из терминальных и нетерминальных символов, A – один терминальный символ.

Контекстно-свободные языки

Контекстно-свободный язык – это язык, порождаемый контекстно-свободной грамматикой.

Вобщем случае разные грамматики могут порождать один язык.

Втом числе разные КС-грамматики могут порождать один КС-язык.

Примеры контекстно-свободных языков

Большинство систем описания структур данных (XML, HTML), а также некоторые языков программирования являются контекстно-свободными языками.

КС-языки хорошо описывают структуру слов и предложений в естественных языках (создатель иерархии грамматик – Ноам Хомский – лингвист).

Порождающие грамматики Хомского

Контекстно-зависимая грамматика (тип 1)

грамматика, в которой правила имеют вид:

wAv → w v, где

– непустая цепочка, состоящая из терминальных и нетерминальных символов,

w и v – произвольные цепочки (м.б. пустые), A – один терминальный символ.

КЗ-грамматики

Важно понимать, что КС-грамматики являются подмножеством КЗ-грамматик, в которых в правиле:

wAv → w v

цепочки w и v строго пустые.

КЗ-грамматики

С КЗ-грамматиками связан другой тип грамматик – неукорачивающие.

В неукорачивающих грамматиках длина цепочки слева должна быть не меньше, чем длин цепочки справа.

Так как в КЗ-грамматиках есть правило о том, что должна быть не пустой, КЗ-грамматики являются неукорачивающими.

КЗ-грамматики

КЗ-грамматики и неукорачивающие грамматики слабоэквивалентны (могут порождать один и тот же язык).

В КЗ-грамматиках может быть правило S → , но только если грамматика подразумевает наличие в порождаемом языке пустого слова и при этом стартовый нетерминал S не используется в правых частях правил (чтобы не сделать грамматику фактически укорачивающей).

КЗ-грамматики

КЗ-грамматики можно записать в нормальной форме Куроды, в которой правила должны иметь одну из следующих форм:

AB → CD

A → BC

A → B A → a

Так как грамматика в нормальной форме Куроды является неукорачивающей, она эквивалентна какой-то КЗ-грамматике (и каждую КЗ-грамматику можно представить в нормальной форме Куроды).

КЗ-грамматики

КЗ-грамматики были предложены Ноамом Хомским для описания структуры естественных языков, так как в естественных языках та или иная часть слова/предложения зависит от окружения.

Однако некоторые особенности естественных языков, например перекрестные зависимости (cross-serial dependencies) не могут быть описаны КЗ-грамматикой:

КЗ-языки

Контекстно-зависимый язык – язык, порождаемый контекстно-зависимой грамматикой (или эквивалентной неукорачивающей грамматикой).

Пример КЗ-языка: L={anbncn| n N} Правила:

S → aSBC S → aBC

CB → BC aB → ab bB → bb

bC → bc cC → cc