Математичні моделі задач лінійного програмування

Завдання 1


Побудувати математичну модель задачі.

Меблева фабрика виготовляє столи, стільці, тумби і книжкові шафи використовуючи дошки двох видів, причому фабрика має 500 м2дошок першого виду і 1000 м2дошок другого виду. Задані також трудові ресурси в кількості 800 людино-годин. У таблиці наведені нормативи витрат кожного виду ресурсів на виготовлення одного виду і прибуток від реалізації одиниці виробу.


Ресурси

Витрати на один виріб

Запас сировини, м2

Столи

Стільці

Тумби

Книжкові шафи

Дошки І виду, м2

5

1

9

12

500

Дошки ІІ виду, м2

2

3

4

1

1000

Трудові ресурси, люд.год.

3

2

5

10

800

Прибуток від реалізації одного виробу, грн.од.

12

5

15

10



Визначити асортимент, що максимізує прибуток.


Розв’язок


Складаємо математичну модель задачі. Позначимо через х1кількість виробів 1-ї моделі, що виготовляє фірма за деяким планом, а через х2 кількість виробів 2-ї моделі та через та через х3і х4кількість виробів 3-ї і 4-ї моделі відповідно. Тоді прибуток, отриманий фабрикою від реалізації цих виробів, складає


∫ = 12х1+5х2 + 15х3+ 10х4.


Витрати сировини на виготовлення такої кількості виробів складають відповідно

А =5х1+1х2 + 9х3+ 12х4,

В =2х1+3х2 + 4х3+ 1х4,

С =3х1+2х2 + 5х3+ 10х4,


Оскільки запаси сировини обмежені, то повинні виконуватись нерівності:


5х1+1х2 + 9х3+ 12х4≤ 500

2х1+3х2 + 4х3+ 1х4≤ 1000

3х1+2х2 + 5х3+ 10х4≤ 800


Оскільки, кількість виробів є величина невід'ємна, то додатково повинні виконуватись ще нерівності: х1> 0, х2> 0, х3> 0, х4> 0.

Таким чином, приходимо до математичної моделі (задачі лінійного програмування):

Знайти х1 , х2, х3 та х4 такі, що функція ∫ = 12х1+5х2 + 15х3+ 10х4 досягає максимуму при системі обмежень:



Розв'язуємо задачу лінійного програмування симплексним методом. Введемо балансні змінні х5 ≥ 0, х6≥ 0, х7≥ 0. Їх величина поки що невідома, але така, що перетворює відповідну нерівність у точну рівність. Після цього, задача лінійного програмування набуде вигляду: ∫ = 12х1+5х2 + 15х3+ 10х4 → max при обмеженнях


де х1,...,х7>0

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

Переходимо до основного алгоритму симплекс-методу.


План

Базис

В

x1

x2

x3

x4

x5

x6

x7

min

1

x5

500

5

1

9

12

1

0

0

55.56


x6

1000

2

3

4

1

0

1

0

250


x7

800

3

2

5

10

0

0

1

160

Індексний рядок

F(X1)

0

-12

-5

-15

-10

0

0

0

0


Оскільки, в індексному рядку знаходяться негативні коефіцієнти, поточний опорний план неоптимальний, тому будуємо новий план. У якості ведучого виберемо елемент у стовбці х3, оскільки значення коефіцієнта за модулем найбільше.


План

Базис

В

x1

x2

x3

x4

x5

x6

x7

min

2

x3

55.56

0.56

0.11

1

1.33

0.11

0

0

100


x6

777.78

-0.22

2.56

0

-4.33

-0.44

1

0

0


x7

522.22

0.22

1.44

0

3.33

-0.56

0

1

2350

Індексний рядок

F(X2)

833.33

-3.67

-3.33

0

10

1.67

0

0

0


Даний план, також не оптимальний, тому будуємо знову нову симплексну таблицю. У якості ведучого виберемо елемент у стовбці х1.


План

Базис

В

x1

x2

x3

x4

x5

x6

x7

min

3

x1

100

1

0.2

1.8

2.4

0.2

0

0

500


x6

800

0

2.6

0.4

-3.8

-0.4

1

0

307.69


x7

500

0

1.4

-0.4

2.8

-0.6

0

1

