- •П.Е. Пустовойтов Логистика
- •«Логистика»
- •7.080404 «Интеллектуальные системы принятия решений»,
- •7.092401 «Телекоммуникационные системы и сети»
- •Вступление
- •1. Транспортные модели
- •1.1. Определение транспортной модели
- •1.2. Нетрадиционные транспортные модели
- •1.3. Решение транспортной задачи
- •1.3.1. Определение начального решения
- •1.3.2. Итерационный алгоритм решения транспортной задачи
- •1.4. Задача о назначениях
- •1.4.1. Венгерский метод
- •1.5. Транспортная модель с промежуточными пунктами
- •2. Детерминированные модели динамического программирования
- •2.1. Рекуррентная природа вычислений дп
- •2.2. Рекуррентные алгоритмы прямой и обратной прогонки
- •2.3. Приложения динамического программирования
- •2.3.1. Задача о загрузке корабля
- •2.3.2. Задача планирования рабочей силы
- •2.3.3. Задача замены оборудования
- •2.3.4. Задача инвестирования
- •3. Детерминированные модели управления запасами
- •3.1. Общая модель управления запасами
- •3.2. Статические модели управления запасами
- •3.2.1. Классическая задача экономичного размера заказа
- •3.2.2. Задача экономичного размера заказа с разрывами цен
- •3.2.3. Многопродуктовая статическая модель с ограниченной вместимостью склада
- •3.3. Динамические задачи экономического размера заказа
- •3.3.1. Модель при отсутствии затрат на оформление заказа
- •3.3.2. Модель с затратами на оформление заказа
- •4. Вероятностные модели управления запасами
- •4.1. Модель с непрерывным контролем уровня запаса
- •4.2. Стохастический вариант модели экономичного размера заказа
- •4.3. Одноэтапные модели
- •4.3.1. Модель при отсутствии затрат на оформление заказа
- •4.3.2. Модель при наличии затрат на оформление заказа
- •4.4. Многоэтапные модели
- •5. Складская логистика
- •5.1. Определение месторасположения склада
- •5.2. Определение границ рынка
- •Список литературы
- •Содержание
- •Логістика
- •«Логістика»
- •7.080404 «Інтелектуальні системи прийняття рішень»,
- •7.092401 «Телекоммунікаційні системи та мережі»
- •61002, Харків, вул. Фрунзе, 21.
2.3. Приложения динамического программирования
Рассмотрим четыре примера, каждый из которых выбран для демонстрации методов динамического программирования. При рассмотрении каждого примера особое внимание необходимо обратить на три основных элемента моделей динамического программирования.
1. Определение этапов.
2. Определение на каждом этапе вариантов решения (альтернатив).
3. Определение состояний на каждом этапе.
Из перечисленных выше элементов понятие состояния, как правило, представляется весьма сложным для восприятия. Рассмотренные в этом разделе приложения последовательно показывают, что определение состояния меняется в зависимости от моделируемой ситуации.
2.3.1. Задача о загрузке корабля
Задача о загрузке — это задача о рациональной загрузке судна, которое имеет ограничения по объему или грузоподъемности. Каждый помещенный на судно груз принесет определенную прибыль. Задача состоит в определении загрузки судна такими грузами, которые принесут наибольшую суммарную прибыль.
Рекуррентное
уравнение процедуры обратной прогонки
выводится для общей задачи загрузки
судна грузоподъемностью
какой-то комбинацией предметов (грузов)
из
наименований.
Пусть
,
— количество предметов
-го
наименования, подлежащих загрузке,
,
— прибыль, которую приносит один
загруженный предмет
-го
наименования,
,—
вес одного предмета
-го
наименования. Общая задача имеет вид
следующей целочисленной задачи линейного
программирования.
Максимизировать
,
при условии, что
,
и
целые.
Три элемента модели динамического программирования определяются следующим образом.
1. Этап
ставится в соответствие предмету
-го
наименования,
.
2. Варианты решения
на этапе
описываются количеством
,
предметов
-го
наименования, подлежащих загрузке.
Соответствующая прибыль равна
.
Значение
,
заключено в пределах от 0 до
,
где
— целая часть числа
.
3. Состояние
,
на этапе
выражает суммарный вес предметов,
решения о погрузке которых, приняты на
этапах
.
Это определение отражает тот факт, что
ограничение по весу является единственным,
которое связывает
этапов вместе.
Пусть
—
максимальная суммарная прибыль,
накопленная на этапах
для каждого заданного состояния
.
Проще всего рекуррентное уравнение
определяется с помощью следующей
двухшаговой процедуры.
Шаг 1.
Выразим
как функцию
в виде
,
,
где
.
Шаг 2.
Выразим
,
как функцию
,
для гарантии того, что левая часть
последнего уравнения является функцией
лишь
.
По определению
представляет собой вес, загруженный на
этапе
,
т.е.
или
.
Следовательно, рекуррентное уравнение
приобретает следующий вид.
,
.
(2.3)
Пример 2.3
В 4-тонный самолет загружаются предметы трех наименований. В таблице (2.4) приведены данные о весе одного предмета , (в тоннах) и прибыли (в тысячах грн.), получаемой от одного загруженного предмета. Как необходимо загрузить самолет, чтобы получить максимальную прибыль?
Таблица 2.4 – Данные задачи из примера 2.3
Предмет
|
|
|
1 |
2 |
31 |
2 |
3 |
47 |
3 |
1 |
14 |
Так как вес одного предмета , для всех наименований и максимальный вес принимают целочисленные значения, состояние может принимать лишь целочисленные значения.
Этап 3.
Точный вес, который может быть загружен
на этапе 3 (предмет наименования 3),
заранее неизвестен, но он должен принимать
одно из значений 0, 1, ..., 4 (так как
).
Состояния
и
представляют собой крайние случаи,
когда предметы третьего наименования
совсем не загружаются или загружают
самолет полностью. Остальные значения
предполагают частичную загрузку самолета
предметами третьего наименования.
Действительно при этих значениях
все оставшиеся емкости самолета могут
быть заполнены предметами третьего
наименования.
Так как вес
одного предмета третьего типа равен 1
тонне, максимальное количество единиц
этого типа, которое может быть загружено,
равно
.
Это означает, что возможными значениями
будут 0, 1, 2, 3 и 4. Решение
является допустимым лишь при условии,
что
.
Следовательно, все недопустимые
альтернативы (те, для которых
)
исключены. Следующее уравнение является
основой для сравнения альтернатив на
этапе 3.
,
.
В следующей таблице сравниваются допустимые решения для каждого значения .
Таблица 2.5 – Этап 3
|
|
Оптимальное решение |
|||||
|
|
|
|
|
|
|
|
0 |
0 |
- |
- |
- |
- |
0 |
0 |
1 |
0 |
14 |
- |
- |
- |
14 |
1 |
2 |
0 |
14 |
28 |
- |
- |
28 |
2 |
3 |
0 |
14 |
28 |
42 |
- |
42 |
3 |
4 |
0 |
14 |
28 |
42 |
56 |
56 |
4 |
Этап 2.
,
.
Таблица 2.6 – Этап 2
|
|
Оптимальное решение |
||
|
|
|
|
|
0 |
0+0=0 |
- |
0 |
0 |
1 |
0+14=14 |
- |
14 |
0 |
2 |
0+28=28 |
- |
28 |
0 |
3 |
0+42=42 |
47+0=47 |
47 |
1 |
4 |
0+56=56 |
47+14=61 |
61 |
1 |
Этап 1.
,
.
Таблица 2.7 – Этап 1
|
|
Оптимальное решение |
|||
|
|
|
|
|
|
0 |
0+0=0 |
- |
- |
0 |
0 |
1 |
0+14=14 |
- |
- |
14 |
0 |
2 |
0+28=28 |
31+0=31 |
- |
31 |
1 |
3 |
0+47=47 |
31+14+45 |
- |
47 |
0 |
4 |
0+61=61 |
31+28=59 |
62+0=62 |
62 |
2 |
Оптимальное решение
определяется теперь следующим образом.
Из условия
следует, что первый этап решения задачи
при
дает оптимальное решение
,
которое означает, что два предмета
первого наименования будут загружены
в самолет. Эта загрузка оставляет
.
Решение на втором этапе при
приводит к оптимальному решению
,
которое, в свою очередь, дает
..
Далее этап 3 при
приводит к
.
Следовательно, оптимальным решением
задачи является
,
и
.
Соответствующая прибыль равна 62 000
долларов.
В таблице для
первого этапа, по существу, необходимо
получить оптимальное решение лишь для
,
так как это последний этап, подлежащий
рассмотрению. Однако в таблицу включены
также вычисления для
,
которые позволяют провести анализ
чувствительности решения. Например,
что произойдет, если максимальная
грузоподъемность самолета будет 3 тонны
вместо 4? Новое оптимальное решение
может быть определено, начиная с
на первом этапе и продолжая так, как
поступают при
.
Задача о загрузке
является типичным представителем задачи
распределения ресурсов, в которой
ограниченный ресурс распределяется
между конечным числом видов (экономической)
деятельности. При этом целью является
максимизация соответствующей функции
прибыли. В таких моделях определение
состояния на каждом этапе будет аналогично
приведенному для задачи о загрузке:
состоянием на этапе
является суммарное количество ресурса,
распределяемого на этапах
.
