Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Литература / Compyuternoe_modelirovanie_v_AnyLogic_7_Boev_VD.pdf
Скачиваний:
228
Добавлен:
12.02.2018
Размер:
8.72 Mб
Скачать

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

Декомпозиция терминала и состав сегментов модели определяются разработчиком. Введем следующие сегменты:

ввод исходных данных; событийная часть модели;

вычисление результатов моделирования.

Как видно, в данном случае можно обойтись без разделения событийной части модели на сегменты.

7.2. Модель в AnyLogic

7.2.1. Исходные данные и результаты моделирования

1.Для ввода исходных данных используем элемент Параметр. Выполните команду Файл/Создать/Модель на панели инструментов.

2.В поле Имя модели диалогового окна Новая модель вве-

дите Терминал. Выберите каталог, в котором будут сохранены файлы модели. Щёлкните кнопку Готово.

Создадим две области просмотра. Первую для ввода исходных данных и вывода результатов моделирования, вторую — для размещения событийной части модели.

Создайте вторую область просмотра для размещения объектов модели на агенте Main.

1.Из палитры Презентация перетащите элемент Область просмотра.

2.На странице Основные панели Свойства в поле Имя:

введите Модель_Терминал.

3.Задайте расположение области просмотра относительно её якоря с помощью элемента управления Выравнивать по: Верхн.

левому углу.

4.Выберите режим масштабирования из выпадающего спис-

ка Масштабирование: Подогнать под окно.

5.На странице Местоположение и размер панели Свойства

введите в поля X: 0, Y: 750, Ширина: 560, Высота: 330.

6.Из палитры Презентация перетащите элемент Скруглённый прямоугольник. Оставьте имя, предложенное системой.

7.На странице Местоположение и размер панели Свойства

введите в поля X: 20, Y: 760, Ширина: 530, Высота: 310. Задайте, как будет располагаться область просмотра относительно её

288

якоря, с помощью элемента управления Выравнивать по:

Верхн. левому углу.

8.Выберите режим масштабирования из выпадающего спис-

ка Масштабирование: Подогнать под окно.

9.На странице Местоположение и размер панели Свойства

введите в поля X: 0, Y: 0, Ширина: 680, Высота: 410.

10.Из палитры Презентация перетащите элемент Прямоугольник. Оставьте имя, предложенное системой.

11.На странице Местоположение и размер панели Свойства

введите в поля X: 30, Y: 40, Ширина: 640, Высота: 350.

12.Из палитры Презентация перетащите второй элемент Об-

ласть просмотра.

13.Перейдите на страницу Основные панели Свойства. В

поле Имя: введите Данные.

14.Задайте, как будет располагаться

15.Перетащите элемент text и на странице Текст панели

Свойства в поле вместо слова text введите Исходные данные. 16. Перетащите второй элемент text и на странице Текст па-

нели Свойства в поле вместо слова text введите Результаты моделирования.

17. В Палитре выделите Основная. Перетащите элементы

Параметр на элементы с именами Исходные данные и Результа-

ты моделирования. Разместите их и дайте имена так, как показано на рис. 7.2.

18. Значения свойств установите согласно табл. 7.1. Имена параметров (в том числе и знак подчёркивания) приняты те же, что и в GPSS-модели.

 

 

 

 

 

Таблица 7.1

 

 

 

 

 

 

Имя

Тип

Значение по

Имя

Тип

Значение по

умолчанию

умолчанию

 

 

 

 

 

 

 

timeD

double

2

D_

int

10

timeE

double

10

timeF

double

2

E_

int

5

timeI

double

5

F_

int

5

timeZ

double

10

I_

int

7

timeJ

double

2

ZP_

int

2

timeA

double

9

J_

int

7

timeFH

double

2

 

 

 

 

 

 

timeIJ

double

2

289

19. Для вывода результатов моделирования используем эле-

мент Переменная. В Палитре выделите Основная. Перетащите элементы Переменная. Разместите их и дайте им имена так, как показано на рис. 7.2. Тип переменных double.

В GPSS World коэффициенты использования элементов терминала, длины к ним очередей определяются системой автоматически и выводятся в стандартном отчёте.

Коэффициенты использования элементов терминала (в нашей модели их будут имитировать объекты delay) автоматически определяются и в AnyLogic. Тем не менее, для удобства их чтения в ходе и по окончании моделирования мы ввели переменные

KoefIsp_E, KoefIsp_F, KoefIsp_Z, KoefIsp_I, KoefIsp_J.

Для определения максимальных длин очередей к этим элементам терминала нами также введены переменные очередь_Е, оче-

редь_F, очередь_Z, очередь_I, очередь_J.

Замечание. При построении событийной части модели нужно устанавливать флажок Включить сбор статистики в свойствах этих элементов на странице Специфические панели Свойства.

Переменные KolObrCar, TimeObr, KoefIsp имеют тот же смысл, что и в GPSS-модели.

Переменная kolJ введена для счета числа обработанных транспортов. Переменная TimeSum введена для счета суммарного времени обработки всех транспортов. По значениям этих переменных рассчитывается среднее время обработки TimeObr транспорта.

Далее для определения количественных значений каждой из этих переменных мы напишем соответствующие Java-коды.

290

Рис. 7.2. Размещение элементов для ввода исходных данных и вывода результатов моделирования

7.2.2. Событийная часть модели

Объекты событийной части модели показаны на рис. 7.3.

Для построения использованы следующие двадцать объектов

Библиотеки моделирования процессов (в скобках после имени каждого объекта указано их количество в событийной части модели): source (один); queue (8); delay (8); split (1); match (1); sink.

Создадим событийную часть модели. Для неё мы уже создали область просмотра с именем Модель_Терминал и перетащили элемент Прямоугольник, в котором и разместим все элементы.

1.Перетащите объект source. Установите его свойства согласно табл. 7.2.

2.Создайте нестандартный тип заявки Car с полями:

long id; double vxod;

Дополнительное поле id нестандартного класса заявки Car введено для проверки объектом match условия объединения двух заявок в одну. Поле vxod предназначено для записи времени входа заявки в модель.

291

Рис. 7.3. Событийная часть модели Терминал

292

Перетащите остальные объекты, соедините так, как показано на рис. 7.3. Установите их свойства согласно табл. 7.3.

 

 

 

Таблица 7.2

 

 

Свойства объекта source

 

 

 

 

Имя

 

Свойства

Значения

 

 

 

 

поток_

 

Отображать имя

Установите флажок

транс-

 

Тип заявки

Car

порта

 

Прибывают согласно

Времени между прибытиями

 

 

Время между

exponential(1/timeA)

 

 

прибытиями

 

 

Новая заявка

Car

 

 

Действия

entity.id =

 

 

При выходе

поток_транспорта.count();

 

 

 

entity.vxod = time();

 

 

 

 

 

 

 

Таблица 7.3

 

 

Свойства объектов событийной части модели

 

 

 

 

 

 

Свойства

Значение

 

 

 

Имя

 

очередь_на_D_

Отображать имя

Установить флажок

Тип заявки

 

Car

Максимальная вместимость

Установить флажок

Включить сбор статистики

Установить флажок

Имя

 

парковка_D_

Отображать имя

Установить флажок

Тип заявки

 

Car

Тип

 

Определённое время

Время задержки

exponential(1/timeD)

Вместимость

D_

Включить сбор статистики

Установить флажок

Имя

 

очередь_в_офис_E_

Отображать имя

Установить флажок

Тип заявки

 

Car

Вместимость

10

Действия

 

if (очередь_E <

При подходе к выходу

очередь_в_офис_E_.size())

 

 

 

очередь_E =

 

 

 

очередь_в_офис_E_.size();

Включить сбор статистики

Установить флажок

293

 

Продолжение табл. 7.3

 

 

Имя

оформл_докум_в_офисе_Е_

Отображать имя

Установить флажок

Тип заявки

Car

Тип

Определённое время

Время задержки

exponential(1/timeE)

Вместимость

E_

Имя

отправка_заявки_в_Z

Отображать имя

Установить флажок

Тип заявки

Car

Количество копий

1

Новая заявка (копия)

Car

Действия

entity.id = original.id;

При выходе копии

entity.vxod = original.vxod;

Имя

очередь_в_зону_Z_

Отображать имя

Установить флажок

Тип заявки

Car

Вместимость

100

Действия

if (очередь_Z < оче-

При подходе к выходу

редь_в_зону_Z_.size())

 

очередь_Z =

 

очередь_в_зону_Z_.size();

Включить сбор статистики

Установить флажок

Имя

выполн_заявки_в_зоне_Z_

Отображать имя

Установить флажок

Тип заявки

Car

Тип

Определённое время

Время задержки

exponential(1/timeZ)

Вместимость

ZP_

Включить сбор статистики

Установить флажок

Имя

фиксация_выполн_заявки_в_Z_

Отображать имя

Установить флажок

Тип заявки

Car

Условие соответствия

entity1.id == entity2.id

Вместимость 1

100

Вместимость 2

100

Действия При выходе1

entity.id = 0;

Действия При выходе 2

if (очередь_I < фиксация

 

_выполн_заявки_в_Z_.size2())

 

очередь_I = фиксация

 

_выполн_заявки_в_Z_.size2();

294

 

Продолжение табл. 7.3

 

 

Имя

очередь_к_воротам_F_

Отображать имя

Установить флажок

Тип заявки

Car

Максимальная вместимость

Установить флажок

Имя

полосы_у_ворот_F_

Отображать имя

Установить флажок

Тип заявки

Car

Вместимость

F_

Действия

if (очередь_F < поло-

При подходе к выходу

сы_у_ворот_F_.size())

 

очередь_F =

 

полосы_у_ворот_F_.size();

Имя

досмотр_у_ворот_F_

Отображать имя

Установить флажок

Тип заявки

Car

Тип

Определённое время

Время задержки

exponential(1/timeF)

Вместимость

F_

Имя

queue1

Тип заявки

Сбросить флажок

Вместимость

Car

 

100

Имя

движение_от_F_к_Н_

Отображать имя

Установить флажок

Тип заявки

Car

Тип

Определённое время

Время задержки

exponential(1/timeFH)

Вместимость

10

Имя

обслуж_в_зоне_I_

Отображать имя

Установить флажок

Тип заявки

Car

Тип

Определённое время

Время задержки

exponential(1/timeI)

Вместимость

I_

Имя

queue

Отображать имя

Сбросить флажок

Тип заявки

Car

Вместимость

100

Имя

движение_от_I_к_J_

Отображать имя

Установить флажок

Тип заявки

Car

295

 

Окончание табл. 7.3

 

 

Тип

Определённое время

Время задержки

exponential(1/timeIJ)

Вместимость

10

Включить сбор статистики

Установить флажок

Имя

очередь_на_ворот_J_

Отображать имя

Установить флажок

Тип заявки

Car

Вместимость

10

Действие при подходе

if (очередь_J < оче-

к выходу

редь_на_ворот_J_.size())

 

очередь_J = оче-

 

редь_на_ворот_J_.size();

Включить сбор статистики

Установить флажок

Имя

осмотр_на_ворот_J_

Отображать имя

Установить флажок

Тип заявки

Car

Тип

Определённое время

Время задержки

exponential(1/timeJ)

Вместимость

J_

Поясним необходимость и целесообразность применения некоторых объектов. В модели заявка имитирует транспорт. Объект split предназначен для расщепления одной заявки в нашей модели на две заявки. Одна поступает, как документ, в зону Z, а вторая, как транспорт, продолжает движение. Когда в зоне Z необходимые для обработки транспорта действия выполнены (подготовлены документы), объект match фиксирует этот момент, то есть синхронизирует дальнейшее движение транспорта. Вторая заявка направляется в объект sink и уничтожается. Как известно, объединить две заявки в одну (а значит не использовать объект sink) можно с помощью объекта combine. Однако в нашем случае combine использовать нельзя, так как он не проверяет выполнение у заявок условий, необходимых для их уничтожения. Поэтому могут быть объединены различные заявки. Объект match проверяет условия объединения, установленные в нашем случае разработчиком модели в дополнительном поле id нестандартного класса заявки Car (entity1.id == entity2.id), именно двух заявок в одну. То есть синхронизации движения заявки как документа и заявки как автомобиля при применения объекта combine не обеспечивается.

296

В табл. 7.4 указаны свойства объекта sink.

Таблица 7.4

Свойства

 

Значение

 

 

 

Имя

выход_J

 

Отображать

Установить флажок

имя

Car

 

Тип заявки

 

Действия

if (entity.id != 0){

При входе

kolJ ++ ;

= kolJ/10000;

 

KolObrCar

 

KoefIsp =

kolJ/поток_транспорта.count();

 

TimeSum += (time() - entity.vxod);

 

TimeObr =

TimeSum / kolJ;

 

KoefIsp_E

=

 

оформл_докум_в_офисе_E_.statsUtilization.

 

mean();

=

 

KoefIsp_F

 

досмотр_у_ворот_F_.statsUtilization.mean();

 

KoefIsp_Z

=

 

выполн_заявки_в_зоне_Z_.statsUtilization.

 

mean();

=

 

KoefIsp_I

 

обслуж_в_зоне_I_.statsUtilization.mean();

 

KoefIsp_J

=

 

осмотр_на_ворот_J_.statsUtilization.mean();}

Остановимся на коде свойства Действия При входе. Заявки с выхода 1 объекта match можно было бы не направлять на этот объект sink, а добавить еще объект sink и уничтожать их там. Но у нас ознакомительная версия, которая не позволяет иметь в модели на диаграмме одного класса больше двадцати объектов (в образовательной версии это возможно). Нам не хватило ровно одного объекта, поэтому пришлось поступить так (размещать объекты на разных диаграммах ради этого мы посчитали нецелесообразным). Для реализации такого приёма на выходе 1 объекта match entity.id = 0, то есть поле id обнуляется и все заявки с таким полем игнорируются. Но в количестве заявок, вошедших в объект sink, они учитываются. Поэтому пришлось для счета количества обработанных транспортов ввести переменную kolJ, хотя имеется стандартная функция count(), которая возвращает количество заявок, вошедших в данный объект. Любых заявок, без какого-либо их разделения.

297