Научная статья на тему 'Вложенные сети Петри и нагруженные метки: распределенная система и рекурсия'

Вложенные сети Петри и нагруженные метки: распределенная система и рекурсия Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
813
199
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
ВЛОЖЕННЫЕ СЕТИ ПЕТРИ / НАГРУЖЕННЫЕ МЕТКИ / РЕКУРСИЯ / РАСПРЕДЕЛЕННЫЕ СИСТЕМЫ / ФАКТОРИАЛ / КОМБИНИРОВАННЫЙ ТИП ДАННЫХ / ГОРИЗОНТАЛЬНАЯ И ВЕРТИКАЛЬНАЯ СИНХРОНИЗАЦИИ СРАБАТЫВАНИЯ ПЕРЕХОДОВ / NESTED PETRI NETS / LOADED INSCRIPTION LABELS / RECURSION / DISTRIBUTED SYSTEMS / FACTORIAL / COMBINED DATA TYPE / HORIZONTAL AND VERTICAL SYNCHRONIZATION OF TRANSITIONS

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Марков Александр Владимирович, Воевода Александр Александрович

Для моделирования параллельных процессов, сложных многоуровневых систем без дополнительных мест, переходов и их взаимосвязей, синхронизации разных потоков информации и представления в разных сетях одинаковых мест с разной маркировкой используются вложенные сети Петри. Альтернативой данного вида сетей являются сети с нагруженными метками, которые содержат дополнительную информацию о структуре системы или об истории её изменений. Сравнение подходов построения сетей Петри на основе вложенных сетей и сетей с нагруженными метками выполняется на примере анализа распределенной системы агентства проката автомобилей и решения рекурсивной задачи нахождения факториала числа. Анализ распределенной системы агентства выполнен на основе двухуровневых вложенных сетей Петри с использованием вертикальной и горизонтальной синхронизации. Для сравнения осуществляется анализ на основе сетей с нагруженными метками в двух вариантах. В первом случае за основу берется структура системной сети, во втором сеть состоит из трёх мест, к каждому из которых добавляется определенный набор типов данных для отображения возможных состояний системы. Нахождение факториала числа у вложенных сетей Петри осуществляется через вертикальную синхронизацию срабатывания переходов между системной сетью и элементными сетями, а при использовании нагруженных меток через комбинированный тип данных мест сети. Переменная первого типа данных отображает значение величины искомого факториала, а во втором случае отслеживается значение текущей переменной, вычисленной на предыдущем шаге. Моделирование и автоматический анализ сетей Петри для данных примеров происходит в программной среде CPN Tools (Version 4.0.0).

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

Похожие темы научных работ по компьютерным и информационным наукам , автор научной работы — Марков Александр Владимирович, Воевода Александр Александрович

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

NESTED PETRI NETS AND LOADED INSCRIPTION LABELS: DISTRIBUTED SYSTEM AND RECURSION

For modeling concurrent processes, complex multi-level systems without additional places, transitions, and their relationships, synchronization of different flows of information and views on different nets of the same places with different markings, nested Petri nets are used. An alternative to this type of the nets are nets with loaded inscription labels containing additional information about the structure of the system or history of its changes. Comparison of the approaches to construction of Petri nets based on the nested nets and nets with loaded inscription labels is made by the example of the analysis of the distributed system of car rent agency and the recursive task finding factorial. The analysis of the distributed system of the agency is made on the basis of two-level nested Petri nets using vertical and horizontal synchronization. In order to compare, the analysis based on the loaded inscriptional labels is carried out in two ways. In the first case, the structure of the system net is taken as a basis; in the second case the net consists of three parts, to each of which a certain set of data types is added to display the possible system states. Finding factorial of the number y in the nested Petri nets is made through vertical synchronization of transitions between the system net and the element nets, and while using the loaded inscription labels it is carried out via the combined data type of the net parts. The variable of the first data type displays the number of the desired factorial, and in the second case the value of the current variable calculated in the previous step is observed. Modeling and automatic analysis of Petri nets for these examples occur in the software environment CPN Tools (version 4.0.0).

Текст научной работы на тему «Вложенные сети Петри и нагруженные метки: распределенная система и рекурсия»

УДК 681.3

