Matemaattinen optimointi

Wikipedia
Loikkaa: valikkoon, hakuun

Matemaattinen optimointi tarkoittaa määritellyn kohde-, hyöty- tai kustannusfunktion perusteella parhaan ratkaisun valintaa kaikkien mahdollisten ratkaisujen joukosta. Kun kohdefunkio kuvaa ratkaisusta saatavaa hyötyä, jonka halutaan olevan mahdollisimman suuri, kutsutaan optimointitehtävää maksimoinniksi. Kun taas halutaan ratkaisusta koituvan mahdollisimman vähän kustannuksia tai haittaa, kutsutaan tehtävää minimoinniksi.

Formaalisti optimointi on sellaisen pisteen x^{*} etsiminen ratkaisujoukosta \in A, missä funktio f : A \to \mathbb{R} saa joko pienimmän tai suurimman arvonsa. Tätä pistettä x^{*} kutsutaan minimipisteeksi.

Jokaista maksimointiongelmaa vastaa tietty minimointiongelma, joka ratkaisee maksimointiongelman. Funktion g maksimointi on sama tehtävä kuin funktion f=-g minimointi. Näin ollen matemaattisen optimointiteorian riittää tarkastella vain minimointiongelmaa.

Sisällysluettelo

Merkintätapa [muokkaa]

Tehtävää, jonka tarkoituksena on etsiä f pienin arvo, kutsutaan minimointitehtäväksi. Tehtäväkuvaus merkitään formaalisti

\min_{x \in \mathbb{R}} f(x)

missä f on tehtävän kohdefunktio.

Vastaavasti kohdefunktion maksimointitehtävää merkitään

\max_{x \in \mathbb{R}} f(x)

Optimointitehtävässä

\min f(\mathbf{x})~,~\mathbf{x} \in S

joukkoa S kutsutaan käyväksi ratkaisujoukoksi tai vain käyväksi joukoksi. Käypä joukko voidaan määritellä esimerkiksi

S = [0, 5]

Monen muuttujan tehtävässä käypä ratkaisujoukko voidaan määritellä esimerkiksi

S = \{ (x,y) | x > 0 \text{ ja } y <= 5 - 2x \}

Optimointitehtävän globaali minimi on piste \mathbf{x}^*, jolle pätee f(\mathbf{x}^*)\leq f(\mathbf{x}) kaikilla \mathbf{x}, jotka kuuluvat käypään alueeseen. Tätä pienempää funktion arvoa ei voida saavuttaa käyvässä joukossa.

Funktiolla voi olla yksi tai useampi paikallinen optimipiste, lokaali optimi. Lokaali minimi määritellään pisteeksi \mathbf{x}_{\mathrm{lok}}^*, jolle on olemassa \varepsilon > 0 siten, että f(\mathbf{x}_{\mathrm{lok}}^*) \leq f(\mathbf{x}_{\mathrm{lok}}^*+\mathbf{h})~,\forall \mathbf{h},~||\mathbf{h}||\leq \varepsilon ja \mathbf{x}_{\mathrm{lok}}^*+\mathbf{h} kuuluu käypään joukkoon. Toisin sanoen on olemassa jokin alue eli ympäristö, jossa piste \mathbf{x}_{\mathrm{lok}}^* antaa pienempiä funktion arvoja kun muut pisteet.

