Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
GPSS_2003.doc
Скачиваний:
36
Добавлен:
13.11.2019
Размер:
13.2 Mб
Скачать

4.18. Проверка числовых выражений. Блок test

Сравнение СЧА может быть выполнено c помощью блока TEST (ПРОВЕРИТЬ)

Его формат:

TEST Х A,B|,C|

Таблица 4.43

Операнд

Значение

Результат по умолча­нию

А

СЧА

Ошибка

В

СЧА

Ошибка

С

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

При отсутствии опе­ранда С проверку вы­полняют в режиме отказа

X

Вспомогательный оператор, кото­рый представляет собой оператор отношения, использующийся при проверке

Значение оператора отношений:

Вопрос оператора отношения:

G

А больше В?

GE

А больше или равно В?

Е

А равно В?

NE

А не равно В?

LE

А меньше или равно В?

L

А меньше В?

Операнды А и В – имена СЧА, которые сравниваются. Вспомогательный оператор Х указывает способ сравнения этих двух СЧА дpyг c другом.

Пример 4.40

Режим отказа

TEST LE Ql,Q2

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

Пример 4.41

Режим условного перехода

TEST LE Ql,Q2,ZHVS

Проверяющий транзакт перейдет в следующий по порядку блок, если содержимое первой очереди меньше или равно содержи­мому второй очереди. Если это условие не выполняется, транзакт перейдет в блок c меткой ZHVS.

Пример 4.42

TEST L KSSCANNER,XSMAX_lJTIL,LLL

SEIZE SCANNER

LLL QL'EL'E QSCANNER2

Если устройство SCANNER имеет коэффициент загрузки меньше, чем значение сохраняемой величины MAX_UTIL, то транзакт идет на обслуживание этим устройством, в противном случае –переходит к блоку c меткой LLL.

Пример 4.43

Пусть в точке модели DISPATCHER необходимо удалить те транзакты, которые находились в модели больше, чем 100 ед. мо­дельного времени. Для этого в модели можно использовать такие блоки:

4.19. Определение и использование таблиц

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

Оператор TABLE (ТАБЛИЦА). В модели может быть не­сколько таблиц. Каждую таблицу нужно сначала определить и только потом использовать в модели. Для определения таблицы необходимо указать:

1) имя таблицы (числовое или символьное);

2) имя случайной переменной, значение которой будет табули­роваться;

3) число, являющееся первым граничным значением. (Значения выборки, меньшие или равные этому числу, попадают в самый левый (нижний) интервал (частотный класс) таблицы);

4) ширину интервала, общую для всех интервалов таблицы за исключением левого (нижнего) и правого (верхнего);

5) общее число интервалов таблицы, включая нижний и верхний. Формат оператора представлен в таблице.

Таблица 4.44

Поле

Информация поля

Метка

Имя таблицы

Операция

TABLE

Операнд А

СЧА, значение которого учитывается в таб­лице

Операнд В

Первое граничное значение (целое число)

Операнд С

Ширина всех промежуточных интервалов (целое положительное число)

Операнд D

Общее число интервалов таблицы, включая левый и правый (целое положительное число)

На рис. 4.11 показана ось действительных значений и ее разде­ление на ряд интервалов таблицы.

Рис. 4.11

Для сбора статистических данных об очередях используется оператор QTABLE. Его формат совпадает c форматом оператора TABLE, за исключением того, что операнд А задает имя очереди.

Блок TABULATE (ТАБУЛИРОВАТЬ). Выборочные значения попадают в таблицу в моменты вхождения транзактов в блок TABU­LATE. Его формат:

TABULATE A

Таблица 4.45

Операнд

Значение

Результат по умолчанию

А

Имя (символьное или числовое) таблицы, в которой табулируется соответствующий СЧА

Ошибка

Операнд А задает имя таблицы, в которую попадают выбороч­ные значения. Одну таблицу можно использовать в нескольких блоках TABULATE модели. Отметим, что СЧА, по которому собирается статистика, в блоке TABULATE не указывается, так как он уже записан в операторе TABLE.

Если в модели используется блок TABLE или QTABLE, в файле стандартной статистики информация будет представлена в таком виде:

Для получения этих данных была определена GPSS-таблица MVP, в которой фиксировалось время нахождения транзакта в модели:

MVP TABLK Mi,100,100,20

Стандартные числовые атрибуты таблицы:

TB<номep таблицы>, ТВ$<имя таблицы> вычисленное среднее значение соответствующего СЧА;

TC<номep таблицы>, ТС$<имя таблицы> общее число вхо­дов в таблицу:

TD<номep таблицы>, ТО$<имя таблицы> вычисленное средне-квадратическое отклонение соответствующего СЧА.

Пример 4.44

В таблице TIMSERV будет табулироваться частотное распределение случайной величины – времени пребывания транзакта между блоками MARK и TABULATE. B табл. 4.46 приведены интервалы регистрации времени пребывания между блоками MARK и TABULATE.

Таблица 4.46

Левый (нижний) интервал

Первый интервал

-∞, < 10

Промежуточные интервалы

Второй интервал

≥10, <15

Третий интервал

≥15, <20

Четвертый интервал

≥20, <25

Пятый интервал

≥20, < 30

Правый (верхний) интервал

Шестой интервал

≥30, + ∞

Для того, чтобы данные, собираемые в таблицу, не попадали в один-два интервала, рекомендуется:

1) сначала сделать пробный прогон; по пробному прогону определить диапазон значений, в которых может колебаться анализируемая случайная величина (в GPSS/PC пе­рейти к окну таблиц c помощью клавиш [ALT+T]);

3) c учетом полученного диапазона скорректировать значения операндов В, C и D соответствующей таблицы.

Пример 4.45

В таблице SYSTIME собирается время пребывания транзакта в модели, которое предположительно принимает значения в интервале [100,2000].

При входе транзакта в блок SAVEVALUE среднее значение СЧА (времени пребывания), соответствующего таблице SYSTIME заносится в сохраняемую величину c именем STD.

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]