Разработка библиотеки имитационного моделирования. Система массового обслуживания. Модель комиссионного магазина

Создание библиотеки классов имитационного моделирования и реализация алгоритма имитационного моделирования системы массового обслуживания "Модель комиссионного магазина". Использование для разработки среды программирования C++. Словарь предметной области.

Рубрика Программирование, компьютеры и кибернетика
Вид курсовая работа
Язык русский
Дата добавления 23.01.2013
Размер файла 581,0 K

Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже

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

Размещено на http://www.allbest.ru/

Содержание

  • Введение
  • 1. Техническое задание
  • 2. Вариант задания
  • 3. Теоретические сведения
  • 3.1 Понятие СМО
  • 3.1.1 Основные определения СМО
  • 3.1.2 Структура СМО
  • 3.1.3 Классификация СМО
  • 3.1.4 Характеристики СМО
  • 3.1.5 Теоретическое представление задачи
  • 3.2 Q-схемы
  • 3.2.1 Непрерывно-стохастические модели (Q-схемы)
  • 3.2.2 Стохастические сети
  • 3.3 Понятие ООП
  • 3.3.1 Принципы ООП
  • 3.3.2 Преимущества ООП
  • 3.3.3 Основные термины и положения ООП
  • 4. Разработка проекта
  • 4.1 Разработка алгоритма СМО
  • 4.2 Выбор языка программирования
  • 4.3 Программная реализация
  • 5. Проектирование иерархии иммитационного моделирования
  • 5.1 Формирование словаря абстракций предметной области
  • 5.1.1 Выделение общих абстракций
  • 5.1.2 Определение отношений между абстракциями
  • 6. Разработка библиотеки классов иммитационного моделирования
  • 6.1 Разработка структуры библиотеки
  • Заключение
  • Библиографический список
  • Приложения

Введение

За последнее время в самых разных областях жизнедеятельности человека возникла необходимость в решении различных вероятностных задач, связанных с работой так называемых систем массового обслуживания (СМО). Под системой массового обслуживания (СМО) понимают динамическую систему, предназначенную для эффективного обслуживания потока заявок (требований на обслуживание) при ограничениях на ресурсы системы.

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

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

Целью курсовой работы является приобретение практических навыков в процессе создания модели системы массового обслуживания при помощи библиотеки классов, созданной в среде программирования C++ Builder.

1. Техническое задание

Задание к курсовому проекту заключается в создании библиотеки классов имитационного моделирования и реализации алгоритма имитационного моделирования СМО "Модель комиссионного магазина". Для разработки использовать среду программирования C++.

Основание для разработки

Данный программный продукт разрабатывается как курсовая работа по дисциплине "Технология программирования"

Назначение разработки

Разрабатываемая программа предназначена для моделирования различных систем массового обслуживания.

Требования к программе

Входные данные

Входные данные программы должны вводиться непосредственно пользователем.

Выходные данные

на каждом шаге отображать модельное время;

статистика по поступившим, находящимся в системе на обслуживании и обработанным заявкам;

статистика по потокам заявок, очередям и аппаратам обслуживания.

коэффициенты использования каналов обслуживания;

максимальная длина очередей в системе;

время нахождения требований в очередях и каналах обслуживания.

Результирующие компоненты изделия

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

Оценка основных характеристик моделируемой системы:

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

Этапы разработки программы

проектирование структуры программы;

разработка сценария диалога с пользователем;

разработка основных алгоритмов;

проектирование формата файлов;

программирование алгоритмов и структур данных;

отладка и тестирование программы;

документирование.

Требования к документации

Перечень представляемых документов:

задание на курсовую работу;

техническое задание на разработку;

описание структуры программы;

описание сценария диалога с пользователем;

схемы основных алгоритмов;

описание форматов данных и файлов;

контрольные примеры и результаты программы;

листинги основных программных модулей;

краткая эксплуатационная документация.

Все документы оформляются на листах формата A4, на одной стороне листа, и представляются в виде пояснительной записки.

Документы по содержанию должны соответствовать ГОСТ 34.201-89, 34.602-89, 19.701-90.

программирование система массовое обслуживание

2. Вариант задания

Система массового обслуживания. Модель комиссионного магазина.

Концептуальная модель.

В комиссионном магазине два товароведа принимают вещи на комиссию у населения. Время обслуживания каждого клиента товароведом случайно и подчиняется показательному закону распределения. Первый товаровед обслуживает в среднем 9 клиентов в час, а второй - 6. Появления клиентов с вещами на комиссию образуют пуассоновский поток с интенсивностью 12 клиентов в час. Выбор клиентами товароведов равновероятен.

Смоделировать процесс приема вещей у населения товароведами в течение N часов. Определить вероятность того, что оба товароведа будут свободны, среднее число клиентов, обслуживаемых товароведами.

3. Теоретические сведения

3.1 Понятие СМО

3.1.1 Основные определения СМО

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

