Алгоритм метода потенциалов

Пусть имеется матрица перевозок, соответствующая начальному решению хij= (распределенные ресурсы), xij = 0 для свободных переменных (ресурсы не рас-пределены). Клетки, соответствующие свободным ресурсам, помечены звездочками.

В крайний правый столбец матрицы введем неизвестные ui, а в нижнюю строку – неизвестные vj. Эти n и m неизвестных должны для всех i, j, соответствующих базисным переменным, удовлетворять линейной системе уравнений

ui + vj = cij,(1)

Можно доказать, что эта система для всех базисных решений имеет треугольный вид. Её ранг равен n+m-1, и, следовательно, систему всегда можно решить следующим способом. На первом шаге полагают vn = 0. Если на k-м шаге найдено значение неизвестной, то в системе всегда имеется еще не определенная неизвестная, которая однозначно может быть найдена на (k+1)-м шаге из уравнения (1), так как значение другой неизвестной в этом уравнении уже известно. Это верно до тех пор, пока не найдены все неизвестные. То, какую неизвестную можно найти на (k+1)-м шаге, определяют методом проб. Переменные ui и vj называются потенциалами.

 

1.Составим и решим систему уравнений (1).

Как было отмечено, уравнения составляются для клеток, в которые распределены ресурсы.

2. Определим расчетные значения затрат zij для клеток, в которые ресурсы не распределены (со свободными переменными):

zij = ui + vj;

3. Вычислим разность заданных и расчетных затрат dij = cij - zij и проверим условие оптимальности dij > 0.

Если все di > 0, то исходный план является оптимальным, и переходят к пункту 5, в противном случае переходят к построению нового плана.

4. Построим новый план (уточним опорный план).

Выберем dab< 0,равное максимальному по модулю dij из состава отрицательных dij, т.е.

dab = - max êdi ê, dij > 0.

Индексом a, bпомечена свободная переменная xab, которая соответствует dab. Соответствующую клетку транспортной таблицы отметим знаком “+”.

Кроме клетки a, bтранспортной таблицы, пометим знаками «–» и «+» другие клетки, в которые ресурсы распределены таким образом, что в каждой строке и столбце транспортной таблицы число знаков «+» будет равно числу знаков «–». Это всегда можно сделать единственным образом, причем в каждой строке и в каждом столбце содержится максимум по одному «+» и «–».

Проставленные в таблице знаки «+» и «–» образуют прямоугольник, в углах которого расположены соответствующие знаки. Указанный прямоугольник далее представляется в виде фрагмента матрицы, который состоит из четырех клеток. В этих клетках производят перераспределение ресурсов (рис. 6).

b
- a + dab<0
+ -

 

Рис. 6. Фрагмент матрицы

 

Затем определяем минимум M из всех элементов, помеченных знаками «–», и выбираем одну клетку g,d где этот минимум достигается. При этом g,d обозначает клетку, в которую ресурсы далее распределяться не будут, а все ее содержимое будет распределено между остальными тремя клетками по следующему правилу:

а) в клетку, соседнюю клетке g,d новой таблицы записывается число M;

б) клетка g,d остается пустой;

г) в остальных клетках, помеченных знаками «+» и «–», число M вычитается из стоящего в клетке числа или складывается с ним, в соответствии со знаками;

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

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

5. Определим значение целевой функции, с учетом перераспределения в мат-рице (уточнение матрицы проводится до тех пор, пока хотя бы одно значение di <0).

Улучшим опорный план, который был получен ранее.

1. Составим и решим систему уравнений (1).

 

u1 + v3 = 24 = c13;

u2 + v2 = 18 = c22;

u3 + v1 = 19 = c31;

u3 + v2 = 10 = c32;

u3 + v3 = 100 = c33;

u4 + v1 = 3 = c41;

u4 + v4 = 8 = c44.

Таким образом, имеется семь уравнений и восемь неизвестных, поэтому одному из неизвестных дается произвольное значение, как правило, для облегчения расчетов рекомендуется задаваться нулевым значением. Например u3 = 0, тогда, решая последовательно соответствующие уравнения, получаем v1=19; v2=10; v3=100; v4=24; u1=-76; u2=8; u3=0; u4=-16.

2. Определим значения zij для клеток, в которые ресурсы не распределены.

z11 = u1 + v1 = –76 + 19 = –57;

z12 = u1 + v2 = –76 + 10 = –66;

z14 = u1 + v4 = –76 + 24 = –52;

z21 = u2 + v1 = 8 + 19 = 27;

z23 = u2 + v3 = 8 + 100 = 108;

z24 = u2 + v4 = 8 + 24 = 32;

z34 = u3 + v4 = 0 + 24 = 24;