357.14

Індексний рядок

F(X3)

1200

0

-2.6

6.6

18.8

2.4

0

0

0


Даний план, знову не оптимальний, тому будуємо знову нову симплексну таблицю. У якості ведучого виберемо елемент у стовбці х2.


План

Базис

В

x1

x2

x3

x4

x5

x6

x7

min

4

x1

38.46

1

0

1.77

2.69

0.23

-0.08

0

500


x2

307.69

0

1

0.15

-1.46

-0.15

0.38

0

307.69


x7

69.23

0

0

-0.62

4.85

-0.38

-0.54

1

357.14

Індексний рядок

F(X4)

2000

0

0

7

15

2

1

0

0


Оскільки всі оцінки >0, то знайдено оптимальний план, що забезпечує максимальний прибуток: х1=38.46, х2=307.69, х3=0, х4=0, х5=0, х6=0, х7=69.23. Прибуток, при випуску продукції за цим планом, становить 2000 грн.


Завдання 2


Записати двоїсту задачу до поставленої задачі лінійного програмування. Розв’язати одну із задач симплексним методом і визначити оптимальний план іншої задачі. Оптимальні результати перевірити графічно.



Розв’язок


Пряма задача лінійного програмування має вигляд:



При обмеженнях:



Оскільки, у прямій задачі лінійного програмування необхідно знайти мінімум функції, то приведемо першопочаткову умову до вигляду:



Для досягнення відповідного вигляду помножимо 3-ю нерівність на -1


0х1-11х2≥-11


В результаті отримаємо наступні матриці:



Для складання двоїстої задачі лінійного програмування знайдемо матриці А, В, СТ.



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


F(Y)= 14Y1+27Y2-11Y3 (max)


Обмеження:


8Y1+3Y2+0Y3≤5

-14Y1+2Y2-11Y3≤3

Y1≥0

Y2≥0

Y3≥0

Розв’яжемо задачу лінійного програмування симплексним методом.

Визначимо мінімальне значення цільової функції F(X) = 5x1+3x2 при наступних умовах-обмежень.


8x1-14x2≥14

3x1+2x2≥27

x2≤11


Для побудови першого опорного плану систему нерівностей приведемо до системи рівнянь шляхом введення додаткових змінних.

Оскільки маємо змішані умови-обмеження, то введемо штучні змінні x.


8x1-14x2-1x3 + 0x4 + 0x5 + 1x6 + 0x7 = 14

3x1 + 2x2 + 0x3-1x4 + 0x5 + 0x6 + 1x7 = 27

0x1 + 1x2 + 0x3 + 0x4 + 1x5 + 0x6 + 0x7 = 11


Для постановки задачі на мінімум цільову функцію запишемо так:


F(X) = 5 x1 +3 x2 +M x6 +M x7 => min


Переходимо до основного алгоритму симплекс-методу.


План

Базис

В

x1

x2

x3

x4

x5

x6

x7


min


1

x6

14

8

-14

-1

0

0

1

0

1.75


x7

27

3

2

0

-1

0

0

1

9


x5

11

0

1

0

0

1

0

0

0

Індексний рядок

F(X1)

4100000

1099995

-1200003

-100000

-100000

0

0

0

0


Оскільки, в індексному рядку знаходяться позитивні коефіцієнти, поточний опорний план неоптимальний, тому будуємо новий план. У якості ведучого виберемо елемент у стовбці х1, оскільки значення коефіцієнта за модулем найбільше.

математичний модель симплексний лінійний

План

Базис

В

x1

x2

x3

x4

x5

x6

x7

min

2

x1

1.75

1

-1.75

-0.13

0

0

0.13

0

0


x7

21.75

0

7.25

0.38

-1

0

-0.38

1

3


x5

11

0

1

0

0

1

0

0

11

Індексний рядок

F(X2)

2175008.75

0

724988.25

37499.38

-100000

0

-137499.38

0

0


Даний план, також не оптимальний, тому будуємо знову нову симплексну таблицю. У якості ведучого виберемо елемент у стовбці х2.


План

Базис

В

x1

x2

x3

x4

x5

x6

x7

min

3

x1

7

1

0

-0.03

-0.24

0

0.03

0.24

0


x2

3

0

1

0.05