Первые задачи теории систем массового обслуживания (ТСМО) были рассмотрены сотрудниками Копенгагенской телефонной компании, датским ученым А.К. Эрлангом (1878 г. - 1929 г.) в период между 1908 и 1922 гг.

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

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

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

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

3.1.2 Структура СМО

Все СМО имеют вполне определенную структуру, изображенную на рис.1

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

2. Поток требований, поступающих в обслуживающую систему, назовем входным потоком.

3. Поток требований, которые обслужены, называется выходным потоком.

4. Совокупность очередей и приборов (каналов) обслуживания называется системой обслуживания.

5. Каждое требование поступает на свой канал, где подвергается операции обслуживания.

6. Каждая СМО имеет правила формирования очереди и правила или дисциплину обслуживания.

3.1.3 Классификация СМО

СМО делятся на системы с отказами и системы без отказов.

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

В системе без отказов (без потерь, с бесконечной длиной очереди) такая заявка не покидает систему, а становится в очередь и ждет, пока не освободится какой-нибудь канал. Время ожидания в общем случае неограниченно. Неограниченным может быть и количество требований, поступающих в систему.

СМО делятся на замкнутые и разомкнутые.

В замкнутых СМО в системе циркулирует определенное конечное число заявок (конечное число требований). В разомкнутых СМО количество, поступающих заявок бесконечно.

СМО делятся на многоканальные и одноканальные системы в зависимости от количества обслуживающих каналов.

В n-канальной CМО одновременно может обслуживаться n заявок. Каналы обслуживания иногда называют обслуживающими аппаратами (ОА).

В простейшем случае каждый ОА характеризуется своей производительностью (интенсивностью обслуживания заявок). Если в СМО поступают заявки нескольких типов, то для каждого типа заявок может быть задана соответствующая интенсивность обслуживания.

Длительность обслуживания заявки в ОА в общем виде - это случайная величина с законом распределения и математическим ожиданием (средним значением) M.

СМО также делятся по приоритету заявок:

СМО с заявками, имеющими разный приоритет (абсолютный, относительный);

СМО с заявками, имеющими одинаковый приоритет.

3.1.4 Характеристики СМО

Перечень характеристик систем массового обслуживания можно представить следующим образом:

· среднее время обслуживания;

· среднее время ожидания в очереди;

· среднее время пребывания в СМО;

· средняя длина очереди;

· среднее число заявок в СМО;

· количество каналов обслуживания;

· интенсивность входного потока заявок;

· интенсивность обслуживания;

· интенсивность нагрузки;

· коэффициент нагрузки;

· относительная пропускная способность;

· абсолютная пропускная способность;

· доля времени простоя СМО;

· доля обслуженных заявок;

· доля потерянных заявок;

· среднее число занятых каналов;

· среднее число свободных каналов;

· коэффициент загрузки каналов;

· среднее время простоя каналов.

3.1.5 Теоретическое представление задачи

Интенсивность поступления заявок входного потока - l. Интенсивность обслуживания заявок системой - ?. Поток поступления заявок характеризуется распределением Эрланга с k=2, поток обслуживания заявок характеризуются показательным законом распределения. Тогда интервал времени поступления заявок 1-го потока представляет собой случайную величину с одним и тем же распределением вероятностей F (t).

Аналогично, интервал времени обслуживания заявок представляет собой случайную величину с одним и тем же распределением вероятностей F (t).

3.2 Q-схемы

3.2.1 Непрерывно-стохастические модели (Q-схемы)

К этому классу моделей относятся системы и сети массового обслуживания.

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

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

· потоки поставок продукции некоторому предприятию,

· потоки деталей и комплектующих изделий на сборочном конвейере цеха,

· транспортные потоки,

· заявки на обработку информации ЭВМ от удаленных терминалов (информационные потоки),

· обслуживание задач в ВС,

· обслуживание покупателей в магазине.

Акт обслуживания состоит из двух составляющих: ожидание обслуживания заявки и собственно обслуживание заявки. Система массового обслуживания или прибор обслуживания состоит из двух элементов:

1) накопителя, в котором заявки ожидают обслуживания;

2) канала обслуживания, в котором выполняется действие обслуживания заявки.

· ЗАЯВКА - объект, обслуживаемый в приборе (которому выделяются ресурсы (канал)).

· В НАКОПИТЕЛЕ заявки ожидают обслуживания. В нем может находиться сразу несколько заявок.

· КАНАЛ - объект, выполняющий действие обслуживания. В канале может обслуживаться не более одной заявки.

· ПОТОК событий детерминированная или стохастическая последовательность событий, происходящих одно за другим в какие-то моменты времени.

· Поток событий называется ОДНОРОДНЫМ, если он характеризуется только моментами поступления этих событий

{tc}={t1,t2,.,tn. }.

· Однородный поток событий также может быть задан в виде последовательности промежутков времени между n-м и (n-1) - м событиями tn.

