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

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

CC BY
196
40
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
МОДЕЛЬ / ИЗОМОРФИЗМ / АЛГОРИТМИЧЕСКАЯ СЕТЬ / ГРАФ / MODEL / IZOMORPHISMS / ALGORITHMIC NETWORK / GRAPH

Аннотация научной статьи по математике, автор научной работы — Марлей В. Е., Плотников С. Н.

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

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

Похожие темы научных работ по математике , автор научной работы — Марлей В. Е., Плотников С. Н.

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

This article is devoted to the definition of isomorphs investment of the algorithmic networks and description of conversions for implementation, using principle to division vertices into classes. Also in this article presented and described approach end algorithm to identification of isomorphism algorithmic networks in detail and its using for base of algorithmic models.

Текст научной работы на тему «Графы классов и алгоритм распознавания изоморфного вложения алгоритмических сетей»

Выпуск 5

УДК 004.383

В. Б. Марлей,

д-р техн. наук, профессор, ГУМРФ имени адмирала С. О. Макарова;

С. Н. Плотников,

старший преподаватель, Воронежский филиал ГУМРФ имени адмирала С. О. Макарова

ГРАФЫ КЛАССОВ И АЛГОРИТМ РАСПОЗНАВАНИЯ ИЗОМОРФНОГО ВЛОЖЕНИЯ АЛГОРИТМИЧЕСКИХ СЕТЕЙ

THE CLASS NTNS AND THE ALGORITHM OF ISOMORPHOUS INVESTMENT OF THE ALGORITHMIC NETWORKS

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

This article is devoted to the definition of isomorphs investment of the algorithmic networks and description of conversions for implementation, using principle to division vertices into classes. Also in this article presented and described approach end algorithm to identification of isomorphism algorithmic networks in detail and its using for base of algorithmic models.

Ключевые слова: модель, изоморфизм, алгоритмическая сеть, граф.

Key words: model, iomorphisms, algorithmic network, graph.

ПРЕДЫДУЩЕЙ статье [1, с. 5-9] рассмотрены основные идеи алгоритма распознавания алгоритмических сетей, было введено понятие графа классов вершин алгоритмических сетей.

Введем формальные определения.

Повторим коротко основные определения для алгоритмических сетей. Алгоритмическая сеть определяется как ориентированный нагруженный граф без петель при вершинах G(V, X), в котором дуги обозначают модельные переменные х.еX, i = \,п, а вершины v.e V— функциональные соотношения (операторы),/ е F, j = \ ,т, связывающие модельные значения переменных на интервале времени, соответствующем At [2].

Структура переменных сетиХ=Х uX uX ,гдеХ ,X ,X —соответственно входные,

Г J J Г Г ВХ вых вн7 вх7 вых7 вн 7

выходные и внутренние переменные, npHneMX r\X =0,X r\X =0,X r\X =0. Учиты-

J A A 71 вх bbix 7 вх вн 7 BBIX вн

вая, что все вершины АС наблюдаемы, можно задать X=X u X ,X — вычисляемые перемен-

7 * 7 вх выч7 выч *

ные AC,X =X u X ,raeX —вычисляемыепеременные.

7 выч вых вн7 выч Г

Формально алгоритмическая сеть (АС) может быть определена следующим образом:

AC::=<P,Q, X,F,P ^ F,Q ^ Х>,

где Р — множество вершин сети; Q — множество дуг сети;Х— множество переменных, при этом X =uX; X — множество переменных z-й вершины; I — множество всех индексов вершин; F — множество операторов; Р — изоморфное отображение Р на F, то есть индекс оператора можно считать индексом вершины; Q — отображение Q наХ

Оператор f.e. F описывается как f:=<X , f\ X > где X ,X.t — множество входных и выходных переменных оператора,/' — символ операции или функции. Для некоммутативных операторов в X, Xout должен быть задан частичный порядок для их элементов. Так, для операции

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