z42 = u4 + v2 = –16 + 10 = –6;

z43 = u4 + v3 = –16 + 100 = 84.

Определим значения dij и проверим условия оптимальности dαβ> 0

δ11 = с11z11 = 70 – (–57) = 127 > 0;

δ12 = с12z12 = 38 – (–66) = 104 > 0;

δ14 = с14z14 = 92 – (–52) = 144 > 0;

δ23 = с23z23 = 56 – 108 = –52 < 0;

δ24 = с24z24 = 72 – 32 = 40 > 0;

δ34 = с34z34 = 30 – 24 = 6 > 0;

δ42 = с42z42 = 36 – (–6) = 42 > 0;

δ43 = с43z43 = 121 – 84 = 37 > 0.

Так как d23 < 0, то переходим к формированию нового плана.

3.Построим новый опорный план.

Для его построения строится фрагмент опорного плана (рис. 7) относительно клетки 2, 3 = α, β, т.к. потенциал в ней отрицательный δ23 = δαβ < 0.

 

b b
B2 B3 B2 B3
- a A2 * + d23<0 - a A2 +
+ A3 - + A3 * -
а   б
                             

Рис. 7. Фрагменты плана:

а – фрагмент опорного плана; б – фрагмент нового плана

 

4. Определим значение целевой функции по новому плану (рис. 8).

 

B a
B1 B2 B3 B4
A1 * * * 14
A A2 * * 20
A3 * * 26
A4 * * 41
b 30 22 15 34

 

Рис. 8. Представление нового плана в форме матрицы

 

Суммарные затраты по новому плану:

Y1 = 14·24+19·18+1·56+23·19+3·10+7·3+34·8=1494 (усл. ед.).

Прежнее значение суммарных затрат составляло 1546 (усл. ед.).

Рассчитаем процент улучшения опорного плана:

D = 100%= 100 % = 3,36 %.

Проведем второй шаг оптимизации.

1. Составим и решим систему уравнений (1)

u1 + v3 = 24 = c13;

u2 + v2 = 18 = c22;

u2 + v3 = 56 = c23;

u3 + v1 = 19 = c31;

u3 + v2 = 10 = c32;

u4 + v1 = 3 = c41;

u4 + v4 = 8 = c44.

При u2 = 0, получим решение v1= 27; v2= 18; v3= 57; v4= 32; u1= –32; u2 = 0; u3 = –8; u4= –24.

2. Определим значения zij для клеток, в которые ресурсы не распределены.

z11 = u1 + v1 = –32 + 27 = –5;

z12 = u1 + v2 = –32 + 18 = –14;

z14 = u1 + v4 = –32 + 32 = 0;

z21 = u2 + v1 = 0 + 27 = 27;

z24 = u2 + v4 = 0 + 32 = 32;

z33 = u3 + v3 = –8 + 56 = 48;

z34 = u3 + v4 = –8 + 32 = 24;

z42 = u4 + v2 = –24 + 18 = –6;

z43 = u4 + v3 = –24 + 56 = 32.

 

3. Определим значения dij и проверим условие оптимальности dij> 0.

δ11 = с11z11 = 70 – (–5) = 75 > 0;

δ12 = с12z12 = 38 – (–14) = 52 > 0;

δ14 = с14z14 = 92 – 0 = 92 > 0;

δ21 = с21z21 = 58 – 27 = 31 > 0;

δ24 = с24z24 = 72 – 32 = 40 > 0;

δ33 = с33z33 = 100 – 48 = 52 > 0;

δ34 = с34z34 = 30 – 24 = 6 > 0;

δ42 = с42z42 = 36 – (–6) = 42 > 0;

δ43 = с43z43 = 121 – 32 = 89 > 0.

Так как все dij > 0, то данный план является оптимальным.

 

Окончательно представим оптимальный план перевозок (рис. 9, 10).

 

 

 

Рис. 9. Оптимальный план перевозок в форме графа

 

B a
B1 B2 B3 B4
A1 * * * 14
A A2 * * 20
A3 * * 26
A4 * * 41
b 30 22 15 34

 

Рис. 10. Оптимальный план перевозок в форме матрицы

 

 

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

 








Дата добавления: 2016-02-16; просмотров: 842;


Поиск по сайту:

При помощи поиска вы сможете найти нужную вам информацию.

Поделитесь с друзьями:

Если вам перенёс пользу информационный материал, или помог в учебе – поделитесь этим сайтом с друзьями и знакомыми.
helpiks.org - Хелпикс.Орг - 2014-2024 год. Материал сайта представляется для ознакомительного и учебного использования. | Поддержка
Генерация страницы за: 0.027 сек.