· Поток событий называется НЕОДНОРОДНЫМ, если он характеризуется не только моментами наступления событий, но и их параметрами, т.е. {tn, fn}, где tn - вызывающие моменты, fn - набор признаков события.

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

· Поток с ОГРАНИЧЕННЫМ ПОСЛЕДЕЙСТВИЕМ - это поток, в котором интервалы между наступлениями событий dt1, dt2,., dtn являются случайными независимыми величинами.

· Поток называется ОРДИНАРНЫМ, если вероятность Рndt того, что на малый интервал времени dt, примыкающий к моменту t, попадает больше одного события (n>1), пренебрежительно мала по сравнению с вероятностью P1dt того, что на интервал времени dt попадает ровно одно событие P1dt >> Pndt

· СТАЦИОНАРНЫЙ поток событий - поток, для которого вероятность появления того или иного числа событий на интервале времени dT зависит лишь от величины этого интервала и не зависит от того, где на оси времени (0,t) взят этот участок.

· То есть, если dT1 = dT2, то Рndt1 = Рndt2.

· Поток событий называется потоком БЕЗ ПОСЛЕДЕЙСТВИЯ, если для любых двух непересекающихся интервалов времени dt1 и dt2, число событий, попадающих на один из них, не зависит от того, сколько событий попало на другой.

· Поток называется ПРОСТЕЙШИМ (или стационарным пуассоновским), если он является стационарным, ординарным и не имеет последействия одновременно.

· У простейшего потока интервалы времени ф между двумя последовательными заявками - независимые случайные величины с функцией распределения

.

· Такое распределение называется экспоненциальным (показательным) и имеет и имеет плотность

.

· СМО характеризуется СОСТОЯНИЯМИ Zi, которое является совокупностью состояний накопителя ZiH и канала ZiK:

Zi = (ZiH, ZiK).

· Накопитель может принимать следующие состояния ZiH:

· ZiH = 0 - накопитель пуст;

· ZiH = 1 - в накопителе одна заявка;

· .ZiH = N - в накопителе N заявок, накопитель полон, однако это возможно для конечных накопителей. Для бесконечных ZiH = .

· Канал может принимать следующие состояния ZiK:

· ZiK = 0 - канал свободен, заявки не обслуживаются;

· ZiK = 1 - канал занят обслуживанием заявки.

3.2.2 Стохастические сети

Типы систем массового обслуживания.

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

Система массового обслуживания (СМО) - это объект, в котором выполняется последовательность операций. Система может осуществлять конечное число операций различного типа. Элемент системы, в котором происходят операции, называется обслуживающим прибором или просто прибором. Физическая и алгоритмическая сущность операций игнорируется. Если прибор выполняет операцию, то считается, что он занят, в противном случае прибор свободен.

Операция может начаться лишь после того, как возникает заявка (требование) на её выполнение, поэтому операции, происходящие в СМО, называют ещё операциями обслуживания заявок. Заявки могут быть внешними и внутренними. Внешние или входящие заявки поступают извне системы и представляют собой нагрузку на систему. Внутренние заявки могут возникать в момент окончания операции. Постоянно поступающие заявки на обслуживание образуют поток заявок.

При случайном характере параметров интенсивности поступления или длительности обслуживания заявок в СМО могут возникать очереди. Очередь - это совокупность заявок, ожидающих обслуживания в момент, когда прибор занят. В простейшем случае сочетание обслуживающего прибора, потока заявок и очереди представляет собой СМО (рис.1.). В таком виде может быть отображена вся ВС или один из функциональных элементов, например процессор.

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

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

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

Системы с приоритетами, в свою очередь, делятся на СМО без прерываний и с прерыванием. В системах с приоритетами без прерываний, если в момент появления заявки проходит обслуживание менее приоритетной заявки, то это обслуживание продолжается до конца, и лишь после этого на обслуживание поступает из очереди наиболее приоритетная заявка, - это система с относительным приоритетом. В системах с прерыванием обслуживание заявки большего приоритета начинается в момент её прихода в СМО за счет прекращения обслуживания предыдущей заявки. Это системы с абсолютным приоритетом. В последнем случае системы подразделяются на СМО с дальнейшим обслуживанием прерванных заявок и СМО с потерями прерванных заявок. Правила упорядочения очередей и выборки из них заявок соответствуют дисциплинам диспетчеризации или приоритетного обслуживания.

В многоканальных системах каналы могут иметь одинаковые или разные параметры обслуживания. Если в момент поступления заявки в многоканальную СМО отсутствует очередь и свободно больше одного канала, в системе должно существовать правило выбора одного из свободных каналов для обслуживания очередной заявки.

Правила определения длительности обслуживания, возможности прерывания обслуживания, до обслуживания заявок после завершения прерывания или после восстановления отказавшего прибора принято называть дисциплиной обслуживания или моделью прибора. По характеру допустимой длительности обслуживания системы делятся на СМО с ограниченной и неограниченной длительностью обслуживания. В системе с ограниченной длительностью обслуживания заявка покидает СМО, если её обслуживание продолжается дольше заданного промежутка времени.