-0.14

0

-0.05

0.14

3


x5

8

0

0

-0.05

0.14

1

0.05

-0.14

11

Індексний рядок

F(X3)

44

0

0

-0.02

-1.62

0

-99999.98

-99998.38

0


Остаточний варіант симплекс-таблиці оптимальний, тому що в індексному рядку знаходяться негативні коефіцієнти.

Оптимальний план можна записати так:


x1 = 7

x2 = 3

x5 = 8

F(X) = 5*7 + 3*3 = 44


Визначаємо оптимальний план двоїстої задачі до поставленої задачі лінійного програмування.


F(Y)= 14Y1+27Y2-11Y3 (max)

Обмеження:

8Y1+3Y2+0Y3≤5

-14Y1+2Y2-11Y3≤3

Y1≥0

Y2≥0

Y3≥0


Для побудови першого опорного плану систему нерівностей приведемо до системи рівнянь шляхом введення додаткових змінних.


8x1 + 3x2 + 0x3 + 1x4 + 0x5 = 5

-14x1 + 2x2-11x3 + 0x4 + 1x5 = 3


Вважаючи, що вільні змінні рівні 0, отримаємо перший опорний план


План

Базис

В

x1

x2

x3

x4

x5

0

x4

5

8

3

0

1

0


x5

3

-14

2

-11

0

1

Індексний рядок

F(X0)

0

8

3

-9

0

0


Перейдемо до основного алгоритму симплекс-метода.


План

Базис

В

x1

x2

x3

x4

x5

min

1

x4

5

8

3

0

1

0

1.67


x5

3

-14

2

-11

0

1

1.5

Індексний рядок

F(X1)

0

-14

-27

11

0

0

0


План

Базис

В

x1

x2

x3

x4

x5

min

2

X4

0.5

29

0

16.5

1

-1.5

0.0172


X2

1.5

-7

1

-5.5

0

0.5

0

Индексная строка

F(X2)

40.5

-203

0

-137.5

0

13.5

0


План

Базис

В

x1

x2

x3

x4

x5

3

x1

0.0172

1

0

0.569

0.0345

-0.0517


x2

1.62

0

1

-1.52

0.2414

0.1379

Индексная строка

F(X3)

44

0

0

-22

7

3


План

Базис

В

x1

x2

x3

x4

x5

4

x3

0.0303

1.76

0

1

0.0606

-0.0909


x2

1.67

2.67

1

0

0.3333

0

Индексная строка

F(X4)

44.67

38.67

0

0

8.33

1


Оптимальний план можливо записати так:

x3 = 0.0303

x2 = 1.67

F(X) = 27*1.67 + -11*0.03 = 44.67


Завдання 3


Розвязати транспортну задачц.


1

4

1

5

6

300

1

3

1

1

2

250

4

1

2

2

3

200

100

120

90

70

80



Розв’язок


Побудова математичної моделі. Нехай xij — кількість продукції, що перевозиться з і-го пункту виробництва до j-го споживача . Оскільки , то задачу треба закрити, тобто збалансувати (зрівняти) поставки й потреби



У нашому випадку робиться це введенням фіктивного постачальника, оскільки . З уведенням фіктивного споживача в транспортній таблиці додатково заявляється n робочих клітинок (додатковий стовпчик).

Виникає проблема, які ціни присвоїти цим клітинкам, щоб фіктивний стовпчик був нейтральним щодо оптимального вибору планових перевезень. Нейтральність забезпечується тим, що всі ціни у фіктивних клітинках вибираються однаковими, а оскільки ці ціни при поставках не повинні впливати на значення цільової функції f, то їх беруть усі рівними нулю.

Занесемо вихідні дані у таблицю.



В1

В2

В3

В4

В5

В6

Запаси

А1

1

4

1

5

6

0

300

А2

1

3

1

1

2

0

250

А3

4

1

2

2

3

0

200

Потреби

100

120

90

70

80

290



Забезпечивши закритість розв'язуваної задачі, розпочинаємо будувати математичну модель даної задачі:



Економічний зміст записаних обмежень полягає в тому, що весь вантаж потрібно перевезти по пунктах повністю.

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



