Автор: Пользователь скрыл имя, 21 Ноября 2011 в 15:28, курсовая работа
Оптимальное решение является наилучшим только в рамках использования данной модели. Не следует считать, что это действительно самое лучшее решение анализируемой задачи.
Целью данной работы является обзор и анализ методов решения специальных задач линейного программирования.
Введение 8
Обзор литературы 9
1. Целочисленное программирование 10
2. Методы ветвей и границ 13
3. Задача выбора вариантов 17
4. Дискретное программирование 21
5. Методы решения дискретных задач 24
Заключение 7
Список используемой литературы 7
Вторым,
но не менее важным источником, служит
книга «Методы оптимизации» (Харчистов
Б.Ф.). В ней изложены основные понятия
и теоретические положения
1.
Целочисленное программирование
Первые упоминания о линейных уравнениях возникли еще за несколько веков до нашей эры.
В Древней Греции Диофант (II-III вв.) формулирует уравнения, в которых искомые переменные — целые. Например, для уравнения первой степени, а0 + a1x1 = 0, где a0, a1 — целые, решение x1 = -a0/a1 — целое, если a0 делится на a1 без остатка, т. е. такое уравнение не всегда разрешимо в целых числах. Из двух уравнений 3x1 - 27 = 0 и 5x2 + 21 = 0 только первое имеет целое решение: x1 = 27/3 = 9, а второе — нет, так как x2 = -21/5.
Для
уравнения с двумя
10x2 - 5x2 = 0 или x1 = 0,5x2 . (1)
Из этого примера можно сделать следующие выводы: уравнение имеет бесчисленное множество решений, так как n > m; решение — целое, если x2 — четное.
Для того чтобы из множества допустимых решений выбрать одно — оптимальное, необходимо, как нам уже известно, добавить к условию (1) целевую функцию. Задачи оптимизации, в которых решение должно быть в целых числах, называют задачами целочисленного программирования. Если в этой задаче целевая функция и ограничения — линейные зависимости, то ее называют целочисленной задачей линейного программирования; если же хотя бы одна зависимость будет нелинейной, то такая задача формулируется как целочисленная нелинейного программирования.
Большинство практических задач принятия решения сводится к целочисленным задачам линейного программирования.
Если к условию (1) добавить такие, например, граничные условия:
2 ≤ x1 ≤ 8; 1 ≤ x2 ≤ 3
то можно видеть, что такая система решения не имеет. Отсюда следует, что задача целочисленного программирования не всегда имеет решение, т. е. она не совместна.
Под целочисленным или дискретным программированием понимают такие задачи (обычно линейные), в которых искомые переменные по смыслу могут принимать только целые значения: число рабочих, разделяемых по рабочим местам; количество единиц оборудования, устанавливаемых на заданной площади, и т. п.
Аналитическая задача целочисленного программирования формулируется:
max(min)
L =
Если n1 = n, то задачу называют полностью целочисленной; если n1 < n, то — частично целочисленной.
Предположим, что задача имеет многогранник решений (рис. 1). Если наложить требование целочисленности, то допустимое множество решений выразится в систему точек и уже не будет выпуклым.
Если добавить новые ограничения, связывающие внешние целочисленные точки, а затем в качестве многогранника использовать все выпуклое множество, ограниченное осями координат и новым контуром, то получим новую задачу линейного программирования со следующими свойствами:
Таким образом, решение задач целочисленного программирования трудоемко. Поэтому по возможности лучше не накладывать ограничений целочисленности переменных.
В ряде случаев задачу целочисленного программирования решают следующим образом:
При необходимости точного решения применяют специальные методы, где учитывается, что множество решений любой целочисленной задачи — конечно. Например, в задаче с переменными x1, x2: 0 < x1 ≤ 4; 0 < xj ≤ 5. Число возможных решений 4*5 = 20. Следовательно, возможен полный перебор всех возможных сочетаний целочисленных x1, x2 и выбор из них наилучших в смысле целевой функции. Трудоемкость этого метода возрастает с ростом числа переменных и области граничных условий, и для реальных задач он неприменим.
Поэтому
в реальных задачах применяют
методы, в которых не рассматривают
все возможные альтернативы. Распространены
методы отсечений
и методы возврата, среди которых наиболее
известен метод ветвей
и границ. Метод отсечений для программной
реализации сложен.
Решение задачи методом Гомори
Во
многих экономических задачах
(1.1)
Присоединяя
равенство (1.1) к ранее решенной задаче,
получить новую задачу линейного
программирования, которую вновь
решить симплексным методом. Если ее
оптимальное решение окажется целочисленным,
то оно и будет оптимальным
решением исходной задачи. Если снова
получится нецелочисленное
Пример.
Найти наибольшее значение функции
при
ограничениях:
2. Метод ветвей и границ
Задача линейного программирования решается без учета целочисленности. Такая задача называется непрерывной. Далее рассматривают одну из переменных xj, на которую накладывают ограничение целочисленности, но которая получила дробное значение. На основе полученного решения составляют дополнительные ограничения:
xj ≤ [] и xj ≥ [] + 1,
где [] — целая часть нецелочисленного значения переменной в оптимальном решении, и затем решаются еще две задачи линейного программирования, в каждую из которых вошли все исходные ограничения и одно из дополнительных.
Полученное решение новых задач проверяют на целочисленность переменных. Если решение не удовлетворяет требованию целочисленности, на основе каждой из задач составляют, аналогично предыдущим, две новые и т. д.
Если одно из решений удовлетворяет требованию целочисленности, значение целевой функции принимается за граничное Lгр. При этом рассмотрение других задач продолжается до тех нор, пока не будет получено:
Таким образом, для получения целочисленного решения методом ветвей и границ приходится решать большое число задач линейного программирования, причем в каждом очередном ветвлении число ограничений увеличивается на 1. Поэтому время решения задачи целочисленного программирования по сравнению с непрерывной значительно увеличивается.
Пример 1.
max
L = 7x1 + 3x2,
Решение. В результате решения задачи симплекс-методом найдем оптимальное решение = 1; = 7,5; L1 = 29,5, где верхний индекс переменных — номер задачи.
В полученном решении x2 = 7,5 — нецелочисленное. Поэтому для дальнейшего решения составляем две новые задачи с различными граничными условиями.
Задача
2.
max L =
7x1 + 3x2,
Результаты решения симплекс методом задачи 2: = 1,2; = 7; L2 = 29,4; задачи 3: = 0,75; = 8; L3 = 29,25;
В задаче 1 переменная = 1 — целочисленная, а в последующих задачах при целочисленности х2 перестала быть целочисленной x1. Затем следует накладывать ограничения целочисленности на x1 и т. д. (рис. 2).
Результаты
решения непрерывной и
Таблица 1.
N задачи | X1 | X2 | L | N задачи | X1 | X2 | L |
1 | 1 | 7,5 | 29,5 | 5 | 2 | 5 | 29 |
4 | 1 | 7 | 28 | 6 | 0 | 9 | 27 |
Из примера видно, что метод ветвей и границ достаточно трудоемкий. При этом оптимальное решение может быть получено в результате сравнения всех допустимых целочисленных решений. Поэтому при решении задач реальной размерности может потребоваться память, которой нет даже в современных компьютерах, или потребуется практически неприемлемое время решения.
Обязательное
условие метода — наличие верхних
границ на значения переменных Dj.
Если Dj не назначена, то ее
определяют по зависимости:
Где
минимальные значения всех ,
для которых определяется верхняя граница
.
3. Задача выбора вариантов
Перейдем теперь к частному случаю задач целочисленного программирования — задаче выбора вариантов.
В этом частном случае искомая переменная , в результате решения может принимать не любое целое значение, а только одно из двух: либо 0, либо 1. Чтобы такие переменные отличать от обычных и каждый раз не писать [0; 1], будем их вместо , обозначать . И это уже будет означать, что в результате решения задачи может быть равным или 0 или 1, т. е. всегда Такие переменные обычно называют булевыми (в честь предложившего их английского математика Джорджа Буля, 1815-1864).
Информация о работе Специальные задачи линейного программирования