Для АС определены отношения равенства и изоморфности, введены основные операции преобразования [2]. Две АС равны (АЦ = АС2), если и только если их множества F совпадают (F) = F2). АС изоморфны (ACj ~ АС2), если и только если между их множествами F можно определить взаимно-однозначное отображение (F) ~ F2) при условии, что поставленные в соответствие элементы множеств F F2 имеют совпадающие символы операций f' и одинаковые мощности множеств in(f.) и out(f ). То есть изоморфные АС отличаются друг от друга только обозначениями переменных. Соответственно изоморфное вложение для AM будем рассматривать как установление изоморфизма одной АС фрагменту другой АС.

Для поиска фрагментов возможны два случая:

1) все переменные моделей относятся к одному тезаурусу, тогда для поиска фрагментов АС достаточно использовать веденные для АС операции пересечения, на которых основаны алгоритмы установления равенства и вложения [2];

2) переменные моделей относятся к разным тезаурусам. В данном случае для поиска полной сети может быть использован алгоритм, описанный в [3], но для поиска фрагмента данный алгоритм не подходит. Необходимо разработать новый алгоритм.

Алгоритм установления изоморфного вложения требует установить соответствие между вершинами двух АС и носит переборный характер. Каждая вершина характеризуется своим индексом, множеством переменных связанной с нейХ, символом оператора, сопоставленного вершине который у соответствующих друг другу вершин, сравниваемых АС, всегда один и тот же. То есть при установлении соответствия вершин требуется определить соответствие переменных вершин, имеющих одинаковые f и одинаковое число входных и выходных переменных.

Используем следующее допущение, разбиение множеств вершин каждой из АС на непересекающиеся классы и подклассы, между элементами которых возможно сопоставление имен переменных, должно не увеличивать число возможных вариантов сопоставления имен переменных сравниваемых сетей. Увеличение числа классов и подклассов увеличивает вероятность снижения числа вариантов. Рассматриваем только связные АС (имеющие одну компоненту связности).

Проведем предварительное преобразование анализируемых АС. Разорвем контуры на входах операторов задержек и выполним для обеих АС их упорядочение по уровням вычислимости. То есть первый уровень будет состоять только из тех вершин, которые могут быть вычислены только на основании входных переменных, второй — из тех вершин, в которых хоть одна входная переменная вычисляется в первом уровне (но не в других уровнях) и т. д., выходы операторов задержки рассматриваем как входные переменные. В результате в каждой АС множества вершин разобьется на классы. Каждая вершина в АС характеризуется собственными |in(f)| (мощность множества входных переменных оператора), |out(f)| (мощность множества выходных переменных оператора) и f (символ операции с индексом), соответствующим ей уровнем вычислимости и списком вершин АС, связанных с ней или по входу, или по выходу. Каждая вершина из такого списка также характеризуется собственными |in(f)|, |out(f)| и/, соответствующим ей шагом алгоритма. Все вершины, имеющие одинаковые перечисленные характеристики, попа-

Выпуск 5

|Выпуск 5

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

АС изоморфно вложимы (обозначим это ~с АС;), если и только если между их множеством F2 и некоторым подмножеством F1 можно определить взаимно-однозначное отображение (изоморфизм), при условии что поставленные в соответствие элементы множества F2 и подмножества F1 имеют совпадающие символы операций f' и одинаковые мощности множеств \va{f.)|, |out(F)|. То есть изоморфные АС отличаются друг от друга только обозначениями переменных.

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

Рассмотрим коротко процесс поиска фрагмента АСр который может быть эквивалентен АС2. Прежде всего необходимо, чтобы число уровней вычислимости было в АС; было не менее чем в АС2, далее, чтобы мощности и число всех выделенных подклассов АС; в каждом уровне были не менее чем в АС2. После данных проверок начинается собственно работа алгоритма распознавания изоморфного вложения.

Введем понятие графа связей классов вершин АС. Граф связей классов — это ориентированный нагруженный граф, который определяется:

