Научная статья на тему 'Синтаксический анализ графов с использованием конъюнктивных грамматик'

Синтаксический анализ графов с использованием конъюнктивных грамматик Текст научной статьи по специальности «Математика»

CC BY
283
30
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
СИНТАКСИЧЕСКИЙ АНАЛИЗ ГРАФОВ / КОНЪЮНКТИВНЫЕ ГРАММАТИКИ / CONJUNCTIVE GRAMMARS / ТРАНЗИТИВНОЕ ЗАМЫКАНИЕ / TRANSITIVE CLOSURE / МАТРИЧНЫЕ ОПЕРАЦИИ / MATRIX OPERATIONS / ВЫЧИСЛЕНИЯ НА ГРАФИЧЕСКОМ ПРОЦЕССОРЕ / PATH QUERYING / GPGPU

Аннотация научной статьи по математике, автор научной работы — Азимов Р. Ш., Григорьев С. В.

Графы используются в качестве структуры данных для представления больших объемов информации в компактной и удобной для анализа форме в различных областях биоинформатике, графовых базах данных, статическом анализе кода и др. При этом оказывается необходимо вычислять запросы к большим графам с целью выявления зависимостей между их вершинами. Ответом на такие запросы обычно является множество всех троек (A, m, n ), для которых существует путь в графе от вершины m до вершины n такой, что метки на ребрах этого пути образуют строку, выводимою из нетерминала A в некоторой контекстно-свободной грамматике. Говорят, что такой тип запросов вычисляется с использованием реляционной семантики запросов. Кроме того, существуют конъюнктивные грамматики, образующие более широкий класс грамматик, чем традиционные контекстно-свободные грамматики. Использование конъюнктивных грамматик в задаче синтаксического анализа графов позволяет формулировать более сложные запросы к графу и решать более широкий круг задач. Известно, что задача вычисления запросов к графу с использованием реляционной семантики и конъюнктивных грамматик является неразрешимой. В данной работе предлагается алгоритм, вычисляющий приближенное решение этой задачи, а именно, аппроксимацию сверху. Предложенный алгоритм основан на матричных операциях, и проведенные эксперименты показывают, что его производительность может быть существенно повышена, благодаря использованию вычислений на графическом процессоре.

i Надоели баннеры? Вы всегда можете отключить рекламу.
iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

Path querying using conjunctive grammars

Graphs are used as a data structure to represent large volumes of information in a compact and convenient for analysis form in many areas: bioinformatics, graph databases, static code analysis, etc. In these areas, it is necessary to evaluate a queries for large graphs in order to determine the dependencies between the nodes. The answer to such queries is usually a set of all triples (A, m, n) for which there is a path in the graph from the vertex m to the vertex n, such that the labels on the edges of this path form a string derivable from the nonterminal A in some context-free grammar. This type of query is calculated using relational query semantics and context-free grammars but there are conjunctive grammars, which form a broader class of grammars than traditional context-free grammars. The use of conjunctive grammars in the path querying allows us to formulate more complex queries to the graph and solve a wider class of problems. It is known that the path querying using relational query semantics and conjunctive grammars is undecidable problem. In this paper, we propose a path querying algorithm which uses relational query semantics and conjunctive grammars, and approximates the exact solution. The proposed algorithm is based on matrix operations, and our evaluation shows that it is possible to significantly improve the performance of the algorithm by using a graphics processing unit.

Текст научной работы на тему «Синтаксический анализ графов с использованием конъюнктивных грамматик»

Синтаксический анализ графов с использованием конъюнктивных грамматик

Р.Ш. Азимов <[email protected]> С.В. Григорьев <[email protected]> Санкт-Петербургский государственный университет, 199034, Россия, г. Санкт-Петербург, Университетская наб., д. 7/9

Аннотация. Графы используются в качестве структуры данных для представления больших объемов информации в компактной и удобной для анализа форме в различных областях - биоинформатике, графовых базах данных, статическом анализе кода и др. При этом оказывается необходимо вычислять запросы к большим графам с целью выявления зависимостей между их вершинами. Ответом на такие запросы обычно является множество всех троек (A, m, n), для которых существует путь в графе от вершины m до вершины n такой, что метки на ребрах этого пути образуют строку, выводимою из нетерминала A в некоторой контекстно-свободной грамматике. Говорят, что такой тип запросов вычисляется с использованием реляционной семантики запросов. Кроме того, существуют конъюнктивные грамматики, образующие более широкий класс грамматик, чем традиционные контекстно-свободные грамматики. Использование конъюнктивных грамматик в задаче синтаксического анализа графов позволяет формулировать более сложные запросы к графу и решать более широкий круг задач. Известно, что задача вычисления запросов к графу с использованием реляционной семантики и конъюнктивных грамматик является неразрешимой. В данной работе предлагается алгоритм, вычисляющий приближенное решение этой задачи, а именно, аппроксимацию сверху. Предложенный алгоритм основан на матричных операциях, и проведенные эксперименты показывают, что его производительность может быть существенно повышена, благодаря использованию вычислений на графическом процессоре.

Ключевые слова: синтаксический анализ графов; конъюнктивные грамматики; транзитивное замыкание; матричные операции; вычисления на графическом процессоре.

DOI: 10.15514/ISPRAS-2018-30(2)-8

Для цитирования: Азимов Р.Ш., Григорьев С.В. Синтаксический анализ графов с использованием конъюнктивных грамматик. Труды ИСП РАН, том 30, вып. 2, 2018 г., стр. 149-166. DOI: 10.15514/ISPRAS-2018-30(2)-8