Загальні витрати, пов’язані з транспортуванням продукції, визначаються як сума добутків обсягів перевезеної продукції на вартості транспортування од. продукції до відповідного замовника і за умовою задачі мають бути мінімальними. Тому формально це можна записати так:


minZ = 1x11 + 4x12 + 1x13 + 5x14 +6x15 + 0x16 +1x21 + 3x22 + 1x23 + 1x24 +2x25+0x26+4x31 + 1x32 + 2x33 + 2x34 +3x35 + 0x36.


Загалом математична модель сформульованої задачі має вигляд:


minZ = 1x11 + 4x12 + 1x13 + 5x14 +6x15 + 0x16 +1x21 + 3x22 + 1x23 + 1x24 +2x25 +0x26+4x31 + 1x32 + 2x33 + 2x34 +3x35 + 0x36.


за умов:



Запишемо умови задачі у вигляді транспортної таблиці та складемо її перший опорний план у цій таблиці методом «північно-західного кута».


Ai

Bj

ui

b1 = 100

b2 = 120

b3 = 90

b4=70

b5=80

B6=290

а1 = 300

1

100

4

[-]120

1

[+]80

5


6


0


u1 = 0

а2 = 250

1


3


1

[-]10

1

70

2

80

0

[+]90

u2 = 0

а3 = 200

4


1

[+]

2


2


3


0

[-]200

u3 = 0

vj

v1 =1

v2 =4

v3 =1

v4 =1

v5=2

V6 =0


В результаті отримано перший опорний план, який є допустимим, оскільки всі вантажі з баз вивезені, потреба магазинів задоволена, а план відповідає системі обмежень транспортної задачі.

Підрахуємо число зайнятих клітин таблиці, їх 8, а має бути m+n-1=8. Отже, опорний план є не вироджених.

Перевіримо оптимальність опорного плану, складемо систему рівнянь (для заповнених клітин таблиці) для визначення потенціалів першого опорного плану:



Записана система рівнянь є невизначеною, і один з її розв’язків дістанемо, узявши, наприклад, u1 = 0. Тоді всі інші потенціали однозначно визначаються з цієї системи рівнянь: u1 =0, u2 = 0, u3 = 0, v1 =1, v2 =4, v3 =1 v4=1, v5=2, v6=0. Ці значення потенціалів першого опорного плану записуємо у транспортну таблицю.

Потім згідно з алгоритмом методу потенціалів перевіряємо виконання другої умови оптимальності ui + vj ≤ cij(для порожніх клітинок таблиці):


А1B4 : u1 + v4 = 0 + 1 = 1<5;

А1B5 : u1 + v5 = 0 + 2 = 2<6;

А1B6 : u1 + v6 = 0 + 0 = 0=0;

А2B1 : u2 + v1 = 0 + 1 = 1= 1;

А2B2 : u2 + v2 = 0 + 4 = 4>3;

А3B1 : u3 + v1 = 0 + 1 = 1< 4;

А3B2 : u3 + v2 = 0 + 4 = 4> 1;

А3B3 : u3 + v3 = 0 + 1 = 1<2;

А3B4 : u4 + v1 = 0 + 1 = 1<2;

А3B5 : u4 + v2 = 0 + 2 = 2<3;


Опорний план не є оптимальним, тому що існують оцінки вільних клітин для яких ui + vi>cij


А2B2 : u2 + v2 = 0 + 4 = 4>3;

А3B2 : u3 + v2 = 0 + 4 = 4> 1;


Тому від нього необхідно перейти до другого плану, змінивши співвідношення заповнених і порожніх клітинок таблиці. Вибираємо максимальну оцінку вільної клітини (А3B2): 1

Ставимо в ній знак «+». Для визначення клітинки, що звільняється, будуємо цикл, починаючи з клітинки А3B2, та позначаємо вершини циклу почергово знаками «–» і «+». Тепер необхідно перемістити продукцію в межах побудованого циклу. Для цього у порожню клітинку А1B4 переносимо менше з чисел хij, які розміщені в клітинках зі знаком «–». Одночасно це саме число хij додаємо до відповідних чисел, що розміщені в клітинках зі знаком «+», та віднімаємо від чисел, що розміщені в клітинках, позначених знаком «–».