Наконец, различают системы с абсолютно надежными каналами и системы с выходом из строя каналов обслуживания. В последнем случае системы подразделяются на СМО с восстановлением и без восстановления вышедших из строя каналов обслуживания.

СТОХАСТИЧЕСКАЯ СЕТЬ Совокупность взаимосвязанных СМО, в среде которых циркулируют заявки, - это сети массового обслуживания или стохастические сети. Представление ВС в виде стохастической сети обеспечивает более глубокий уровень стратификации системы, чем ВС в виде отдельной СМО.

Рис 15. Разомкнутая (а) и замкнутая (б) стохастические сети С.

Для описания ВС используются разомкнутые и замкнутые стохастические сети. В разомкнутой (открытой) сети интенсивность входного потока заявок задается внешней средой без учета состояния сети (рис.2. а). После завершения обслуживания заявки покидают сеть.

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

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

Если в стохастической сети есть СМО с двумя и более выходами, т.е. такие СМО, после обслуживания которыми поток заявок разветвляется, то задаются правила разветвления потока. В этом случае обычно указывают вероятности передачи заявки по тому или иному пути.

3.3 Понятие ООП

3.3.1 Принципы ООП

Объектно-ориентированное программирование основано на трех важнейших принципах, придающих объектам новые свойства. Этими принципами являются инкапсуляция, наследование и полиморфизм.

Инкапсуляция есть объединение в единое целое данных и алгоритмов обработки этих данных. В рамках ООП данные называются полями объекта, а алгоритмы - объектными методами.

Инкапсуляция позволяет в максимальной степени изолировать объект от внешнего окружения. Она существенно повышает надежность разрабатываемых программ, т.к. локализованные в объекте алгоритмы обмениваются с программой сравнительно небольшими объемами данных, причем количество и тип этих данных обычно тщательно контролируются. В результате замена или модификация алгоритмов и данных, инкапсулированных в объект, как правило, не влечет за собой плохо прослеживаемых последствий для программы в целом (в целях повышения защищенности программ в ООП почти не используются глобальные переменные).

Другим немаловажным следствием инкапсуляции является легкость обмена объектами, переноса их из одной программы в другую. Можно сказать, что ООП "провоцирует" разработку библиотек объектов, таких как Turbo Vision.

Наследование есть свойство объектов порождать своих потомков. Объект-потомок автоматически наследует от родителя все поля и методы, может дополнять объекты новыми полями и заменять (перекрывать) методы родителя или дополнять их.

Принцип наследования решает проблему модификации свойств объекта и придает ООП в целом исключительную гибкость. При работе с объектами программист обычно подбирает объект, наиболее близкий по своим свойствам для решения конкретной задачи, и создает одного или нескольких потомков от него, которые "умеют" делать то, что не реализовано в родителе.

Последовательное проведение в жизнь принципа "наследуй и изменяй" хорошо согласуется с поэтапным подходом к разработке крупных программных проектов и во многом стимулирует такой подход.

Полиморфизм - это свойство родственных объектов (т.е. объектов, имеющих одного общего родителя) решать схожие по смыслу проблемы разными способами. В рамках ООП поведенческие свойства объекта определяются набором входящих в него методов. Изменяя алгоритм того или иного метода в потомках объекта, программист может придавать этим потомкам отсутствующие у родителя специфические свойства. Для изменения метода необходимо перекрыть его в потомке, т.е. объявить в потомке одноименный метод и реализовать в нем нужные действия. В результате в объекте-родителе и объекте-потомке будут действовать два одноименных метода, имеющие разную алгоритмическую основу и, следовательно, придающие объектам разные свойства. Это и называется полиморфизмом объектов.

3.3.2 Преимущества ООП

ООП хорошо применяется в практике программирования для более лёгкого создания управляемых проектов.

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

Программный код с использованием ООП более читабельный и легче для восприятия. Код с ООП организован лучше потому что в нём понятно какой объект чем обрабатывается.

Таким образом, исходя из изложенного выше, можно вынести преимущества использования ООП:

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

Основное требование ООП: всё что вы хотите сделать - делайте объектами. Объекты это отдельная маленькая часть кода которая может объединять данные и свойства вместе. В приложениях все объекты взаимодействуют друг с другом.

ООП может быть рассмотрен лучше с разных сторон, особенно когда вам важно время разработки и последующее развитие приложения:

o Повторное использование: Объект это логический объект у которого есть комплект свойств и методов и он может взаимодействовать с другими объектами. Объект может быть абсолютно независимым или может зависеть от других объектов. Объект обычно создают для решения специфических поставленных проблем. Следовательно когда другие разработчики сталкиваются с похожими проблемами, они могут подключить ваш класс к своему проекту и использовать его не боясь что он нарушит процесс их разработки.