1. Введение

Графы используются во многих областях, например, в биоинформатике [1], в графовых базах данных [2], при статическом анализе программ [3], в навигационных сервисах для средств визуального моделирования [4]. При этом оказывается необходимым вычислять запросы к большим графам с целью выявления сложных зависимостей между их вершинами. Результатом вычисления таких запросов является множество неявных отношений между вершинами графа, то есть путей [5].

Естественно помечать ребра графа символами из некоторого конечного алфавита и выделять пути с помощью формальных грамматик над тем же алфавитом (регулярные выражения, контекстно-свободные грамматики). Говорят, что такой тип запросов вычислен с использованием реляционной семантики запросов. Наиболее популярными являются запросы, которые используют контекстно-свободные (КС) грамматики. Также существуют конъюнктивные грамматики [6], задающие более широкий класс языков, чем контекстно-свободные.

Использование конъюнктивных грамматик в задаче синтаксического анализа графов позволяет формулировать более сложные запросы к графам и решать более широкий круг задач, например, задачи поиска псевдонимов и уязвимостей в исходном коде [3]. Необходимо отметить, что задача вычисления запросов к графу с использованием реляционной семантики и конъюнктивных грамматик является неразрешимой [5]. Один из распространенных способов найти приближенное решение неразрешимой задачи - построить аппроксимацию решения.

В данной работе предложен алгоритм, вычисляющий приближенное решение задачи синтаксического анализа графов с использованием реляционной семантики запросов и конъюнктивных грамматик. Предложенный алгоритм основан на матричных операциях, что позволяет повысить производительность, используя для вычислений графический процессор. Статья организована следующим образом. В разд. 2 приведены основные определения, связанные с задачей синтаксического анализа графов, и рассмотрены основные подходы данной области; в разд. 3 проанализированы существующие решения данной задачи; в разд. 4 представлен алгоритм синтаксического анализа графов, использующий реляционную семантику запросов и конъюнктивные грамматики, а также доказана его корректность; в разд. 5 работа предложенного алгоритма разобрана на небольшом примере; в разд. 6 представлены результаты проведенных экспериментов; заключение и направления будущих исследований приведены в разд. 7.

2. Обзор

В этом разделе мы определим задачу синтаксического анализа графов и обсудим основные подходы, применяемые для ее решения.

Пусть Е - конечное множество терминальных символов. Помеченным графом будем называть пару D = (V, E), где V является множеством вершин, а Е £ 7x^x7 - множеством ребер с метками из алфавита Е. Для пути п в графе D мы будем использовать обозначение /(л), чтобы указать на слово, полученное конкатенацией меток на ребрах данного пути. Кроме того, запись тип будет обозначать, что в рассматриваемом графе существует путь из вершины т Е V в вершину п Е V.

Результатом работы алгоритма синтаксического анализа графов с использованием формальной грамматики О обычно является множество всех троек (А, т, п), для которых путь тип таков, что строка /(п) выводима из нетерминала А в грамматике О. Говорят, что такой тип запросов вычислен с использованием реляционной семантики запросов [5].

Традиционно в качестве грамматики О используются регулярные выражения [2, 7, 8, 9, 10]. Но в последнее время стало популярным использовать КС-грамматики [5, 11, 12, 13], так как некоторые полезные запросы не могут быть описаны с помощью регулярных грамматик. Примером таких запросов являются классические запросы поиска всех вершин в графе, находящихся на одном уровне иерархии [14]. Все рассмотренные алгоритмы синтаксического анализа графов принимают на вход КС-грамматики в нормальной форме Хомского [15].

Существует ряд алгоритмов синтаксического анализа графов с использованием реляционной семантики запросов и КС-грамматик [5, 12, 13], которые основаны на методе динамического программирования. Данные алгоритмы обобщают такие алгоритмы синтаксического анализа, как СУК [16, 17] и Еаг1еу [18]. В работе [5] для заданного графа D = (V, Е) и КС-грамматики О = (Ы, Е, Р) для каждого А Е N определяются контекстно-свободные отношения ИА £ V х V, являющиеся множеством пар вершин, между которыми существует путь, образующий строку, выводимую из нетерминала А. Такие отношения определяются следующим образом:

ЯА = {(п,т) | Зплт(1(л) Е ¿(Сл)}, где Ь(СА) - это язык, порожденный грамматикой О со стартовым нетерминалом А.

В [5] представлен алгоритм, вычисляющий контекстно-свободные отношения ИА. Кроме того, существует алгоритм синтаксического анализа графов с использование реляционной семантики запросов и КС-грамматик, вычисляющий данные контекстно-свободные отношения ЯА используя матричное транзитивное замыкание [11]. Данный алгоритм обобщает алгоритм Вэлианта [19] и сводится к умножению булевых матриц.

Также существуют конъюнктивные грамматики [6], образующие более широкий класс грамматик, чем контекстно-свободные. Конъюнктивная грамматика - это тройка О = (Ы, Е, Р), где N - конечное множество

нетерминальных символов, 2 - конечное множество терминальных символов и P -конечное множество правил следующего вида:

• А^ В1С1&.&ВтСт, для т > l,A,Bi,Ci Е N,

• А^ х, для А Е N, х ЕЕ.

Как и в случае КС-грамматик, мы рассматриваем только конъюнктивные грамматики в бинарной нормальной форме [20], так как для каждой конъюнктивной грамматики можно построить эквивалентную ей грамматику в данной форме. Кроме того, мы не выделяем стартовый нетерминал, так как его можно будет определить во время синтаксического анализа графа. Мы будем писать А w, чтобы указать, что строка w Е Z* может быть получена из нетерминала A некоторой последовательностью применений правил конъюнктивной грамматики. Отношение ^ определим следующим образом.

• При применении правила (А ^ В1С1&... &BmCm) Е Р любой подтерм A любого терма может быть заменен подтермом В1С1&.&ВтСт:

... А ... ^ ... (B-Ci&... &ВтСт) ...

• Конъюнкция нескольких одинаковых строк из Z* может быть перезаписана одной строкой, т.е. для любого w Е Z*

... (w&... &w) ... ^ ...W ... Языком, задаваемым конъюнктивной грамматикой G = (N, P) со стартовым нетерминалом S Е N, будем называть L(GS) = {w Е w}.

Определение контекстно-свободных отношений RA естественным образом обобщается до определения конъюнктивных отношений RA путем замены КС-грамматики на конъюнктивную. Таким образом, задача синтаксического анализа графов с использованием реляционной семантики запросов и конъюнктивных грамматик сводится к поиску конъюнктивных отношений RA для всех нетерминалов A.

Но также известен факт, что данная задача является неразрешимой [5]. Поэтому единственный известный алгоритм для решения данной задачи, описанный в [3], дает приближенный результат. Данный алгоритм используется для статического анализа программ и аппроксимирует сверху конъюнктивные отношения RA, то есть точное решение является подмножеством предложенного.

3. Существующие работы

Имеется ряд алгоритмов для синтаксического анализа графов с использованием реляционной семантики запросов и КС-грамматик [5, 12, 13], которые, однако, демонстрируют низкую производительность на больших графах, так как имеют в худшем случае кубическую временную сложность. Одной из самых популярных техник, используемых для увеличения производительности при работе с большими объемами данных, является использование графического процессора. В работе [11] представлен алгоритм синтаксического анализа

графов, использующий реляционную семантику запросов и КС-грамматики и вычисляющий матричное транзитивное замыкание с применением матричных операций. Кроме того, известно, что для вычислений матричных операции можно эффективно использовать графический процессор [21]. Однако все перечисленные алгоритмы работают только с КС-грамматиками и не позволяют обрабатывать запросы, описанные с помощью конъюнктивных грамматик. В работе [3] описан алгоритм, работающий с конъюнктивными грамматиками. Но данный алгоритм принимает на вход только определенный подкласс конъюнктивных грамматик, а именно, линейные конъюнктивные грамматики, которые имеют не более одного нетерминального символа в каждом конъюнкте правила.

Таким образом, задача построения алгоритма синтаксического анализа графов, использующего реляционную семантику запросов и работающего с произвольными конъюнктивными грамматиками, является открытой.

4. Алгоритм

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

Пусть даны помеченный граф D = (V, Е) и конъюнктивная грамматика О = (Ы, Е, Р). Определим конъюнктивное матричное умножение а°Ъ = с, где а и Ь -матрицы подходящего размера, элементами которых являются подмножества множества нетерминалов Ы, следующим образом:

су = (Л | 3(Л ^ В1С1&^&ВтСт) Е Р,т.ч. (Вк,Ск) Е йу}, где матрица ё является результатом декартового произведения матриц а и Ь, т.а ^ = и^а^ х ЬК].

Кроме того, определим конъюнктивное транзитивное замыкание квадратной матрицы а как асоп' = а(1) и а(2) и ... , где а® = а(1-1) и (а(1-1) о а('-1)) для 1>2 и а(1) = а.

Чтобы построить аппроксимацию сверху для конъюнктивных отношений ЯА, мы построим матрицу Т, используя ребра графа D и грамматику О. Для начала пронумеруем вершины графа D от 0 до (|У| - 1) и будем ассоциировать вершины с их номерами. Инициализируем каждый элемент |У|х|У| матрицы Т пустым множеством 0. Далее, для каждых I и ] мы присваиваем в ячейки матрицы следующие значения:

Ту = (Ак I Вх(((1,х,]) ЕЕ) А ((Ак ^х)Е Р))}. Наконец, мы вычисляем конъюнктивное транзитивное замыкание Тсоп' = Т(1) и Т(2) и ... , где Г® = Т(1-1) и (Т(1-1) о т(1-1)) для I > 2, а Т(1) - это

построенная нами матрица Т. Спецификация алгоритма представлена на листинге 1.