Optimointitehtävätyyppejä [muokkaa]

  • Konveksin optimointitehtävän kohdefunktio sekä mahdolliset rajoitusehdot ovat konvekseja. Konveksin minimointitehtävän tärkeä ominaisuus on, että paikallinen minimipiste on myös tehtävän globaali minimipiste.
    • Lineaarisen optimointitehtävän (engl. lyh. LP) kohdefunktio ja rajoitusehdot ovat lineaarisia funktioita. Lineaarinen tehtävä on laajasti tutkittu ja tälle on kehitetty paljon tehokkaita ratkaisualgoritmeja kuten George Dantzigin vuonna 1947lähde?.
    • Neliöllinen optimointitehtävä on konveksin optimointitehtävän erikoistapaus, missä kohdefunktio on neliöllinen ja käypä ratkaisujoukko monitahokas.
  • Epälineaarinen optimointi on yleisnimitys optimointitehtävälle, jonka kohdefunktio ja mahdolliset rajoitusehdot ovat epälineaarisia
  • Stokastisen optimointitehtävän kohdefunktiossa ja rajoitusehdoissa esiintyy yksi tai useampi satunnaismuuttuja.
  • Kokonaislukuoptimointitehtävän käypä ratkaisujoukko kuuluu kokonaislukujen joukkoon. Kokonaislukuoptimointitehtävän ratkaiseminen on laskennallisesti haastavaa ja usein tyydytään riittävän hyvään ratkaisuun globaalin optimiratkaisun sijasta.
    • Dynaaminen ohjelmointitehtävä on tehokas kokonaislukutehtävän ratkaisumalli, jota voidaan soveltaa vain jos tehtävä on mahdollista esittää toisistaan riippumattomia alitehtävien yhdistelmänä. Ns. Bellmanin yhtälö määrää välttämättömät ehdot kohdetehtävlle, johon voidaan soveltaa dynaamisen ohjelmoinnin periaatetta.

Lineaarinen optimointi [muokkaa]

Lineaarinen optimointi tarkoittaa optimointia kun kohdefunktio ja käypää aluetta rajoittavat ehdot ovat lineaarisia. Lineaarista optimointi kutsutaan myös lineaariseksi ohjelmoinniksi. Yleinen linearinen tehtävä voidaan esittää muodossa

\min \mathbf{c}^T \mathbf{x}
\mathbf{A_1 x} \leq \mathbf{b_1}
\mathbf{A_2 x} \geq \mathbf{b_2}
\mathbf{A_3 x} = \mathbf{b_3}

Tässä \leq ja \geq merkeillä tarkoitetaan, että jokaista alkiota verrataan riveittäin toisiinsa. Voidaan osoittaa, että kaikki lineaariset optimointitehtävät voidaan esittään ali- ja ylijäämämuuttujien (engl. slack variable) avulla ns. standardimuodossa

\min \mathbf{c}^T \mathbf{x}
\mathbf{A x} = \mathbf{b}
\mathbf{x\geq 0}

missä \mathbf{c}\in \mathbb{R}^{n\times 1}, \mathbf{b}\in \mathbb{R}^{m\times 1} ja \mathbf{A}\in \mathbb{R}^{m\times n}. Ts. aina kun tarkastellan yleistä lineaarista tehtävää, voidaan tarkastella pelkästään standarditehtävää menettämättä tuloksien yleispätevyyttä. Huomaa, että myös vektorit \mathbf{c} ja \mathbf{x} muuttuvat tehtävätyypin muunnoksessa.

Tuloksia [muokkaa]

  • Lineaarisen optimointitehtävän käypä alue on n dimensioisen avaruuden monitahokas (engl. polyhedra).
  • Oletetaan, että tehtävänä on minimoida lineaarista kohdefunktiota epätyhjän monitahokkaan sisällä (ts. kyseessä on lineaarinen optimointitehtävä). Tällöin kohdefunktion optimaalinen arvo on -\infty tai on olemassa optimaalinen ratkaisu \mathbf{x}^*. Huomaa, että optimipisteen yksikäsitteisyyttä ei ole taattu.
  • Jos lineaarisen optimointitehtävän ratkaisu \mathbf{x}^* on äärellinen, tulee yksi ratkaisu löytymään jostain rajoittavan monitahokkaan S kulmasta. Jos kaksi pistettä \mathbf{x}_1 ja \mathbf{x}_2 ovat optimaalisia ovat myös pisteet muotoa \lambda \mathbf{x}_1 + (1-\lambda)\mathbf{x}_2~,\lambda\in (0,1) optimaalisia. Tämän voi tulkita siten, että kahden kulman välillä oleva särmä on optimaalinen, jos kummatkin kulmat ovat optimaalisia. Todistus: Oletetaan, että annetut pisteet minimoivat kohdefunktion f. Voidaan osoittaa, että monitahokas on konveksi joukko, eli kaikilla \mathbf{x_1,x_2}\in S pätee \lambda \mathbf{x}_1 + (1-\lambda)\mathbf{x}_2\in S~,\lambda\in (0,1). Koska annetut pisteet ovat optimaalisia, eli niitä pienempiä arvoja funktio ei voi monitahokkaassa saada, päteef(\mathbf{x}_1)= f(\mathbf{x}_2)=: z. Toisaalta f(\lambda \mathbf{x}_1 + (1-\lambda)\mathbf{x}_2) = \mathbf{c}^T(\lambda \mathbf{x}_1 + (1-\lambda)\mathbf{x}_2) = \underbrace{\mathbf{c}^T \lambda \mathbf{x}_1}_{= \lambda f(\mathbf{x}_1)} + \underbrace{\mathbf{c}^T(1-\lambda)\mathbf{x}_2}_{=(1-\lambda)f(\mathbf{x}_2)}
