Matemaattinen optimointi

testwikistä
Siirry navigaatioon Siirry hakuun

Malline:Lähteetön Matemaattinen optimointi tarkoittaa määritellyn parhaan ratkaisun valintaa kaikkien mahdollisten ratkaisujen joukosta. Yleensä matemaattinen optimointi liittyy funktioihin: kohde-, hyöty- tai kustannusfunktioihin. Kun kohdefunktio 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 A, missä funktio f:A 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.

Merkintätapa

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

minxf(x)

missä f on tehtävän kohdefunktio.

Vastaavasti kohdefunktion maksimointitehtävää merkitään

maxxf(x)

Optimointitehtävässä

minf(𝐱),𝐱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 ja y<=52x}

Optimointitehtävän globaali minimi on piste 𝐱*, jolle pätee f(𝐱*)f(𝐱) kaikilla 𝐱, 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. Paikallinen minimi määritellään pisteeksi 𝐱lok*, jolle on olemassa ε>0 siten, että f(𝐱lok*)f(𝐱lok*+𝐡),𝐡,||𝐡||ε ja 𝐱lok*+𝐡 kuuluu käypään joukkoon. Toisin sanoen on olemassa jokin alue eli ympäristö, jossa piste 𝐱lok* antaa pienempiä funktion arvoja kun muut pisteet.

Optimointitehtävätyyppejä

  • 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 1947 Malline:Lä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

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

min𝐜T𝐱
𝐀𝟏𝐱𝐛𝟏
𝐀𝟐𝐱𝐛𝟐
𝐀𝟑𝐱=𝐛𝟑

Tässä ja 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𝐜T𝐱
𝐀𝐱=𝐛
𝐱𝟎

missä 𝐜n×1, 𝐛m×1 ja 𝐀m×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 𝐜 ja 𝐱 muuttuvat tehtävätyypin muunnoksessa.

Tuloksia

  • 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 tai on olemassa optimaalinen ratkaisu 𝐱*. Huomaa, että optimipisteen 𝐱* yksikäsitteisyyttä ei ole taattu.
  • Jos lineaarisen optimointitehtävän ratkaisu 𝐱* on äärellinen, tulee yksi ratkaisu löytymään jostain rajoittavan monitahokkaan S kulmasta. Jos kaksi pistettä 𝐱1 ja 𝐱2 ovat optimaalisia ovat myös pisteet muotoa λ𝐱1+(1λ)𝐱2,λ(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 𝐱𝟏,𝐱𝟐S pätee λ𝐱1+(1λ)𝐱2S,λ(0,1). Koska annetut pisteet ovat optimaalisia, eli niitä pienempiä arvoja funktio ei voi monitahokkaassa saada, päteef(𝐱1)=f(𝐱2)=:z. Toisaalta f(λ𝐱1+(1λ)𝐱2)=𝐜T(λ𝐱1+(1λ)𝐱2)=𝐜Tλ𝐱1=λf(𝐱1)+𝐜T(1λ)𝐱2=(1λ)f(𝐱2), mikä voidaan kirjoittaa f(λ𝐱1+(1λ)𝐱2)=λz+(1λ)z=z.. Helposti voidaan huomata, että tapaus voidaan yleistää koskemaan n:ää pistettä, eli jos pisteet 𝐱i,i=1,...n ovat optimaalisia, niin ovat myös niiden ns. konveksikombinaatiot i=1nan𝐱n,i=1nan=1,an0 myös optimaalisia. Todistus on analoginen kahden pisteen tapauksen kanssa.

Esimerkkejä

Lineaarinen optimointitehtävä

minx1+x2
x1+x20
x11

voidaan esittää standardimuodossa muunnoksella xi=xi+xi, missä xi+ ja xi0. Kun lisätään vielä ali- ja ylijäämämuuttujat s1 ja s2 saadaan tehtäväksi

minx1++x1+x2+x2
x1+x1+x2+x2+s1+0s2=0
x1+x1+0x2+0x2+0s1s2=1
xi±,si1,i=1,2

Jos siis valitaan 𝐜=[1,1,1,1,0,0]T, 𝐛=[0,1]T, 𝐱=[x1+,x1,x2+,x2,s1,s2]T ja

𝐀=[111110110001],

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

Epälineaarinen optimointi

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

minf(𝐱)
gi(𝐱)0,i=1,...,m
hj(𝐱)=0,j=1,...,l
xXn

missä f,gi,hj:n, f on mielivaltainen kohdefunktio, funktiot gi epäyhtälörajoitukset, hj yhtälörajoitukset ja X käypä joukko. Vaikka yhtälörajoitukset voidaan esittää epäyhtälörajoitusten avulla (hi0 ja hi0), 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

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 𝐱* on

f(𝐱*)=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 optimaalisuusehdot (välttämättömät FJ-ehdot).

Fritz Johnin välttämättömät optimaalisuusehdot

Olkoon käypä joukko epätyhjä ja avoin sekä 𝐱 jonkin epälineaarisen tehtävän lokaali optimi. Tällöin on olemassa vektori (u0,𝐮,𝐯) siten, että

u0f(𝐱)+i=1muigi(𝐱)+i=1lvihi(𝐱)=0
uigi(𝐱)=0,i=1,...,m
u00,ui0,i=1,...,m

missä 𝐮 ja 𝐯 ovat m ja l vektoreita joiden i:nnet komponintit ovat ui ja vi. 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

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 u0 on nollasta poikkeava, jolloin jakamalla sillä puolittain saadaan ns. KKT-ehdot.

Olkoon 𝐱 jonkin epälineaarisen tehtävän lokaali optimi, jolla on sopivat rajoitusehdot. Tällöin on olemassa vektori (𝐮,𝐯) siten, että

f(𝐱)+i=1muigi(𝐱)+i=1lvihi(𝐱)=0
uigi(𝐱)=0,i=1,...,m
ui0,i=1,...,m

missä 𝐮 ja 𝐯 ovat m ja l vektoreita joiden i:nnet komponentit ovat ui ja vi.

Esimerkkejä

  • Funktio f(x)=ax2+bx+c, kun a>0, saavuttaa miniminsä pisteessä b2a.
  • Funktiolla f(x)=x, kun x, ei ole minimipistettä, sillä jokaista pistettä x kohden on aina olemassa pienempi piste y<x.
  • Funktiolla f(x)=(x+1)2(x1)2on kaksi nollakohtaa x1=1 ja x1=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 x0, niin optimi on yksikäsitteinen.

Kirjallisuutta