Опубликован: 19.11.2012 | Уровень: для всех | Доступ: платный | ВУЗ: Национальный исследовательский университет "Высшая Школа Экономики"
Лекция 8:

Обработка данных

< Лекция 7 || Лекция 8: 123456 || Лекция 9 >

Формальное определение сети Петри

Чтобы можно было использовать сети Петри для анализа процессов обработки, необходимо иметь точное определение.

Графом сети Петри будем называть тройку (Р, Т, F), где

P - непустое множество элементов сети, называемых местами,

T - непустое множество элементов сети, называемых переходами,

F\subseteq Р \times Т \bigcup T \times P- отношение инцидентности,

и для (Р, Т, F) выполнены следующие условия:

  • P \bigcap T=\varnothing (множества мест и переходов не пересекаются);
  •  (F \ne \varnothing) \wedge (\forall x \in P \bigcup T, \exists y \in P \bigcup T : xFy \vee yFx)) (т.е. любой элемент сети инцидентен хотя бы одному элементу другого типа);
  • если для произвольного элемента сети x \in X обозначить через *x множество его входных элементов \{y|yFx\}, а через x* - множество его выходных элементов \{y|xFy\}, то

    \forall p_1,p_2 \in P:(^{\cdot}p_1=^{\cdot}p_2)\wedge(p_1^{\cdot}=p_2^{\cdot})\Rightarrow (p_1=p_2),

    то есть сеть не содержит пары мест, которые инцидентны одному и тому же множеству переходов.

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

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

Сеть Петри - это набор N=\{Р, Т, F, Ф, M_0\}, где (Р, Т, F) - конечная сеть (множество X= Р \bigcup T конечно), a Ф:P \times T \bigcup T \times P \to N и M_0 :P\to N- две функции, называемые соответственно кратностью дуг и начальной разметкой. Первая сопоставляет каждой дуге число n \ge 0 (кратность дуги). Если n>0, то в графическом представлении сети число n выписывается рядом с короткой чертой, пересекающей дугу. Часто такая дуга будет также заменяться пучком из п дуг, соединяющих соответствующие элементы сети. Условимся никак не отмечать кратность дуг, равную 1. Такую сеть будем называть ординарной. Вторая функция сопоставляет каждому месту p \in Р некоторое число M_0(p) \in N (разметка места). В графическом представлении сети разметка места р изображается помещением в вершину-кружок числа M_o(р) или, если это число невелико, соответствующего числа точек (фишек).

Разметка сети N - это функция M:P \to N. Если предположить, что все места сети N строго упорядочены каким-либо образом, т.е. P=(p_1, p_2, \dots , p_n), то разметку М сети (в том числе начальную разметку) можно задать как вектор целых неотрицательных чисел

M=\begin{pmatrix}m_1\\m_2\\\vdots\\m_n\end{pmatrix}

такой, что для любого i, 1 <i<n, m_i = M(p_i) .

На основе отношения инцидентности F можно ввести функцию инцидентности Ф: P \times T\bigcup T \times P \to N, которая определяется выражением

Ф(х,у)=\begin{cases}n \in N^+, \mbox {\ если\ } xFy\\o, \mbox {\ если\ } \neg xFy\end{cases}

Значения функции Ф(x, y) можно трактовать как кратность дуги между вершинами сети x и y. Если Ф(x, y) = 0, то это означает, что между вершинами x и y дуги нет.

Если места сети упорядочены, то можно каждому переходу t сопоставить два целочисленных вектора  'F(t) и F'(t) длиной n, где n = |Р|:

Ф(t)=\begin{pmatrix}b_1\\b_2\\\vdots\\b_n\end{pmatrix}, \; где\; b_i=Ф(p_i,t)

и

Ф(t)=\begin{pmatrix}b_1\\b_2\\\vdots\\b_n\end{pmatrix}, \; b_1=Ф(t,p_i)

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