, mikä voidaan kirjoittaa f(\lambda \mathbf{x}_1 + (1-\lambda)\mathbf{x}_2) = \lambda z + (1-\lambda) z = z~.~\square. Helposti voidaan huomata, että tapaus voidaan yleistää koskemaan n:ää pistettä, eli jos pisteet \mathbf{x}_i, i=1,... n ovat optimaalisia, niin ovat myös niiden ns. konveksikombinaatiot \sum_{i=1}^n a_n \mathbf{x}_n, \sum_{i=1}^n a_n =1, a_n\geq 0 myös optimaalisia. Todistus on analoginen kahden pisteen tapauksen kanssa.

Esimerkkejä [muokkaa]

Lineaarinen optimointitehtävä

\min~-x_1+x_2
x_1+x_2\leq 0
x_1\geq 1

voidaan esittää standardimuodossa muunnoksella x_i = x_i^+-x_i^-, missä x_i^+ ja x_i^-~\geq 0. Kun lisätään vielä ali- ja ylijäämämuuttujat s_1 ja s_2 saadaan tehtäväksi

\min -x_1^+ + x_1^- + x_2^+ - x_2^-
x_1^+ - x_1^- + x_2^+ - x_2^- + s_1 + 0\cdot s_2= 0
x_1^+ - x_1^- + 0\cdot x_2^+ - 0 \cdot x_2^- + 0\cdot s_1 - s_2= 1
x_i^{\pm}, s_i \geq 1~,i = 1,2

Jos siis valitaan \mathbf{c} = [-1, 1, 1, -1, 0, 0]^T, \mathbf{b} = [0, 1]^T, \mathbf{x} = [x_1^+, x_1^-, x_2^+, x_2^-, s_1, s_2]^T ja

\mathbf{A} = \begin{bmatrix}
1 & -1 & 1 & -1 & 1 & 0  \\
1 & -1 & 0 &  0 & 0 & -1 \\ \end{bmatrix}~,

on tehtävä saatu standardimuotoon. Huomaa, että optimipisteessä vain toinen muuttujista x_i^+ ja x_i^- on nollasta poikkeava, joten ylimääräiset muuttujat eivät vaikuta rajoitusehtoihin.

Epälineaarinen optimointi [muokkaa]

Epälineaarisella optimoinnilla tarkoitetaan sellaisen optimointitehtävän ratkaisemista, joka on muotoa

\min f(\mathbf{x})
g_i(\mathbf{x})\leq 0, i = 1,...,m
h_j(\mathbf{x})=0, j= 1,...,l
x\in X\subseteq \mathbb{R}^n

missä f,g_i,h_j:\mathbb{R}^n\mapsto \mathbb{R}, f on mielivaltainen kohdefunktio, funktiot g_i epäyhtälörajoitukset, h_j yhtälörajoitukset ja X käypä joukko. Vaikka yhtälörajoitukset voidaan esittää epäyhtälörajoitusten avulla (h_i \leq 0 ja -h_i \leq 0), tämä ei käytännössä aina ole mahdollista, sillä jotkin ratkaisumenetelmät olettavat tehtävän rajoitusten olevan optimipisteessä lineaarisesti riippumattomat.

Epälineaarinen ja lineaarinen tehtävä (LP) eroavat toisistaan seuraavasti. Epälineaarisessa tehtävässä käypä alue voi olla mielivaltainen, kun LP-tehtävän käypä joukko on aina monitahokas. Toiseksi LP-tehtävän lineaarinen kohdefunktio on aina myös konveksi, joten tehtävälle löydetään globaali optimi hyödyntämällä konveksin optimoinnin tuloksia. Epälineaarinen tehtävä on lineaarista tehtävää yleisempi, joten kaikki tulokset, jotka on johdettu epälineaariselle tehtävälle, pätevät myös lineaariselle tehtävälle.