o Рефакторинг: Когда вам необходимо в проекте использовать рефакторинг, ООП предоставляем вам максимум преимуществ, так как все объекты это маленькие элементы и содержат свои свойства и методы как часть себя. По этому использовать рефакторинг относительно легко.

o Расширяемость: Если вам необходимо расширять функциональность вашего проекта, вы можете достичь лучших результатов при помощи ООП. Одна из основных функциональностей ООП это расширяемость. Вы можете использовать рефакторинг объектов что бы добавить функциональность. Работая над этим, вы по прежнему можете сохранить прежнюю совместимость объекта - следовательно вы можете прекрасно работать и с прежним кодом. Или же вы можете расширить объект и создать абсолютно новый, который будет содержать все необходимые свойства и методы родительского объекта от которого происходит новый, а потом уже добавить в него новые функции. Это называется "наследование" и это очень важная возможность ООП.

o Поддержка: объектно-ориентированный код легче поддерживать так как он следует весьма жёстким соглашениям написания кода и пишется в самопоясняющейся форме. К примеру, когда разработчик дополняет, перерабатывает код, или отлаживает его, он может легко найти внутреннюю структуру кода и поддерживать код время от времени.

o Эффективность: Идея ООП в действительности была разработана для повышения эффективности и облегчения процесса разработки. Несколько шаблонов проектирования разработаны что бы создавать более эффективный и хороший код. Более того в ООП вы можете вы можете размышлять над вашими решениями в более удобной форме чем в процедурном подходе. Поскольку вы разбиваете вашу проблему на несколько маленьких проблем и вы находите решение для каждой из них отдельно, большая проблема решается сама по себе.

3.3.3 Основные термины и положения ООП

Объектно-ориентированное программирование (ООП) - парадигма программирования, в которой основными концепциями являются понятия объектов и классов (либо, в менее известном варианте языков с прототипированием - прототипов).

Класс - это тип, описывающий устройство объектов. Понятие "класс" подразумевает некоторое поведение и способ представления. Понятие "объект" подразумевает нечто, что обладает определённым поведением и способом представления. Говорят, что объект - это экземпляр класса. Класс можно сравнить с чертежом, согласно которому создаются объекты. Обычно классы разрабатывают таким образом, чтобы их объекты соответствовали объектам предметной области.

Класс является описываемой на языке терминологии (пространства имён) исходного кода моделью ещё не существующей сущности, т. н. объекта.

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

Прототип - это объект-образец, по образу и подобию которого создаются другие объекты.

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

В настоящее время количество прикладных языков программирования (список языков), реализующих объектно-ориентированную парадигму, является наибольшим по отношению к другим парадигмам. В области системного программирования до сих пор применяется парадигма процедурного программирования, и общепринятым языком программирования является язык C. Хотя при взаимодействии системного и прикладного уровней операционных систем заметное влияние стали оказывать языки объектно-ориентированного программирования. Например, одной из наиболее распространенных библиотек мультиплатформенного программирования является объектно-ориентированная библиотека Qt, написанная на языке C++.

Структура данных "класс", представляющая собой объектный тип данных, внешне похожа на типы данных процедурно-ориентированных языков, такие как структура в языке Си или запись в Паскале или QuickBasic. При этом элементы такой структуры (члены класса) могут сами быть не только данными, но и методами (то есть процедурами или функциями). Такое объединение называется инкапсуляцией.

Наличие инкапсуляции достаточно для объектности языка программирования, но ещё не означает его объектной ориентированности - для этого требуется наличие наследования.

Но даже наличие инкапсуляции и наследования не делает язык программирования в полной мере объектным с точки зрения ООП. Основные преимущества ООП проявляются только в том случае, когда в языке программирования реализован полиморфизм.

ООП имеет уже более чем сорокалетнюю историю, но, несмотря на это, до сих пор не существует чёткого общепринятого определения данной технологии. Основные принципы, заложенные в первые объектные языки и системы, подверглись существенному изменению (или искажению) и дополнению при многочисленных реализациях последующего времени. Кроме того, примерно с середины 1980-х годов термин "объектно-ориентированный" стал модным, в результате с ним произошло то же самое, что несколько раньше с термином "структурный" (ставшим модным после распространения технологии структурного программирования) - его стали искусственно "прикреплять" к любым новым разработкам, чтобы обеспечить им привлекательность.

Следовательно, объектно-ориентированный подход является сейчас одним из самых распространенных и эффективных в программировании различных информационных процессов.

С помощью среды объектно-ориентированного программирования Borland С++ Builder и языка C++ возможно реализовать информационную систему практически любой сложности. Поэтому эта среда подходит для описания параметров систем массового обслуживания и проверки их эффективности.

4. Разработка проекта

4.1 Разработка алгоритма СМО

Рассмотрим алгоритм решения поставленной задачи:

1. Рассматриваемая в задаче система представляет собой СМО с многоканальным обслуживанием;

2. Определение времен поступления и обслуживания заявок:

· Времена поступления и обслуживания заявок генерируются случайно с заданным показательным законом распределения;

· Интенсивности поступления и обслуживания заявок заданы;

3. Функционирование рассматриваемой СМО:

· Каждый канал обслуживает в каждый момент времени одну заявку;

· Если в момент поступления новой заявки свободен хотя бы один канал, то пришедшая заявка поступает на обслуживание;

· Если отсутствуют заявки, то система простаивает.

4. Дисциплина обслуживания:

· Если к моменту поступления заявки оба канала заняты, то поступившая заявка попадает в очередь.

· Если к моменту поступления заявки все места в очереди заняты, то заявка получает отказ.

Зная параметры входных потоков заявок промоделировать поведение системы и вычислить её основные характеристики эффективности.

Характеристики эффективности функционирования СМО выделим следующие:

· Вероятность отказа;

· Абсолютная пропускная способность;

· Вероятность простоя;

· Доля обслуженных заявок;

· Среднее количество занятых каналов.

Таким образом, общий алгоритм выглядит так:

· Вводим начальные условия: общее время работы системы, значения интенсивностей потока заявок и потока обслуживания заявок; число реализаций работы системы;

· Генерируем моменты времени, в которые прибывают заявки, время обслуживания каждой заявки;

· Считаем сколько заявок было обслужено, а сколько получило отказ;

· Рассчитываем характеристики эффективности СМО:

4.2 Выбор языка программирования

С++ - это универсальный язык программирования, задуманный так, чтобы сделать программирование более приятным для серьёзного программиста. За исключением второстепенных деталей С++ является надмножеством языка программирования С. Помимо возможностей, которые дает С, С++ предоставляет гибкие и эффективные средства определения новых типов. Используя определения новых типов, точно отвечающих концепциям приложения, программист может разделять разрабатываемую программу на легко поддающиеся контролю части. Такой метод построения программ часто называют абстракцией данных. Информация о типах содержится в некоторых объектах типов, определённых пользователем. Такие объекты просты и надёжны в использовании в тех ситуациях, когда их тип нельзя установить на стадии компиляции. Программирование с применением таких объектов часто называют объектно-ориентированным. При правильном использовании этот метод даёт более короткие, проще понимаемые и легче контролируемые программы.

С++ обеспечивает полный набор операторов структурного программирования. Он также предлагает необычно большой набор операций. Многие операции С ++ соответствуют машинным командам, и поэтому допускают прямую трансляцию в машинный код. Разнообразие операций позволяет выбирать их различные наборы для минимизации результирующего поля.

С++ поддерживает указатели не переменные и функции. Указатель на объект программы соответствует машинному адресу этого объекта. Посредством разумного использования указателей можно создавать эффективно-выполняемые программы, так как указатели позволяют ссылаться на объекты тем же самым путём, как это делает машина. С++ поддерживает арифметику указателей, и тем самым позволяет осуществлять непосредственный доступ и манипуляции с адресами памяти.

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

Для реализации курсового проекта выбрана интегрированная среда программирования Borland C++ Builder 6.0, как наиболее мощная реализация языка программирования Object C++ с возможностью написания программ как под DOS так и под операционные системы Windows 95/98/2000 и NT. Расширенный "менеджер" проектов с множественными типами исполняемого кода, компилятор с оптимизацией кода, инкрементальный линкер, мощные средства интегрированной отладки, стройная архитектура распределенных приложений клиент/сервер, новые технологии разработки приложений для сети Интернет - наиболее известные достоинства Borland C++ Builder 6.0.

Интегрированная среда системы (Integrated Development Environment, IDE) обеспечивает ускорение визуального программирования, а также продуктивность повторно используемых компонентов в сочетании с усовершенствованными инструментами IDE и разномасштабными средствами доступа к базам данных.

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

Borland C++ Builder 6.0 позволяет повысить быстродействие и надежность разрабатываемой подсистемы, придать пользовательскому интерфейсу качество профессионального уровня.

Исходя из вышеизложенного для написания программы, был выбран среда программирования Borland С ++ Builder версии 6.0.

4.3 Программная реализация

Программа была разработана в среде программирования Borland C++ Builder 6.

Процесс разработки программного обеспечения с использованием ООП включает четыре этапа: анализ и уточнение спецификаций, проектирование, реализация, модификация. Рассмотрим их подробнее.

Анализ и уточнение спецификаций. Цель этапа - максимально полное описание задачи. На этом этапе выполняют анализ предметной области задачи, объектную декомпозицию разрабатываемой системы и определяют важнейшие особенности поведения объектов (описание абстракций). По результатам анализа разрабатывают диаграмму объектов программного продукта, на которой показывают основные абстракции (объекты) предметной области и сообщения, передаваемые между ними. Все выявленные абстракции и отношения между ними описывают.

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

Проектирование различают:

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

2. физическое проектирование, при котором приходится принимать во внимание указанные факторы.