А. В. Марков, А. А. Воевода

ВЛОЖЕННЫЕ СЕТИ ПЕТРИ И НАГРУЖЕННЫЕ МЕТКИ: РАСПРЕДЕЛЕННАЯ СИСТЕМА И РЕКУРСИЯ1

Для моделирования параллельных процессов, сложных многоуровневых систем без дополнительных мест, переходов и их взаимосвязей, синхронизации разных потоков информации и представления в разных сетях одинаковых мест с разной маркировкой используются вложенные сети Петри. Альтернативой данного вида сетей являются сети с нагруженными метками, которые содержат дополнительную информацию о структуре системы или об истории её изменений. Сравнение подходов построения сетей Петри на основе вложенных сетей и сетей с нагруженными метками выполняется на примере анализа распределенной системы агентства проката автомобилей и решения рекурсивной задачи - нахождения факториала числа. Анализ распределенной системы агентства выполнен на основе двухуровневых вложенных сетей Петри с использованием вертикальной и горизонтальной синхронизации. Для сравнения осуществляется анализ на основе сетей с нагруженными метками в двух вариантах. В первом случае за основу берется структура системной сети, во втором - сеть состоит из трёх мест, к каждому из которых добавляется определенный набор типов данных для отображения возможных состояний системы. Нахождение факториала числа у вложенных сетей Петри осуществляется через вертикальную синхронизацию срабатывания переходов между системной сетью и элементными сетями, а при использовании нагруженных меток - через комбинированный тип данных мест сети. Переменная первого типа данных отображает значение величины искомого факториала, а во втором случае отслеживается значение текущей переменной, вычисленной на предыдущем шаге. Моделирование и автоматический анализ сетей Петри для данных примеров происходит в программной среде CPN Tools (Version 4.0.0).

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

Введение

