Определите, сколько времени каждая сущность берет, чтобы совершенствоваться от одного блока до другого, или сколько времени каждая сущность проводит в конкретной области вашей модели. Чтобы вычислить эту длительность, можно измерить длительность времени на каждой сущности, которая достигает конкретного места в модели. Общий рабочий процесс:
Создайте атрибут на сущности, которая может содержать временную стоимость.
Когда сущность достигнет конкретной точки в модели, установите текущее значение времени на атрибуте. Вызовите функцию Simulink®, которая содержит блок Digital Clock.
Когда сущность достигает места назначения, вычислите временной интервал путем передачи значения атрибута другой функции Simulink, которая сравнивает его с текущим временем симуляции.
Этот пример позволяет вам видеть, приоритизировал ли порядок FIFO или очередь для потребительских результатов в более короткое время ожидания. startTimer и readTimer Функции Simulink совместно выполняют расчет синхронизации. Этот пример использует блок Mean из DSP System Toolbox™, чтобы вычислить средние времена.

Этот пример имеет четыре блока Simulink Function. Два задают таймерные функции, startTimer и readTimer. Другие функции вычисляют средние времена.
В новой модели перетащите блоки, показанные в примере, и повторно пометьте и соедините их как показано.
Для блока startTimer задайте:

Для блока readTimer задайте:

Для avg_time_fifo(t) и avg_time_priorityБлоки Simulink Function, вставьте блок Mean, например:

Для блока Entity Generator:
Во вкладке Entity type добавьте два атрибута, ServiceTime и Timer.
Во вкладке Entity actions, набор эти два значения атрибута:
entity.ServiceTime = exprnd(3); entitySys.priority = randi(2);
В Entity Queue:
Во вкладке Main, набор Queue type к FIFO.
Во вкладке Event actions вызовите startTimer функция для действия Записи:
entity.Timer = startTimer();
В Entity Queue1:
Во вкладке Main сконфигурируйте блок, чтобы быть приоритетной очередью с приоритетным источником entitySys.priority:

Во вкладке Event actions вызовите startTimer функция для действия Записи:
entity.Timer = startTimer();
Для обоих блоков Entity Server:
Установите Service time source на Attribute.
Установите Service time attribute name на ServiceTime.
Для Entity Terminator вызовите readTimer и avg_time_fifo функции для события Entry:
% Read timer elapsedTime = readTimer(entity.Timer); % Compute average avg_time_fifo(elapsedTime);
Для Entity Terminator1 вызовите readTimer и avg_time_priority функции для события Entry:
% Read timer elapsedTime = readTimer(entity.Timer); % Compute average avg_time_priority(elapsedTime);
Сохраните и запустите модель.

Entity Generator | Entity Replicator | Simulink Function