Логическое проектирование заключается в разработке структуры классов: определяются поля для хранения составляющих состояния объектов и алгоритмы методов, реализующих аспекты поведения объектов. При этом используются специальные приемы разработки классов (наследование, композиция, наполнение, полиморфизм и т.д.). Результатом является иерархия или диаграмма классов, отражающая взаимосвязи классов, и описание структуры каждого класса.

Физическое проектирование включает объединение реализаций классов в модули, выбор схемы их подключения (статическая или динамическая компоновка), определение способов взаимодействия с оборудованием, с операционной системой и/или другим программным обеспечением (например, базами данных, сетевыми программами), обеспечение синхронизации процессов доя систем параллельной обработки и т.д.

Реализация программного комплекса. Это процесс поэтапной реализации и подключения классов к проекту.

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

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

Если состояние системы S=0, то генерируется время поступления заявки в систему, время работы системы увеличивается на данное время, количество обслуженных заявок инкрементируется. Если S=1, то генерируется и время поступления заявки в систему, и время обслуживания заявки системой, время работы системы увеличивается на меньшее значение сгенерированных величин. Если же время обслуживания меньше, то S=0, количество обслуженных заявок инкрементируется, иначе S=1. Если S=2, то генерируется и время поступления заявки в систему, и время обслуживания заявки системой, время работы системы увеличивается на меньшее значение сгенерированных величин. Если же время обслуживания меньше, то S=1, количество обслуженных заявок инкрементируется, иначе S=2. В этом случае заявка получает отказ.

Модификация. Это процесс добавления новых функциональных возможностей или изменение существующих свойств системы. Как правило, изменения затрагивают реализацию класса, оставляя без изменения его интерфейс, что при использовании ООП обычно обходится без особых неприятностей, так как процесс изменений затрагивает локальную область. Изменение интерфейса - также не очень сложная задача, но ее решение может повлечь за собой необходимость согласования процессов взаимодействия объектов, что потребует изменений в других классах программы. Однако сокращение количества параметров в интерфейсной части по сравнению с модульным программированием существенно облегчает и этот процесс.

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

Существенным также является то, что при использовании ООП объект или группа объектов могут разрабатываться отдельно, и, следовательно, их проектирование может находиться на различных этапах.

При решении поставленной задачи была разработана программа с применением объектно-ориентированного подхода.

5. Проектирование иерархии иммитационного моделирования

5.1 Формирование словаря абстракций предметной области

Для построения эффективной и наращиваемой иерархии классов, представляющей всевозможные Q-схемы, необходимо выявление всех абстракций предметной области, их анализ, выделение общих свойств, поведения и отличий. По спискам общих свойств и отличий можно получить более общие абстракции и затем построить отношение "обобщения", которое будет основой иерархии классов.

Все выявленные абстракции сведены вместе с их характеристиками в табл.1:

Таблица 1

Название абстракции

Характеристика абстракции

1

Генератор заявок

Входит в структуру Q-схемы

Обрабатывает заявки

Имеет выходные информационные связи

Выдает заявки

Задерживает заявки (по времени)

Характеризуется законом распределения

Не имеет входов

Не имеет управляющих выходов

2

Канал

Входит в структуру Q-схемы

Обрабатывает заявки

Имеет входные информационные связи

Имеет выходные информационные связи

Принимает заявки

Выдает заявки

Задерживает заявки (по времени)

Характеризуется законом распределения

Не имеет управляющих входов

Может иметь управляющие выходы

3

Очередь

Входит в структуру Q-схемы

Обрабатывает заявки

Имеет входные информационные связи

Имеет выходные информационные связи

Принимает заявки

Выдает заявки

Задерживает заявки (по готовности приемника)

Характеризуется дисциплиной обслуживания

Имеет контейнер заявок

Не имеет управляющих входов

Может иметь управляющие выходы

4

Клапан

Входит в структуру Q-схемы

Обрабатывает заявки

Имеет входные информационные связи

Имеет входные управляющие связи

Имеет выходные информационные связи

Принимает заявки

Выдает заявки

Не задерживает заявки

Характеризуется функцией управления

Не имеет управляющих выходов

5

Простой случайный контроллер

Входит в структуру Q-схемы

Не обрабатывает заявки

Имеет хотя бы 2 управляющих выхода

Управляет группой клапанов по случайному закону

Выбор клапанов по принципу "один из N"

Не имеет информационных связей

Характеризуется законом распределения

Не имеет управляющих входов

6

Адаптивный случайный контроллер

Входит в структуру Q-схемы

Не обрабатывает заявки

Имеет хотя бы 2 управляющих выхода

Управляет группой клапанов по случайному закону

Выбор клапанов по принципу "один из N"

Адаптирует закон управления по состоянию других элементов

Не имеет информационных связей

Характеризуется законом распределения

Имеет управляющие входы (ассоциации)

7

Обобщенный массовый контроллер

Входит в структуру Q-схемы

Не обрабатывает заявки

