Транспортные сети. Задача о максимальном потоке в сети
Изучение и нахождение ограниченного поперечного сечения, определяющего пропускную способность системы в целом. Нахождение алгоритма величины максимального потока в транспортной сети с помощью теоремы Форда-Фалкерсона. Обзор определенной на множестве.
Рубрика | Математика |
Вид | реферат |
Язык | русский |
Дата добавления | 07.08.2013 |
Размер файла | 102,7 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Размещено на http://www.allbest.ru/
Московский Государственный Институт Делового Администрирования
Реферат
На тему:
Транспортные сети. Задача о максимальном потоке в сети
Работу выполнила:
Болотина Юлия
Работу проверил:
Аллавердиев А.М.
Москва, 2003 год
Содержание
Введение
1. Теоретическая часть
2. Теорема Форда-Фалкерсона
3. Алгоритм решения
4. Поток в транспортной сети
5. Орграф приращений
6. Алгоритм построения максимального потока в транспортной сети
7. Практическая часть
Заключение
Список используемой литературы
Введение
В постановке задаче, которую я рассматриваю, да и вообще в задачах на данную тему фундаментальную роль играет изучение поперечных сечений сети (то есть множеств дуг, которые соединяют вершины двух не пересекающихся множеств вершин) и нахождение ограниченного поперечного сечения, которое является самым узким местом. Эти узкие места определяют пропускную способность системы в целом.
1. Теоретическая часть
Транспортной сетью называется конечный Связный орграф G(V, E) без петель, каждой дуге которого поставлено в соответствие некоторое неотрицательное число c(), называемое пропускной способностью дуги, и существует:
1) ровно одна вершина , в которую не заходит ни одна дуга, называемая источником или началом сети;
2) ровно одна вершина , из которой не выходит ни одной дуги; эта вершина называется стоком или концом сети.
Потоком сети называется неотрицательная функция f(1) такая, что f(e) меньше или равно c(e). (Поток не может превышать пропускную способность дуги.)
Дуга называется насыщенной потоком f. (Поток называется полным, если содержит насыщенную).
Разрезом L сети G(V,E) называется множество насыщенных дуг, отделяющих источник s от стока t.
2. Теорема Форда-Фалкерсона
Пусть D - транспортная сеть, - допустимый поток в этой сети, - множество вершин таких, что длина минимального пути из в в орграфе приращений равна нулю.
Тогда, если , то - максимальный поток, величина которого равна .
Пусть .
Тогда выполняется равенство:
(1)
Если , так как в противном случае, используя:
Имеем , а следовательно, в силу существует путь нулевой длины из в , что противоречит условию . Но тогда из (1) получаем:
Следствие 1. Используя теорему Форда-Фалкерсона получаем, что величина максимального потока в транспортной сети равна пропускной способности минимального разреза.
Следствие 2. Пусть - допустимый поток в транспортной сети D. Тогда, если длина минимального пути из v1 в vn в орграфе приращений равна бесконечности, то - максимальный поток.
3. Алгоритм решения
Сначала будем строить полный поток, затем проверим, можно ли его увеличить. Если нет, то этот поток является максимальным. Если же его можно увеличить, то будем строить другой полный поток и т. д. Решать задачу будем с помощью метода расстановки пометок.
Две основные процедуры (операции алгоритма):
- операция расстановки пометок;
- операция изменения потока.
Рассмотрим первую процедуру. Для каждой вершины данной сети нужно приписать пометку, которая имеет следующий вид: или где , а - натуральное число или бесконечность. Вообще возможны три состояния вершины:
1) не помечена;
2) помечена, но не просмотрена;
3) помечена и просмотрена.
Расставлять пометки начнем с источника S. Он получит пометку Источник помечен, но не просмотрен. Остальные вершины не помечены. Чтобы источник S был помечен и просмотрен, надо поместить все вершины, смежные с S.
Вершина получит пометку , где:
Теперь все вершины смежные с S, помечены, но не просмотрены. А вершина S помечена и просмотрена. Начнём просматривать ту из вершин , которая имеет наименьший индекс. Для этого нужно расставить пометки вершинам, смежным с . Если для вершины выполняется следующее условие, где:
Если же для вершины выполняется условие:
Далее просматриваем следующую вершину, и так до тех пор, пока не пометим сток t или же пока нельзя будет больше пометить ни одной вершины, сток при этом останется не помеченным. Если сток окажется не помеченным, то процесс нахождения максимального потока в сети можно считать законченным, а если сток помечен, то нужно переходить к процедуре 2. Рассмотрим процедуру изменения потока.
Если же вершина имеет пометку , то заменяем на:
Переходим к следующей вершине и так до тех пор, пока не достигнем источника S.
Здесь изменение потока прекращается. Далее переходим к процедуре 1 и так до тех пор, пока величину потока уже нельзя изменить.
Рассмотрим конкретную задачу о нахождении максимального потока в сети. Дана сеть G(V,E) с источником S и стоком t. Пропускные способности дуг указаны.
Найти максимальный поток из S в t.
4. Поток в транспортной сети
Функция , определенная на множестве X дуг транспортной сети D и принимающая целочисленные значения, называется допустимым потоком (или просто потоком) в транспортной сети D, если:
- для любой дуги величина , называемая потоком по дуге , удовлетворяет условию;
- для любой промежуточной вершины v выполняется равенство:
Т. е. сумма потоков по дугам, заходящим в v, равна сумме потоков по дугам, исходящим из v.
Рисунок:
Пример.
На рисунке показан допустимый поток в транспортной сети. При каждой дуге указана величина потока по ней.
Очевидно, что выполняются все условия, перечисленные в определении допустимого потока (проверяем выполнение второго условия для промежуточных вершин ).
Для любого допустимого потока в транспортной сети D выполняется равенство:
По определению допустимого потока имеем:
Заметим, что для каждой дуги , величина входит в левую часть равенства лишь один раз и при этом со знаком плюс. Аналогично для каждой дуги, величина входит в левую часть равенства лишь один раз и при этом со знаком минус. С другой стороны, для каждой дуги величина входит в левую часть равенства один раз со знаком плюс и один раз со знаком минус, что в сумме даёт нулевой вклад в левую часть равенства (2). Учитывая сказанное, заключаем, что из равенства (2) следует справедливость равенства (1).
Величиной потока в транспортной сети D называется величина , равная сумме потоков по всем дугам, заходящим в , или, что то же самое - величина, равная сумме потоков по всем дугам, исходящим из :
Пусть - допустимый поток в транспортной сети D. Дуга называется насыщенной, если поток по ней равен её пропускной способности, т. е. если:
Поток называется полным, если любой путь в D из содержит, по крайней мере, одну насыщенную дугу.
Поток называется максимальным, если его величина принимает максимальное значение по сравнению с другими допустимыми потоками в транспортной сети D.
Очевидно, что максимальный поток обязательно является полным (т. к. в противном случае в D существует некоторая простая цепь из V1 в Vn, не содержащая насыщенных дуг, а следовательно, можно увеличить на единицу потоки по всем дугам из и тем самым увеличить на единицу , что противоречит условию максимальности потока). Обратная же, вообще говоря, неверно.
Существуют полные потоки, не являющиеся максимальными. Тем на менее полный поток можно рассматривать как некоторое приближение к максимальному потоку.
5. Орграф приращений
Введем для заданной транспортной сети D и допустимого потока в этой сети орграф приращений , имеющий те же вершины, что и сеть D. Каждой дуге:
Транспортной сети D в орграфе приращений соответствует две дуги: и - дуга. Противоположная по направлению дуге . Припишем дугам орграфа приращений длину :
Т. е. орграф является нагруженным.
При этом очевидно:
- длина любого пути из в в орграфе равна либо 0, либо бесконечности.
6. Алгоритм построения максимального потока в транспортной сети
Важным следствием теоремы Форда-Фалкерсона является Алгоритм построения максимального потока в транспортной сети.
Алгоритм:
Шаг 1. Полагаем i=0. Пусть - любой допустимый поток в транспортной сети D.
Шаг 2. По сети D и потоку строим орграф приращений .
Шаг 3. Находим простую цепь , являющуюся минимальным путем из в в нагруженном орграфе .
Если длина этой цепи равна бесконечности, то поток максимален, и работа алгоритма закончена.
В противном случае увеличиваем поток вдоль цепи на максимально допустимую величину , такую, что при этом сохраняется условие 1 допустимого потока. Используя:
Получаем, что указанная величина существует. В результате меняется поток в транспортной сети D, т. е. от потока мы перешли к потоку , и при этом:
Присваиваем:
7. Практическая часть
Для заданной транспортной сети определить величину максимального потока грузов, которые можно доставить в течение заданного времени из города S в город t. Пропускные способности всех участков дорог считаются известными.
Этап 1.
Начнём с процедуры расстановки пометок. Пометка источника S Далее рассмотрим те вершины, которые соединены с источником дугой. Это V, V, V. Пропустим по всей сети первоначальный нулевой поток:
Припишем около каждой дуги после значения пропускной способности значение первоначального потока.
Просмотрим вершину S, для этого пометим вершины V, V, V.
Просмотрим вершину V, ставим метки. Просмотрим , ставим метки. Изменение потока:
Поэтому заменим величину первоначального потока:
Рисунок:
Этап 2.
Просмотрим вершину V1, вершины V4 и V2 получают метки и Просмотрим V3, V2 уже просмотрена, . Просмотрим V2, V4 уже помечена,
Изменение потока:
Вносим изменения потока. Дуга (V2, t) стала насыщенной.
Рисунок:
Этап 3.
Просмотрим вершину V1. Вершины V4 и V2 получают метки.
Просмотрим V3, V2 уже помечена, Просмотрим V2, V4 уже помечена, Просмотрим V4.
Изменение потока:
Вносим изменения потока. Дуга (V3,V2) стала насыщенной.
Рисунок:
Этап 4.
Просмотрим вершину V3. Вершины V2 и V3 получают метки.
Просмотрим V2. Вершины V4, V5 и t получают метки.
Вносим изменения потока. Дуга (V3, V2) стала насыщенной.
Этап 5.
Просмотрим вершину V3. Вершина V6 получает метку.
Просмотрим V6.
Изменение потока:
Вносим изменения потока. Дуга (S,V3) стала насыщенной.
Поток f=21 является максимальным, а множество дуг составляют минимальный разрез сети. Минимальный разрез на рисунке обозначен волнистой линией.
Заключение
Бурное развитие дискретной математики обусловлено прогрессом компьютерной техники, необходимостью создания средств обработки и передачи информации, а также представления различных моделей на компьютерах, являющихся по своей природе конечными структурами.
Транспортной сетью называется конечный Связный орграф G(V, E) без петель, каждой дуге которого поставлено в соответствие некоторое неотрицательное число c(), называемое пропускной способностью дуги, и существует: алгоритм теорема множество
1) ровно одна вершина , в которую не заходит ни одна дуга, называемая источником или началом сети;
2) ровно одна вершина , из которой не выходит ни одной дуги; эта вершина называется стоком или концом сети.
Список используемой литературы
1. А.М. Аллавердиев, И.В. Платонова «Прикладная математика. Элементы теории графов» М. 2000;
2. Лекции по прикладной математике И.В. Платоновой;
3. В.Н. Нефедов, В.А. Осипова «Курс дискретной математики» М. 1992;
4. С.В. Судоплатов, Е.В. Овчинникова «Элементы дискретной математики» М. 2002.
Размещено на Allbest.ru
...Подобные документы
Общая характеристика распространенных проблем поиска величины максимального потока в сети при помощи алгоритма Форда-Фалкерсона. Знакомство с задачами по дискретной математике. Рассмотрение особенностей и этапов постройки дерева кратчайших расстояний.
контрольная работа [740,3 K], добавлен 09.03.2015Определение количества способов, которыми можно выбрать трех дежурных из группы в 20 человек. Построение таблицы истинности без предварительного упрощения функции по данному логическому выражению. Упрощение логических выражений с помощью карты Карно.
контрольная работа [81,1 K], добавлен 25.08.2013Эйлеровы цепи и циклы, теоремы. Алгоритм построения эйлерова цикла. Обоснование алгоритма. Нахождение кратчайших путей в графе. Алгоритм Форда отыскания кратчайшего пути. Задача отыскания кратчайших расстояний между всеми парами вершин. Алгоритм Флойда.
реферат [108,4 K], добавлен 01.12.2008Решение системы линейных уравнений по правилу Крамера и с помощью обратной матрицы. Нахождение ранга матрицы. Вычисление определителя с помощью теоремы Лапласа. Исследование на совместимость системы уравнений, нахождение общего решения методом Гауса.
контрольная работа [97,3 K], добавлен 24.05.2009Нахождение производных функций, построение графика функции с помощью методов дифференциального исчисления, нахождение точки пересечения с осями координат. Исследование функции на возрастание и убывание, нахождение интегралов, установка их расходимости.
контрольная работа [130,5 K], добавлен 09.04.2010Минимальное остовное дерево связного взвешенного графа и его нахождение с помощью алгоритмов. Описание алгоритма Краскала, возможность строить дерево одновременно для нескольких компонент связности. Пример работы алгоритма Краскала, код программы.
курсовая работа [192,5 K], добавлен 27.03.2011Нахождение статических моментов и центра тяжести кривой. Нахождение статических моментов и центра тяжести плоской фигуры. Первая и вторая теоремы Гульдина. Нахождение объема тела вращения плоской фигуры. Использование интеграла вместо обыкновенной суммы.
курсовая работа [275,3 K], добавлен 30.12.2011Математическая теория массового обслуживания как раздел теории случайных процессов. Системы массового обслуживания заявок, поступающих через промежутки времени. Открытая марковская сеть, ее немарковский случай, нахождение стационарных вероятностей.
курсовая работа [374,3 K], добавлен 07.09.2009Нахождение минимального пути от фиксированной до произвольной вершины графа с помощью алгоритма Дейкстры, рассмотрение основных принципов его работы. Описание блок-схемы алгоритма решения задачи. Проверка правильности работы разработанной программы.
курсовая работа [495,4 K], добавлен 19.09.2011Характеристика открытой сети массового обслуживания с многорежимными стратегиями обслуживания, в которую поступают обычные положительные заявки и пуассоновские потоки информационных сигналов, оказывающие разовое воздействие на соответствующий узел сети.
курсовая работа [221,8 K], добавлен 02.03.2010Задача на вычисление скалярного произведения векторов. Нахождение модуля векторного произведения. Проверка коллинеарности и ортогональности. Составление канонического уравнения эллипса, гиперболы, параболы. Нахождение косинуса угла между его нормалями.
контрольная работа [102,5 K], добавлен 04.12.2013Понятие дифференциального уравнения. Нахождение первообразной для заданной функции. Нахождение решения дифференциального уравнения. Выделение определенной интегральной кривой. Понятие произвольных независимых постоянных. Уравнение в частных производных.
презентация [42,8 K], добавлен 17.09.2013Графический и симплексный методы решения ОЗЛП. Построение функции цели, образующая совместно с системой ограничений математическую модель экономической задачи. Нахождение неотрицательного решения системы линейных уравнений. Решение транспортной задачи.
лабораторная работа [322,9 K], добавлен 10.04.2009Потоки в сетях, структура и принципы формирования алгоритма Форда-Фалкерсона, особенности его реализации программным методом. Минимальные остовные деревья. Алгоритм Борувки: понятие и назначение, сферы и специфика практического использования, реализация.
курсовая работа [311,3 K], добавлен 15.06.2015Пример решения задачи на нахождение корня уравнения. Определение веса бетонного шара. Коэффициент полезного действия: понятие, формула. Нахождение значения функции. Плоскость основания цилиндра. Угол между плоскостью сечения и основания цилиндра.
контрольная работа [57,2 K], добавлен 27.12.2013Задача на нахождение модуля и аргумента заданных чисел, пример решения. Область дифференцируемости заданной функции, действительная часть производной. Правило для определения уравнения образа кривой. Нахождение действительной и мнимой части функции.
методичка [693,0 K], добавлен 21.12.2011Необхідні поняття теорії графів. Задача про максимальний потік. Алгоритм Форда знаходження максимального потоку. Модифікація алгоритму Форда розв’язання задачі максимізації кількості призначень у задачах розподілу. Результати числового експерименту.
курсовая работа [499,9 K], добавлен 18.12.2013Основные понятия теории массового обслуживания: марковский процесс, простой поток, сеть Джексона. Исследование стационарного распределения сети с ромбовидным контуром: для марковских и немарковских процессов, а также для сети с отрицательными заявками.
дипломная работа [957,4 K], добавлен 17.12.2012Метод интегрирования по частям. Задача на нахождение частных производных 1-го порядка. Исследование на экстремум заданную функцию. Нахождение частных производных. Неоднородное линейное дифференциальное уравнение 2-го порядка. Условия признака Лейбница.
контрольная работа [90,0 K], добавлен 24.10.2010Полное исследование функции с помощью производных, построение графика функции, нахождение ее наибольшего и наименьшего значения на отрезке. Методика вычисления неопределенных и определенных интегралов. Нахождение общего решения дифференциального уравнения
контрольная работа [133,4 K], добавлен 26.02.2012