Постановка задачи и её математическая модель

 

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

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

Таблица 7.1

Поставщики Потребители Запасы
. . .
. . .
. . . . . . . . . . . . . . . . . .
. . .
Запросы . . .

 

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

Систему ограничений получаем из следующих условий:

а) все грузы должны быть вывезены, т.е. (эти уравнения получаются из строк);

б) все потребности должны быть удовлетворены, т.е. .

Таким образом, математическая модель транспортной задачи может быть записана следующим образом:

– найти минимум линейной функции

(7.1.1)

при ограничениях

В рассматриваемой модели предполагается, что суммарные запасы равны суммарным запросам потребителей:

. (7.1.4)

 

Такая задача называется задачей с правильным балансом, а её модель – закрытой. Если же равенство (7.1.4) не выполняется, то задача называется задачей с неправильным балансом, а её модель – открытой.

Теорема 7.1. Для того чтобы транспортная задача ЛП имела решение, необходимо и достаточно, чтобы суммарные запасы поставщиков равнялись суммарным запросам потребителей (см. (7.1.4)).

Доказательство теоремы опускается.

Особенности решения транспортных задач с неправильным балансом:

1. Если суммарные запасы поставщиков превосходят суммарные запросы потребителей, т.е.

,

то необходимо ввести фиктивного (n + 1)-го потребителя с запросами

, равными разности суммарных запасов поставщиков и запросов потребителей, и нулевыми стоимостями перевозок единиц груза .

2. Если суммарные запросы потребителей превосходят суммарные запасы поставщиков, т.е.

,

то необходимо ввести фиктивного (m+1)-го поставщика с запасами , равными разности суммарных запросов потребителей и запасов поставщиков, и нулевыми стоимостями перевозок единиц груза .

3. При составлении начального опорного решения в последнюю очередь следует распределять запасы фиктивного поставщика и удовлетворять запросы фиктивного потребителя, несмотря на то, что им соответствует наименьшая стоимость перевозок, равная нулю.

 

Построение первоначального опорного плана

 

Рассмотрим систему ограничений (7.1.2) и (7.1.3) транспортной задачи. Она содержит неизвестных и уравнений, связанных соотношением (7.1.4). Если сложить почленно отдельно уравнения подсистемы (7.1.2)

и (7.1.3), то в силу (7.1.4) получим два одинаковых уравнения, что говорит о линейной зависимости всей системы. Однако если отбросить любое из этих уравнений, то получившаяся система из уравнений будет линейно независимой. Следовательно, опорный план транспортной задачи содержит компонент перевозок. Если условия транспортной задачи и её опорный план записаны в виде таблицы (например, табл. 7.1), то клетки, в которых проставлены перевозки, называют занятыми, а остальные – незанятыми. Занятие клетки соответствует базисным переменным, и их количество также равно .

Однако опорный план должен удовлетворять ещё и условию ацикличности. Для того, чтобы пояснить это понятие, рассмотрим вначале следующее определение:

Определение 7.2.1. Циклом называется набор клеток таблицы транспортной задачи , , ,…, , в которой две и только две соседние клетки содержатся в одной строке или столбце, причём последняя находится в том же столбце, что и первая.

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

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

Метод северо-западного угла. Для наглядности рассмотрим данный метод на примере. Пусть условия транспортной задачи заданы табл. 7.2.

Таблица 7.2

Поставщики Потребители Запасы
         
         
         
         
         
         
         
         
Запросы

Заметим, что модель задачи является закрытой. Не учитывая стоимость перевозок, заполняем клетки, начиная с таким образом, чтобы запросы всех потребителей удовлетворялись, а запасы всех поставщиков были бы вывезены. Итак, запас 1-го поставщика – 100 единиц товара, а запрос 1-го потребителя – 200. Поэтому в первую клетку 1-го столбца заносим , исключаем из рассмотрения первого поставщика ( его запасы вывезены) и переходим ко второму поставщику, у которого 250 единиц товара. Для того, чтобы удовлетворить первого потребителя, необходимо ещё 100 единиц. Поэтому в клетку первого столбца заносим . Исключаем первого потребителя и переходим ко второму, запасы которого равны 200. У второго поставщика осталось 150 единиц товара, поэтому в клетку заносим . Исключаем из рассмотрения второго поставщика и переходим к третьему. Этот процесс продолжается до тех пор, пока остаётся неисключённой в точности одна строка или один столбец. В результате получим табл. 7.3.

 

Таблица 7.3

Поставщики Потребители Запасы
         
       
         
     
         
   
         
     
Запросы

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

Замечание. Если одновременно и столбец, и строка удовлетворяют ограничениям, очередная переменная, включаемая в базисное решение, обязательно имеет нулевое значение.

Вычислим стоимость перевозки, соответствующую этому опорному плану:

.

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

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

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

Рассмотрим метод минимальной стоимости на примере табл. 7.2.

