Программа имитационного моделирования работы банка
Программа имитационного моделирования работы банка
Содержание
1. Постановка задачи
2. Метод решения задачи
3. ПРОГРАММНОЕ РЕШЕНИЕ
4. Инструкция пользователю
5. РУКОВОДСТВО ПРОГРАММИСТА
6. ПРИЛОЖЕНИЕ А – «Блок-схема имитационного моделирования работы банка»
Постановка задачи
В современном мире гарантией эффективной работы любого предприятия служит рациональное использование денежных средств и трудового фактора. Так для расчета экономического эффекта работы банка необходимо провести имитационное моделирование на основании предварительно установленных зависимостей.
Допустим, что клиенты в банк прибывают с интервалом, исчисляемым в минутах (см. рис. 1).
0100090000032a0200000200a20100000000a201000026060f003a03574d4643010000000000010032970000000001000000180300000000000018030000010000006c000000000000000000000011000000230000000000000000000000393b0000614c000020454d460000010018030000120000000200000000000000000000000000000015060000d2080000c60000001f0100000000000000000000000000006b0403002e600400160000000c000000180000000a0000001000000000000000000000000900000010000000aa04000003060000250000000c0000000e000080250000000c0000000e000080120000000c00000001000000520000007001000001000000e1ffffff00000000000000000000000090010000000000cc04400022430061006c00690062007200690000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000110040ae110010000000a4b1110024af110052516032a4b111009cae1100100000000cb0110088b1110024516032a4b111009cae11002000000049642f319cae1100a4b1110020000000ffffffff0c48d200d0642f31ffffffffffff0180ffff01800fff0180ffffffff0000000000080000000800006cd212000100000000000000c800000025000000372e9001cc00020f0502020204030204ef0200a07b20004000000000000000009f00000000000000430061006c006900620072000000000040c1670470a0603287755f17ec47d200a456c300d0ae11009c38273104000000010000000caf11000caf1100e87825310400000034af11000c48d2006476000800000000250000000c00000001000000250000000c00000001000000250000000c00000001000000180000000c0000000000000254000000540000000000000000000000110000002300000001000000dc774b41a65d4b41000000001c000000010000004c000000040000000000000000000000aa0400000406000050000000200000001200000046000000280000001c0000004744494302000000ffffffffffffffffab04000004060000000000004600000014000000080000004744494303000000250000000c0000000e000080250000000c0000000e0000800e000000140000000000000010000000140000000400000003010800050000000b0200000000050000000c02eb024302040000002e0118001c000000fb020800030000000000bc02000000cc0102022253797374656d0000000000000000000000000000000000000000000000000000040000002d010000040000002d01000004000000020101001c000000fb02f1ff0000000000009001000000cc0440002243616c6962726900000000000000000000000000000000000000000000000000040000002d010100040000002d010100040000002d010100050000000902000000020d000000320a0e00000001000400000000004402eb0220690900040000002d010000040000002d010000030000000000
Рис. 1 – «Приход клиентов в банк»
Приход клиентов в банк описывается пуассоновским потоком с интенсивностью r, который определяется следующим образом:
(1.1)
где: r – интенсивность потока;
k – время между приходами клиентов.
Параметр k может принимать дискретные значения от нуля до бесконечности. Причем k=0 означает приход сразу двух клиентов.
Предположим, в банке имеется N касс. Математическое ожидание обслуживания клиентов в банке обозначим . Обслуживание клиентов у касс происходит по экспоненциальному закону распределения случайной величины ( - время обслуживания клиентов) с плотностью распределения :
(1.2)
Примечание:
Если в банке есть свободные кассы, то клиент становится на обслуживание к ближайшей из них (т.е. к кассе с минимальным номером). Если все кассы заняты – клиент становится в очередь к той кассе, где очередь минимальна. Если очереди одинаковы, то клиент становится в любую из них.
Для решения поставленной задачи необходимо разработать алгоритм имитационного моделирования работы банка за восьмичасовой рабочий день. А также определить время простоя касс и количество клиентов в очереди не обслуженных на момент закрытия банка.
Метод решения задачи
Имитационное моделирование на ЭВМ процесса функционирования автоматизированной системы управления работой банка позволяет получить численное решение поставленной задачи. Суть рассматриваемого приближенного метода решения состоит в проведении ряда случайных испытаний вероятностной модели исследуемой системы и получении совокупности реализаций случайных процессов изменения состояния.
В результате многократной реализации случайных процессов определяются оценки вероятности тех или иных событий и средние значения случайных величин. Имитационное моделирование связано с необходимостью воспроизведения случайных событий и величин, распределенных по произвольному закону. Существует несколько способов генерации случайных величин и формирования их распределений. Модель системы управления работой банка включает в себя:
Приход клиентов в банк ;
Время обслуживания клиентов у касс .
По условию поставленной задачи приход клиентов в банк описывается пуассоновским потоком с интенсивностью r. Для лучшего понимания сути распределения Пуассона необходимо знать основные определения:
Интенсивность потока – среднее число событий, которое появляется в единицу времени.
Поток – последовательность событий, которые наступают в случайные моменты времени.
Закон распределения Пуассона выражается формулой (1.1).
Будем моделировать интервал времени между двумя последовательно зашедшими в банк клиентами методом Монте-Карло с датчиком случайных чисел на интервале [0 - 1].
Совокупность независимых случайных событий, образующих полную группу, характеризуется вероятностями появления каждого из событий , причем . Для моделирования этой совокупности случайных событий используется генератор случайных чисел, равномерно распределенных в интервале [0 - 1]. При делении отрезка [0 - 1] на n частей, численно равных , возникновение события устанавливается путем определения нахождения случайного числа Х в пределах интервала при проверке условия , где изменяется от нуля до n. При имеем ; при имеем и так далее. При подстановке в формулу (1.1) получим:
;
;
и так далее.
Причем (мин.) – максимальное количество ожидания клиентов.
Так как опыт проводится многократно, то, очевидно, что частота попадания случайных чисел на каждый из отрезков, определяющихся их длиной, и соответствует полученным вероятностям.
Моделирование времени обслуживания клиентов у касс происходит по экспоненциальному закону распределения, формула которого представлена выше (формула (1.2)).
Время обслуживания клиентов , как и любая иная случайная величина, описывается функцией распределения , определяемая как вероятность случайного события, заключающегося в том, что время обслуживания клиентов меньше некоторого заданного времени :
Эта вероятность рассматривается как функция во всем диапазоне возможных значений величины . Функция распределения любой случайной величины является неубывающей функцией времени . Примерный вид функции дан на рисунке 3.
Рис. 3 – «Функция распределения экспоненциального закона»
Так как значения не могут быть отрицательными, то . При величина стремится к единице. Таким образом, функция распределения времени обслуживания клиентов:
(1.3)
где - параметр распределения (среднее время обслуживания клиентов у кассы).
Соответственно плотность распределения:
(1.4)
Для моделирования времени обслуживания клиента у кассы проинтегрируем функцию распределения :
(1.5)
От датчика случайных чисел равномерно распределенных на интервале [0 - 1] получаем очередное число Х, которое подставляем в формулу (1.5) и вычисляем :
(1.6)
Из соотношения (1.6) найдем соответствующее Х, которое будем принимать за случайное число, обозначающее время обслуживания данной кассой.
ПРОГРАММНОЕ РЕШЕНИЕ
Программа имитационного моделирования работы банка написана на языке C с помощью среды разработки Borland C++ 3.1.
Исходный текст программы состоит из следующих файлов:
– main.c – содержит реализацию основных функций программы:
void ZovnVydProg (void) – перерисовка интерфейса программы;
void InZminnyh (void) – очистка переменных;
void Zapusk (void) – прием входных данных и их обработка.
Данный файл содержит так же описание используемых глобальных переменных.
– main.h – файл содержит прототипы основных функций, реализованных в файле main.c, а так же прототипы функций вычисления, реализованных в файле engine.c;
– engine.c – файл содержит реализацию функций вычисления:
ZVIT* Obchyslennya (void) – функция, содержащая основной цикл вычисления;
void KorChasuObsl (void) – коррекция времени обслуживания каждого клиента;
int TObsl(void) – моделирование времени обслуживания для очередного клиента;
int MinCherga (void) – определение номера кассы с минимальной очередью;
void DobKlUChergy (void) – постановка клиента в очередь, либо к свободной кассы;
int Ksi(void) – моделирование времени прихода очередного клиента;
Инструкция пользователю
Программа имитационного моделирования работы банка расположена по следующему адресу:
С:\П – 00 – 51\К&F\Bank.exe
На запрос программы:
« Введите количество касс : »
Вводим предполагаемое (данное) количество касс обслуживающих клиентов.
На запрос программы:
« Введите интенсивность потока r: »
Вводим r - интенсивность потока, равную среднему числу событий, которые появляются в единицу времени.
На запрос программы:
« Введите параметр распределения lambda: »
Вводим равное среднему времени обслуживания клиентов у кассы.
На запрос программы:
« Введите максимальное время ожидания клиента: »
Вводим k равное максимальному времени в минутах ожидания клиентов.
РУКОВОДСТВО ПРОГРАММИСТА
Несмотря на то, что программа предназначена для создания имитационной модели работы банка, она также может использоваться для других целей, к примеру, для моделирования работы магазина. Вследствие этого может возникнуть необходимость в модернизации или изменении программы.
– Для изменения продолжительности рабочего дня необходимо изменить значение константы WORK_TIME, описанную в файле engine.c;
– Для изменения закона распределения, использующегося для моделирования времени прихода следующего клиента необходимо изменить содержимое функции int Ksi(void), подставив в тело реализацию необходимого распределения;
– Для изменения закона распределения, использующегося для моделирования времени обслуживания клиента кассиром необходимо изменить содержимое функции int TObsl(void), подставив в тело реализацию необходимого распределения;
– В случае возникновения необходимости ввода времени работы банка пользователем при каждом запуске программы необходимо сделать следующие изменения:
Добавить название соответствующего поля ввода к массиву названия полей *ZagolPol[];
Добавить окно поля ввода в функцию void ZovnVydProg(void);
Увеличить верхнюю границу счетчика в цикле перерисовки названий полей функции void ZovnVydProg (void);
Добавить соответствующий обработчик в функцию void Zapusk(void);
В файле engine.c изменить строку #define WORK_TIME 8*60 строкой #define WORK_TIME timevar, где timevar – имя переменной, содержащей введенное пользователем время работы банка;
– В случае возникновения необходимости получения более детальной информации о работе банка необходимо добавить соответствующие переменные в структуру ZVIT и обеспечить заполнение этих переменных значениями в соответствующих функциях.
ПРИЛОЖЕНИЕ А – «Блок-схема имитационного моделирования работы банка»
0100090000032a0200000200a20100000000a201000026060f003a03574d4643010000000000010032970000000001000000180300000000000018030000010000006c000000000000000000000011000000230000000000000000000000393b0000614c000020454d460000010018030000120000000200000000000000000000000000000015060000d2080000c60000001f0100000000000000000000000000006b0403002e600400160000000c000000180000000a0000001000000000000000000000000900000010000000aa04000003060000250000000c0000000e000080250000000c0000000e000080120000000c00000001000000520000007001000001000000e1ffffff00000000000000000000000090010000000000cc04400022430061006c00690062007200690000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000110040ae110010000000a4b1110024af110052516032a4b111009cae1100100000000cb0110088b1110024516032a4b111009cae11002000000049642f319cae1100a4b1110020000000ffffffff0c48d200d0642f31ffffffffffff0180ffff01800fff0180ffffffff0000000000080000000800006cd212000100000000000000c800000025000000372e9001cc00020f0502020204030204ef0200a07b20004000000000000000009f00000000000000430061006c006900620072000000000040c1670470a0603287755f17ec47d200a456c300d0ae11009c38273104000000010000000caf11000caf1100e87825310400000034af11000c48d2006476000800000000250000000c00000001000000250000000c00000001000000250000000c00000001000000180000000c0000000000000254000000540000000000000000000000110000002300000001000000dc774b41a65d4b41000000001c000000010000004c000000040000000000000000000000aa0400000406000050000000200000001200000046000000280000001c0000004744494302000000ffffffffffffffffab04000004060000000000004600000014000000080000004744494303000000250000000c0000000e000080250000000c0000000e0000800e000000140000000000000010000000140000000400000003010800050000000b0200000000050000000c02eb024302040000002e0118001c000000fb020800030000000000bc02000000cc0102022253797374656d0000000000000000000000000000000000000000000000000000040000002d010000040000002d01000004000000020101001c000000fb02f1ff0000000000009001000000cc0440002243616c6962726900000000000000000000000000000000000000000000000000040000002d010100040000002d010100040000002d010100050000000902000000020d000000320a0e00000001000400000000004402eb0220690900040000002d010000040000002d0100000300000000000100090000032a0200000200a20100000000a201000026060f003a03574d4643010000000000010032970000000001000000180300000000000018030000010000006c000000000000000000000011000000230000000000000000000000393b0000614c000020454d460000010018030000120000000200000000000000000000000000000015060000d2080000c60000001f0100000000000000000000000000006b0403002e600400160000000c000000180000000a0000001000000000000000000000000900000010000000aa04000003060000250000000c0000000e000080250000000c0000000e000080120000000c00000001000000520000007001000001000000e1ffffff00000000000000000000000090010000000000cc04400022430061006c00690062007200690000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000110040ae110010000000a4b1110024af110052516032a4b111009cae1100100000000cb0110088b1110024516032a4b111009cae11002000000049642f319cae1100a4b1110020000000ffffffff0c48d200d0642f31ffffffffffff0180ffff01800fff0180ffffffff0000000000080000000800006cd212000100000000000000c800000025000000372e9001cc00020f0502020204030204ef0200a07b20004000000000000000009f00000000000000430061006c006900620072000000000040c1670470a0603287755f17ec47d200a456c300d0ae11009c38273104000000010000000caf11000caf1100e87825310400000034af11000c48d2006476000800000000250000000c00000001000000250000000c00000001000000250000000c00000001000000180000000c0000000000000254000000540000000000000000000000110000002300000001000000dc774b41a65d4b41000000001c000000010000004c000000040000000000000000000000aa0400000406000050000000200000001200000046000000280000001c0000004744494302000000ffffffffffffffffab04000004060000000000004600000014000000080000004744494303000000250000000c0000000e000080250000000c0000000e0000800e000000140000000000000010000000140000000400000003010800050000000b0200000000050000000c02eb024302040000002e0118001c000000fb020800030000000000bc02000000cc0102022253797374656d0000000000000000000000000000000000000000000000000000040000002d010000040000002d01000004000000020101001c000000fb02f1ff0000000000009001000000cc0440002243616c6962726900000000000000000000000000000000000000000000000000040000002d010100040000002d010100040000002d010100050000000902000000020d000000320a0e00000001000400000000004402eb0220690900040000002d010000040000002d010000030000000000
Процедура постановки клиента в очередь
0100090000032a0200000200a20100000000a201000026060f003a03574d4643010000000000010032970000000001000000180300000000000018030000010000006c000000000000000000000011000000230000000000000000000000393b0000614c000020454d460000010018030000120000000200000000000000000000000000000015060000d2080000c60000001f0100000000000000000000000000006b0403002e600400160000000c000000180000000a0000001000000000000000000000000900000010000000aa04000003060000250000000c0000000e000080250000000c0000000e000080120000000c00000001000000520000007001000001000000e1ffffff00000000000000000000000090010000000000cc04400022430061006c00690062007200690000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000110040ae110010000000a4b1110024af110052516032a4b111009cae1100100000000cb0110088b1110024516032a4b111009cae11002000000049642f319cae1100a4b1110020000000ffffffff0c48d200d0642f31ffffffffffff0180ffff01800fff0180ffffffff0000000000080000000800006cd212000100000000000000c800000025000000372e9001cc00020f0502020204030204ef0200a07b20004000000000000000009f00000000000000430061006c006900620072000000000040c1670470a0603287755f17ec47d200a456c300d0ae11009c38273104000000010000000caf11000caf1100e87825310400000034af11000c48d2006476000800000000250000000c00000001000000250000000c00000001000000250000000c00000001000000180000000c0000000000000254000000540000000000000000000000110000002300000001000000dc774b41a65d4b41000000001c000000010000004c000000040000000000000000000000aa0400000406000050000000200000001200000046000000280000001c0000004744494302000000ffffffffffffffffab04000004060000000000004600000014000000080000004744494303000000250000000c0000000e000080250000000c0000000e0000800e000000140000000000000010000000140000000400000003010800050000000b0200000000050000000c02eb024302040000002e0118001c000000fb020800030000000000bc02000000cc0102022253797374656d0000000000000000000000000000000000000000000000000000040000002d010000040000002d01000004000000020101001c000000fb02f1ff0000000000009001000000cc0440002243616c6962726900000000000000000000000000000000000000000000000000040000002d010100040000002d010100040000002d010100050000000902000000020d000000320a0e00000001000400000000004402eb0220690900040000002d010000040000002d010000030000000000
Блок схема корректировки времени обслуживания клиентов у касс и продвижения очереди.
0100090000032a0200000200a20100000000a201000026060f003a03574d4643010000000000010032970000000001000000180300000000000018030000010000006c000000000000000000000011000000230000000000000000000000393b0000614c000020454d460000010018030000120000000200000000000000000000000000000015060000d2080000c60000001f0100000000000000000000000000006b0403002e600400160000000c000000180000000a0000001000000000000000000000000900000010000000aa04000003060000250000000c0000000e000080250000000c0000000e000080120000000c00000001000000520000007001000001000000e1ffffff00000000000000000000000090010000000000cc04400022430061006c00690062007200690000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000110040ae110010000000a4b1110024af110052516032a4b111009cae1100100000000cb0110088b1110024516032a4b111009cae11002000000049642f319cae1100a4b1110020000000ffffffff0c48d200d0642f31ffffffffffff0180ffff01800fff0180ffffffff0000000000080000000800006cd212000100000000000000c800000025000000372e9001cc00020f0502020204030204ef0200a07b20004000000000000000009f00000000000000430061006c006900620072000000000040c1670470a0603287755f17ec47d200a456c300d0ae11009c38273104000000010000000caf11000caf1100e87825310400000034af11000c48d2006476000800000000250000000c00000001000000250000000c00000001000000250000000c00000001000000180000000c0000000000000254000000540000000000000000000000110000002300000001000000dc774b41a65d4b41000000001c000000010000004c000000040000000000000000000000aa0400000406000050000000200000001200000046000000280000001c0000004744494302000000ffffffffffffffffab04000004060000000000004600000014000000080000004744494303000000250000000c0000000e000080250000000c0000000e0000800e000000140000000000000010000000140000000400000003010800050000000b0200000000050000000c02eb024302040000002e0118001c000000fb020800030000000000bc02000000cc0102022253797374656d0000000000000000000000000000000000000000000000000000040000002d010000040000002d01000004000000020101001c000000fb02f1ff0000000000009001000000cc0440002243616c6962726900000000000000000000000000000000000000000000000000040000002d010100040000002d010100040000002d010100050000000902000000020d000000320a0e00000001000400000000004402eb0220690900040000002d010000040000002d010000030000000000