Переписывание графа - Graph rewriting

В Информатика, преобразование графа, или же переписывание графа, касается техники создания нового график из исходного графа алгоритмически. Он имеет множество приложений, начиная от программная инженерия (разработка программного обеспечения а также проверка программного обеспечения ) к алгоритмы верстки и создание изображений.

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

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

Иногда грамматика графа используется как синоним система перезаписи графов, особенно в контексте формальные языки; другая формулировка используется, чтобы подчеркнуть цель построений, такую ​​как перечисление всех графов из некоторого начального графа, то есть создание языка графов - вместо простого преобразования данного состояния (основного графа) в новое состояние.

Подходы к переписыванию графов

Алгебраический подход

В алгебраический подход переписывание графов основано на теория категорий. Алгебраический подход далее делится на подподходы, наиболее распространенными из которых являются подход двойного выталкивания (DPO) и подход одиночного выталкивания (SPO). Другие под-подходы включают полуторный и откат подход.

С точки зрения подхода DPO правило перезаписи графа - это пара морфизмы в категории графиков и гомоморфизмы графов между ними: (или же ) куда является инъективный. Граф K называется инвариантный или иногда склейка графа. А переписывание шаг или же заявление правила r к граф хоста G определяется двумя выталкивание диаграммы, оба происходят из одного и того же морфизм , где D - контекстный граф (вот где имя двойной-pushout происходит от). Другой морфизм графов моделирует вхождение L в G и называется матч. Практическое понимание этого состоит в том, что это подграф, который соответствует (видеть проблема изоморфизма подграфов ), а после нахождения совпадения заменяется на в графе хоста куда служит интерфейсом, содержащим узлы и ребра, которые сохраняются при применении правила. График необходим для присоединения сопоставленного шаблона к его контексту: если он пуст, сопоставление может обозначать только весь связанный компонент графа .

В отличие от этого, правило переписывания графа подхода SPO - это единственный морфизм в категории маркированные мультиграфы и частичные сопоставления сохраняющие мультиграфическую структуру: . Таким образом, шаг перезаписи определяется одним выталкивание диаграмма. Практическое понимание этого аналогично подходу DPO. Разница в том, что между графом хоста G и графом G ', являющимся результатом этапа перезаписи, нет интерфейса.

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

Существует также другой алгебраический подход к переписыванию графов, основанный в основном на булевой алгебре и алгебре матриц, который называется грамматики матричных графов.[1]

Детерминированная перезапись графа

Еще один подход к переписыванию графов, известный как определенный переписывание графа, вышло из логика и теория баз данных.[2] В этом подходе графы рассматриваются как экземпляры базы данных, а операции перезаписи - как механизм для определения запросов и представлений; поэтому для получения уникальных результатов требуется вся переписывание (с точностью до изоморфизма ), и это достигается путем одновременного применения любого правила перезаписи по всему графу, где бы оно ни применялось, таким образом, чтобы результат действительно был однозначно определен.

Переписывание срочного графа

Другой подход к переписыванию графов: график терминов переписывание, которое включает в себя обработку или преобразование графов терминов (также известных как абстрактные семантические графы) набором синтаксических правил перезаписи.

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

Конференция ТЕРМГРАФ[3] полностью фокусируется на исследованиях переписывания графов терминов и его приложений.

Классы грамматики графов и системы переписывания графов

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

Реализации и приложения

Пример правила перезаписи графа (оптимизация из конструкции компилятора: умножение на 2 заменено сложением)

Графы - это выразительный, наглядный и математически точный формализм для моделирования объектов (сущностей), связанных отношениями; объекты представлены узлами, а отношения между ними - ребрами. Узлы и ребра обычно типизируются и приписываются. Вычисления в этой модели описываются изменениями отношений между сущностями или изменениями атрибутов элементов графа. Они закодированы в правилах перезаписи графов / преобразования графов и выполняются системами перезаписи графов / инструментами преобразования графов.

Смотрите также

Примечания

Рекомендации

Цитаты

  1. ^ Перес 2009 подробно описывает этот подход.
  2. ^ «Графо-ориентированная объектная модель для интерфейсов конечных пользователей баз данных» (PDF).
  3. ^ «ТЕРМГРАФ».

Источники