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

Автор работы: Пользователь скрыл имя, 15 Января 2012 в 22:33, контрольная работа

Описание

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

Работа состоит из  1 файл

Методы моделирования.docx

— 74.27 Кб (Скачать документ)

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

     Этот  алгоритм похож на алгоритм поиска в глубину: начиная с произвольно  выбранной стартовой вершины  α, строим путь, выбирая каждый раз  для дальнейшего продвижения  еще не пройденное ребро. Главное  отличие от поиска в глубину состоит  в том, что как пройденные помечаются именно ребра, а не вершины. Поэтому  одна и та же вершина может посещаться несколько раз, но каждое ребро проходится не более одного раза, так что  в полученном маршруте ребра не будут  повторяться. Вершины пути накапливаются  в стеке S. Через некоторое количество шагов неизбежно наступит тупик - все ребра, инцидентные активной (последней посещенной) вершине x, уже  пройдены. Так как степени всех вершин графа четны, в этот момент x=a и пройденные ребра образуют цикл, но он может включать не все ребра  графа. Для обнаружения еще не пройденных ребер возвращаемся по пройденному  пути, перекладывая вершины из стека S в другой стек C, пока не встретим вершину x, которой инцидентно непройденное ребро. Так как граф связен, такая  вершина обязательно встретится. Тогда возобновляем движение вперед по непройденным ребрам, пока не дойдем до нового тупика и т.д. Процесс заканчивается, когда в очередном тупике обнаруживается, что S пуст. В этот момент в стеке C находится последовательность вершин эйлерова цикла.

     Алгоритм 1. Построение эйлерова цикла  

     
  1. выбрать произвольно  вершину α
  2. while S≠Ø do
  3. x:= top(S)
  4. if имеется непройденное ребро (x, y)
  5. then пометить ребро (x, y) как пройденное
  6. else переместить вершину x из S в C
 

     Для обоснования алгоритма заметим  сначала, что первой в стек S помещается вершина α, и она будет последней  перемещена из S в C. Следовательно, она  будет последней вершиной в стеке C. Далее, как было отмечено выше, первый раз, когда обнаружится, что все  инцидентные активной вершине ребра  пройдены (т.е. будет выполняться  ветвь else в строке 8), активной будет стартовая вершина α. Значит, эта вершина будет первой перемещена из S в C. Итак, по окончании работы алгоритма в начале и в конце последовательности вершин, содержащейся в стеке C, находится вершина α. Иначе говоря, если эта последовательность представляет маршрут (а далее будет показано, что так оно и есть), то этот маршрут замкнут.

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

     Будем говорить, что ребро (x, y) представлено в стеке (S или C), если в какой-то момент работы алгоритма в стеке рядом  находятся вершины x и y. Ясно, что  каждое ребро графа будет представлено в стеке S и что каждые две вершины, расположенные рядом в этом стеке, образуют ребро. Допустим, в какой-то момент из стека S в стек C перемещается вершина x, а непосредственно под  ней в стеке S находится вершина y. Возможно, что вершина y будет перемещена из S в C при следующем повторении цикла while, тогда ребро (x, y) будет представлено в стеке C. Другая возможность - между перемещением вершины x и следующим перемещением, т.е. следующим выполнением ветви else, будет несколько раз выполнена ветвь then (строки 6,\,7). Это означает, что будет пройдена некоторая последовательность ребер, начинающаяся в вершине y. Ввиду четности степеней эта последовательность может закончиться только в вершине y. Значит, и в этом случае следующей за вершиной x будет перемещена из S в C вершина y. В любом случае ребро (x, y) будет представлено в стеке C. Из этого рассуждения видно, что последовательность вершин в стеке C является маршрутом и что каждое ребро графа в конечном итоге будет содержаться в этом маршруте, причем один раз.

     При каждом повторении цикла while в рассмотренном алгоритме либо проходится одно ребро, либо одна вершина перемещается из S в C. Последнее можно трактовать как прохождение уже пройденного однажды ребра в обратном направлении. Каждое ребро в каждом направлении будет пройдено один раз, поэтому общая трудоемкость этого алгоритма оценивается как O(m). Необходимо только оговориться, что этот вывод, как и аналогичные заключения об алгоритмах обхода в первых разделах этой главы, справедлив лишь при определенных предположениях о том, как задан граф. Способ задания должен обеспечить возможность быстрого просмотра множества ребер, инцидентных данной вершине. Подходящим является, например, задание графа списками инцидентности, в которых для каждой вершины перечисляются инцидентные ей ребра. Необходимо также иметь возможность быстро пометить ребро как пройденное или проверить, пройдено ли данное ребро. Для этого подходящей структурой может служить характеристический массив на множестве ребер.

     Гамильтоновы пути и циклы

 

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

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

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

     Более рациональный подход состоит в рассмотрении всевозможных простых путей, начинающихся в произвольно выбранной стартовой  вершине α, до тех пор, пока не будет  обнаружен гамильтонов цикл или  все возможные пути не будут исследованы. По сути дела, речь тоже идет о переборе перестановок, но значительно сокращенном - если, например, вершина b не смежна с  вершиной α, то все (n-2)! перестановок, у  которых на первом месте стоит  α, а на втором b, не рассматриваются.

     Рассмотрим  этот алгоритм подробнее. Будем считать, что граф задан окрестностями  вершин: для каждой вершины x задано множество вершин, смежных с x. На каждом шаге алгоритма имеется уже  построенный отрезок пути, он хранится в стеке PATH. Для каждой вершины x, входящей в PATH, хранится множество N(x) всех вершин, смежных с x, которые еще не рассматривались в качестве возможных продолжений пути из вершины x. Когда вершина x добавляется к пути, множество N(x) полагается равным V(x). В дальнейшем рассмотренные вершины удаляются из этого множества. Очередной шаг состоит в исследовании окрестности последней вершины x пути PATH. Если N(x) ≠Ø и в N(x) имеются вершины, не принадлежащие пути, то одна из таких вершин добавляется к пути. В противном случае вершина x исключается из стека. Когда после добавления к пути очередной вершины оказывается, что путь содержит все вершины графа, остается проверить, смежны ли первая и последняя вершины пути, и при утвердительном ответе выдать очередной гамильтонов цикл. 

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

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

 

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

      1.1 Предмет и задачи теории массового обслуживания 

      Теория  массового обслуживания опирается  на теорию вероятностей и математическую статистику.

      На  первичное развитие теории массового  обслуживания оказали особое влияние  работы датского ученого А.К. Эрланга (1878-1929).

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

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

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

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

      1.2 Система массового обслуживания 

      Система обслуживания считается заданной, если известны:

      1) поток требований, его характер;

      2) множество обслуживающих приборов;

      3) дисциплина обслуживания (совокупность  правил, задающих процесс обслуживания).

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

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

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

 

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

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

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

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

Информация о работе Системы массового обслуживания