/* D - Входной помеченный граф

/* G - Входная конъюнктивная грамматика

/*Т - Результат

1 п^ количество вершин графа D

2 Е ^ множество помеченных ребер графа D

3 Р ^ множество правил грамматики G

4 Т ^ матрица пхп с каждым элементом равным 0

5 for each (I, x,j) e E

6 T1J^TIJU{AI (A^x)eP]

7 while матрица T изменяется do

8 /* вычисление транзитивного замыкания

Листинг 1. Алгоритм синтаксического анализа графов Listing 1. A path querying algorithm

Для представленного алгоритма справедливы следующие утверждения. Лемма 1. Пусть даны помеченный граф D = (V, E) и конъюнктивная грамматика G = (N, 2, P) в нормальной форме. Рассмотрим вершины i, j такие, что (i,y) Е йл и существует путь inj такой, что для строки l(n) существует дерево вывода грамматики G = (N, 2, P) с некоторым стартовым нетерминалом A с высотой h < fc. Тогда А Е 7^. Доказательство.

База индукции. Покажем, что утверждение леммы верно при к = 1. Для любых i, j и для любого нетерминала ЛЕИ, если (i,y) Е и существует путь inj такой, что для строки l(n) существует дерево вывода грамматики G = (N, 2, P) со стартовым нетерминалом A с высотой h < l, то путь п состоит из единственного ребра, ведущего из вершины i в вершину j, и (Л ^ х) Е Р, где x = 1(п) . Таким образом, А Е Гг(1) и утверждение леммы при к = 1 доказано.

Индукционный переход. Предположим, что утверждение леммы верно для всех к < (р — l), где р > 2. Покажем, что утверждение леммы также верно при к = Р.

Пусть существует путь inj, образующий строку 1(п), для которой существует дерево вывода грамматики G = (N, 2, P) со стартовым нетерминалом A с высотой h < р. Если h < р, то утверждение леммы верно по индукционному предположению. Пусть h = р, и правило, использованное для корня этого дерева выглядит так: (Д ^ ß1C1&... &ßmCm). Тогда все поддеревья для нетерминалов (ß1,C1, Cm) имеют высоту меньше, чем р. Пусть каждая пара нетерминалов в конъюнктах (ß1C1, ...,SmCm) разбивает в вершинах 154

t1,.,tm путь inj на два подпути. По индукционному предположению получаем, что Вх Е а Сх Е для всех 1 < х < т. Таким образом,

все пары нетерминалов (В1, C-J,... (Вт, Ст) принадлежат dy, где dy = ö1k=1T(k 1 1). Значит, по определению конъюнктивного матричного

умножения получаем, что А Е где Т(р) = Т(р-1) U (Т(р-1) ° Т(р-1)).

Таким образом, утверждение леммы также верно для к = p, ч. т. д. Теорема 1. (Корректность алгоритма). Пусть даны помеченный граф D = (V, E) и конъюнктивная грамматика G = (N, Е, P) в нормальной форме. Тогда для любых i, j и для любого нетерминала А Е N, если (i,j) Е RA, то А Е ff°n}. Доказательство.

Пусть (i,j) Е Ra. По определению конъюнктивных отношений RA получаем, что существует путь inj такой, что строка 1(п) принадлежит языку, порожденному грамматикой G со стартовым нетерминалом A. Рассмотрим некоторое дерево вывода этой грамматики для строки l(n). Пусть высота этого дерева равна h. Тогда, по лемме 1 получаем, что А Е А так как Tconi = Т(1) U Т(2) U ..., то А Е Tc°nj, ч. т. д.

Теорема 2. (Конечность алгоритма). Пусть даны помеченный граф D = (V, E) и конъюнктивная грамматика G = (N, Е, P) в нормальной форме. Тогда конъюнктивное транзитивное замыкание матрицы T, построенной по графу D и грамматике G, может быть вычислено за конечное число операций. Доказательство.

Если для некоторого р > 2, Т(р) = т(р-1), то для любого к >р, Т(к) = Т(р-1) и jconj = т(р-1). Таким образом, для нахождения матрицы Tconj достаточно вычислять матрицы Т(1) до тех пор, пока не встретятся две подряд идущие одинаковые матрицы. По определению конъюнктивного транзитивного замыкания, в каждой ячейке матрицы T(l+1 количество нетерминалов больше либо равно, чем в соответствующей ячейке матрицы Т(1\ А так как общее количество нетерминалов в любой матрице Т(1) не может быть больше, чем IVI2INI, то Tconj =tivi2ini. Таким образом, матрица Tconj может быть вычислена за конечное число операций, ч. т. д.

Таким образом, мы показали, как аппроксимация сверху всех конъюнктивных отношений Ra может быть найдена с помощью вычисления конъюнктивного транзитивного замыкания ТС0П}.

5. Пример работы алгоритма

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

Пример основан на грамматике G со стартовым нетерминалом S и правилами, представленными на рис. 1 .

S ->AB8t.DC A -> a В -> ВС В -t Ь С с Ь-> AD D -> b

Рис. 1. Пример входной конъюнктивной грамматики Fig. 1. An example of the input conjunctive grammar

Конъюнкт AB порождает язык = {айс*}, а конъюнкт DC порождает язык Ldc = {а*Ьс}. Таким образом, конъюнктивная грамматика G со стартовым нетерминалом S порождает язык Ls = П Loc = {айс}. Рассмотрим работу предложенного алгоритма с входной грамматикой G и графом D, представленным на рис. 2.

Рис. 2. Пример входного графа Fig. 2. An example of the input graph

Сначала матрица Т инициализируется в строках 5-6 листинга 1. Мы будем индексировать состояния матрицы Т. Обозначим через Г0 состояние матрицы Т, после инициализации. Матрица Г0 приведена на рис. 3.

{Л} 0 0 0 0 0

0 {B,D} 0 0 0

0 0 {С} 0 0 0

0 0 0 {С} 0 0

0 0 0 0 0 0

0 0 0 0 0 {B,D}

0 0 0 {С} 0 0

Рис. 3. Матрица Т0 Fig. 3. The matrix Т0

Далее в строках 7-8 листинга 1 вычисляются последующие состояния матрицы T до тех пор, пока не найдется такое к > 1, что Тк = Тк-1. Таким образом, матрица Тк будет является результатом работы алгоритма. Для вычисления матрицы 7-1 = 70^ (Т0 °Т0) необходимо вычислить матрицу d, являющуюся декартовым произведением матрицы Т0 с собой же. Матрица d представлена на рис. 4.

0 0 [(A,B),(A,D)] 0 0 0 0

0 0 0 [(B,C),(D,C)] 0 0 [(A,B),(A,D)]

0 0 0 0 [(С, С)] 0 0

0 0 0 0 0 0 0

0 0 0 0 0 0 0

0 0 0 0 [(B,C),(D,C)] 0 0 0 )

(0 0 0 0 0 0

Рис. 4. Матрица d Fig. 4. The matrix d

По матрице d строится матрица Т± = T0U (Т0 ° Т0), представленная на рис. 5. Новые нетерминалы матрицы Т1, по сравнению с матрицей Т0, выделены жирным шрифтом.

/0 [А] [D] 0 0 0

'0 0 [B,D] [В] 0 [Л]

0 [С] 0 0 0

00 00 00 00 00

0 0 0

0 [С] 0 000

0

[D] 0 0 0

0 [В] 0 [B,D] 0 [С] 0 0 )

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

Рис. 5. Матрица Тх = T0U (Т0 ° Т0) Fig. 5. The matrix T1 = T0U (T0 ° T0)

Далее вычисляются последующие состояния матрицы T до Т4 включительно, так как Т4 = Т3. Все последующие состояния матрицы T представлены на рис. 6. Новые нетерминалы матрицы Tt, по сравнению с матрицей Ti-1, выделены жирным шрифтом.

Ту =

0 [А] [D] [S] 0 0 [Щ

0 0 [B,D] [В] [S,В] [А] [D]

0 0 0 [С] 0 0 0

0 0 0 0 [С] 0 0

0 0 0 0 0 0 0

0 0 0 0 [В] 0 [B,D]

0 0 0 0 [С] 0 0

(Л) (О) (5) (S) 0 (D) '

0 (B.D) (ß) (S.B) W (О)

0 0 (С) 0 0 0

0 0 0 (С) 0 0

0 0 0 0 0 0

0 0 0 (ß) 0 (ß,D)

0 0 0 (С) 0 0

(О) (5) (5) 0 (D) '

0 (B.D) (ß) (S, В) (О)

0 0 (С) 0 0 0

0 0 0 (С) 0 0

0 0 0 0 0 0

0 0 0 (ß) 0 (ß,D)

0 0 0 (С) 0 0 ,

74 =

Рис. 6. Последующие состояния матрицы T Fig. 6. Remaining states of the matrix T

Таким образом, результатом работы предложенного алгоритма является матрица 74. Далее мы можем сконструировать множества Д^, которые являются аппроксимацией сверху конъюнктивных отношений Дл для всех нетерминалов ЛЕИ, т.е. Д^ Э Дл. Например, так как в ячейке (0,3) результирующей матрицы 74 имеется нетерминал S, то (0,3) Е Д^. Сконструированные множества Д" для всех нетерминалов ЛЕИ представлены на рис. 7.

73 =

R, = {(0,3), (0,4), (1,4)3

Па = [(0,1), (1,5)3

R3 =((1,2), (1,3), (1,4), (5,4), (5,6)]

Rc = [(2,3), (3,4), (6,4)3

R'B = {(0,2), (0,6), (1,2), (1,6), (5,б)}

Рис. 7. Аппроксимация конъюнктивных отношений Fig. 7. An approximation of the conjunctive relations

Данный пример демонстрирует, что не всегда удается получить точное решение. Например, пара вершин (0,4) принадлежит Д^, хотя не существует пути из вершины 0 в вершину 4, образующего строку, выводимую из нетерминала S (таковой является единственная строка abc). Лишние пары вершин добавляются в том случае, если существуют различные пути из вершины i в вершину j, которые суммарно соответствуют конъюнктам одного правила, но не существует пути из вершины i в вершину j, который одновременно соответствовал бы всем конъюнктам этого правила. Например, для конъюнктов правила S ^ ^ß&DC существует путь из вершины 0 в

вершину 4, образующий строку abcc, и существует также путь из вершины 0 в вершину 4, образующий строку aabc. Первый путь соответствует конъюнкту AB, так как строка abcc принадлежит языку LAB = [abc*], а второй путь соответствует конъюнкту DC, так как строка aabc принадлежит языку LDC = [а*Ьс]. Однако, очевидно, что не существует пути из вершины 0 в вершину 4, образующего строку abc.

6. Эксперименты

В этом разделе мы приводим результаты экспериментов, целью которых является демонстрация практической применимости предложенного алгоритма и возможности его значительного ускорения при использовании для вычислений графического процессора. Для достижения данной цели мы реализовали алгоритм двумя способами: вычисляя матричные операции на ЦПУ и вычисляя их на графическом процессоре. Мы запустили данные реализации на классических конъюнктивных грамматиках [6] и случайно сгенерированных графах.

6.1 Постановка экспериментов

Эксперименты проводились на рабочей станции со следующими характеристиками: операционная система - Microsoft Windows 10 Pro x64-based PC, ЦПУ - Intel i7-4790, 3601 Mhz, 4 Core(s), 4 Logical Processor(s), оперативная память - 16 GB, графический процессор - NVIDIA GeForce GTX 1070 (CUDA Cores: 1920, Core clock: 1556 MHz, Memory data rate:8008 MHz, Memory interface: 256-bit, Memory bandwidth: 256.26 GB/s, Dedicated video memory: 8192 MB GDDR5).

Было выполнено две реализации алгоритма на языке программирования F# [22].

o Реализация onCPU использует ЦПУ для вычисления матричных операций. Для хранения матриц в разреженном формате и вычисления матричных операций использована библиотека Math.Net Numerics [23].

o Реализация onGPU использует графический процессор для вычисления матричных операций. Для вычисления матричных операций на графическом процессоре использована обёртка CUSPARSE-библиотеки, взятую из библиотеки managedCuda [24]. Сравнение производительности двух выполненных реализаций позволит определить эффективность ускорения предложенного алгоритма, с использованием вычислений матричных операций на графическом процессоре.

Для экспериментов мы использовали два запроса к случайно сгенерированным графам, соответствующим двум классическим конъюнктивным грамматикам.

Azimov R.Sh., Grigorev S.V. Path querying using conjunctive grammars. Trudy ISP RAN/Proc. ISP RAS, vol. 30, issue 2, 2018, pp. 149-166

Запрос 1. Данный запрос основан на конъюнктивной грамматике G со стартовым нетерминалом S, которая порождает язык {апЬпси|п > 0}. Правила данной грамматики представлены на рис. 8.

5 AB&DC В -»■ ЬВс | be D -»■ aDb | ab

Рис. 8. Конъюнктивная грамматика, порождающая язык {апЬпсп|п > 0} Fig. 8. An example of the input conjunctive grammarfor language {апЬпсп | n > 0}

Представленная грамматика приводится в бинарную нормальную форму и подается на вход алгоритма вместе со случайно сгенерированными графами, метки на ребрах которых принадлежат алфавиту £ = {а, Ь, с}. Предложенный алгоритм выделяет пары вершин в найденной аппроксимации конъюнктивного отношения Д5, как потенциальные, между которыми существует путь, формирующий строку из языка {anbncn|n > 0}. Запрос 2. Данный запрос основан на конъюнктивной грамматике G со стартовым нетерминалом S, которая порождает язык {wcw | w Е {а, Ь}*}. Правила данной грамматики представлены на рис. 9.

S -S CSzD

С ^ аСа. а.СЬ ЪСа ЬСЬ с D -m^&oD I bB&bD сЕ А ->оАа| аДЬ \ ЬАа \ ЬАЬ сЕа. В аВа | аВЬ \ ЬВа \ ЬВЬ сЕЬ В аЕ\ЬЕ е

Рис. 9. Конъюнктивная грамматика, порождающая язык {wcw | w £ {а, Ь}*} Fig. 9. An example of the input conjunctive grammar for language {wcw | w £ {а, b}*}

Представленная грамматика также приводится в бинарную нормальную форму и генерируются графы с метками на ребрах из алфавита £ = {а, Ь, с}. Предложенный алгоритм выделяет пары вершин в найденной аппроксимации конъюнктивного отношения Д5, как потенциальные, между которыми существует путь, формирующий строку из языка {wcw | w £ {a, b}*}.

6.2 Результаты

Результаты вычислений запроса 1 представлены в табл. 1, где \V\ является количеством вершин сгенерированного графа, \E\ - количеством ребер, #results - это количество пар вершин в найденной аппроксимации

конъюнктивного отношения R's. Для двух выполненных реализаций в соответствующих столбцах представлено время работы алгоритма в миллисекундах.

Табл. 1. Результаты вычислений запроса 1 Table 1. Evaluation results for query 1

\V\ \E\ #results onCPU (ms) onGPU (ms)

100 25 0 2 7

100 75 0 10 20

100 200 79 101 213

1000 250 1 265 25

1000 750 13 2781 102

1000 2000 731 12050 347

10000 2500 4 26595 41

10000 7500 136 241087 213

10000 20000 4388 1305177 1316

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

6.3 Анализ результатов

Результаты вычислений запроса 1 показывают, что реализация, вычисляющая матричные операции на ЦПУ, более производительная только на нескольких небольших графах. Это связано с временными затратами на выделение памяти и обмен данными с графическим процессором. Кроме того, прирост производительности при использовании графического процессора для вычисления матричных операций значительно увеличивается с ростом размера входного графа.

Табл. 2. Результаты вычислений запроса 2 Table 2. Evaluation results for query 2

\V\

\E\

#results

onCPU (ms) onGPU (ms)

100

25

14

67

9

100 75 29 114 129

100 100 47 254 483

1000 250 82 2566 127

1000 750 279 21394 530

1000 1000 438 64725 1951

10000 2500 829 268843 257

10000 7500 2796 3380046 1675

10000 10000 27668 - 3017

Аналогично, результаты вычислений запроса 2 показывают, что реализация onCPU более производительная по сравнению с реализацией onGPU только на нескольких небольших графах и прирост производительности при использовании графического процессора также значительно увеличивается с ростом размера входного графа. Кроме того, сравнение результатов вычислений запросов 1 и 2 показывает, что вычисление запроса 2 требует значительно большего времени, чем вычисление запроса 1 при аналогичных входных графах. Одной из причин этого является наличие большего количества правил в грамматике, приведенной в нормальную форму, для запроса 2, чем в аналогичной грамматике для запроса 1.

Таким образом, поставленные эксперименты демонстрируют практическую применимость предложенного алгоритма и показывают наличие возможности его значительного ускорения благодаря использованию вычислений на графическом процессоре.

7. Заключение

В данной работе был предложен алгоритм, вычисляющий приближенное решение задачи синтаксического анализа графов с использованием реляционной семантики запросов и конъюнктивных грамматик. Кроме того, были проведены эксперименты, демонстрирующие практическую применимость предложенного алгоритма и возможность повысить его производительность, используя для вычислений графический процессор. Кроме того, мы можем определить несколько открытых проблем для будущих исследований. В данной работе была рассмотрена только одна семантика запросов - реляционная. Но существуют другие семантики запросов [25], в которых необходим предоставлять один или даже все пути, образующие строки, выводимые из нетерминалов входной грамматики. Может ли предложенный алгоритм быть обобщен до данных семантик запросов? Также, существуют Булевы грамматики [26], которые принадлежат более широкому и выразительному классу грамматик, чем конъюнктивные.

Существует также матричный алгоритм [27] синтаксического анализа строк,

использующий Булевы грамматики. Может ли наш алгоритм быть обобщен до

алгоритма синтаксического анализа графов использующего реляционную

семантику запросов и Булевы грамматики?

Список литературы

[1]. Anderson J. W. et al. Quantifying variances in comparative RNA secondary structure prediction. BMC bioinformatics, vol. 14, № 1, 2013.

[2]. Mendelzon A., Wood P. Finding Regular Simple Paths in Graph Databases. SIAM J. Computing, vol. 24, № 6, 1995, pp. 1235-1258.

[3]. Zhang Q., Su Z. Context-sensitive data-dependence analysis via linear conjunctive language reachability. Proceedings of the 44th ACM SIGPLAN Symposium on Principles of Programming Languages, 2017, pp. 344-358.

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

[4]. Кознов Д.В., Ларчик Е.В., Терехов А.Н. Трансформация динамических представлений в предметно-ориентированном визуальном моделировании. Программирование, том 41, № 4, 2015 г., стр. 3-12

[5]. Hellings. J. Conjunctive context-free path queries. In: Proc. of ICDT'14, 2014, pp.119130.

[6]. Okhotin A. Conjunctive grammars. Journal of Automata, Languages and Combinatorics, vol. 6, № 4, 2001, pp. 519-535.

[7]. Abiteboul S., Vianu V. Regular path queries with constraints. In Proceedings of the sixteenth ACM SIGACT-SIGMOD-SIGART symposium on Principles of database systems, 1997 pp. 122-133.

[8]. Fan W., Li J., Ma S., Tang N, and Wu Y. 2011. Adding regular expressions to graph reachability and pattern queries. In 27th Data Engineering International Conference, 2011, pp. 39-50.

[9]. Nolé M. and Sartiani C. Regular path queries on massive graphs. In Proceedings of the 28th International Conference on Scientific and Statistical Database Management, 2016.

[10]. Reutter J., Romero M., and Vardi M. Regular queries on graph databases. Theory of Computing Systems, vol. 61, № 1, 2017, pp. 31-83

[11]. Azimov R. Sh., Grigorev S. V. Context-Free Path Querying by Matrix Multiplication. arXiv preprint, arXiv:1707.01007v2, 2017.

[12]. Sevon P., Eronen L. Subgraph queries by context-free grammars. Journal of Integrative Bioinformatics, vol. 5, № 2, 2008.

[13]. Zhang X. et al. Context-free path queries on RDF graphs. International Semantic Web Conference, 2016, pp. 632-648.

[14]. Abiteboul S., Hull R., Vianu V. Foundations of databases: the logical level. Addison-Wesley Longman Publishing Co., Inc., 1995.

[15]. Chomsky N. On certain formal properties of grammars. Information and control, vol. 2, № 2, 1959, pp. 137-167.

[16]. Kasami T. An Efficient Recognition and Syntax-Analysis Algorithm for Context-Free Languages. Report of University of Hawaii, Contract No. AF 19(628)-4379, No. 2, July, 1965.

[17]. Younger D.H. Recognition and parsing of context-free languages in time n3, Information and control, vol. 10, № 2, 1967, pp. 189-208.

[18]. Grune D., Jacobs C. J. H. Parsing Techniques (Monographs in Computer Science). Secaucus, NJ, USA: Springer-Verlag New York, Inc., 2006.

[19]. Valiant L.G. General context-free recognition in less than cubic time. Journal of computer and system sciences, vol., №№ 2, pp. 308- 315.

[20]. Okhotin A. Conjunctive and Boolean grammars: the true general case of the context-free grammars. Computer Science Review, vol. 9, 2013. pp. 27-59.

[21]. Che S., Beckmann B.M., Reinhardt S.K. Programming GPGPU Graph Applications with Linear Algebra Building Blocks. International Journal of Parallel Programming, vol. 45, Issue 3, June 2017, pp 657-679.

[22]. Syme D., Granicz A., and Cisternino A. Expert F# 3.0. Springer, 2012.

[23]. The Math.Net Numerics WebSite. Доступно по ссылке: https://numerics.mathdotnet.com/, 20.03.2018.

[24]. The managedCuda library. Доступно по ссылке: https://kunzmi.github.io/managedCuda/, 20.03.2018.

[25]. Hellings J. Querying for Paths in Graphs using Context-Free Path Queries. arXiv preprint arXiv:1502.02242, 2015.

[26]. Okhotin A. 2004. Boolean grammars. Information and Computation, vol. 194, issue 1, 2004, pp. 19-48.

[27]. Okhotin A. Parsing by matrix multiplication generalized to Boolean grammars. Theoretical Computer Science, vol. 516, 2014, pp. 101-120.

Path querying using conjunctive grammars

R.Sh. Azimov <[email protected]> S.V. Grigorev <[email protected]> Saint Petersburg State University, 7/9, Universitetskaya nab., St. Petersburg, 199034, Russia

Abstract. Graphs are used as a data structure to represent large volumes of information in a compact and convenient for analysis form in many areas: bioinformatics, graph databases, static code analysis, etc. In these areas, it is necessary to evaluate a queries for large graphs in order to determine the dependencies between the nodes. The answer to such queries is usually a set of all triples (A, m, n) for which there is a path in the graph from the vertex m to the vertex n, such that the labels on the edges of this path form a string derivable from the nonterminal A in some context-free grammar. This type of query is calculated using relational query semantics and context-free grammars but there are conjunctive grammars, which form a broader class of grammars than traditional context-free grammars. The use of conjunctive grammars in the path querying allows us to formulate more complex queries to the graph and solve a wider class of problems. It is known that the path querying using relational query semantics and conjunctive grammars is undecidable problem. In this paper, we propose a path querying algorithm which uses relational query semantics and conjunctive grammars, and approximates the exact solution. The proposed algorithm is based on matrix operations, and our evaluation shows that it is possible to significantly improve the performance of the algorithm by using a graphics processing unit.

Keywords: path querying; conjunctive grammars; transitive closure; matrix operations; GPGPU.

DOI: 10.15514/ISPRAS-2018-30(2)-8

For citation: Azimov R.Sh., Grigorev S.V. Path querying using conjunctive grammars. Trudy ISP RAN/Proc. ISP RAS, vol. 30, issue. 2, 2018, pp. 149-166 (in Russian). DOI: 10.15514/ISPRAS-2018-30(2)-8

References

1

Anderson J. W. et al. Quantifying variances in comparative RNA secondary structure prediction. BMC bioinformatics, vol. 14, № 1, 2013.

Mendelzon A., Wood P. Finding Regular Simple Paths in Graph Databases. SIAM J. Computing, vol. 24, № 6, 1995, pp. 1235-1258.

Zhang Q., Su Z. Context-sensitive data-dependence analysis via linear conjunctive language reachability. Proceedings of the 44th ACM SIGPLAN Symposium on Principles of Programming Languages, 2017, pp. 344-358.

Koznov D.V., Larchik E.V., Terekhov A.N. View to view transformations in domain specific modeling. Programming and Computer Software, vol. 41, № 4, 2015, pp. 208214. DOI: 10.1134/S0361768815040039.

Hellings. J. Conjunctive context-free path queries. In: Proc. of ICDT'14, 2014, pp.119130.

Okhotin A. Conjunctive grammars. Journal of Automata, Languages and Combinatorics, vol. 6, № 4, 2001, pp. 519-535.

Abiteboul S., Vianu V. Regular path queries with constraints. In Proceedings of the sixteenth ACM SIGACT-SIGMOD-SIGART symposium on Principles of database systems, 1997 pp. 122-133.

Fan W., Li J., Ma S., Tang N, and Wu Y. 2011. Adding regular expressions to graph reachability and pattern queries. In 27th Data Engineering International Conference, 2011, pp. 39-50.

Nolé M. and Sartiani C. Regular path queries on massive graphs. In Proceedings of the 28th International Conference on Scientific and Statistical Database Management, 2016. Reutter J., Romero M., and Vardi M. Regular queries on graph databases. Theory of Computing Systems, vol. 61, № 1, 2017, pp. 31-83

Azimov R. Sh., Grigorev S. V. Context-Free Path Querying by Matrix Multiplication. arXiv preprint, arXiv:1707.01007v2, 2017.

Sevon P., Eronen L. Subgraph queries by context-free grammars. Journal of Integrative Bioinformatics, vol. 5, № 2, 2008.

Zhang X. et al. Context-free path queries on RDF graphs. International Semantic Web Conference, 2016, pp. 632-648.

Abiteboul S., Hull R., Vianu V. Foundations of databases: the logical level. Addison-Wesley Longman Publishing Co., Inc., 1995.

Chomsky N. On certain formal properties of grammars. Information and control, vol. 2, № 2, 1959, pp. 137-167.

Kasami T. An Efficient Recognition and Syntax-Analysis Algorithm for Context-Free Languages. Report of University of Hawaii, Contract No. AF 19(628)-4379, No. 2, July, 1965.

Younger D.H. Recognition and parsing of context-free languages in time n3, Information and control, vol. 10, № 2, 1967, pp. 189-208.

Grune D., Jacobs C. J. H. Parsing Techniques (Monographs in Computer Science). Secaucus, NJ, USA: Springer-Verlag New York, Inc., 2006.

2

3

4

7

8

[19]. Valiant L.G. General context-free recognition in less than cubic time. Journal of computer and system sciences, vol., №№ 2, pp. 308- 315.

[20]. Okhotin A. Conjunctive and Boolean grammars: the true general case of the context-free grammars. Computer Science Review, vol. 9, 2013. pp. 27-59.

[21]. Che S., Beckmann B.M., Reinhardt S.K. Programming GPGPU Graph Applications with Linear Algebra Building Blocks. International Journal of Parallel Programming, vol. 45, Issue 3, June 2017, pp 657-679.

[22]. Syme D., Granicz A., and Cisternino A. Expert F# 3.0. Springer, 2012.

[23]. The Math.Net Numerics WebSite. Доступно по ссылке: https://numerics.mathdotnet.com/, 20.03.2018.

[24]. The managedCuda library. Доступно по ссылке: https://kunzmi.github.io/managedCuda/, 20.03.2018.

[25]. Hellings J. Querying for Paths in Graphs using Context-Free Path Queries. arXiv preprint arXiv:1502.02242, 2015.

[26]. Okhotin A. 2004. Boolean grammars. Information and Computation, vol. 194, issue 1, 2004, pp. 19-48.

[27]. Okhotin A. Parsing by matrix multiplication generalized to Boolean grammars. Theoretical Computer Science, vol. 516, 2014, pp. 101-120.

i Надоели баннеры? Вы всегда можете отключить рекламу.