Välttämättömät optimaalisuusehdot [muokkaa]

Kun jokin optimointitehtävän käyvän alueen piste on optimaalinen, se täyttää välttämättömät optimaalisuusehdot. Lause ei päde toisin päin, eli tehtävälle voi olla mahdollista löytää optimaalisuusehdot täyttävä piste, joka ei välttämättä ole optimipiste.

Rajoittamattoman tehtävän välttämätön optimaalisuusehto optimointitehtävän ratkaisupisteelle \mathbf{x}^* on

\nabla f(\mathbf{x}^*) = 0

Yleiselle rajoitetulle tehtävälle voidaan johtaa Karush-Kuhn-Tuckerin välttämättömät optimaalisuusehdot (välttämättömät KKT-ehdot), ja hieman yleisemmät Fritz-Johnin välttämättömät optimaalisuus ehdot (välttämättömät FJ ehdot).

Fritz-Johnin välttämättömät optimaalisuusehdot [muokkaa]

Olkoon käypä joukko epätyhjä ja avoin sekä \mathbf{x} jonkin epälineaarisen tehtävän lokaali optimi. Tällöin on olemassa vektori (u_0,\mathbf{u,v}) siten, että

u_0\nabla f(\mathbf{x})+\sum_{i=1}^m u_i \nabla g_i(\mathbf{x})+\sum_{i=1}^l v_i \nabla h_i(\mathbf{x}) = 0
u_i g_i(\mathbf{x}) = 0, i = 1,...,m
u_0 \geq 0, u_i \geq 0, i = 1,...,m

missä \mathbf{u} ja \mathbf{v} ovat m ja l vektoreita joiden i:nnet komponintit ovat u_i ja v_i. Luonnollisesti on oletettava, että gradientit ovat olemassa. FJ-ehdot saadaan toteutumaan mielivaltaiselle käyvälle pisteelle lisäämällä sopivia merkityksettömiä rajoituksia.

Karush-Kuhn-Tuckerin välttämättömät optimaalisuusehdot [muokkaa]

Fritz-Johnin ehdot redusoituvat tietyin ehdoin KKT-ehdoiksi. KKT-ehdot ovat FJ-ehtoja hyödyllisempiä, sillä ne karsivat pois turhia kandidaattipisteitä. Käytännössä näiden ehtojen on taattava, että FJ-ehtojen u_0 on nollasta poikkeava, jolloin jakamalla sillä puolittain saadaan ns. KKT-ehdot.

Olkoon \mathbf{x} jonkin epälineaarisen tehtävän lokaali optimi, jolla on sopivat rajoitusehdot. Tällöin on olemassa vektori (\mathbf{u,v}) siten, että

\nabla f(\mathbf{x})+\sum_{i=1}^m u_i \nabla g_i(\mathbf{x})+\sum_{i=1}^l v_i \nabla h_i(\mathbf{x}) = 0
u_i g_i(\mathbf{x}) = 0, i = 1,...,m
u_i \geq 0, i = 1,...,m

missä \mathbf{u} ja \mathbf{v} ovat m ja l vektoreita joiden i:nnet komponentit ovat u_i ja v_i.

Esimerkkejä [muokkaa]

  • Funktio f(x)=ax^2+bx+c, kun a > 0, saavuttaa miniminsä pisteessä \frac{-b}{2a}.
  • Funktiolla f(x)=x, kun x \in \mathbb{R}, ei ole minimipistettä, sillä jokaista pistettä x kohden on aina olemassa pienempi piste y < x.
  • Funktiolla f(x)=(x+1)^2(x-1)^2on kaksi nollakohtaa x_1=-1 ja x_1=1. Se on aina ei-negatiivinen, joten funktion minimiarvo on nolla. Huomaa, että kaksi eri x:n arvoa antavat saman optimin, eli optimi ei ole yksikäsitteinen. Jos optimointi tehdään rajoitetussa joukossa x\geq 0, niin optimi on yksikäsitteinen.

Katso myös [muokkaa]