Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лабораторная работа 1_12.doc
Скачиваний:
1
Добавлен:
01.03.2025
Размер:
233.47 Кб
Скачать

ИТ, 2012

Лабораторная работа № 1

Моделирование систем средствами GPSS World

Цель работы

  1. Изучить особенности блоков GPSS.

  2. Получить практические навыки моделирования простейших систем массового обслуживания средствами GPSS World.

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

  1. Установите на компьютер систему GPSS World (студенческая версия – файл Student.exe).

  2. Запустите систему, в появившемся окне Notices (заметки) нажмите кнопку Don’t Download.

  3. Выполните общие задания для лабораторной работы.

Общие задания построены следующим образом: сначала приводится пример, затем пояснения и описания блоков в примере, в конце – задания для самостоятельной работы. По мере выполнения заданий помещайте скриншоты в файл отчета. В конце каждого задания поясняйте результат (файл статистики GPSS): время моделирования; количество поступивших и обслужившихся транзактов, статистика ОКУ, МКУ и очередей и т.д. в зависимости от задания.

  1. Выполните индивидуальное задание: проанализируйте задание, нарисуйте схему моделируемого процесса в виде СМО, создайте и запустите GPSS-модель, сделайте выводы об эффективности работы исследуемой системы.

Общие задания для лабораторной работы

Задача. К компьютеру на обработку поступают задания. Из предварительного обследования получена информация, что интервал времени между двумя последовательными поступлениями заданий к компьютеру подчиняется равномерному закону распределения в интервале (1-11 мин). Перед компьютером допустима очередь заданий, длина которой не ограничена. Время выполнения задания также равномерно распределено в интервале (1-19 мин). Смоделировать обработку 100 заданий.

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

GENERATE 360,300

SEIZE B

ADVANCE 600,540

RELEASE B

TERMINATE 1

START 100

Единица модельного времени задана 1 секунда.

Так как время среднее время обработки задания больше, чем среднее время поступления задания, в вычислительной системе будет накапливаться очередь с течением времени. Для сбора статистики об очереди используются операторы QUEUE, DEPART. В этом случае программа выглядит следующим образом:

GENERATE 360,300

QUEUE BR

SEIZE B

DEPART BR

ADVANCE 600,540

RELEASE B

TERMINATE 1

START 100

Наберите эту программу в среде GPSS World. Для этого:

  1. Выберите File | New и в открывшемся диалоговом окне «Новый документ» – Создать Model.

  2. В результате будет открыто окно Untitled Model1, в котором необходимо набрать текст программы.

  3. Файл с программой можно сохранить в файле с расширением .gps (пункты меню File | Save; File | Save As).

  4. Для запуска программы на выполнение необходимо выбрать пункт меню Command | Create Simulation.

  5. В результате выполнения программы моделирования работы вычислительной системы GPSS выдаст отчет:

Основные обозначения:

START TIME – время начала моделирования

END TIME – время окончания моделирования

BLOCKS – количество блоков, используемых в программе

FACILITIES – количество устройств

STORAGES – количество многоканальных устройств, для которых определяется емкость накопителя

Далее приводится информация о блоках:

LOC – номер блока, назначенный системой

BLOCK TYPE – название блока

ENTRY COUNT – количество транзактов, прошедших через блок за время моделирования

СURRENT COUNT – количество транзактов, задержанных в блоке на момент конца моделирования

RETRY – количество транзактов, ожидающих специальных условий для прохождения через данный блок

Отчет о работе устройства

FACILITY – название устройства

ENTRIES – количество транзактов, прошедших через устройство

UTIL. – вероятность загрузки устройства (часть периода моделирования, когда устройство было свободно)

AVE. TIME – среднее время обработки одного транзакта устройством

AVAIL. – состояние готовности устройства на момент конца моделирования (1 –готово к обслуживанию очередной заявки; 0 – не готово)

OWNER – номер последнего транзакта занимающего устройство (если не занималось, то значение 0)

PEND – количество транзактов, ожидающих устройство, и находящихся в режиме прерывания

INTER – количество транзактов, прерывающих устройство в данный момент

RETRY – количество транзактов, ожидающих специальных условий, зависящих от состояния объекта типа «устройство»

DELAY – определяет количество транзактов, ожидающих занятия или освобождения устройства

Статистика об очередях:

QUEUE – имя очереди

MAX - максимальная длина очереди

CONT. – текущая длина очереди

ENTRY – общее количество входов

ENTRY(0) – количество «нулевых» входов. Нулевые входы означают, что транзакты поступают на обслуживание без задержки, если же этих нулевых входов нет, то транзактам приходиться находиться в очереди, и значит увеличивается время пребывания в очереди.

AVE.CONT. – средняя длина очереди

AVE.TIME – среднее время пребывания транзактов в очереди

AVE.(-0) – среднее время пребывания в очереди без учета «нулевых» входов

RETRY – количество транзактов, ожидающих специальных условий

Информация о списке текущих событий

CEC (Current Events Chain)

XN – номер транзакта

PRI – приоритет транзакта (по умолчанию - 0)

M1 – время пребывания транзакта в системе с момента начала моделирования

ASSEM – номер семейства транзактов

CURRENT – номер блока в котором находится транзакт

NEXT – номер блока в который перейдет транзакт далее

PARAMETER – номер или имя параметра транзакта

VALUE – значение параметра

Информация о списке будущих событий

FEC (Future Events Chain)

XN – номер транзакта

PRI – приоритет транзакта

BDT – таблица модельных событий – абсолютное модельное время выхода транзакта из списка будущих событий (и перехода транзакта в список текущих событий)

ASSEM – номер семейства транзактов

CURRENT – номер блока в котором находится транзакт (0 – если транзакт не вошел в модель)

NEXT – номер блока в который перейдет транзакт далее

PARAMETER – номер или имя параметра транзакта

VALUE – значение параметра

Рассмотрим основные операторы, которые используются в программе.