Неоднозначные грамматики. Способы устранения неоднозначности

Содержание

Слайд 2

Напомним, что КС-грамматика G является неоднозначной, если существует цепочка w ∈ L(G),

Напомним, что КС-грамматика G является неоднозначной, если существует цепочка w ∈ L(G),
имеющая два или более различных левых или правых вывода. Если грамматика используется для определения языка программирования, желательно, чтобы она была однозначной. В противном случае программист и компилятор языка могут по-разному понять смысл некоторых программ.

Слайд 3

Пример 13.1. Самый известный пример неоднозначности в языках программирования - это "кочующее

Пример 13.1. Самый известный пример неоднозначности в языках программирования - это "кочующее
else". Рассмотрим грамматику с правилами
S → if b then S else S
S → if b then S
S → a
Эта грамматика неоднозначна, так как в ней цепочка
if b then if b then a else a имеет два левых вывода:
S ⇒ if b then S else S ⇒ if b then if b then S else S⇒ if b then if b then a else S
⇒ if b then if b then a else a

Слайд 4

и S ⇒ if b then S ⇒ if b then if

и S ⇒ if b then S ⇒ if b then if
b then S else S⇒ if b then if b then a else S
⇒ if b then if b then a else a.
Эти выводы предполагают разную интерпретацию if b then (if b then a else a) или if b then (if b then a) else a.
Определенная неоднозначность - это свойство грамматики, а не языка. Для некоторых неоднозначных грамматик можно построить эквивалентные им однозначные грамматики.

Слайд 5

Пример 13.2. Построим эквивалентную грамматику для грамматики примера 13.1.
S1 → if

Пример 13.2. Построим эквивалентную грамматику для грамматики примера 13.1. S1 → if
b then S1
S1 → if b then S2 else S1
S1 → a
S2 → if b then S2 else S2
S2 → a
Здесь очевидно грамматика является однозначной. Неоднозначность исходной грамматики можно устранить, договорившись, что else должно ассоциироваться с последним из предшествующих ему then (как это принято в языках программирования).

Слайд 6

Общего алгоритма, выясняющего, однозначна ли грамматика, не существует. Приведем несколько наиболее распространенных

Общего алгоритма, выясняющего, однозначна ли грамматика, не существует. Приведем несколько наиболее распространенных
конструкций, приводящих к неоднозначности, и способов ее устранения.
1. Пусть грамматика содержит правила
A → AA
A → a
Очевидно, что такая грамматика будет неоднозначной. Эта неоднозначность устраняется следующей грамматикой
A → AD
A → D
D → a

Слайд 7

или
A → DA
A → D
D → a
2. Следующий пример правил, приводящих к

или A → DA A → D D → a 2. Следующий
неоднозначности
A → AaA
3. Грамматика, содержащая следующие правила, также неоднозначна
A → aA
A → Ab

Слайд 8

4. Еще один пример неоднозначной грамматики
A → aAbA
A → aA
Во всех рассмотренных

4. Еще один пример неоднозначной грамматики A → aAbA A → aA
случаях введение нового нетерминального символа позволяет устранить неоднозначность.

Слайд 9

Определение 13.1

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

Определение 13.1 КС-язык называется существенно неоднозначным, если он не порождается никакой однозначной

В примере 8.1.приведена неоднозначная грамматика, порождающая арифметическое выражение
E→E+E | E*E | (E) | a
Эту неоднозначность можно устранить, взяв вместо G грамматику G1 cо схемой:
E→E+T| E*T| T
T→(E) | a
либо грамматику G2
E → E+T
T → T *F| F
F → (E) | a

Слайд 10

Теорема 13.1

Проблема, однозначна ли КС-грамматика, неразрешима.
Рассмотрим еще один пример грамматики, порождающей оператор

Теорема 13.1 Проблема, однозначна ли КС-грамматика, неразрешима. Рассмотрим еще один пример грамматики,
присваивания (приведем только те правила, которые приводят к неоднозначности).
<оператор присваивания> → <левая часть> := <выражение>
<левая часть> → <идентификатор функции>
<левая часть> → <идентификатор переменной>
<идентификатор функции> → <идентификатор>
<идентификатор переменной> → <идентификатор>
<идентификатор> → А<символ идентификатора>
<символ идентификатора> → 1

Слайд 11

<символ идентификатора> → 2
<выражение> → <арифметическое выражение>
<выражение> → <символьное выражение>
<арифметическое выражение> →

→ 2 → → → → → ( ) Легко видеть, что
<указатель функции>
<символьное выражение> → <указатель функции>
<указатель функции> → <идентификатор функции>(<аргументы функции>)
Легко видеть, что данная грамматика является неоднозначной. В данном случае можно построить однозначную грамматику, порождающую тот же язык.

Слайд 12

<оператор присваивания> → <левая часть> := <выражение>
<левая часть> → <идентификатор>
<идентификатор> → А<символ

→ := → → А → 1 → 2 → → ( )
идентификатора>
<символ идентификатора> → 1
<символ идентификатора> → 2
<выражение> → <указатель функции>
<указатель функции> → <идентификатор>(<аргументы функции>)

Слайд 13

Первая грамматика содержит нетерминальные символы, определяющие "смысл" идентификатора, во второй грамматике "смысл"

Первая грамматика содержит нетерминальные символы, определяющие "смысл" идентификатора, во второй грамматике "смысл"
отсутствует. Тем не менее, при разборе цепочек языка необходимо знать, какой смысл имеет используемый идентификатор. Эта проблема решается определением контекстных условий для языка программирования. Контекстные условия языков программирования формулируются с помощью естественного языка. Приведем классификацию контекстных условий языка (см. [3])

Слайд 14

(1) Контекстные условия о правилах описания идентификаторов в программах. Сюда относятся контекстные

(1) Контекстные условия о правилах описания идентификаторов в программах. Сюда относятся контекстные
условия следующих типов: все используемые в программах идентификаторы должны быть описаны до их использования в программе; каждый из идентификаторов, используемых в программе, должен быть описан один раз (для каждого идентификатора обычно определяется его область действия, и единственное описание должно относиться к этой области действия - блоку программы, модулю программы, подпрограммы, описание в формальных параметрах процедур и функций и т.д.).

Слайд 15

(2) Контекстные условия о правилах использования идентификаторов в своей области действия, т.е.

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

Слайд 16

(3) Контекстные условия, определяющие правила соответствия видов величин, входящих в синтаксические конструкции

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

Слайд 17

(4) Контекстные условия, задающие различные количественные ограничения, их обычно называют ограничениями реализации.

(4) Контекстные условия, задающие различные количественные ограничения, их обычно называют ограничениями реализации.
Сюда можно отнести контекстные условия о вложенности скобок в выражении, о допустимом количестве идентификаторов в программах и т.д.
Имя файла: Неоднозначные-грамматики.-Способы-устранения-неоднозначности.pptx
Количество просмотров: 31
Количество скачиваний: 0