Студопедия.Орг Главная | Случайная страница | Контакты | Мы поможем в написании вашей работы!  
 

Стратегии синтаксического анализа



Существует две основных стратегии синтаксического анализа:

1. нисходящая (top-down), когда для данного предложения, исходя из начального символа грамматики, строят вывод;

2. восходящая, когда данного предложения, исходя из символов самого предложения (терминалов), строят разбор.

Таким образом, различают нисходящие и восходящие анализаторы.

Для того, чтобы представить, как это работает технически, на базе нашего примера рассмотрим как работает нисходящий анализ. Для этого нашу грамматику заменим сокращенной эквивалентной грамматикой типа 3:

<Пр>→кот<с>

<Пр>→пес<с>

<Пр>→он<с>

<с>→идет

<с>→лежит

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

Входной символ   состояние кот пес он идет лежит
<Пр> <с> <с> <с>    
<с>       + +

Отличительная черта нисходящего анализа – это целенаправленность. На каждом шаге анализа нисходящие распознаватели формируют цель – найти вывод, начинающийся с некоторого нетерминального символа и порождающий часть входной строки. Распознаватель пытается достичь этой цели путем направленного перебора различных возможностей. Основная идея нисходящего анализа в следующем: начиная процесс анализа входной строки S1, S2…,Sn, распознаватель исходит из предположения, что эта строка является предложением входного языка. Отсюда вытекает главная цель анализа – найти вывод (построить дерево)

S S1, S2…,Sn S – начальный символ

Если существует такой вывод, то существуют и промежуточные порождающие правила, но для каждого нетерминального символа в грамматике может быть несколько правил с разными правыми частями и какое именно правило следует применить, заранее не известно. При неудачном выборе правила, вспомогательная цель может оказаться недостижимой, тогда нужно попытаться применить другое правило. Возможны случаи, когда для какой-либо вспомогательной цели все правила приводят к неудаче. Описание процесса завершается, когда найден конечный вывод (цепочка) или когда установлено, что этого вывода не существует, т.е. входная строка не является предложением этого языка. Обычно нисходящий распознаватель просматривает символа входящей строки и символы правой части применяя правило «слева – направо». Такие распознаватели называют левосторонними. (Например БНФ)

В памяти машины правила формальной грамматики могут храниться в виде синтаксических таблиц. Пусть требуется найти вывод для предложения «Он идет» и построить синтаксическое дерево. В качестве главной цели выбираем начальный символ формальной грамматики <Пр>. первая наша вспомогательная цель – это первый символ правой части правила (<П>), вторая вспомогательная цель - <ис>. Непосредственная проверка показывает, что вспомогательная цель «он» недостижима через <ис>, поэтому вместо <ис> выбирают новую вспомогательную цель - <М>…

<Пр>

<П> <с>

<М> <ГФ>

| |

он идет

Соответственно строится вторая ветка.

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





Дата публикования: 2015-02-20; Прочитано: 801 | Нарушение авторского права страницы | Мы поможем в написании вашей работы!



studopedia.org - Студопедия.Орг - 2014-2025 год. Студопедия не является автором материалов, которые размещены. Но предоставляет возможность бесплатного использования (0.006 с)...