бесплатно рефераты

бесплатно рефераты

 
 
бесплатно рефераты бесплатно рефераты

Меню

Имитационное моделирование на основании предварительно установленных зависимостей бесплатно рефераты

Имитационное моделирование на основании предварительно установленных зависимостей

КАФЕДРА

Экономической кибернетики








имитационное моделирование на основании предварительно установленных зависимостей.













г. Желтые Воды 2004

Содержание


1.                 Постановка задачи       _________________________________ 3

2.                 Метод решения задачи _________________________________ 5

3.                 Программное решение _________________________________ 8

4.                 Руководство пользователя_______________________________ 11

5.                 Листинг программы    _________________________________ 12

Постановка задачи


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

Допустим, что клиенты в зал прибывают с интервалом, исчисляемым в минутах (см. рис. 1).


 

Рис. 1 – «Приход клиентов в зал»

Приход клиентов в зал описывается пуассоновским потоком с интенсивностью r, который определяется следующим образом:

                              (1.1)

где:  r – интенсивность потока;

k – время между приходами клиентов.

Параметр k может принимать дискретные значения от нуля до бесконечности. Причем k=0 означает приход сразу двух клиентов.

Предположим, в зале имеется N касс. Математическое ожидание обслуживания клиентов в банке обозначим . Обслуживание клиентов у касс происходит по экспоненциальному закону распределения случайной величины  ( - время обслуживания клиентов) с плотностью распределения :

                               (1.2)

Примечание:

Если в зале есть свободные кассы, то клиент становится на обслуживание к ближайшей из них (т.е. к кассе с минимальным номером). Если все кассы заняты – клиент становится в очередь к той кассе, где очередь минимальна. Если очереди одинаковы, то клиент становится в любую из них.

Для решения поставленной задачи необходимо разработать алгоритм имитационного моделирования работы кассового зала за 24-часовый рабочий день. А также определить время простоя касс и количество клиентов в очереди не обслуженных на момент закрытия банка.

1.                Метод решения задачи


Имитационное моделирование на ЭВМ процесса функционирования автоматизированной системы управления работой кассового зала позволяет получить численное решение поставленной задачи. Суть рассматриваемого приближенного метода решения состоит в проведении ряда случайных испытаний вероятностной модели исследуемой системы и получении совокупности реализаций случайных процессов изменения состояния.

В результате многократной реализации случайных процессов определяются оценки вероятности тех или иных событий и средние значения случайных величин. Имитационное моделирование связано с необходимостью воспроизведения случайных событий и величин, распределенных по произвольному закону. Существует несколько способов генерации случайных величин и формирования их распределений. Модель системы управления работой кассового зала включает в себя:

·                    Приход клиентов в зал ;

·                    Время обслуживания клиентов у касс .

По условию поставленной задачи приход клиентов в зал описывается пуассоновским потоком с интенсивностью 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) найдем  соответствующее Х, которое будем принимать за случайное число, обозначающее время обслуживания данной кассой.

2.                ПРОГРАММНОЕ РЕШЕНИЕ


Программа имитационного моделирования работы кассового зала написана на языке C с помощью среды разработки Borland C++ 3.1.

Блок-схема имитационного моделирования работы кассового зала


 





 
















































 

















Исходный текст программы состоит из одного файла Kas1.c который содержит реализацию таких функций программы:

–   float RND_DIG (void) - Функция возвращающая СЧ в диапазоне [0, 1];

–   void massive (void) - Функция выделяющая память под массив времени  обслуживания у каждой из касс;

–   float _tau(void) - Функция возвращающая время обслуживания у кассы;

– float time_to(void) - Функция определяет время входа следующего клиента. Промежутки        между входами распределены по закону Пуассона с параметром lambda;

–   void inf (void) - Функция вывода информации пользователю.

РУКОВОДСТВО пользователя


1.                 Программа имитационного моделирования работы банка расположена по следующему адресу:

A:\Kas1.exe

