Optimizacijske metode - vaje 19.3.2021


Dualni programi

Linearni program \(\Pi = \Pi''\):

\[ \begin{aligned} \max \ c^\top x \\ A x &\le b \\ x &\ge 0 \end{aligned} \]

Dualni linearni program \(\Pi'\):

\[ \begin{aligned} \min \ b^\top y \\ A^\top y &\ge c \\ y &\ge 0 \end{aligned} \]

  • Šibki izrek o dualnosti:

    \[ Ax \le b \land A^\top y \ge c \land x, y \ge 0 \Rightarrow c^\top x \le b^\top y \]

  • Krepki izrek o dualnosti: če je \(x^{*}\) optimalna rešitev \(\Pi\) in \(y^{*}\) optimalna rešitev \(\Pi'\), potem velja \(c^\top x^{*}\) \(=\) \(b^\top y^{*}\)

Pričakovana časovna zahtevnost simpleksne metode za LP z \(m\) omejitvami in \(n\) spremenljivkami: \(O(m \log n)\)


Naloga 1

S pomočjo dualnega programa reši naslednji problem:

\[ \begin{aligned} \max \quad - x_1 - 2 x_2 \\[1ex] -3 x_1 + x_2 &\le -1 \\ x_1 - x_2 &\le 1 \\ -2 x_1 + 7 x_2 &\le 6 \\ 9 x_1 + 4 x_2 &\le 6 \\ -5 x_1 + 2 x_2 &\le -3 \\ 7 x_1 - 3 x_2 &\le 6 \\[1ex] x_1, x_2 &\ge 0 \end{aligned} \]


Dualni LP:

\[ \begin{aligned} \min \quad -y_3 + y_4 + 6 y_5 + 6 y_6 - 3 y_7 + 6 y_8 \\[1ex] -3 y_3 + y_4 - 2 y_5 + 9 y_6 - 5 y_7 + 7 y_8 &\ge -1 \\ y_3 - y_4 + 7 y_5 + 4 y_6 + 2 y_7 - 3 y_8 &\ge -2 \\[1ex] y_3, y_4, y_5, y_6, y_7, y_8 &\ge 0 \end{aligned} \]

V standardni obliki:

\[ \begin{aligned} \max \quad y_3 - y_4 - 6 y_5 - 6 y_6 + 3 y_7 - 6 y_8 \\[1ex] 3 y_3 - y_4 + 2 y_5 - 9 y_6 + 5 y_7 - 7 y_8 &\le 1 \\ -y_3 + y_4 - 7 y_5 - 4 y_6 - 2 y_7 + 3 y_8 &\le 2 \\[1ex] y_3, y_4, y_5, y_6, y_7, y_8 &\ge 0 \end{aligned} \]

Začetni slovar:

\[ \begin{aligned} y_1 &= 1 - 3 y_3 + y_4 - 2 y_5 + 9 y_6 - 5 y_7 + 7 y_8 \\ y_2 &= 2 + y_3 - y_4 + 7 y_5 + 4 y_6 + 2 y_7 - 3 y_8 \\ -z &= y_3 - y_4 - 6 y_5 - 6 y_6 + 3 y_7 - 6 y_8 \end{aligned} \]

  • vstopi \({y_7}\)
  • izstopi \({y_1}\)

Drugi slovar:

\[ \begin{aligned} y_7 &= 1/5 - 1/5 y_1 - 3/5 y_3 + 1/5 y_4 - 2/5 y_5 + 9/5 y_6 + 7/5 y_8 \\ y_2 &= 12/5 - 2/5 y_1 - 1/5 y_3 - 3/5 y_4 + 31/5 y_5 + 38/5 y_6 - 1/5 y_8 \\ -z &= 3/5 - 3/5 y_1 - 4/5 y_3 - 2/5 y_4 - 36/5 y_5 - 3/5 y_6 - 9/5 y_8 \end{aligned} \]

Optimalna rešitev dualnega programa:

  • \({y_2^{*}} = 12/5\)
  • \({y_7^{*}} = 1/5\)
  • \(z^{*} = -3/5\)

Optimalna rešitev originalnega programa:

  • \({x_1^{*}} = 3/5\)
  • \({x_2^{*}} = 0\)
  • \({x_3^{*}} = 4/5\)
  • \({x_4^{*}} = 2/5\)
  • \({x_5^{*}} = 36/5\)
  • \({x_6^{*}} = 3/5\)
  • \({x_7^{*}} = 0\)
  • \({x_8^{*}} = 9/5\)
  • \(z^{*} = -3/5\)

Naloga 2

V mizarski delavnici izdelujejo stole, mize in omare. Proizvodni proces ima dve fazi: struženje in lakiranje. Stol stružijo 18 minut, lakirajo 6 minut, dobiček pri enem prodanem stolu pa je 200 evrov. Mizo stružijo 24 minut, lakirajo 12 minut, z njo pa zaslužijo 500 evrov. Omare ne stružijo, lakirajo jo pol ure, z njo pa zaslužijo 800 evrov.

Koliko posameznih izdelkov naj izdelajo, da bodo imeli največji možen dobiček, če je čas struženja omejen s 120 minutami, čas lakiranja pa je največ 150 minut? Zapiši tudi dualni program ter razmisli o pomenu spremenljivk in omejitev!


Linearni program:

\[ \begin{aligned} \max \quad 200 x_1 + 500 x_2 + 800 x_3 \\[1ex] 18 x_1 + 24 x_2 &\le 120 \\ 6 x_1 + 12 x_2 + 30 x_3 &\le 150 \\[1ex] x_1, x_2, x_3 &\ge 0 \end{aligned} \]

Dualni linearni program:

\[ \begin{aligned} \min \quad 120 y_4 + 150 y_5 \\[1ex] 18 y_4 + 6 y_5 &\ge 200 \\ 24 y_4 + 12 y_5 &\ge 500 \\ 30 y_5 &\ge 800 \\[1ex] y_3, y_4, y_5 &\ge 0 \end{aligned} \]

S simpleksno metodo rešujemo originalni LP:

\[ \begin{aligned} x_4 &= 120 - 18 x_1 - 24 x_2 \\ x_5 &= 150 - 6 x_1 - 12 x_2 - 30 x_3 \\ z &= 200 x_1 + 500 x_2 + 800 x_3 \end{aligned} \]

  • vstopi: \({x_3}\)
  • izstopi: \({x_5}\)

\[ \begin{aligned} x_3 &= 5 - 1/5 x_1 - 2/5 x_2 - 1/30 x_5 \\ x_4 &= 120 - 18 x_1 - 24 x_2 \\ z &= 4000 + 40 x_1 + 180 x_2 - 80/3 x_5 \end{aligned} \]

  • vstopi: \({x_2}\)
  • izstopi: \({x_4}\)

\[ \begin{aligned} x_2 &= 5 - 3/4 x_1 - 1/24 x_4 \\ x_3 &= 3 + 1/10 x_1 + 1/60 x_4 - 1/30 x_5 \\ z &= 4900 - 95 x_1 - 15/2 x_4 - 80/3 x_5 \end{aligned} \]

Optimalna rešitev originalnega LP:

  • \({x_1^{*}} = 0\) stolov
  • \({x_2^{*}} = 5\) miz
  • \({x_3^{*}} = 3\) omare
  • \({x_4^{*}} = 0\) minut
  • \({x_5^{*}} = 0\) minut
  • \(z^{*} = 4900 €\)

Optimalna rešitev dualnega LP:

  • \({y_1^{*}} = 95\) €/stol (koliko bi morali dvigniti ceno stola, da bi se jih izplačalo proizvajati)
  • \({y_2^{*}} = 0\) €/mizo
  • \({y_3^{*}} = 0\) €/omaro
  • \({y_4^{*}} = 15/2\) €/min (največja cena dodatne minute lakiranja, da se nam izplača povečati omejitev)
  • \({y_5^{*}} = 80/3\) €/min (največja cena dodatne minute struženja, da se nam izplača povečati omejitev)
  • \(z^{*} = 4900\)

\[ \begin{aligned} \max \quad (200 + c_1) x_1 + 500 x_2 + 800 x_3 &- c_4 t_4 - c_5 t_5 \\[1ex] 18 x_1 + 24 x_2 &\le 120 + t_4 \\ 6 x_1 + 12 x_2 + 30 x_3 &\le 150 + t_5 \\[1ex] x_1, x_2, x_3 &\ge 0 \end{aligned} \]

\[ \begin{aligned} x_4 - t_4 &= 120 - 18 x_1 - 24 x_2 \\ x_5 - t_5 &= 150 - 6 x_1 - 12 x_2 - 30 x_3 \\ z &= (200 + c_1) x_1 + 500 x_2 + 800 x_3 - c_4 t_4 - c_5 t_5 \end{aligned} \]

\[ \begin{aligned} x_2 &= 5 - 3/4 x_1 - 1/24 (x_4 - t_4) \\ x_3 &= 3 + 1/10 x_1 + 1/60 (x_4 - t_4) - 1/30 (x_5 - t_5) \\ z &= 4900 + (c_1 - 95) x_1 - 15/2 x_4 - 80/3 x_5 + (15/2 - c_4) t_4 + (80/3 - c_5) t_5 \end{aligned} \]


Naloga 3

Ali je \({x_1} = 7, {x_2} = 1, {x_3} = 3\) optimalna rešitev linearnega programa:

\[ \begin{aligned} \max \quad 2 x_1 + 3 x_2 - x_3 \\[1ex] x_1 - x_2 - x_3 &\le 3 \\ x_1 + 2 x_2 + 3 x_3 &\le 18 \\ x_1 + 3 x_2 - 2 x_3 &\le 4 \\[1ex] x_1, x_2, x_3 &\ge 0 \end{aligned} \]

Pomagaj si z dualnim dopolnjevanjem:

  1. preveri, ali je \(({x_1}, {x_2}, {x_3})\) dopustna rešitev
  2. tam, kjer omejitve niso dosežene, spremenljivke dualnega problema nastavi na \(0\)
  3. za vse spremenljivke \({x_i}\), različne od \(0\), nastavi enačbo med spremenljivkami dualnega problema.
  4. reši dobljene enačbe
  5. preveri, ali je dobljena rešitev dopustna.

Izrek o dualnem dopolnjevanju: če sta \(x^{*}\) in \(y^{*}\) optimalni rešitvi \(\Pi\) in \(\Pi'\), potem:

  • \(\forall i:\) \(({x_i^{*}} = 0\) \(\lor\) \({y_i^{*}} = 0)\)
  • \(\forall i = 1, 2, \dots, n:\) \(({x_i^{*}} = 0\) \(\lor\) \({\sum_{j=1}^m} {a_{ji}} {y_{j+n}^{*}} = {c_i})\)
  • \(\forall j = 1, 2, \dots, m:\) \(({\sum_{i=1}^n} {a_{ji}} {x_i^{*}} = b_i\) \(\lor\) \({y_{j+n}^{*}} = 0)\)

Dualni LP:

\[ \begin{aligned} \min \quad 3 y_4 + 18 y_5 + 4 y_6 \\[1ex] y_4 + y_5 + y_6 &\ge 2 \\ -y_4 + 2y_5 + 3y_6 &\ge 3 \\ -y_4 + 3y_5 - 2y_6 &\ge -1 \\[1ex] y_4, y_5, y_6 &\ge 0 \end{aligned} \]

  1. Dopustnost rešitve:

    \[ \begin{aligned} 7 - 1 - 3 &= 3 \\ 7 + 2 \cdot 1 + 3 \cdot 3 &= 18 \\ 7 + 3 \cdot 1 - 2 \cdot 3 &= 4 \\[1ex] 7, 1, 3 &\ge 0 \end{aligned} \]

    Rešitev je dopustna.

  2. Vse omejitve so dosežene.

  3. Nastavimo sistem enačb:

    \[ \begin{aligned} y_4 + y_5 + y_6 &= 2 \\ -y_4 + 2y_5 + 3y_6 &= 3 \\ -y_4 + 3y_5 - 2y_6 &= -1 \\[1ex] \end{aligned} \]

  4. Rešimo sistem enačb:

    \[ \begin{aligned} y_4 + y_5 + y_6 &= 2 \\ 19y_5 &= 9 \\ 4y_5 - y_6 &= 1 \\[1ex] \end{aligned} \]

    • \({y_5} = 9/19\)
    • \({y_6} = 17/19\)
    • \({y_4} = 12/19\)
  5. Imamo dopustno rešitev dualnega LP, torej imamo optimalno rešitev.


Naloga 4

Stara mama Tilka ljubi peko piškotov in zna speči kar tri vrste piškotov: čokoladne, jajčne in maslene. Za kilogram vsakih najprej potrebuje pol kilograma moke in 200g sladkorja. Nato za čokoladne piškote potebuje še 200g čokolade in 100g masla, za jajčne piškote 100g masla in 4 jajca, za maslene pa 200g masla in 2 jajci.

V soboto se poroči njena vnukinja Slavka, zato so ji sorodniki povedali, da v petek zvečer pridejo po piškote, nato pa odhiteli po opravkih in jo brez prevoza pustili doma. K sreči ima na zalogi 50kg moke, 5kg sladkorja, 3kg čokolade, 2kg masla in 40 jajc.

  1. Dokaži, da 15kg čokoladnih in 2,5kg maslenih piškotov ni optimalna rešitev.
  2. Dokaži, da bo največ piškotov spekla, če speče 10kg čokoladnih in 10kg jajčnih piškotov.

Linearni program:

\[ \begin{aligned} \max \quad x_1 + x_2 + x_3 \\[1ex] 5 x_1 + 5 x_2 + 5 x_3 &\le 500 \\ 2 x_1 + 2 x_2 + 2 x_3 &\le 50 \\ 2 x_1 &\le 30 \\ x_1 + x_2 + 2 x_3 &\le 20 \\ 4 x_2 + 2 x_3 &\le 40 \\[1ex] x_1, x_2, x_3 &\ge 0 \end{aligned} \]

Dual:

\[ \begin{aligned} \min \quad 500 y_4 + 50 y_5 + 30 y_6 + 20 y_7 + 40 y_8 \\[1ex] 5 y_4 + 2 y_5 + 2 y_6 + y_7 &\ge 1 \\ 5 y_4 + 2 y_5 + y_7 + 4 y_8 &\ge 1 \\ 5 y_4 + 2 y_5 + 2 y_7 + 2 y_8 &\ge 1 \\[1ex] y_4, y_5, y_6, y_7, y_8 &\ge 0 \end{aligned} \]

  1. Preverjamo optimalnost rešitve \(x = (15, 0, 2.5)\).

    \[ \begin{aligned} 5 \cdot 15 + 5 \cdot 2.5 &< 500 &&\Rightarrow y_4 = 0 \\ 2 \cdot 15 + 2 \cdot 2.5 &< 50 &&\Rightarrow y_5 = 0 \\ 2 \cdot 15 &= 30 \\ 15 + 2 \cdot 2.5 &= 20 \\ 2 \cdot 2.5 &< 40 &&\Rightarrow y_8 = 0 \\ 15, 0, 2.5 &\ge 0 \end{aligned} \]

    \[ \begin{aligned} 2 y_6 + y_7 &= 1 \\ 2 y_7 &= 1 \end{aligned} \]

    • \({y_7} = 1/2\)
    • \({y_6} = 1/4\)
    • \(1/2 \not\ge 1\) rešitev ni dopustna
    • \(x\) ni optimalna rešitev originalnega LP
  2. Preverjamo optimalnost rešitve \(x = (10, 10, 0)\).

    \[ \begin{aligned} 5 \cdot 10 + 5 \cdot 10 &< 500 &&\Rightarrow y_4 = 0 \\ 2 \cdot 10 + 2 \cdot 10 &< 50 &&\Rightarrow y_5 = 0 \\ 2 \cdot 10 &< 30 &&\Rightarrow y_6 = 0 \\ 10 + 10 &= 20 \\ 4 \cdot 10 &= 40 \\ 10, 10, 0 &\ge 0 \end{aligned} \]

    \[ \begin{aligned} y_7 &= 1 \\ y_7 + 4 y_8 &= 1 \\ \end{aligned} \]

    • \({y_7} = 1\)
    • \({y_8} = 0\)
    • \(2 \cdot 1 + 2 \cdot 0 \ge 1\)
    • \(y \ge 0\)
    • \(y\) je dopustna rešitev za dualni program, torej je \(x\) optimalna rešitev za originalni LP

Naloga 5

Reklamna agencija želi s svojimi oglasi doseči vsaj 50000 potrošnikov, pri čemer ima na voljo 20000 evrov sredstev. Oglašujemo na sledečih medijih:

Medij Doseg Cena Vpliv Max. št. oglasov
TV SLO 2000 1200 65 12
POP TV 3000 1500 90 15
Val 202 2500 200 5 30
Dnevnik 1500 800 35 10
Večer 1200 750 30 5

Na televiziji želimo imeti vsaj 10 oglasov, vendar zanje lahko porabimo največ 3/4 sredstev. Oglase želimo razporediti tako, da bomo dosegli čimvečji vpliv. Dokaži, da je \((0, 10, 5, 5, 0)\) optimalna rešitev!


\[ \begin{aligned} \max \quad 65 x_1 + 90 x_2 + 5 x_3 + 35 x_4 + 30 x_5 \\[1ex] -20 x_1 - 30 x_2 - 25 x_3 - 15 x_4 - 12 x_5 &\le -500 \\ 120 x_1 + 150 x_2 + 20 x_3 + 80 x_4 + 75 x_5 &\le 2000 \\ -x_1 - x_2 &\le -10 \\ 12 x_1 + 15 x_2 &\le 150 \\ x_1 &\le 12 \\ x_2 &\le 15 \\ x_3 &\le 30 \\ x_4 &\le 10 \\ x_5 &\le 5 \\[1ex] x_1, x_2, x_3, x_4, x_5 &\ge 0 \end{aligned} \]

Dual:

\[ \begin{aligned} \min \quad -500 y_6 + 2000 y_7 - 10 y_8 + 150 y_9 + 12 y_{10} + 15 y_{11} + 30 y_{12} + 10 y_{13} + 5 y_{14} \\[1ex] -20 y_6 + 120 y_7 - y_8 + 12 y_9 + y_{10} &\ge 65 \\ -30 y_6 + 150 y_7 - y_8 + 15 y_9 + y_{11} &\ge 90 \\ -25 y_6 + 20 y_7 + y_{12} &\ge 5 \\ -15 y_6 + 80 y_7 + y_{13} &\ge 35 \\ -12 y_6 + 75 y_7 + y_{14} &\ge 30 \\[1ex] y_7, y_8, y_9, y_{10}, y_{11}, y_{12}, y_{13}, y_{14} &\ge 0 \end{aligned} \]

Select a repo