Для верификации проектируемых моделей на семантические ошибки прибегают к использованию сетей Петри [1], которые являются четверкой N = (P, T, F, m), где P = {p1,p2, ...,pn} - множество мест; T = {t1, t2, ..., tm} - множество переходов, таких как P n T = 0; F с P х T u T х P - отношение; m{. P ^ N - начальная маркировка (размещение меток в местах сети Петри).

Анализ сетей Петри позволяет выявить тупиковые состояния m' е V, m' = mn,

( mn, tn, mn+1 ), tn i T, мертвые переходы2, зацикливания m' ^ *m , а также проверять свойства ограниченности3 сети, достижимости me[m^ и покрываемости m"e[m'^ маркировок. Одним из популярных способов анализа свойств сети Петри является построение и исследование графа состояний. Граф состояний представляется четверкой ( V, E, src, trg) , где V- множество вершин; E - множество рёбер между вершинами; src, trg . E ^ V - отображает в каждом ребре вершину, из которой оно получено, и вершину, к которой приводит выполнение срабатывания перехода, соответственно. Существует стандартный способ, когда происходит хранение информации обо всех посещенных состояниях сети, и альтернативный способ. метод плавающей линии [2], побитовое хеширование о состоянии [3], метод возможных ребер (comeback метод) [4], метод анализа пространства состояний [5-9].

1 Работа выполнена при финансовой поддержке Минобрнауки России по государственному заданию № 2014/138. Тема проекта «Новые структуры, модели и алгоритмы для прорывных методов управления техническими системами на основе наукоемких результатов интеллектуальной деятельности».

2 Переход называется мёртвым, если не существует достижимая от начальной разметки маркировка ш е [т¡), при которой переход t е Т может сработать (ш, ш').

3 Сеть Петри (Р, Т, F, ш1) ¿-ограничена, если и только если все маркировки ш е [ ш,} и для всех р е Р : ш( р ) < к .

Существует большое количество классов (общие сети GN; общие сети без петель LFN; ординарные сети PN, бесконфликтные сети CFN, сети со свободным выбором FCN, маркированные графы MG, автоматные сети SM) [10] и видов сетей Петри (временные сети, стохастические, ингибиторные, простые, цветные, иерархические, вложенные [11], возможные модификации и др.). Остановимся подробнее на вложенных сетях Петри, в частности, на двухуровневых системах, которые представлены набором:

NPN = (Atom, Lab, SN, (EN,..., EN), Л),

где Atom = Var u Con - множество меток имен переменных Var = {v,...} и имен констант Con = Conatom u Connet ={c,...}; Lab = Labv u Labh - множество меток, использующихся для вертикальной и горизонтальной синхронизации срабатывания переходов; (EN1,..., ENk)(k > 1) - конечный набор обыкновенных (элементных в NPN) сетей Петри; Л - частичная функция пометки переходов, выделяющая некоторые переходы системной сети метками Labv и некоторые переходы в элементных сетях метками Labv u Labh; SN - сеть высокого уровня, которую представляют набором:

SN = (N, L, U, W, M0 ),

где N = (P, T, F) - сеть; L = Expr (Atom) - язык выражений для представления переменных и констант; U - модель языка L; W - функция, сопоставляющая каждой дуге (x, y) е F некоторое выражение W (x, y) = (9^ ..., 9n) размерности n, где 9i е L (1 < i < n) и n - арность позиции, инцидентной дуге (x, y); M0 - начальная разметка сети.

Моделирование распределенной системы на основе вложенных сетей Петри

Одним из вариантов представления вложенных сетей Петри является использование списков в маркировке мест [12, 13], которой сходно со способами, предложенными в [14].

Отдельно выделим сети Петри с нагруженными меткам1 и [15], которые, по сути, являются альтернативным представлением вложенных сетей. В нагруженных метках информация о некоторых из позиций сети закладывается в тип данных некоторой метки. Данная информация интерпретирует количество меток в позиции, состояние или тип данных. Рассмотрим подробнее вложенные сети и сети с нагруженными метками на примере агентства по прокату автомобилей (рис. 1).

Вложенная сеть, моделирующая работу агенства, состоит из системной сети SN и двух элементных сетей EN1 и EN2, представляющих клиентов и автомобили, соответственно. Для того, чтобы учитывать какой именно автомобиль получил конкретный клиент, удобно использовать в качестве фишек пары элементов. В нашем случае рассматриваются пары клиент-автомобиль. Соответственно сеть SN будет содержать фишки следующих типов: атомарные черные, сетевые - автомобили, сетевые - клиенты и пары маркированных сетей (клиент - автомобиль). В системной сети SN фишками в позициях s1, s4 будут черные атомарные фишки (для позиций, представляющих пропозициональные условия); в позициях s5, s8 - сетевые фишки2 - автомобили; в позициях s2, s3 - сетевые фишки - клиенты; в позициях s6, s7 - пары сетевых фишек (клиент, автомобиль).

Приведем значения мест и переходов. Места: s2 - клиенты, желающие арендовать автомобиль; s3 - клиенты, обратившиеся за автомобилем в агентство; s4 - количество арендованных автомобилей; s5 - свободные автомобили; s6 - клиенты вместе с арендованными автомобилями; s7 - клиенты, которые хотят вернуть автомобиль в агентство; s8 - автомобили на мойке; c1 - клиенты, не нуждающиеся в автомобиле; c2 - клиенты, которые хотят арендовать автомобиль; c3 - клиенты, обратившиеся в агентство за автомобилем; c4 - клиенты, использующие автомобиль; c5 - клиенты, желающие вернуть автомобиль в агентство; c6 - клиенты, обратившиеся в агентство, чтобы вернуть автомобиль; a1 - автомобиль в гараже агентства; a2 - автомобиль

1 Нагруженная метка - метка с дополнительной информацией о структуре системы или об истории ее передвижения.

2 Сетевая фишка - фишка, перемещающаяся в системной и элементной сетях.

арендован; а3 - автомобиль используется; а4 - автомобиль находится на мойке. Переходы: 11 - клиенты, обратившиеся в агентстве за автомобилем (агентство, клиент); 12 - отказ в аренде (агентство, клиент); 13 - передача автомобиля клиенту (агентство, клиент, автомобиль); 14 - обращение в агентство для возврата автомобиля (агентство, клиент, автомобиль); 15 - возвращение автомобиля в агентство (агентство, клиент, автомобиль); 16 - возвращение автомобиля в гараж агентства (агентство, автомобиль).

Рис. 1. Вложенная сеть Петри на примере агентства по прокату автомобилей (по [11])

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

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

Моделирование распределенной системы на основе сетей Петри с нагруженными метками

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

Рис. 2. Сеть Петри с нагруженными метками на примере агентства по прокату автомобилей, способ 1

При проектировании данной сети использовались следующие типы данных и переменные:

- colset INT = int;

- colset CAC = product INT x INT x INT;

- colset CC = product INT x INT;

- colset CA = product INT x INT;

- colset C = INT;

- var cac : CAC;

- var cc : CC;

- var ca : CA.

Места элементных сетей PEN ={q, c2, c3, c4, c5, c6} и Рщ ={a,, a2, a3, a4, a} преобразуются в переменные, добавленные к маркировкам у соответствующих мест, т. к. элементные сети интерпретируются при использовании нагруженных меток. Значение переменной соответствует индексу места, с которым она соотносится, например, в месте s2 находится фишка только со значением m2 = (l (2, 2)). Для удобства состояния системной сети добавлены к типам данных, например, позиция s7 содержит фишки с комбинированным типом данных (INT x INT x INT), т. е. можно отследить состояние клиента и автомобиля по отношению к агентству. Место a3

и переходы a1, a2 добавляются к системной сети из элементных {s6} [a^ {a3}, {a3} [a2^ {s6}.

Изменение переменных происходит при срабатывании перехода за счет увеличения или уменьшения значений. Места c1 и s5 содержат пять и четыре фишки, соответственно, что означает пять потенциальных клиентов и четыре автомобиля в наличии у агентства.

Анализ сети проводился в программной среде CPN Tools Version 4.0.0, которая автоматически исследует пространство состояний с последующим сохранением результатов в текстовый файл (таблица).

Результаты анализа сети Петри

State Space. Nodes: 54, Arcs: 116, Secs: 0, Status: Full Пространство имеет 54 состояния и 116 взаимосвязи между ними

Dead Markings - None Тупиковых маркировок в сети нет

Dead Transition Instances - None Мёртвых переходов в сети нет

Live Transition Instances - All Все переходы живые, т. е. срабатывают при моделировании

Для реализации второго способа используется три места {Р = CAC} (Company, Automobile, Client) и восемь переходов (рис. 3). Проектирование данной сети осуществляется на основе следующих типов данных и переменных:

- colset INT = int;

- colset company = product INT x INT x INT x INT x INT x INT x INT x INT;

- colset automobile = product INT x INT x INT x INT x INT;

- colset client = product INT x INT x INT x INT x INT x INT;

- var Со, ci, С2, C3, C4, C5, c6? cy, cs: INT;

- var ao, ab a2, аз, a4, a5 : INT;

- var clo, cli, c/2, c/3, c/4, c/5, с/б: INT.

ill' (1,0,0,1,2,0,0,0)1 l| Company

Company (Cl.c2+l,c3,c4,c5,c6,c7.c8) Company -> II (cl,c2,c3,c4,c5,c6,c7,c8)

11 -> Company (Cl,c2-l,c3+l,c4,c5,c6,c7,c8) Company -> 12 (cl.c2,c3,c4,c5,c6,c7,cS)

12 -> Company (cl,c2,c3-l,c4,c5,c6,c7,c8) Company -> 13 (cl,c2.c3,c4,c5,c6.c7,cS)

13 -»Company (cl,c2,c3-l,c4+l,c5-l,c6+l,c7,c Company-> 14 (cl,c2,c3,c4,c5,c6,c7,cS) , , л , ... 11Г

14 -> Company (cl,c2,c3,c4,c5,c6-l,c7+l,cS) Cpl-lia2+l#d3id4fd5(d6)

Company -> 15 (с1,с2,сЗ,с4,с5,с6,с7,с*

15 -> Company (cl,c2,c3,c4-l,c5,c&,c7-l,cS+l) Company -> 16 (cl.c2,c3,c4,c5,c6,c7,cB)

16 -> Company (cl,c2,c3,c4,c5+l,c6,c7,c8-l)

t -> [cl=l andalso cll>0]

11 -> [cl=l andalso c2>0 andalso cl2>0]

12 -> [cl=l andalso c3>0 andalso c4>0 andalso cl3>0]

13 -> [cl=l andalso c3>0 andalso c5>0 andalso cl3>0 andalso al>0]

14 -> [cl=l andalso c6>0 andalso cl4>0 andalso a2>0]

15 -> [cl=l andalso c4>0 andalso c7>0 andalso cl6>0 andalso a4>0]

16 -> [cl=l andalso c8>0 andalso a5>0] al -> [d4>0 andaiso a2>0]

a2 -> [cl5>0 andalso a3>0]

(dl,d2,d3,d4,d5,< (dl,cl2-l,cl3+l,d4, (cll.cl2,d3,c (cll+l,d2,d: (dl.c

(cli,d:

J6) 14,< 5,c

<d:

1'(1,0,0,0,0,0) 1

Client dient

Ü2 ]

Eids) 4.ql5,c 44- i,c :,cJ3,cl d3rcl4 -

2

"Ж *

»3

5,фб)

:H5, ,q!3,c

Vl

Г"

1-Г

i)

i5,ds)

1. 12.

Id:

(al,a2,a3,a4,a5) ( Automobile

(a 1-1, a2+1 ,a3,a4,a5)

(al,a2,a3,a4,a5)

(al,a2-l,a3,a4 fl,a5)

(al,a2,a3,a4,a5)

(al,a2,a3,a4,a5)

(al+l,a2,a3,a4 ,a5-l)

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

(al,a2,a3,a4,a5)

(al,a2-l,a3+l

:I6)

-I,il5+l,d6) :I2,( 3,d4,cl5,

is)

-J-

(al,a2,a3,a4,a5)

(a l,a2+ l,a3-l ,a4,a5)

I a2

J

r (1,0,0,0,0)

Рис. 3. Сеть Петри с нагруженными метками на примере агентства по прокату автомобилей, способ 2

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

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

Реализация рекурсии с использованием вложенных сетей Петри

В представленном ранее примере сеть имеет только один уровень вложенности. Но существует вложенность нескольких уровней [11]:

NPN = (N, A^, I, N0, M0),

где N = (N0,..., Nk) - конечный набор сетевых компонент (сетевых фишек); Aatom - конечный набор сетевых фишек; I - интерпретация констант в выражениях на дугах в N ; N0 - выделенная компонента (системная сеть); M0 - разметка системной сети No над N и Aatom.

Данное свойство рассмотрим на примере реализации рекурсии [11-14], а именно - вычисления факториала (рис. 4).

Рекурсивная NP-сеть RN, изображенная на рис. 4, состоит из системной сети F0 и элементной сети F. Константа F, приписанная дуге, интерпретируется как элементная сеть F с начальной разметкой. Значения переменной x - сеть F с возможными (достижимыми) маркировками.

Исполнение рекурсивной RN происходит следующим образом. Изначально системная сеть имеет единственную фишку (черную точку) в позиции p1. Первый шаг выбирается недетермини-ровано и зависит от начального значения аргумента n вычисляемой функции. Если n = 0, то срабатывает переход t1 (что соответствует вычислению fact (0) = 1) и вычисление завершается.

I

Рис. 4. Рекурсивная вложенная сеть Петри нахождения факториала числа (по [11])

Если n Ф 0, то срабатывает переход t2, порождая элементную сеть F с начальной разметкой, что соответствует уменьшению n на 1 и внутреннему вызову процедуры вычисления факториала. После этого системная сеть F0 содержит сетевую фишку (сеть F с начальной разметкой) в позиции p3. Далее в этой сетевой фишке может сработать переход s2, что приведет к появлению новой сетевой фишки и нового уровня в сети RN. При срабатывании перехода s1 происходит синхронизация с переходом s3, помеченным меткой l в сети предыдущего уровня. Это приводит к исчезновению сетевой фишки самого нижнего уровня и уменьшению числа уровней в NP-сети на 1. При срабатывании перехода s4 в сетевой фишке (текущего) самого нижнего уровня происходит синхронизация с переходом s3 в «родительской» сети, что также уменьшит число уровней на 1. Этот процесс будет продолжаться до тех пор, пока в разметке не останется только один уровень -системная сеть с черной точкой в позиции p3, после чего исполнение завершится.

Реализация рекурсии с использованием сетей Петри с нагруженными метками

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

В данном исполнении нахождение факториала происходит от искомого числа до единицы с уменьшением текущего значения на каждом шаге. Если значение на предыдущем шаге равно 0, то срабатывает переход Recursion 1, который декрементирует значение первой переменной и вычисляет вторую посредством произведения текущего значения числа, уменьшенного на 1. Если значение первой переменной не равно 1, а вторая переменна не равна 0, то сработает переход Recursion 2, который декрементирует значение первой переменной и вычисляет вторую посредством произведения текущего значения числа полученным на прошлом шаге произведением. Если первая переменная равна 1, то сработает переход Complete: в место Complete попадет фишка с найденным значением искомого факториала.

[x = 1] (x, i)

Рис. 5. Сеть Петри с нагруженными метками нахождения факториала числа

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

Заключение

На основе проведенных исследований вложенных сетей Петри и сетей с нагруженными метками сделаны предположения о подходящих областях их использования. Представлены положительные и отрицательные аспекты видов сетей на примере агентства по прокату автомобилей. Вложенные сети - это мощный инструмент, на основе которого показаны параллельные процессы, сложные многоуровневые системы без дополнительных мест, переходов и их взаимосвязей, синхронизация разных потоков информации и представление в разных сетях одинаковых мест с разной маркировкой, что весьма удобно. Отметим, что предпочтительным является применение сетей с нагруженными метками (метки с дополнительной информацией о структуре системы или об истории её изменений), если предполагается использование вложенных сетей одного или двух уровней.

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

СПИСОК ЛИТЕРАТУРЫ

1. Романников Д. О. Разработка программного обеспечения с применением UML диаграмм и сетей Петри для систем управления локальным оборудованием: дис. ... канд. техн. наук / Д. О. Романников. Новосибирск, 2012. 195 с.

2. Christensen S. A. Sweep-Line Method for State Space Exploration / S. A. Christensen, L. M. Kristensen, T. Mailund // URL: http://www.tzi.de/~edelkamp/lectures/dmc/slides/sweep.pdf.

3. Holzmann G. J. An Improved Protocol Reach ability Analysis Technique / G. J. Holzmann // URL: http: //spinroot.com/spin/Doc/spe88. pdf.

4. Westergaard M. Behavioural Verification and Visualisation of Formal Models of Concurrent Systems / M. Westergaard // URL: https://westergaard.eu/wp-content/uploads/2009/10/thesis.pdf.

5. Марков А. В. Анализ сетей Петри при помощи деревьев достижимости: / А. В. Марков, А. А. Воевода // Сб. науч. тр. Новосибир. гос. техн. ун-та. 2013. № 1 (71). С. 78-95.

6. Марков А. В. Анализ отдельных частей дерева достижимости сетей Петри / А. В. Марков // Сб. науч. тр. Новосибир. гос. техн. ун-та. 2013. № 3 (73). С. 58-74.

7. Воевода А. А. Инверсия простой ординарной сети Петри / А. А. Воевода, А. В. Марков // Науч. вест. Новосибир. гос. техн. ун-та. 2013. №4 (53). С. 215-218.

8. Марков А. В. Инверсия сетей Петри / А.В. Марков // Сб. науч. тр. Новосибир. гос. техн. ун-та. 2013. № 4 (74). С. 97-121.

9. Марков А. В. Проверка достижимости маркировки сетей Петри при помощи инвертирования деревьев состояний для протокола передачи данных / А. В. Марков, А. А. Воевода // Докл. Томск. гос. ун-та систем управления и радиоэлектроники. 2014. №1 (31). С. 143-148.

10. Бандман М. К. Территориально-производственные комплексы: прогнозирование процесса формирования с использованием сетей Петри / М. К. Бандман, О. Л. Бандман, Т. Н. Есикова. Новосибирск: Наука, 1990. 303 с.

11. Ломазова И. В. Вложенные сети Петри: моделирование и анализ распределенных систем с объектной структурой / И. В. Ломазова. Москва: Научный мир, 2004. 208 с.

12. Дворянский Л. В. Имитационное моделирование и верификация вложенных сетей Петри с использованием CPN Tools / Л. В. Дворянский, И. В. Ломазова // Моделирование и анализ информационных систем. 2012. Т. 19. № 5. С. 115-130.

13. Марков А. В. Моделирование процесса поиска пути в лабиринте при помощи сетей Петри / А. В. Марков // Сб. науч. тр. Новосибир. гос. техн. ун-та. 2010. № 4 (62). С. 133-140.

14. Марков А. В. Поиск манипулятором кратчайшего пути в лабиринте / А. В. Марков // Сб. науч. тр. Новосибир. гос. техн. ун-та. 2011. №4 (66). С. 75-90.

15. Воевода А. А. Рекурсия в сетях Петри / А. А. Воевода, А. В. Марков // Сб. науч. тр. Новосибир. гос. техн. ун-та. 2012. № 3 (69). С. 115-122.

16. Марков А. В. Понятие рекурсии в сетях Петри: факториал числа, числа Фибоначчи / А. В. Марков, А. А. Воевода // Сб. науч. тр. Новосибир. гос. техн. ун-та. 2013. №1 (71). С. 72-77.

Статья поступила в редакцию 02.02.2015, в окончательном варианте - 27.03.2015

ИНФОРМАЦИЯ ОБ АВТОРАХ

Марков Александр Владимирович - Россия, 630073, Новосибирск; Новосибирский государственный технический университет; аспирант кафедры «Автоматика»; [email protected].

Воевода Александр Александрович - Россия, 630073, Новосибирск; Новосибирский государственный технический университет; д-р. техн. наук, профессор; профессор кафедры «Автоматика»; [email protected].

А. V. Markov, А. А. Voevoda

NESTED PETRI NETS AND LOADED INSCRIPTION LABELS: DISTRIBUTED SYSTEM AND RECURSION

Abstract. For modeling concurrent processes, complex multi-level systems without additional places, transitions, and their relationships, synchronization of different flows of information and views on different nets of the same places with different markings, nested Petri nets are used. An alternative to this type of the nets are nets with loaded inscription labels containing additional information about the structure of the system or history of its changes. Comparison of the approaches to construction of Petri nets based on the nested nets and nets with loaded inscription labels is made by the example of the analysis of the distributed system of car rent agency and the recursive task -finding factorial. The analysis of the distributed system of the agency is made on the basis of two-level nested Petri nets using vertical and horizontal synchronization. In order to compare, the analysis based on the loaded inscriptional labels is carried out in two ways. In the first case, the structure of the system net is taken as a basis; in the second case the net consists of three parts, to each of which a certain set of data types is added to display the possible system states. Finding factorial of the number y in the nested Petri nets is made through vertical synchronization of transitions between the system net and the element nets, and while using the loaded inscription labels it is carried out via the combined data type of the net parts. The variable of the first data type displays the number of the desired factorial, and in the second case the value of the current variable calculated in the previous step is observed. Modeling and automatic analysis of Petri nets for these examples occur in the software environment CPN Tools (version 4.0.0).

Key words: nested Petri nets, loaded inscription labels, recursion, distributed systems, factorial, combined data type, horizontal and vertical synchronization of transitions.

REFERENCES

1. Romannikov D. O. Razrabotka programmnogo obespecheniia s primeneniem UML diagramm i setei Petri dlia sistem upravleniia lokal'nym oborudovaniem. Dis. kand. tekhn. nauk [Development of the software using UML diagrams and Petri nets for the systems of control of local equipment. Dis. cand. tech. sci.]. Novosibirsk, 2012. 195 p.

2. Christensen S. A., Kristensen L. M., Mailund T. Sweep-Line Method for State Space Exploration. Available at: http://www.tzi.de/~edelkamp/lectures/dmc/slides/sweep.pdf.

3. Holzman G. J. An Improved Protocol Reach ability Analysis Technique. Available at: http://spinroot. com/spin/Doc/spe88.pdf.

4. Westergaard M. Behavioural Verification and Visualisation of Formal Models of Concurrent Systems. Available at: https://westergaard.eu/wp-content/uploads/2009/10/thesis.pdf.

5. Markov A. V., Voevoda A. A. Analiz setei Petri pri pomoshchi derev'ev dostizhimosti [Analysis of Petri nets by means of accessibility trees]. Sbornik nauchnykh trudov Novosibirskogo gosudarstvennogo tekhnicheskogo universiteta, 2013, no. 1 (71), pp. 78-95.

6. Markov A. V. Analiz otdel'nykh chastei dereva dostizhimosti setei Petri [Analysis of the separate parts of the accessibility tree of Petri nets]. Sbornik nauchnykh trudov Novosibirskogo gosudarstvennogo tekhnicheskogo universiteta, 2013, no. 3 (73), pp. 58-74.

7. Voevoda A. A., Markov A. V. Inversiia prostoi ordinarnoi seti Petri [Inversion of simple ordinary Petri net]. Nauchnyi vestnik Novosibirskogo gosudarstvennogo tekhnicheskogo universiteta, 2013, no. 4 (53), pp. 215-218.

8. Markov A. V. Inversiia setei Petri [Inversion of Petri nets]. Sbornik nauchnykh trudov Novosibirskogo gosudarstvennogo tekhnicheskogo universiteta, 2013, no. 4 (74), pp. 97-121.

9. Markov A. V., Voevoda A. A. Proverka dostizhimosti markirovki setei Petri pri pomoshchi invertirovaniia derev'ev sostoianii dlia protokola peredachi dannykh [Testing the accessibility of labeling of Petri nets using the inverting of state trees for the protocol of data transmission. Doklady Tomskogo gosudarstvennogo universiteta sistem upravleniia i radioelektroniki, 2014, no. 1 (31), pp. 143-148.

10. Bandman M. K., Bandman O. L., Esikova T. N. Territorial'no-proizvodstvennye kompleksy [Territorial and industrial complexes]. Novosibirsk, Nauka Publ., 1990. 303 p.

11. Lomazova I. V. Vlozhennye seti Petri: modelirovanie i analiz raspredelennykh sistem s ob"ektnoi struk-turoi [Nested Petri nets: modeling and analysis of the distributed systems with the objective structure]. Moscow, Nauchnyi mir Publ., 2004. 208 p.

12. Dvorianskii L. V., Lomazova I. V. Imitatsionnoe modelirovanie i verifikatsiia vlozhennykh setei Petri s is-pol'zovaniem CPN Tools [Simulation and verification of the nested Petri nets using CPN Tools]. Modelirovanie i analiz informatsionnykh sistem. 2012, vol. 19, no. 5. pp. 115-130.

13. Markov A. V. Modelirovanie protsessa poiska puti v labirinte pri pomoshchi setei Petri [Modeling the process of searching the way in the labyrinth using Petri nets]. Sbornik nauchnykh trudov Novosibirskogo gosu-darstvennogo tekhnicheskogo universiteta, 2010, no. 4 (62), pp. 133-140.

14. Markov A. V. Poisk manipuliatorom kratchaishego puti v labirinte [Search of the fastest way in the labyrinth using manipulator]. Sbornik nauchnykh trudov Novosibirskogo gosudarstvennogo tekhnicheskogo universiteta, 2011, no. 4 (66), pp. 75-90.

15. Voevoda A. A., Markov A. V. Rekursiia v setiakh Petri [Recursion in Petri nets]. Sbornik nauchnykh trudov Novosibirskogo gosudarstvennogo tekhnicheskogo universiteta, 2012, no. 3 (69), pp. 115-122.

16. Markov A. V., Voevoda A. A. Poniatie rekursii v setiakh Petri: faktorial chisla, chisla Fibonachchi [The notion of recursion in Petri nets: factorial, Fibonacci number]. Sbornik nauchnykh trudov Novosibirskogo gosu-darstvennogo tekhnicheskogo universiteta, 2013, no. 1 (71), pp. 72-77

The article submitted to the editors 02.02.2015, in the final version - 27.03.2015

INFORMATION ABOUT THE AUTHORS

Markov Alexander Vladimirovich - Russia, 630073, Novosibirsk; Novosibirsk State Technical University; Postgraduate Student of the Department "Automation"; [email protected].

Voevoda Alexander Aleksandrovich - Russia, 630073, Novosibirsk; Novosibirsk State Technical University; Doctor of Technical Sciences, Professor; Professor of the Department "Automation"; [email protected].

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