2.                 На запрос программы:

«Введите количество касс в кассовом зале ж\\д вокзала:»

Вводим предполагаемое (данное) количество касс обслуживающих клиентов.

3.                 На запрос программы:

«Введите параметр распределения Пуассона для определения времени между входами пассажиров в зал:»

Вводим lambda – Параметр распределения Пуассона

4. На запрос программы:

«Введите минимальную продолжительность обслуживания у касс»

Вводим tau_min – минимальную продолжительность обслуживания.

4.                 На запрос программы:

«Введите максимальную продолжительность обслуживания у касс»

Вводим tau_max – максимальную продолжительность обслуживания.

5.                 На запрос программы:

«Введите время моделирования работы зала(в ч.):»

Вводим hours -  время моделирования работы зала.

6.                 На запрос программы:

«Введите математическое ожидание времени обслуживания у касс:»

Вводим MO - математическое ожидание.

7.                 На запрос программы:

«Введите среднеквадратическое отклонение времени обслуживания у касс:»

Вводим SKO - среднеквадратическое отклонение.

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

5. Листинг программы


/* Включаемие модули*/

#include<stdio.h>                    // Функции потокового ввода - вывода

#include<conio.h>                   // Формирование экракна

#include<math.h>                    // Математические функции

#include<alloc.h>                    // Функции по работе с динам. памятью

//Прототипы функций

float RND_DIG( void );           // Ф-я генерирует случ. числа

void inf( void);                         // Ф-я сообщает о назн-ии программы

void massive( void );                // Ф-я выделяющая память под массив

float _tau( void );                     // Расчет времени обсл-я клиента у кассы

float time_to ( void );               // Расчет времени входа пассажира в зал

//Объявление переменных

float

         tau_min,                                      // Мин. время обсл-я у касс

         tau_max,                                     // Макс. время обсл-я у касс

         *tau,                                           // Тек. время обсл-я у касс

         current_time,                           // Тек. время

         minutes,                                   // Общ. время работы в минутах

         lambda,                                    // Пар-р закона распр-я Пуассона

         enter_time_,                            // Время входа очередного пассажира

         MO,                                         // Мат. ожид-е времени обсл-я

         SKO,                                       // Среднекв. откл-е времени обсл-я у касс

         t_free,                                      // Общ. время простоя касс

         t_free_av,                                // Ср. время простоя

         serve_av,                                 // Ср. % обслуж-я пассажиров

         refuse_av,                                // Ср. % отказов в обсл-ии

         N0=7836,                                // 1-й множитель для расчета случ. числа

         NI=4792,                                  // 2-й множитель для расчета случ. числа

         N,                                             // Прозведение N0 и NI

         ND;                                           // Средние 4 цифры из числа N


int

         m,                                               // Кол-во касс

         i,                                                 // Тек. номер кассы

         enter,                                          // Кол-во вошедших

         hours,                                         // Время работы зала в часах

         serve,                                         // Кол-во обслуж-х пассажиров

         refuse,                                        // Кол-во необслуж-х пассажиров

         stand,                                          // Кол-во стоящих в очереди на момент обслуживания

         INDPAS;                                    // Флаг обслуживания пассажиров

// Главная функция программы

 void main(void)

  {

         inf();                                             // cообщение о назначении программы

         textcolor( 14 );                             //установка цвета и фона

         textbackground( 1 );

         clrscr();                                            //очистка экрана

                                        /* Прием данных от пользователя */

         printf("\n████████████████████████████████████████████████████████████████████████████████");

         for(i=1;i<=21;i++)

                   printf("█                                                                              █");

         printf("████████████████████████████████████████████████████████████████████████████████");

         gotoxy(10,7);

         do

          {

                   printf("\n█\tВведите количество касс в кассовом"

                                      " зале ж\\д вокзала:");

                   scanf( "%d", &m );

          }

         while( (m<=0)||(m>=100) );

Страницы: 1, 2