Имеет хотя бы 2 управляющих выхода

Управляет группой клапанов по произвольному закону

Выбор клапанов по любому принципу

Адаптирует закон управления по состоянию других элементов и другой информации

Не имеет информационных связей

Имеет управляющие входы (ассоциации)

8

Заявка

Формируется в генераторе

Включает атрибуты (тип, приоритет, время генерации)

Уничтожается при выходе из системы

9

Структура схемы

Содержит информационные и управляющие связи для всех пар связанных элементов

Для управляющих связей задает состояния управления

10

Q-схема

Охватывает управление запуском модели, остановом моделирования, организует сбор статистики, имитирует попарную передачу заявок элементами, управляет отслеживанием ошибок

11

Генератор случайных чисел

Используется генераторами заявок и каналами для получение временных интервалов выдачи заявок и обслуживания

12

Дисциплина обслуживания

Используется очередями для задания порядка извлечения заявок

13

Функция управления

Используется клапанами для объединения сигналов управления

14

Менеджер статистики

Вспомогательная абстракция, используемая Q-схемой для управления сбором статистики и ведения протокола статистики

15

Менеджер ошибок

Вспомогательная абстракция, используемая Q-схемой для управления отслеживанием ошибок

16

Разветвитель

Обрабатывает заявки, имеет входную информационную связь, имеет как минимум две выходные информационные связи, не задерживает заявки, создает копию заявки

5.1.1 Выделение общих абстракций

Из табл.1 легко увидеть, что многие элементы Q-схем имеют общие свойства и поведение, что позволяет построить на их основе обобщенные абстракции.

В дальнейшем эти абстракции могут быть представлены абстрактными классами, которые, в свою очередь, будут порождать неабстрактные классы элементов Q-схем. Список выявленных новых абстракций представлен в табл.2.


Подобные документы

  • Разработка решения задачи имитационного моделирования системы массового обслуживания (СМО), на примере склада продукции. Построение концептуальной модели системы. Сравнение результатов имитационного моделирования и аналитического расчета характеристик.

    курсовая работа [75,5 K], добавлен 26.06.2011

  • Характеристика функций имитационного моделирования. Знакомство с особенностями имитационного моделирования агрегированной системы массового обслуживания. Анализ программы GPSSWorld: рассмотрение возможностей, способы составления имитационной модели.

    курсовая работа [1,6 M], добавлен 27.05.2013

  • Обзор средств компьютерного имитационного моделирования по созданию веб-приложения для визуализации имитационных моделей. Система имитационного моделирования AnyLogic, Arena, SimuLab. Серверная, клиентская часть. Модель работы отдела банка и участка цеха.

    дипломная работа [3,3 M], добавлен 25.05.2015

  • Методика системного исследования реальной динамической сложной системы посредством разработки ее имитационной модели. Разработка программы реализации алгоритма имитационного моделирования системы массового обслуживания "Интернет-провайдерская фирма".

    курсовая работа [2,0 M], добавлен 20.01.2010

  • Концептуальная модель процесса обслуживания покупателей в магазине. Описание системы моделирования GPSS. Разработка моделирующей программы на специализированном языке имитационного моделирования в среде AnyLogic. Результаты вычислительных экспериментов.

    курсовая работа [906,9 K], добавлен 12.07.2012

  • Особенности систем массового обслуживания и сущность имитационного моделирования с использованием GPSS. Структурная схема модели системы и временная диаграмма. Сравнение результатов имитационного моделирования и аналитического расчета характеристик.

    курсовая работа [214,2 K], добавлен 23.06.2011

  • Сфера применения имитационного моделирования. Исследование и специфика моделирования системы массового обслуживания с расчетом стационарных значений системы и контролем погрешности получаемых значений. Реализация ее в GPSS и на языке высокого уровня Java.

    курсовая работа [818,7 K], добавлен 23.05.2013

  • Программные средства имитационного моделирования систем массового обслуживания. Программная среда Matlab, ее структура и основные компоненты, функциональные особенности, а также назначение. Разработка подсистем моделирования. Инструкция пользователя.

    дипломная работа [3,3 M], добавлен 10.07.2017

  • Основы технологии моделирования Arena. Построение простой имитационной модели. Моделирование работы системы обслуживания покупателей на кассе супермаркета. Построение модели IDEF3. Анализ результатов имитационного моделирования и аналитического решения.

    курсовая работа [659,1 K], добавлен 24.03.2012

  • Математическое описание имитационной модели. Описание блок-схемы алгоритма. Анализ полученных результатов имитационного моделирования. Сопоставление полученных результатов для разработанных моделей. Математическое описание аналитического моделирования.

    курсовая работа [306,5 K], добавлен 25.03.2015

Работы в архивах красиво оформлены согласно требованиям ВУЗов и содержат рисунки, диаграммы, формулы и т.д.
PPT, PPTX и PDF-файлы представлены только в архивах.
Рекомендуем скачать работу.