Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
ИМИТАЦ_МОДЕЛИРОВАНИЕ_лекции_last.doc
Скачиваний:
1
Добавлен:
01.05.2025
Размер:
4.6 Mб
Скачать

Лекция №6.

Сетевые модели (N-схемы). Сети Петри

Основные соотношения. Для формального описания структуры и взаимодействия параллельных систем и процессов, а также анализа причинно-следственных связей в сложных системах используются сети Петри (англ. Petri Nets), называемые N-схемами.

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

Формально N-схема задается четверкой вида

N = <B, D, I, O>,

где В – конечное множество символов, называемых позициями, BO;

D – конечное множество символов, называемых переходами D O,

B D = O;

I – входная функция (прямая функция инцидентности), I: BD  0, 1;

О – выходная функция (обратная функция инцидентности),

О: B  D  0, 1.

I - переход dj в множество входных позиций bj I(dj),

O - переход dj в множество выходных позиций bj О(dj).

Для каждого перехода dj  D

I(dj) = { biB I(bi, dj) = 1 },

O(dj) = { biB O(dj, bi) = 1 },

i = ; j = ; n = | B |, m = | D |.

Для каждой позиции bi B

I(bi) = { dj D I(dj, bi,) = 1 },

O(bi) = { dj D O(bi, dj) = 1 }.

Таким образом входная функция I отображает переход dj в множество входных позиций bj I(dj), а выходная функция O отображает переход dj в множество выходных позиций bj О(dj). Для каждого перехода dj D можно определить множество входных позиций перехода I(dj) и выходных позиций перехода O(dj) как

Аналогично для каждой позиции bi B вводятся определения множеств входных переходов позиции I(bi) и выходных переходов позиции O(bi):

Графически N-схема изображается в виде двудольного ориентированного мультиграфа, представляющего собой совокупность позиций и переходов (рис. 1). Граф N-схемы имеет два типа узлов: позиции и переходы, изображаемые O и | соответственно. Ориентировочные дуги соединяют позиции и переходы, причем каждая дуга направлена от элемента одного множества (позиции или перехода) к элементу другого множества (переходу или позиции). Граф N-схемы является мультиграфом, так как он допускает существование кратных дуг от одной вершины к другой.

Рис. 1. Графическое изображение N-схемы

Пример. Представим формально N-схему, показанную в виде графа на рис. 1:

N = <B, D, I, O>,

B = <b1, b2, b3, b4, b5>,

D = <d1, d2, d3, d4>.

Входные позиции перехода Выходные позиции

перехода

I(d1)={b1}, O(d1)={b2, b3, b5},

I(d2)={b2, b3, b5}, O(d2)={b5},

I(d3)={b3}, O(d3)={b4},

I(d4)={b4}. O(d4)={b2, b3}.

Возможные приложения N-схем. Приведенное представление N-схемы может использоваться только как отражение статики моделируемой системы (взаимосвязи событий и условий), но не позволяет отразить в модели динамику функционирования моделируемой системы. Для представления динамических свойств объекта вводится функция маркировки (разметки) позиций М: В  {0, 1, 2, …}. Маркировка М есть присвоение неких абстрактных объектов, называемых метками (фишками), позициям N-схемы, причем количество меток, соответствующее каждой позиции, может меняться. При графическом задании N-схемы разметка отображается помещением внутри вершин позиций соответствующего числа точек (когда количество точек велико, ставят цифры).

М: В  {0, 1, 2, …}.

Маркированная (размеченная) N-схема может быть описана в виде

NМ = <B, D, I, O, M>.

М0: В  {0, 1, 2, …}.

Функционирование N-схемы отражается путем перехода от разметки к разметке. Начальная разметка обозначается как Смена разметок происходит в результате срабатывания одного из переходов dj D сети.

Правило срабатывания перехода

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

1) переход разрешен, если все входные значения b помечены не менее чем w(b, d) фишками, где w(b, d) - вес дуги от b к d;

2) запуск разрешенного перехода носит случайный характер (в зависимости от наступления или ненаступления соответствующего события.

3) запущенный переход d изымает w(b, d) фишек из каждой своей входной позиции и добавляет w(d, b) фишек в каждую свою выходную позицию. Здесь w(d, b) - вес дуги, ведущей из d в b.

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

/* не беру в 2012-2013 уч.г.

Пример. Рассмотрим размеченную N-схему с начальной разметкой M0 = {1, 0, 0, 0, 1, 0, 1}, которая приведена на рис. 2.8, а. При такой начальной разметке N-схемы единственным готовым к срабатыванию является переход d2, срабатывание которого ведет к смене разметки на M1, где M1 = {0, 1, 1, 0, 1, 0, 1} (рис. 2).

Рис.2. Пример функционирования размеченной N-схемы:

а

б

в

г

д

Рис. 2. (Окончание)

При разметке M1 возможно срабатывание переходов d1 d3 и d5. В зависимости от того, какой переход сработал первым, получается одна из трех возможных новых маркировок (рис. 2., в, г, д). Функционирование N-схемы продолжается до тех пор, пока существует хотя бы один возможный переход.

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

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

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

Пример. Требуется описать с помощью сети Петри функционирование системы из предприятий A, В и С. Предприятия А и В поставляют узлы Х1 и X2 соответственно, а на предприя­тии С происходит сборка, в каждый сборочный узел входит один узел X1 и два узла X2. На рис. 2.10 предприятиям А, В и С соответствуют переходы t1, t2 и t3.

Рис. 3. Сеть Петри для примера

Срабатывание перехода t3 происходит только в том случае, если, во-первых, в позиции pl имеется метка, а в позиции р2 - не менее двух меток, что означает поступление от предприятии А и В соответствующих комплектующих, и, во-вторых, имеется метка в позиции p4, что означает, что предприятие С закончило сборку предыдущего изделия и готово приступить к сборке следующего. Пока очередное изделие не будет собрано, метки в p4 не будет, следовательно, запросы, пришедшие во входные позиции р1 и р2, вынуждены ожидать срабатывания перехода t4. Переходам t1, t2 и t3 поставлены в соответствие процедуры вычисления задержек срабатывания. Задержки в первых двух переходах равны интервалам времени между появлениями готовых узлов, задержка в t3 равна времени сборки изделия.

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

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

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

Несомненным достоинством сетей Петри является математически строгое описание модели. Это позволяет проводить их анализ с помощью современной вычислительной техники.