Наименьшую стоимость имеет клетка . Запасы 1-го поставщика, как и запросы 4-го потребителя равны 100 единицам, поэтому заносим в эту клетку 100 и исключаем, например, 4-го потребителя. Затем переходим к следующей клетке, содержащей минимальную стоимость, например, к . Запасы 2-го поставщика равны 200 единицам, а запросы 1-го потребителя – 250 единиц, поэтому в клетку заносим и исключаем 1-го потребителя. У 2-го поставщика остаётся ещё 50 единиц. Следующая клетка из неисключённых, соответствующая минимальной стоимости, находится на пересечении 3-й строки и 5-го столбца. Согласно тому же правилу, заносим в неё и исключаем 3-го поставщика и т.д. В результате получим табл. 7.4.

Таблица 7.4

Поставщики Потребители Запасы
         
     
         
     
         
       
         
   
Запросы

 

Легко проверить, что полученное решение является опорным. Найдём соответствующую ему стоимость перевозок:

.

Естественно возникает вопрос, является ли это решение оптимальным. Ответ на него будет дан в следующем пункте.

 

Метод потенциалов

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

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

(7.3.1)

для занятых клеток;

(7.3.2)

 

для свободных клеток.

Доказательство теоремы см. [3, с. 618-619].

Числа называются потенциалами поставщиков, а – потенциалами потребителей.

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

Рассмотрим алгоритм решения транспортных задач методом потенциалов:

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

2. Построить начальное опорное решение (методом минимальной стоимости или каким-либо другим методом), проверить правильность его построения по количеству занятых клеток (их должно быть m + n – 1) и убедиться в линейной независимости векторов условий.

3. Построить систему потенциалов, соответствующих опорному решению. Для этого решают систему уравнений

при xij > 0,

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

при xij > 0,

если известен потенциал vi , и

при xij > 0,

если известен потенциал uj.

4. Проверить выполнение условия оптимальности для свободных клеток таблицы. Для этого вычисляют оценки для всех свободных клеток по формулам

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

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

.

Строят цикл, включающий в свой состав данную клетку и часть клеток, занятых опорным решением. В клетках цикла расставляют поочередно знаки «+» и «–», начиная с «+» в клетке с наибольшей положительной оценкой. Осуществляют сдвиг (перераспределение груза) по циклу на величину . Клетка со знаком «–», в которой достигается , остается пустой. Если минимум достигается в нескольких клетках, то одна из них остается пустой, а в остальных проставляют базисные нули, чтобы число занятых клеток оставалось равным m + n – 1.

Далее перейти к пункту 3 данного алгоритма.

Проиллюстрируем применение указанного алгоритма на опорном плане, полученном в предыдущем примере методом наименьшей стоимости.

Шаг 1. Составим систему соотношений, соответствующих условиям (7.3.1) и (7.3.2):

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

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

. Из последних трёх соотношений системы определяем , и . Из остальных уравнений получаем , , , , (табл. 7.5).

Таблица 7.5

Поставщики Потребители Запасы
     
    0 100  
     
50    
         
       
     
  150  
Запросы

Шаг 2. Проверим условие оптимальности для незанятых клеток. Если для всех таких клеток, то план является оптимальным, если же для некоторых , то план – неоптимальный. Тогда для каждой клетки, в которой не выполняется условие оптимальности, находим величину разности и записываем её значение в левый нижний угол этой клетки. Получилось 3 таких клетки: , , .

Шаг 3.Теперь выбираем клетку, которую необходимо сделать базисной. Загрузке подлежит, в первую очередь, клетка, которой соответствует . В нашем случае это . Необходимо определить, сколько груза должно быть в неё распределено.

Шаг 4.Здесь необходимо выбрать клетку, которая выводится из базиса и определить величину перераспределения груза. Отмечаем знаком « + » незанятую клетку, которую надо загрузить. Вместе с ней в таблице стало занятых клеток, следовательно, появится цикл (причём единственный), все вершины которого, за исключением клетки, находятся в занятых клетках. Начинаем движение по этому циклу от клетки, отмеченной знаком , расставляя поочерёдно во всех вершинах, в которых он меняет направление, знаки

« – » и « + ». Затем находим в клетках, отмеченных знаком «–». Эта величина определяет, сколько единиц груза можно перераспределить по найденному циклу. Значение записываем в незанятую клетку, отмеченную знаком « + ». Двигаясь по циклу, вычитаем из объёмов перевозок в клетках, отмеченных знаком « – » и прибавляем к в клетках, отмеченных знаком « + ».

Итак, строим цикл, в клетку заносим 50единиц и перераспределяем груз (табл. 7.6). Исключаем из базисных переменных и вводим .

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

Полагая , получим: , , , , , , , .

Таблица 7.6

Поставщики Потребители Запасы
         
     
         
     
         
       
         
   
Запросы

 

Проверяя условие оптимальности, получаем, что оно выполняется во всех клетках. Следовательно, построенный план является оптимальным. Стоимость перевозки по нему .

 

 

Образец типового расчета

Задача 1. Используя градиентный метод, найти минимум функции при системе ограничений .

 

Решение

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

 

Итак, . Вычисляем .

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

 

Задача 2. Составить математическую модель и решить симплекс-методом следующую задачу.