ЕКАС::=<КР, G, FN, КР ^FN,F^ FN>

где КР — множество вершин графа, соответствующих выделенным классам; G — множество дуг графа, дуга между классами означает, что хотя бы один элемент одного класса по выходу связан со входом хотя бы одного элемента в другом классе, дуги не нагружены; FN— множество наборов параметров, определяющих классы; КР ^ FN— изоморфное отображение КР на FN; F ^ FN — сюрьективное отображение множества операторов сопоставленным вершинам АС на множество наборов параметров. Правила операций над графами классов принимаем такие же, как над обычными графами. Два ГКАС равны, когда равны все элементы определения ГКАС.

Теперь основная идея рассматриваемого алгоритма. Строим граф связей между классами АС2. Аналогично строится граф связей классов для АСГ Далее проводим операцию пересечения графов классов. Если получаем результат, что пересечение полностью включает граф классов АС2, то возможен дальнейший поиск изоморфного вложения.

Далее выделяется подграф графа классов АСР соответствующий графу классов АС2. В нем проверяется, что мощность соответствующих классов не менее мощности соответствующих классов в графе классов АС2, далее ищется связный подграф, который проверяется по ранее разработанному алгоритму [2] на изоморфность с АС2. Если связного подграфа нет, то изоморфного вложения нет.

Рассмотрим признаки, по которым выделяются классы вершин АС, например:

— тип оператора в вершине;

— уровень вычислимости вершины;

— мощность множества входных переменных вершины;

— мощность множества выходных переменных вершины;

— количество вершин других уровней вычислимости, с которыми она связана для каждой выходной переменной вершины.

Любую вершину АС, имеющую несколько выходов, можно представить в виде фрагмента АС, в котором в каждой вершине есть только один выход [2], поэтому в дальнейшем пока рассма-

триваем только такие АС. Таким образом, класс, к которому принадлежит вершина, будет определяться следующими параметрами:

— тип оператора в вершине;

— уровень вычислимости вершины;

— мощность множества входных переменных вершины;

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

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

Каждая вершина АС имеет свой уникальный номер /. Таким образом, /-я вершина АС в классе будет характеризоваться:

1) типом оператора (/');

2) номером уровня вычислимости (А);

3) мощностью множества входных переменных (|in(/.)|);

4) количеством вершин, с которыми вершина связана по своей выходной переменной (к.).

Рассмотрим свойства ГКАС.

Утверждение 1.

Для каждой АС существует только один ГКАС.

Доказательство.

Предположим, что для какой-либо АС существуют два различных ГКАС. Это означает, что существует хотя бы одна вершина АС с сопоставленным ей оператором, принадлежащая одновременно к разным классам, но тогда из определения ГКАС F ^ FN не будет являться отображением, что исключает подобный вариант.

Следствие утверждения 1.

ГКАС подграфа АС является подграфом ГКАС исходной сети или равен ему.

Доказательство.

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

Можно сформулировать следующие утверждения, которые позволят упростить поиск изоморфного вложения.

1. Утверждение 2.

Если АС изоморфны, то их графы классов равны.

Выпуск 5

Выпуск 5

Доказательство.

В самом деле, если АС изоморфны, то существует переобозначение переменных одной из АС, при котором она становится равной второй АС. Следовательно, ГКАС у нее будет равный ГКАС второй АС, так как по утверждению 1 АС имеет только один ГКАС.

2. Следствие утверждения 2.

Если АС равны, то их графы классов равны.

Данное следствие есть частный случай утверждения 2, когда не требуется переобозначения.

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

3. Утверждение 3.

Если АС изоморфно вложима в другую АС, то ее граф классов подграф графа классов большей АС или равен ему.

Доказательство.

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

4. Следствие утверждения 3.

Если АС есть подграф другой АС, то ее граф классов подграф графа классов большей АС или равен ему.

Данное следствие есть частный случай утверждения 3, когда не требуется переобозначения.

