Автор: Пользователь скрыл имя, 22 Декабря 2011 в 08:48, курсовая работа
Задачами данной курсовой работы являются:
1) Рассмотреть теоретические аспекты решения задач динамического программирования: реккурентность природы задач данного типа; принципы оптимальности Беллмана
2) Разработка алгоритма. Блок-схемы. Структура алгоритма
3) Реализация на ЭВМ построенного алгоритма на выбранном языке программирования
Введение
1. Динамическое программирование
1.1 Основные понятия
1.2 Принципы динамического программирования. Функциональные уравнения Беллмана
1.3 Особенности задач динамического программирования
1.4 Примеры задач динамического программирования
2. Задача о замене оборудования
3. Расчет показателей экономико-математической модели
Список использованных источников
Приложение
Из анализа идеи
поэтапной оптимизации можно
сформулировать следующие принципы,
лежащие в основе динамического
программирования: принцип оптимальности
и принцип погружения.
Принцип оптимальности.
Оптимальное управление на каждом шаге
определяется состоянием системы на
начало этого шага и целью управления.
Или в развернутой форме: оптимальная
стратегия не зависит от начального
состояния и начального решения,
поэтому последующие решения
должны приниматься с учетом состояния
системы в результате первого
решения.
Принцип погружения.
Форма задачи, решаемая методом динамического
программирования, не меняется при
изменении количества шагов N, т.е. форма
такой задачи инвариантна относительно
N. В этом смысле всякий конкретный процесс
с заданным числом шагов оказывается
как бы погруженным в семейство
подобных ему процессов и может
рассматриваться с позиции
Реализация названных
принципов дает гарантию того, что
решение, принимаемое на очередном
шаге, окажется наилучшим относительно
всего процесса в целом, а не узких
интересов данного этапа. Последовательность
пошаговых решений приводит к
решению исходной N -шаговой задачи.
Функциональные уравнения
Беллмана. Как отмечалось выше, в
основе динамического программирования
лежит принцип оптимальности, направленный
на процедуру построения оптимального
управления. Так как оптимальной
стратегией может быть только та, которая
одновременно оптимальна и для любого
количества оставшихся шагов, ее можно
строить по частям: сначала для
последнего этапа, затем для двух
последних, для трех и т. д., пока не
придем к первому шагу. Отсюда принцип
оптимальности связан со вторым принципом
- принципом погружения, согласно которому
при решении исходной задачи ее как бы
погру жают в семейство подобных ей и решают
для одного последнего этапа, для двух
последних и т. д., пока не получат решение
исходной задачи.
Дадим математическую
формулировку принципа оптимальности.
Для простоты будем считать, что
начальное x0 и конечное xT состояния
системы заданы. Обозначим через z1(х0, u1)
значение функции цели на первом этапе
при начальном состоянии системы x0 и при
управлении u1, через z2(х1, u2) - соответствующее
значение функции цели только на втором
этапе, ..., через zi(хi-1,ui) - на i-м этапе, ...,
через zN(хN-1, uN) на N-м этапе. Очевидно, что
Z = z (x0, u) = (1)
Надо найти оптимальное
управление u*=(;;...;), такое, что доставляет
экстремум целевой функции (1) при
ограничениях u Ω. Для решения этой
задачи погружаем ее в семейство
подобных. Введем обозначения. Пусть
ΩN, ΩN-1,N, +, Ω1,2,+,N ≡ Ω - соответственно
области определения для
F1(xN-1), F2(xN-2), +, Fk(xN-k), +,
FN(x0)
соответственно условно-
F1(xN-1) = zN (xN-1, uN). (2)
Для двух последних
этапов получаем
F2(xN-2) = (ZN-1(xN-2, uN-1)+F1(xN-1)).
(3)
Аналогично:
F3(xN-3) = (ZN-2(xN-3, uN-2)+F2(xN-2)).
(4)
Fk(xN-k) = (zN-k+1(xN-k, uN-k+1)+Fk-1(xN-k+1)).
(5)
FN(x0) = (z1(x0, u1)+FN-1(x1)). (6)
Выражение (6) представляет
собой математическую запись принципа
оптимальности. Выражение (5) - общая
форма записи условно-оптимального
значения функции цели для k оставшихся
этапов. Выражения (2) - (6) называются функциональными
уравнениями Беллмана. Отчетливо
просматривается их рекуррентный (возвратный)
характер, т. е. для нахождения оптимального
управления на N шагах нужно знать
условно-оптимальное управление на
предшествующих N - 1 этапах и т. д. Поэтому
функциональные уравнения часто
называют рекуррентными (возвратными)
соотношениями Беллмана.
1.3
Особенности задач
динамического программирования
На основании приведенных
примеров можно выделить следующие
особенности задач
- Рассматривается
система, состояние которой на
каждом шаге определяется
- На каждом шаге
выбирается одно решение ut, под
действием которого система переходит
из предыдущего состояния xt-1 в новое хt.
Это новое состояние является функцией
состояния на начало интервала xt-1 и принятого
в начале интервала решения ut, т. е. xt = xt(xt-1,ut).
- Действие на каждом
шаге связано с определенным
выигрышем (доходом, прибылью) или
потерей (издержками), которые зависят
от состояния на начало шага
(этапа) и принятого решения.
- На векторы состояния
и управления могут быть
- Требуется найти
такое допустимое управление
ut для каждого шага t, чтобы получить экстремальное
значение функции цели за все Т шагов.
Любую допустимую последовательность
действий для каждого шага, переводящую
систему из начального состояния
в конечное, называют стратегией управления.
Стратегия управления, в результате которой
можно получить экстремальное значение
функции цели, называется оптимальной.
Геометрическая интерпретация
задачи динамического программирования
состоит в следующем. Пусть n - размерность
пространства состояний. В каждый момент
времени координаты системы имеют
вполне определенное значение. С изменением
времени t могут изменяться значения
координат вектора состояния. Назовем
переход системы из одного состояния
в другое траекторией ее движения
в пространстве состояний. Такой
переход осуществляется воздействием
на координаты состояния. Пространство,
в котором координатами служат состояния
системы, называется фазовым. Особенно
наглядно задачу динамического программирования
можно интерпретировать в случае,
если пространство состояний двухмерно.
Область возможных состояний
в этом случае изобразится некоторой
фигурой Ω, начальное и конечное состояния
системы - точками х0, xt Ω. Управление это
воздействие, переводящее систему из начального
состояния в конечное. Для многих экономических
задач не известно начальное либо конечное
состояние, а известна область X0 или XT,
которой эти точки принадлежат. Тогда
допустимые управления переводят точки
из области Х0 в XT. Задача динамического
программирования геометрически может
быть сформулирована следующим образом:
найти такую фазовую траекторию, начинающуюся
в области Х0 и оканчивающуюся в области
ХT, для которой функция цели достигает
экстремального значения. Если в задаче
динамического программирования известны
начальное и конечное состояния, то говорят
о задаче с закрепленными концами. Если
известны начальные и конечные области,
то говорят о задаче со свободными концами.
1.4
Примеры задач
динамического программирования
Приведем еще несколько
типичных задач, для решения которых
необходимым является применение метода
динамического
max Z = , u Ω,
где Ω область
допустимых управлений, или множество
экономических возможностей, определяемых
различными ограничениями, которые
налагаются на состояние системы
и вектор управления.
Задача об оптимальном
управлении поставками. В различных
областях народного хозяйства возникает
задача определения момента подачи партии
поставки и ее объема. С размещением заказов
связаны некоторые фиксированные затраты
К, не зависящие от величины заказываемой
партии, а зависящие только от факта заказа.
С содержанием материальных ресурсов
связаны затраты, пропорциональные остатку
нереализованной продукции на конец интервала
планирования. Пусть Т - промежуток планирования.
Обозначим через vt интенсивность потребления
ресурса в t-м интервале. Состояние системы
будем описывать величиной остатка нереализованной
продукции на конец интервала хt, при этом
начальное х0 и конечное хt состояния системы
можно считать заданными. Для обеспечения
непрерывности потребления поставками
нужно управлять. Обозначим через u = {ut}
вектор управления, координаты которого
величина поставок в начале соответствующих
интервалов планирования. Очевидно, что
вектор управления есть функция состояния
на начало интервала. Из множества возможных
управлений требуется выбрать такое, при
котором достигается минимум издержек
на заказ и содержание материальных ресурсов.
Если St издержки содержания единицы продукции
в t-м интервале, то функция цели примет
вид:
min Z = ,
Состояние системы
опишется соотношением хt = xt-1 + ut - vt (t =
). На состояние системы может быть наложено
ограничение, связанное с надежностью
снабжения: хt ≥ x0, где х0 - величина некоторого
страхового запаса, защищающего с заданной
надежностью от сбоев в системе. Объединение
ограничений, налагаемых на состояние
системы и вектор управления, обозначим
через Ω.
Получим задачу:
min Z = , u Ω.
2.
Задача о замене
оборудования
Задача о замене
оборудования (обновлении, восстановлении,
перестройке) имеет важное значение.
Рассмотрим ее в упрощенной постановке
Известно, что оборудование со временем
изнашивается, стареет физически и морально.
В процессе эксплуатации, как правило,
падает его производительность и растут
эксплуатационные расходы на текущий
ремонт. Со временем возникает необходимость
замены оборудования, так как его дальнейшая
эксплуатация обходится дороже, чем ремонт
или замена. Отсюда задача о замене может
быть сформулирована так: в процессе работы
оборудование дает ежегодно прибыль, требует
эксплуатационных затрат и имеет остаточную
стоимость. Эти характеристики зависят
от возраста оборудо вания. В любом году
оборудование можно сохранить, продать
по остаточной цене и приобрести новое.
В случае сохранения оборудования возрастают
эксплуатационные расходы и понижается
производительность. При замене нужны
значительные дополнительные капитальные
вложения. Задача состоит в определении
оптимальной стратегии замен в плановом
периоде с тем, чтобы суммарная прибыль
за этот период была максимальной.
Для количественной
формулировки задачи введем следующие
обо значения r(t) стоимость продукции,
производимой за год на единице оборудования
возраста t лет, u(t) расходы, связанные
с эксплуатацией этого
Решение
Чтобы решить задачу,
применим принцип оптимальности
Беллмана. Рассмотрим интервалы (годы)
планового периода в
В этой задаче систему
составляет оборудование. Ее состояние
характеризуется возрастом. Вектор
управления это решение в момент
t = 0, 1, 2, +, Т о сохранении или замене
оборудования. Для нахождения оптимальной
политики замен следует
s(t) - p + r(0) - u(0) > r(t) -
u(t)
Если же
s(t) - p + r(0) - u(0) < r(0) -
u(0)