Представленный ниже целочисленный алгоритм обладает следующими свойствами: - Целочисленное программирование

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

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

Обычно в ограничения задачи (2) включаются в тривиальные соотношения xj= - (-Xj) (j'=1,..., n), а задача в матричной форме принимает вид:х = А (-хn), (3)

Где х - вектор-столбец с компонентами Х 0, x1,..., xn, xn+1,..., xn+m А - соответствующая матрица размера (п + т + 1) * (n + 1) и (-хn) - вектор с компонентами (1, - x1, - x2,..., - xn), представляющими собой небазисные переменные исходной таблицы. Задачу целочисленного программирования также можно записать в виде таблицы.

Причины представления переменных в виде (-x1), (-x2,......, (-xn)) - чисто исторические, но это стало обычной практикой в целочисленном программировании. Будем использовать бj(j = 0, 1,..., п) для обозначения j-го столбца текущей таблицы и aij (i = 0, 1,..., п + т; j = 0, 1,..., n) для обозначения элемента 1-й строки и 7-го столбца таблицы. Предполагается, что все a, ij в исходной таблице целые. Следовательно, все слабые переменные xn+1,..., Хn+m должны быть также неотрицательными целыми числами.

При изложении алгоритма для решения целочисленных задач будем следовать работе Гомори. Вначале задача целочисленного программирования рассматривается как линейная программа и алгоритм решает ее с помощью прямого или двойственного симплекс-метода. В конце работы алгоритма аij?0 (i = 1,......, п + т) и a0j? 0 (j' = 1,..., n). (Для получения исходного двойственного допустимого решения введем дополнительное ограничение xn+m+1 == М - X1 - x2 - ... - xn? 0, где M - достаточно большая константа, и проделаем одну итерацию с этой строкой и лексикографически минимальным столбцом в качестве ведущего.) Если аi0? 0 и целые для всех i, то получено оптимальное решение целочисленной задачи. В этом случае решение получается сразу, без использования ограничений целочисленности. Если аi0? 0, но не все целые, добавим к ограничениям (1) еще одно. Новое ограничение записывается внизу таблицы так, чтобы она перестала быть прямо допустимой, т. е. аi0<О для i == п + т + 1. Затем используется двойственный симплекс-метод с целью сделать все аi0? 0. Если аi0 получаются нецелыми, в таблицу добавляются новые ограничения до тех пор, пока аi0 (i = 1,..., n,..., n + m) не станут все целыми и неотрицательными.

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

Каждый раз после проведения итерации симплекс-метода происходит изменение множества небазисных переменных. Таблица также меняется. Будем использовать t для обозначения t-й. таблицы. Матричное уравнение (3) запишется как

Хt = Аt (-хtn), (4)

Где х° - вектор-столбец с n + т + 1 компонентами, А° - матрица размера (п + т + 1)*(n + 1) и (-х 0n) - вектор с компонентами (1, - x1,..., - xn), представляющими собой текущие небазисные переменные, взятые со знаком минус. Если в матрице А а 0i?0 (j = 1,..., n), а 00 ? 0 (mod 1) 1} и аi0 ? 0 (i=1,..., п+т) - целые неотрицательные числа, то получено оптимальное решение целочисленной задачи. Если аi0 не все целые, введем дополнительное ограничение. Рассмотрим такое уравнение из (4), в котором аi0m нецелое. Опуская индексы строки, имеем

X=a0+?aj(-xj) (5)

Где xj в правой части - текущие небазисные переменные и a0 - нецелое. Поскольку требуется, чтобы х было целым, или х ?0 (mod1), правая часть уравнения (5) также должна удовлетворять условию

0?a0+?aj(-xj) (mod1). (6)

Это условие должно выполняться при допустимом целочисленном решении. Поскольку требуется, чтобы xj, были целыми, можно алгебраически складывать с отношения 0?f0+?jfi(-xi) (mod1) (0<f0<1, 0?fj<1).

Похожие статьи




Представленный ниже целочисленный алгоритм обладает следующими свойствами: - Целочисленное программирование

Предыдущая | Следующая