Задачи целочисленного программирования решаются методом

1.1 Постановка задачи целочисленного программирования

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

Задача линейного целочисленного программирования формируется следующим образом: найти такое решение (план) X = (x1,x2. xn), при котором линейная функция

принимает максимальное или минимальное значение при ограничениях

=bi, i=1, 2…, m. (2)

хj ³ 0, j=1, 2. п. (3)

xj целые числа (4)

2. Методы решения задач целочисленного программирования

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

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

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

Для иллюстрации основной идеи методов решения задач целочисленного программирования, известных как методы отсечений, рассмотрим полностью целочисленную задачу, множество допустимых решений которой изображено на рисунке 1. Допустимым решениям этой задачи соответствуют не все точки множества G допустимых решений, а лишь те, координаты которых удовлетворяют требованию целочисленности. Теоретически из множества G всегда можно выделить такое подмножество G*, что (см. рис. 1):

а) оно содержит все точки множества G, координаты которых удовлетворяют требованию целочисленности;

б) оно является выпуклым множеством;

в) координаты всех его крайних точек удовлетворяют требованию целочисленности.

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

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

Наиболее известным комбинаторным методом является метод ветвей и границ, использующий процедуру решения задачи линейного программирования с ослабленными ограничениями, соответствующей исходной задаче целочисленного программирования. Если оптимальное решение X* задачи линейного программирования с ослабленными ограничениями не удовлетворяет требованию целочисленности (на рисунке 2 этому решению соответствует точка В), то из множества G допустимых решений выделяют два непересекающихся выпуклых подмножества К1 и К2, содержащих все допустимые решения из G, удовлетворяющих требованию целочисленности и не содержащих X* (см. рис. 2). Это позволяет заменить рассматриваемую задачу целочисленного программирования совокупностью двух эквивалентных ей задач с множествами допустимых решений К1 и К2 соответственно, так как или .

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

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

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

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

Элемент 3. В результате анализа решения ослабленной задачи в зависимости от специфики метода, как правило, принимается решение, относящееся к задаче-истоку:

а) исключить ее из рассмотрения;

б) заменить одной порожденной задачей, выбранной по специальному правилу из определенной совокупности;

в) заменить системой порожденных задач.

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

В моей курсовой мы с вами рассмотрим такие методы как : метод ветвей и границ, метод Гомори, циклический алгоритм целочисленного программирования, полностью целочисленный алгоритм.

Источник

4.5. Методы решения задач целочисленного программирования

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

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

Рис. 4.5.1. Область допустимых решений для задачи ЦП

Точками на рисунке 4.5.1 отмечены целочисленные координаты области значений переменных 1 и 2, которые по существу являются целыми значениями оценок альтернатив по критериям 1 и 2.

При решении задач целочисленного программирования, казалось бы, можно использовать симплекс – метод решения задач ЛП, не считаясь с тем, что введено дополнительное ограничение на целочисленные значения переменных, а затем округлить полученное решение до ближайшей точки с целыми координатами. Однако полученное при этом решение может быть не оптимальным, т. к., даже в случае с двумя переменными, не ясно до какой ближайшей точки с целыми координатами следует округлять решение. На рис. 4.5.1 таких точек две: (4, 2) и (4, 3). Две прямые линии, показанные на рис. 4.5.1, соответствуют проекциям двух множеств точек плоскости целевой функции W(), равноудаленных по вертикали от плоскости ( 1, 2) на эту плоскость. Прямая линия, проходящая через точку (4, 2), соответствует большему значению W(), чем параллельная ей прямая, проходящая через точку (4, 3).

Существует несколько методов непосредственного решения задач целочисленного программирования. Наиболее распространенным из таких методов является метод Гомори (метод отсекающих плоскостей).

Метод Гомори для решения задач

целочисленного программирования [19]

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

Если значения переменных, дающие оптимальное значение целевой функции, целые, то задача решена, и применение метода заканчивается.

В противном случае, т. е. когда значение хотя бы одной переменной получилось не целым, следует ввести дополнительное линейное ограничение, которое отсекает нецелочисленную точку ( 1опт, 2опт) решения задачи ЛП вместе с целой областью допустимых решений задачи ЛП, не содержащей целочисленные решения. Прибавленное отсечение (дополнительное линейное ограничение) не отбрасывает ни одной исходной допустимой целочисленной точки. Но каждое отсечение должно проходить, по меньшей мере, через одну допустимую точку (допустимую или не допустимую). Искомое отсечение (дополнительное линейное ограничение) строится на основании дробных составляющих коэффициентов производящей строки симплекс – таблицы, в столбце «Решение» которой находится не целое число. Такой производящей строкой также может быть и W()-строка, если в исходной целевой функции все коэффициенты перед переменными являются целыми числами (из этого следует, что при целых значениях аргументов значение целевой функции также является целым).

Затем задача ЛП с полученной целевой функцией и новыми ограничениями (старыми и одним дополнительным) снова решается симплекс – методом.

Если новое решение оказалось еще не целочисленным, то итерация повторяется, т. е. вводится еще одно дополнительное ограничение и снова задача решается симплекс – методом. И так до тех пор, пока не будет получено решение, при котором значения всех переменных целые.

Источник

Читайте также:  Прибыль от разработки приложений
Оцените статью