Строительное управление ведет капитальный ремонт жилых домов. Перегородки внутри этих домов могут быть изготовлены гипсобетонными или каркасными. Ресурсы на месяц заданы в табл. 7.7 (потребность на 1 м2 площади перегородок).

Таблица 7.7

Наименование Каркасные Гипсобетонные
Гипсобетон 0,25 м3
Пиломатериалы 0,08 м3 0,1 м3
Сухая штукатурка 4 м3
Трудоресурсы 0,8 чел. дн. 0,5 чел. дней

 

Рассчитать общее количество м2 как каркасных, так и гипсобетонных перегородок, которые следует возвести в текущем месяце, чтобы общая их площадь была наибольшей, если строительное управление имеет в наличии гипсобетона – 300 м3; пиломатериалов – 200 м3; сухой штукатурки – 8000 м3; трудоресурсов – 2000 чел/дней.

 

 

Решение

Составим математическую модель задачи. Пусть требуется возвести каркасных и гипсобетонных перегородок. Из условия на это уйдёт: гипсобетона , пиломатериалов , сухой штукатурки , трудоресурсов . Учитывая лимиты материалов и трудоресурсов, составляем систему ограничений – неравенств:

Для решения задачи симплекс-методом вводим дополнительные переменные:

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

- -
0,25
0,08 0,1
0,8 0,5

 

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

столбца:

, , .

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

Теперь запишем правила перехода к новой симплекс-таблице, соответствующие приведённому выше алгоритму симплекс-метода:

1. Базисная переменная, находящаяся в ведущей строке, и свободная переменная, находящаяся в ведущем столбце, меняются местами.

2. Ведущий элемент заменяется величиной, ему обратной.

3. Все элементы ведущей строки (включая свободный член), кроме ведущего элемента, заменяются их отношениями к ведущему элементу.

4. Все элементы ведущего столбца (кроме ведущего элемента) заменяются взятыми с обратными знаками их отношениями к ведущему элементу.

5. Остальные элементы заменяются по «правилу 4 элементов»: любой такой элемент умножается на ведущий и из произведения вычитается произведение двух других элементов, составляющих с первыми вершины прямоугольника, после чего результат делится на ведущий элемент.

Проводя вычисление по этим правилам, получаем следующую симплекс-таблицу:

- -
0,08 -0,4
0,8 -2
-4 -1200

 

  Значение -1200 ещё не является минимальным для функции , т.к. в последней строке ещё есть положительный коэффициент.

 

Аналогично составляем следующую симплекс-таблицу:

 
 


- -
12,5 -5
-12,5
-10
-12,5 -2200

 

  Значение -2200 не является минимальным для . Составим ещё одну симплекс-таблицу:
- -
   
   
     
     
-10 -1/5 -2400

 

Пересчитывая последнюю строку, сразу убеждаемся, что значение -2400 является минимальным для функции . Нам ещё следует пересчитать свободные члены при и . Поскольку в опорном плане, соответствующем симплекс-таблице, свободные неизвестные равны 0, то найденные значения свободных членов при и дадут оптимальный план производства:

,

.

Задача 3. Максимизировать функцию Z=x1+2x2-2x3 при ограничениях

Решение

Преобразуем исходную задачу линейного программирования к канонической. Для этого введём в ограничения дополнительные неотрицательные переменные. А именно, в первое неравенство – переменную x4 со знаком «+», во второе – x5 со знаком «-». Система ограничений примет вид:

Эту систему запишем в векторной форме: A1x1+A2x2+A3x3+A4x4+A5x5=B, где , , , , , .

Очевидно, что в данной системе ограничений отсутствует единичный базис. Это означает, что среди векторов Aj нет трёх необходимых единичных векторов, которые должны образовывать базис в R3. Однако заметим, что вектор A4 является частью базиса. Ему соответствует базисная переменная x4. Необходимо найти ещё два единичных вектора. Для этого применим метод искусственного базиса. Введём искусственные переменные в те уравнения ограничений, в которых не присутствует базисная переменная x4, и построим следующую вспомогательную задачу (ВЗ):

 

F=-w1-w2®max

где w1, w2 – искусственные переменные. Система ограничений ВЗ в векторном виде имеет вид: A1x1+A2x2+A3x3+A4x4+A5x5+A6w1+A7w2=B, где векторы Aj , j=1,2,3,4,5 определяются так же, как и выше, а и . Таким образом, вектора A4, A6, A7 образуют базис в R3 и им соответствуют базисные переменные (БП) – x4, w1, w2. Все остальные переменные, а именно x1, x2, x3, x5 объявляются свободными (СП). Далее к ВЗ применяем обычный симплекс-метод. Как и раньше (см. § 5. 1) начальный опорный план получается, если присвоить свободным переменным значения, равные нулю. При этом базисные переменные принимают значения, равные числам в соответствующей строке столбца свободных коэффициентов В, то есть x1=x2=x3=x5=0¸ а x4=8, w1=4, w2=12. Строим симплекс-таблицу, соответствующую начальному опорному плану: