Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:

9758

.pdf
Скачиваний:
0
Добавлен:
25.11.2023
Размер:
3.19 Mб
Скачать

водство единицы каждого вида продукции ( i 1, m; j 1, n ), cj – цена реализации 1

ед. j –й продукции, bi – запасы i x ресурсов. Требуется найти x j* – оптималь-

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

Двойственная задача к рассмотренной следующая.

Найти yi* – оценки единицы каждого вида ресурсов, минимизирующие сум-

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

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

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

В матричной форме задачи максимизации прибыли и минимизации цены бу-

дут выглядеть следующим образом:

 

Функция цели (полученная прибыль

Функция цели (полученная прибыль

от реализации продукции)

от продажи сырья)

Z = C * X max

F = BT * Y min

при существующих ограничениях

при существующих ограничениях

A * X B

AT * Y CT

X 0 ,

Y 0 ,

где C – матрица норм прибыли на

где BT, AT, CT транспортированные

единицу продукции;

матрицы B, А, С;

X – матрица переменных, определя-

Y – матрица переменных, определя-

ющих количество единиц выпускае-

ющих цену за единицу сырья.

мой продукции каждого вида;

 

 

31

zmax

A – матрица норм расхода видов сы-

рья на единицу продукции;

B – матрица запасов видов сырья.

Свойства двойственных оценок (значений переменных двойственной зада-

чи при оптимальном решении).

Двойственные оценки – значения переменных yi* называют также тене-

выми ценами.

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

(см. 2), если же ресурс не полностью израсходован в оптимальном плане, то его оценка равна нулю (см. 3). В первом случае ресурс будем называть де-

фицитным, во втором недефицитным, т.е. для недефицитного ресурса

yi* =0. Для недефицитного ресурса значение соответствующей балансовой переменной в оптимальном решении покажет его остаток после выполнения оптимального плана.

2. Чем больше оценка ресурса, тем выше дефицитность ресурса с точки зре-

ния его вклада в целевую функцию.

Оценка (yi*) i–го ресурса показывает, на сколько изменится оптимальное значение целевой функции исходной задачи (доход от реализации про-

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

3.Двойственные оценки показывают, как влияют изменения правой части ограничений (запасов ресурсов) на значение целевой функции. Практиче-

ский интерес представляют границы (нижняя и верхняя) изменения ресур-

сов, в которых величины оценок остаются неизменными).

32

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

j-го вида, для которой выполняется условие:

m

a ij yi c j i 1

где yi – оптимальное значение двойственной оценки i-го ресурса; aij – технологические коэффициенты;

сij – доход, получаемый с единицы продукции j-го вида; m – количество видов ресурсов.

5.Двойственные оценки позволяют провести сравнение суммарных условных затрат и результатов. Из принципа двойственности (max f=min g) следует,

что оценка всех затрат производства должна равняться оценке произведен-

ного продукта.

Целочисленные задачи линейного программирования.

Целочисленное программирование ориентировано на решение задач матема-

тического программирования, в которых все или некоторые переменные должны принимать только целочисленные значения.

Задача называется полностью целочисленной, если условие целочиc-

ленности наложено на все ее переменные; когда это условие относится лишь к не-

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

ется линейной целочисленной.

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

которых переменные величины означают количество единиц неделимой продук-

ции, например, распределение производственных заданий между предприятиями,

раскрой материалов, загрузка оборудования, распределение судов по линиям, са-

33

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

шение находят обычным симплексным методом, округляя его до целых единиц,

исходя из смысла задачи. В противном случае округление может привести к реше-

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

Методы решения задач целочисленного программирования можно классифи-

цировать как (1) методы отсечений и (2) комбинаторные методы.

Исходной задачей для демонстрации возможностей методов отсечений, ис-

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

вания целочисленности переменных. По мере введения специальных дополни-

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

пока координаты оптимального решения не станут целочисленными. Название

«методы отсечений» связано с тем обстоятельством, что вводимые дополнитель-

ные ограничения отсекают (исключают) некоторые области многогранника допу-

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

численных точек).

В основе комбинаторных методов лежит идея перебора всех допустимых це-

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

ним как к полностью, так и к частично целочисленным задачам.

Метод Гомори.

Целочисленное решение может быть найдено с использованием алгоритма,

предложенного Гомори, который состоит в следующем:

Симплексным методом находят оптимальное решение задачи. Если решение

34

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

чение по целочисленности. Вычисления продолжают до тех пор, пока не будет получено целочисленное решение или показано, что задача не имеет целочислен-

ного решения.

Пусть получено оптимальное решение хцел ( f1, f2 , , fr ,0,0, ,0) , которое не является целочисленным, тогда последний шаг симплексной таблицы имеет

следующий вид:

х1

 

h1r 1

 

b1

х2

 

h2r 1

 

b2

 

 

 

 

 

хi

 

hir 1

 

bi

 

 

 

 

 

хr

 

hrr 1

 

br

где r – ранг системы ограничений;

hir 1 – коэффициент симплексной таблицы i-й строки, r + 1 столбца; bi – свободный член i-й строки.

Пусть bi и хотя бы одно hij – дробные числа.

Обозначим [ bi ] и [ hij ] – целые части чисел bi и hij .

Целой частью числа bi называют наибольшее целое число, не превосходящее числа bi .

Дробную часть чисел bi и hij обозначим { bi } и { hij }, она определяется сле-

дующим образом: {bi }= bi [bi ], { hij }= hij – [ hij ].

Если bi и хотя бы одно значение hij дробное, то с учетом введенных обозна-

чений целых и дробных чисел дополнительное ограничение по целочисленности

35

примет вид: { hir 1} хr 1 +{ hir 2 } хr 2 +{ hin } хn >{ bi }. Это неравенство называют сечением Гомори.

Примечание.

Если bi дробное, а все hij целые, то задача не имеет целочисленного реше-

ния.

Ограничение целочисленности может быть наложено не на все переменные,

алишь на их часть. В этом случае задача является частично целочисленной.

Пример решения по методу Гомори на стр. 128.

Метод ветвей и границ.

Согласно общей идее метода, сначала решается задача с ослабленными огра-

ничениями (задача линейного программирования без условия целочисленности).

Пусть хк целочисленная переменная, значение которой хк* в оптимальном реше-

нии ослабленной задачи является дробным. Интервал [ хк* ]< хк <[ хк* ]+1 не содер-

жит допустимых целочисленных компонент решения. Поэтому допустимое целое

значение х

к

должно удовлетворять одному из неравенств х

к

[ х* ] или

 

 

 

 

к

х

к

[ х* ]+1.

 

 

 

 

 

к

 

 

 

 

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

сти многогранника допустимых решений, не содержащие точек с целыми коорди-

натами.

Затем каждая подзадача решается как задача линейного программирования (с

целевой функцией исходной задачи). Если полученный оптимум оказывается до-

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

скольку улучшить полученное решение, очевидно, не удастся. В противном случае

36

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

фиксированного ранее. Процесс ветвления продолжается, насколько это возмож-

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

В этом случае зафиксированное допустимое решение является оптимальным.

Эффективность вычислительной схемы метода можно повысить, введя в рас-

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

чи с ослабленными ограничениями обеспечивает худшее значение целевой функ-

ции, чем имеющееся решение, эту подзадачу далее рассматривать не следует. В

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

лучено допустимое целочисленное решение некоторой подзадачи, целочисленное решение некоторой подзадачи, соответствующее значение целевой функции мо-

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

цедуру исключения прозондированных подзадач.

Пример 7.

На двух небольших заводах по сборке автомашин выпускаются грузовики и микроавтобусы. Затраты на сборку одного грузовика на первом заводе составляют

5 человеко-дней, а на сборку одного микроавтобуса – 2 человеко-дня. На втором заводе аналогичные затраты составляют по 3 человеко-дня на грузовик и на мик-

роавтобус. Мощности заводов ограничены и составляют для первого завода 180

чел-дней в неделю, для второго – 125. Каждый грузовик стоит 3000 руб., микроав-

тобус – 2000 руб. Необходимо определить, сколько всего нужно выпускать грузо-

37

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

Математическая модель имеет вид:

3 x1+2 x2 max; 5 x1+2 x2180 , 3 x1+3 x2125, x10, x20, х1, х2

Решение методом ветвей и границ.

x1

32

 

Задача P0

x1 33

F0

= 115,56

 

 

 

x0 = ( 32,22; 9,44 ) F=0

x2 9

Задача P1

x2 10

Задача P8

 

F1 = 115,33

 

 

F8 = 114

 

 

 

 

x1 = ( 32; 9,67 )

 

 

x8 = ( 33; 7,5 )

 

 

 

 

 

Задача P2

x1 31

Задача P3

x1 32

F2 = 114

 

 

F2 = 115

 

 

 

 

 

 

x2 = ( 32; 9 )

 

 

x2 = ( 31,67; 10 )

 

 

 

 

 

 

 

 

x2 11

 

Задача P4

x2 10

Задача P7

 

 

F4

= 114,33

 

 

Недопустимое

 

 

 

 

 

 

 

 

решение

 

 

x2 = ( 31; 10,67 )

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Задача P6

F6 = 114

x6 = ( 30,67; 11 )

Задача P5

F5 = 113

x5 = ( 31; 10 )

38

Специальные задачи линейного программирования

– это задачи со специальной структурой: транспортная задача и задача о назначениях.

Экономико-математическая модель ТЗ

Постановка задачи: Имеются m поставщиков и n потребителей. Заданы мощ-

ности поставщиков M i , i 1,..., m и спросы (мощности) потребителей

N j , j 1,..., n . А также затраты на перевозку единицы груза для каждой пары

«поставщик – потребитель» cij (коэффициент затрат). Требуется найти объем пе-

ревозок для каждой пары «поставщик – потребитель» так, чтобы:

1)мощности всех поставщиков были реализованы;

2)спросы всех потребителей были удовлетворены;

3)суммарные затраты на перевозку были бы минимальные.

Для удобства записи данные заносятся в таблицу:

Постав-

Мощность

Потребители и их спрос

 

 

щики

поставщика

1

2

n

 

 

N1

N2

Nn

1

M1

c11

c12

 

c1n

 

 

x11

x12

x1n

2

M2

c21

c22

 

c2n

 

 

x21

x22

x2n

m

Mm

cm1

cm2

 

cmn

 

 

x m1

x m2

x mn

Сформулируем математическую модель задачи.

Обозначим хij – искомый объем перевозки от i – того поставщика к j – тому потребителю, xij 0 . Заданные мощности поставщиков и спросы потребителей накладывают ограничения на значения неизвестных хij.

Например, x11 x12 ... x1n M1 – уравнение баланса по первой строке.

Суммарные затраты F на перевозку выражается через коэффициент затрат и поставку следующим образом.

39

n m

F cij xij j 1 i 1

Система ограничений примет вид:

n

 

 

xij

M i ,

i 1,2,..., m

j 1

 

 

m

 

 

xij

N j ,

j 1,..., n

i 1

 

 

(1)

(2)

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

ния (2) соответствуют тому, что количество продукции, ввозимой j-му потребите-

лю, должно полностью удовлетворять его спрос (для всех потребителей).

Формулировка транспортной задачи в общей постановке будет следующей:

на множестве допустимых решений системы ограничений (2) найти такое реше-

ние X x11,..., x1n , x21,..., xij ,..., xmn , при котором значение линейной функции (1)

минимально.

Совокупность чисел (xij), i=1,…m; j=1,…n, удовлетворяющая ограничениям

(2)-(3), доставляющая минимум целевой функции (1), называется планом перево-

зок или планом транспортной задачи. План

Х * , при котором целевая функция

обращается в минимум, называется оптимальным.

 

Теорема 1. Для разрешимости транспортной задачи необходимо и достаточ-

 

m

n

 

но, чтобы выполнялось условие баланса: M i

N j

 

 

i 1

j 1

 

Выделяют два вида транспортных задач:

 

 

1) закрытая ТЗ: суммарная мощность поставщиков = сумме мощности потре-

m

n

 

 

бителей, т.е. M i

N j .

 

 

i 1

j 1

 

 

2) В противном случае транспортная задача называется открытой.

 

Для открытой модели может быть два случая:

 

 

 

m

n

a) Суммарные запасы превышают суммарные потребности: M i

N j

 

 

i 1

j 1

 

40

 

 

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]