Переход t может сработать при некоторой разметке М сети N, если \forall p \in 't M(p) \ge Ф(p,t) , то есть каждое входное место p перехода t имеет разметку, не меньшую, чем кратность дуги, соединяющей р и t. Это условие можно переписать в векторной форме следующим образом: M \ge 'Ф(t) .

Предполагается, что для векторов x \in R^n, y\in R^n выражение x \ge y озна-чает, что x_i \ge y_i, i= 1, 2,\dots, n.

Из определения векторов 'Ф(t) и Ф'(t) ясно, что вектор  'Ф(t) является столбцом матрицы D^-, а вектор Ф'(t) является столбцом матрицы D^+

D^-=\begin{pmatrix}
Ф(p_1,t_1)&Ф(p_1,t_2)&\dots&Ф(p_1,t_m)\\
Ф(p_2,t_1)&Ф(p_2,t_2)&\dots&Ф(p_2,t_2)\\
\vdots&\vdots&\ddots&\vdots\\
Ф(p_n,t_1)&Ф(p_n,t_2)&\dots &Ф(p_n,t_m)
\end{pmatrix},
D^+=\begin{pmatrix}
Ф(t_1,p_1)&Ф(t_2,p_1)&\dots&Ф(t_m,p_1)\\
Ф(t_1p_2)&Ф(t_2,p_2)&\dots&Ф(t_m,p_2)\\
\vdots&\vdots&\ddots&\vdots\\
Ф(t_1,p_n)&Ф(t_2,p_n)&\dots &Ф(t_m,p_n)
\end{pmatrix}

Векторы 'Ф(t) и Ф'(t) могут быть представлены как произведения D^- \times \tau_i и D^+ \times \tau_i матриц D^- и D^+ на вектор х_i вида

\tau_i=\begin{pmatrix}0\\0\\\vdots\\1\\\vdots\\0\end{pmatrix}\mbox{i-я строка} ( 8.3)

у которого все компоненты равны 0, кроме i -й компоненты, равной 1.

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

Срабатывание перехода t_i при разметке M порождает разметку М' по следующему правилу:

\forall p \in P\;  М(р) = М(р)-Ф(р,t_i) + Ф(t_i,р)

В матричном виде изменение разметки при срабатывании перехода t_i описывается выражением

М' = М-'Ф(t_i)+Ф'(t_i) \mbox{или} M'=M-D^- *\tau_i+D^+*\tau_i ( 8.4)

Обозначив D=D^+ - D^- , получим еще более краткую запись для выражения (8.4)

M=M+D^-*\tau_t ( 8.5)

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

Элемент матрицы D=D^+-D-, находящийся в i-й строке и j-м столбце, представляет собой разность числа появившихся и удаленных в i-м месте фишек в результате срабатывания j-го перехода.

На множестве разметок можно ввести отношение непосредственного следования разметок:

М \triangleright М \leftrightarrow \exists t \in Т:(М\ge Ф(t) \wedge(М'= - 'Ф(t) + Ф'(t))

Будем использовать уточняющее обозначение  М^t \triangleright М', если  М' непосредственно следует после М в результате срабатывания перехода  t. Говорят, что разметка М' достижима от разметки  М, если существует последовательность разметок  М, М_1, М_2, \dots , М' и слово \tau= t_1t_2 \dots t_k в алфавите  Т, такие что

 М^{t_1}\triangleright М^{t_2} \triangleright М^{t_2} \dots \triangleright М'

Слово \tau в этом случае называется последовательностью срабатываний, ведущих от М к М'. Обобщим отношения непосредственного следования до отношения " М' достижима от  М", используя обозначение М \triangleright М или M^{\tau} \triangleright М' , если уточняется последовательность срабатываний (последовательность может быть пустой, т.е. М' не достижима от М).

Множество \{М'| М\triangleright М'\} разметок, достижимых в сети N от разметки М, обозначим через R(N, М). Множество R(N) = R(N, M_0) , т.е. множество всех разметок, достижимых в N от начальной разметки М_0, называют множеством достижимых разметок сети N (заметим, что M \in R(N, М) и M_0 \in R(N)).

Множеством последовательностей срабатываний сети N, или свободным языком сети N, называется множество

L(N) =\{\tau \in T'| \exists M\in R(N):M_0^{\tau}\triangleright M\)

то есть множество всех последовательностей срабатываний, ведущих от М_0 к каждой достижимой в N разметке.

На рис.8.6 изображена сеть Петри, на примере которой поясним данные выше определения. В этой сети Р=\{p_1, p_2, p_3\}, T=\{t_1, t_2, t_3\}. Функция инцидентности Ф задается с помощью следующих двух таблиц, в которых на пересечении строки х и столбца y стоит число Ф(x, y):

p_1 p_2 p_3
t_1 1 1 0
t_2 0 0 1
t_3 0 2 0
t_4 1 0 0
t_1 t_2 t_3 t_4
p_1 1 1 0 0
p_2 0 2 0 0
p_3 0 0 1 1

Начальная разметка M_0 задается следующим образом: M_0(p_1) = 1, M_0(p_2) = 2, M_0(p_3) =0, или в векторной форме: M_0 = (1, 2, 0)^т.

При разметке M_0 могут сработать переходы t_1 и t_2, так как M_0 = (1,2,0)^т > 'Ф(t_1) = (1,0,0)^т, M_0 > 'Ф(t_2) = (1,2,0)^т. Переходы t_3 и t_4 не могут сработать, так как вектор начальной разметки M_o не покрывает векторы  'Ф(t_3) = (0, 0, 1)^т, и  'Ф(t_4 ) = (0, 0, 1)^т.

Пример сети Петри

Рис. 8.6. Пример сети Петри

В результате срабатывания перехода t_1 разметка M_0 сменяется на разметку (1, 3, 0), а в результате срабатывания перехода t_2 разметка М_0 сменяется на разметку (0, 0, 1) . Обе новые разметки непосредственно следуют после M_0 в рассматриваемой сети. Можно представить возможные изменения разметок сети N, происходящие в результате срабатывания ее переходов, в виде графа разметок - ориентированного графа, множество вершин которого образовано множеством R(N) достижимых в N разметок. Из вершины М в вершину М' ведетa дуга, помеченная символом перехода t, если и только если М^t \triangleright М' . На рис.8.7 показан начальный фрагмент графа разметок сети на рис.8.6. Этот граф бесконечен, так как множество R(N) достижимых разметок бесконечно для рассматриваемой сети.

Разметка M \in R(N) называется тупиковой, если в сети N не существует ни одного перехода, который может сработать при этой разметке. Для рассматриваемой сети тупиковыми являются разметки (0, 2, 0), (0, 3, 0), (0,4,0),..., (0, n, 0)...

Легко видеть, что если выделить путь по дугам графа разметок, начинающийся в вершине М и заканчивающийся в вершине М', и выписать подряд все встречающиеся символы переходов, то полученное слово образует последовательность срабатываний, ведущих от М к М'. Множество всех слов, которые получены выписыванием символов переходов вдоль путей, начинающихся в M_0, образует множество последовательностей срабатываний сети, или ее свободный язык. Так, язык рассматриваемой сети включает слова \{\epsilon , t_1, t_2, t_1t_1, t_1t_2, t_2t_3, t_2t_4, t_1t_1t_1, t_1t_1t_2t, t_1t_2t_3, t_1t_2t_4, t_2t_4t_1, t_1t_1t_1t_1, t_1t_1t_1t_2, \dots \}.

< Лекция 7 || Лекция 8: 123456 || Лекция 9 >
Фахруддин хемракулыев
Фахруддин хемракулыев
Шерхон Давлатов
Шерхон Давлатов

Почему тесты (1,2,3..) не работают. Хочу пройти тест но не получается

Денис Шаяхметов
Денис Шаяхметов
Россия, г. Нижневартовск
Кирилл Коршук
Кирилл Коршук
Беларусь, Минск, Международный университет МИТСО