З вантажів хij що стоять в мінусових клітинах, вибираємо найменше, , тобто . Додаємо 10 до обсягів вантажів, що стоять в плюсових клітинах і віднімаємо 10 з Хij, що стоять в мінусових клітинах. В результаті отримаємо новий опорний план. Усі інші заповнені клітинки першої таблиці, які не входили до циклу, переписуємо у другу таблицю без змін. Кількість заповнених клітинок у новій таблиці також має відповідати умові невиродженості плану, тобто дорівнювати (n + m – 1).

Отже, другий опорний план транспортної задачі матиме такий вигляд:

Ai

Bj

ui

b1 = 100

b2 = 120

b3 = 90

b4=70

b5=80

B6=290

а1 = 300

1

100

4

[-] 110

1

90

5


6


0

[+]

u1 = 0

а2 = 250

1


3


1


1

70

2

80

0

100

u2 = -3

а3 = 200

4


1

[+] 10

2


2


3


0

[-] 190

u3 = -3

vj

v1 =1

v2 =4

v3 =1

v4 =4

v5=5

V6 =3



Перевіримо оптимальність опорного плану. Знайдемо потенціали ui, vi. по зайнятих клітинам таблиці, в яких ui + vi = cij, вважаючи, щоu1 = 0.

Опорний план не є оптимальним, тому що існують оцінки вільних клітин для яких ui + vi>cij


(А1B6): 0 + 3 = 3 >0;


Вибираємо максимальну оцінку вільної клітини (А1B6): 0

Для цього в перспективну клітку (А3B2) поставимо знак «+», а в інших вершинах багатокутника чергуються знаки «-», «+», «-». Цикл наведено в таблиці.

З вантажів хij що стоять в мінусових клітинах, вибираємо найменше, тобто у = min (А1B2) = 110. Додаємо 110 до обсягів вантажів, що стоять в плюсових клітинах і віднімаємо 110 з Хij, що стоять в мінусових клітинах. В результаті отримаємо новий опорний план.


Ai

Bj

ui

b1 = 100

b2 = 120

b3 = 90

b4=70

b5=80

B6=290

а1 = 300

1

100

4


1

90

5


6


0

110

u1 = 0

а2 = 250

1


3


1


1

70

2

80

0

100

u2 = 0

а3 = 200

4


1

120

2


2


3


0

80

u3 = 0

vj

v1 =1

v2 =1

v3 =1

v4 =1

v5=2

V6 =0


Перевіримо оптимальність опорного плану, тобто повторюємо описані раніше дії.

Знайдемо потенціали ui, vi. по зайнятих клітинам таблиці, в яких ui + vi = cij, вважаючи, що u1 = 0.

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

Розрахуємо значення цільової функції відповідно до другого опорного плану задачі:


Z(x) = 1*100 + 1*90 + 0*110 + 1*70 + 2*80 + 0*100 + 1*120 + 0*80 = 540


За оптимальним планом перевезень загальна вартість перевезень всієї продукції є найменшою і становить 540 грн.


Завдання 4


Знайти графічним методом екстремуми функції в області, визначеній нерівностями (в усіх варіантах вважати )


,  ,  ,


Розв’язок


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


Межі області


Позначимо границі області багатокутника рішень.



Цільова функція F(x) => min

Розглянемо цільову функцію завдання F = 6X1+8X2 => min.

Побудуємо пряму, що відповідає значенню функції F = 0: F = 6X1+8X2 = 0. Будемо рухати цю пряму паралельним чином. Оскільки нас цікавить мінімальне рішення, тому рухався прямо до першого торкання позначеної області. На графіку ця пряма позначена пунктирною лінією.


Рівний масштаб


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

Пряма F(x) = const перетинає область у точці A. Оскільки точка A отримана в результаті перетину прямих 1 i 5, то її координати задовольняють рівнянням цих прямих:


x1+2x2≥2

x1=0


Вирішивши систему рівнянь, одержимо: x1 = 0, x2 = 1

Звідки знайдемо мінімальне значення цільової функції:


F(X) = 6*0 + 8*1 = 8

 


Теги: Математичні моделі задач лінійного програмування  Контрольная работа  Экономика отраслей
Просмотров: 23100
Найти в Wikkipedia статьи с фразой: Математичні моделі задач лінійного програмування
Назад