Рассмотрим теперь укрупненно процедуру установления изоморфного вложения, АС; исходная, АС2 вкладываемая.

1. Начало.

2. Построить ГКАС для АС; и АС2 (без учета уровня вычислимости).

3. Выполнить TKACj П ГКАС2.

4. Если TKACj П ГКАС2^ ГКАС2, то конец — изоморфного вложения нет.

5. В АС2 выбираем самый длинный путь. (Все начала входных дуг АС считаем исходящей из фиктивной вершины I, все концы выходных дуг АС считаем входящими в фиктивную вершину S, длина каждой дуги единица.)

6. Ищем в ACj последовательность вершин с типами операторов, совпадающими с вершинами максимального пути в АС2, с мощностями множеств входных переменных числом вершин, связанных с выходами не меньшими, чем в пути. Если таких путей нет, то конец — изоморфного вложения нет.

7. Производим переобозначения переменных в вершинах найденного в АС2 пути (подграфа АС2) в соответствии вершинами АС;.

8. Проверяем связи вершин полученного подграфа АС2. Если тип оператора совпадает, число входных переменных и связей по выходу не более соответствующих вершин соответствует аналогичным вершинам в АСр то включаем их в формируемый подграф и производим переобозначения переменных, нет к 11.

9. Все связанные с рассматриваемым подграфом вершины просмотрены, нет к 8.

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

10. Подграф изоморфен АС2? Да — конец, определено изоморфное вложение, нет к 8.

11. Запоминаем исходную последовательность в АС; как запрещенную, к 6.

Данный алгоритм носит обобщенный характер и ссылается на другие алгоритмы. Рассмотрим их укрупненно.

Алгоритм построения ГКАС.

1. Сортировка вершин АС по классам, имеющим одинаковый уровень вычислимости, тип оператора, мощность множества входных переменных и число вершин, связанных с выходом вершины. Это множество вершин ГКАС.

2. Просмотр пар полученных классов, если в них есть вершины, связанные дугой, то вершины ГКАС связываются дугой.

3. Все пары классов просмотрены — ГКАС построен.

В АС при определении уровней вычислимости разрываются связи по операторам задержки, то есть АС становится бесконтурной, поэтому ГКАС также бесконтурный.

Пересечение ГКАС — это обычная операция пересечения графов. Равенство — это равенство для нагруженного графа. Поиск максимального пути может быть реализован, например, методом редукции индексов.

Рассмотренный алгоритм может быть использован для определения изоморфности АС, только в пункте 4 нужно вставить определение равенства ГКАС и использовать параметр уровня вычислимости.

Данный алгоритм позволяет его использовать для поиска фрагментов в базе моделей независимо от того, к какой предметной области модели принадлежат.

Ключевые слова

Алгоритмическая модель (AM) — формализованное описание сценария предметного специалиста для моделируемого процесса.

Алгоритмическая сеть (АС) — конечный ориентированный нагруженный граф, вершинам которого сопоставлены операторы, а дугам - переменные, связываемые операторами.

Изоморфизм — сходство двух или более объектов по форме или строению.

Абстрагирование — это мысленное выделение, вычленение некоторых элементов конкретного множества и отвлечение их от прочих элементов данного множества.

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

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

1. Плотников С. Н. Распознавание изоморфного вложения алгоритмических сетей /

С. Н. Плотников // Вестник ВГУ. Сер.: Системный анализ и информационные технологии. — Воронеж, 2014. — № 2.

2. Иванищев В. В. Введение в теорию алгоритмических сетей / В. В. Иванищев, В. Е. Марлей. — СПб.: СПбГТУ, 2000. — 180 с.

3. Васильченко Д. С. Распознавание изоморфизма алгоритмических сетей при моделировании транспортных процессов / Д. С. Васильченко // Журнал Университета водных коммуникаций. — СПб., 2010. — Вып. 8.

сзз

Выпуск 5

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