Bilineaarinen interpolaatio

testwikistä
Siirry navigaatioon Siirry hakuun
Kuvassa on yksikköneliön sisälle interpoloitu bilineaarisella menetelmällä neliön nurkissa olevat arvot (meritty z:lla). Arvot on väritetty sateenkaaren eli spektrin väreillä siten, että sininen on nolla ja punainen on yksi. Spektrin värit "nousevat" siten sininen, syaani, vihreä, keltainen, oranssi ja punainen.

Bilineaarinen interpolaatio on matematiikassa approksimaatiomenetelmä, joka on lineaarisen interpolaatiomenetelmän kaksiulotteinen laajennus. Siinä tasoalueen pisteiden arvoja lasketaan lähimpien pisteiden arvojen avulla sovittamalla kahdessa suunnassa lineaarisia polynomeja eli interpolaatiosuoria. Koska lineaarisia sovituksia on kaksi, kutsutaan menetelmää bilineaariseksi. Yleisessä käytössä on ollut kaksi menetelmää, joista toinen hyödyntää kolme ja toinen neljä näytepistettä. Interpoloinnin seurauksena syntyy silloin joko lineaarisia- tai kvadraattisia pintoja. Näitä pintoja kutsutaan interpolanteiksi tai interpolaatiopinnoiksi.[1][2][3]

Tasoalueella satunnaisesti sijaitsevat pisteet voidaan aina yhdistää toisiinsa kolmioiksi, jotka sivuavat toisensa tiiviisti. Kolmion sisällä tapahtuva bilineaarinen interpolaatio on siksi aina mahdollista toteuttaa yksinkertaisella tavalla. Satunnaisia tason pisteitä ei aina ole helppo yhdistää nelikulmioiksi, jotka olisivat aina konvekseja. Bilineaarinen interpolaatiomenetelmässä nelikulmion vastakkaisten sivujen väliset suorat tulisi leikata toisensa nelikulmion sisällä, mikä ei aina onnistu ei-konveksissa nelikulmiossa. Neljän pisteen bilineaarinen interpolaatio totetutetaankin yleensä pisteille, jotka sijaitsevat suorakulmion kärjissä. Silloin näytepisteet on otettu hilamaisen verkon solmukohdissa.[1]

Aiemmin bilineaarista interpolaatiota käytettiin kartografiassa, luonnontieteellisessä tutkimuksessa ja numeerisessa matematiikassa. Nykyään yleisimpiä sovelluskohteita ovat sekä digitaalisten valokuvien kuvankäsittely, tietokonepelien hahmojen käsittely ja elokuva-alan tehosteet. Nykyään nelikulmiossa totetutetut bilineaariset interpolaatiot ovat suoritetuista algoritmeista yleisimpiä, koska esimerkiksi monet kuvankäsittelyohjelmat hallitsevat bilineaarisen kuvankäsittelyn.[1][4]

Lineaarinen interpolaatio janalla

Alkuun voidaan esitellä lyhyesti yksiulotteisen lineaarisen interpolaation lausekkeet. Ensin muodostetaan interpolaatio lyhyellä välillä [0,1], jonka päätepisteissä funktio saa arvokseen f(0)=f1 ja f(1)=f2. Silloin välin sisäpisteiden arvoksi saadaan

f(x)a0+a1x=f1+(f2f1)x. [4]

Kun interpolaatio viedään toiseen väliin [x1,x2], missä f(x1)=f1 ja f(x2)=f2, saadaan sisäpisteen arvoksi

f(x)a0+a1x=(f1x2f2x1)+f2f1x2x1x. [5]

Bilineaarinen interpolaatio kolmiossa

Vaikka kolmella näytepisteellä toteutettu lineaarinen interpolaatio jää suosiossa neljän pisteen menetelmälle, on sillä vielä etulyöntiasema tietyissä tilanteissa. Jokainen pinta, esimerkiksi tasot, pallopinnat tai aaltoilevat pinnat, voidaan miehittää epäsäännöllisellä näytepopulaatiolla. Tällaisellä pistejoukolla voidaan aina muodostaa kolmioita, jotka peittävät pinnan tarkasti ja joilla voidaan suorittaa bilineaarinen interpolaatio kaikille tason pisteille.

Kolmiomenetelmässä valitaan kaksi sivua, joihin merkitään kumpaankin yksi sisäpiste. Sisäpisteiden arvot lasketaan lineaarisella interpolaatiolla, jossa hyödynnetään sivujensa päätepisteiden arvoja. Toisessa vaiheessa yhdistetään sivujen sisäpisteet suoralla, jonka pisteet lasketaan lineaarisella interpolaatiolla edellisessä vaiheessa laskettujen arvojen avulla. Kolmion sisäpisteen arvo selviää kolmella interpolaatiolla.[1]

Yksikkökolmiossa: bilineaarisesti

Edellinen laskentamenetelmä ei sovellu tilanteisiin, jossa on tilattu bilineaarinen interpolaatio tiettyyn kolmion sisäpisteeseen. Siinä on ongelmana määrittää sivujen pisteet, jotta niiden lineaarinen interpolaatio voidaan suorittaa. Edullinen lähestymistapa on suorittaa kolmiolle affiinimuunnos suorakulmaiselle tasakylkiselle kolmiolle, jonka sivut ovat origon vieressä sijaitsevan yksikköneliön [0, 1]×[0, 1] sivuilla. Tätä kolmiota kututaan tässä yksikkökolmioksi ja sen kärkien koordinaatit ovat (0, 0), (1, 0) ja (0, 1).

Yksikkökolmion sisäpisteen (xy) interpoloitua arvoa merkitään tässä f(xy). Merkitään kolmion kärkien tunnetut funktion arvot f(0, 0) = f00,f(0, 1) = f01 ja f(1, 0) = f10. Kohtisuorilla sivuilla suoritetut lineaarit interpoloinnit tuottavat arvot f(a, 0) = fa0 ja f(0, b) = f0b seuraavasti

fa0f00+(f10f00)a
f0bf00+(f01f00)b

Kun interpoloidaan haluttua pistettä f(xy) = fxy, kannattaa interpolointiin valita kolmion hypotenuusan suuntainen suora, koska sen päätepisteet ovat yhtä etäällä origosta. Mainittu etäisyys pisteen (xy) interpoloimiseksi on a = b = x + y. Edelliset tulokset kirjoitetaan silloin

f(x+y)0f00+(f10f00)(x+y)
f0(x+y)f00+(f01f00)(x+y).

Koska pisteen (xy) etäisyys päätepisteestään hypotenuusan suuntaisella suoralla on verrannollinen koordinaatin x ja matkan x + y suhteeseen, voidaan haluttu interpolaatio kirjoittaa (pisteestä (0, x + y) lukien)

fxy=f(x,y)f0(x+y)+(f(x+y)0f0(x+y))xx+y.

Yksikkökolmiossa: tasopinnan sovitys

Vaikka pinnansovitus ei ole billineaarista interpolointia, voidaan asiaa sivuta myös tässä. Menetelmän tuottaman pinnan laatu selviää, kun sieventää edellisen laskelman viimeinen lauseke:

fxy=f(x,y)f00+(f10f00)x+(f01f00)y.

Interpolaatiopisteet muodostavat (lausekkeen muodon mukaisesti) tason, jossa kolmion sisäpisteen arvo saadaan yhtälöstä

f(x,y)a00+a10x+a01y, [4]

missä vakiot ovat

a00=f00,
a10=f10f00 ja
a01=f01f00.

Bilineaarinen interpolaatio nelikulmiossa

Pisteen P (vihreä) interpolointi, kun tunnetaan arvot suorakulmion kulmissa (punainen). Pisteet R1 ja R2 (sininen) ovat ensimmäiset apupisteet, joidan arvo interpoloidaan ensimmäiseksi.

Tässä esitettävä menetelmä perustuu suorakulmioon, koska sen avulla on helppo demostroida suorakulmaisessa koordinaatistossa menetelmän perusperiaatteet. Sillä ratkeaa myös suorakulmioista affiinikuvauksella muodostettavien muiden nelikulmioiden bilineaariset interpolaatiot. Affiinikuvauksia ei käsitellä tässä.

Yksikköneliössä: bilineaarisesti

Interpoloidan bilineaarisesti origosta alkavan yksikköneliön, eli alueen [0, 1]×[0, 1], sisäpisteen (xy) arvo f(xy). Merkitään neliön kärjissä sijaitsevat funktion arvot f(0, 0) = f00,f(0, 1) = f01, f(1, 0) = f10 ja f(1, 1) = f11. Vaakasuorilla sivuilla suoritetut lineaarit interpoloinnit tuottavat arvot f(x, 0) = fx0 ja f(x, 1) = fx1 seuraavasti

fx0f00+(f10f00)x,
fx1f01+(f11f01)x.

Kun interpoloidaan pystysuoraan f(xy) = fxy, saadaan

fxy=f(x,y)fx0+(fx1fx0)y.

Suorakulmiossa: bilineaarisesti

Valitaan suorakulmiosta yksi sivu ja sivulta piste. Lasketaan tämän pisteen arvo lineaarisella interpolaatiolla sivunsa päätepisteiden avulla. Piirretään sivun pisteestä normaali suorakulmion vastakkaiselle sivulle. Normaalin leikkauspiste vastakkaisen sivun kanssa on seuraavan interpolaation kohde. Se suoritetaan vastakkaista sivua pitkin. Kun molempien pisteiden interpoloidut arvot tunnetaan, voidaan pisteiden väliset suorakulmion sisäpisteet interpoloida lineaarisesti.[1]

Interpoloidaan bilineaarisesti pisteessä (x, y) olevaa arvoa suorakulmion kärjissä (viereinen kuva) Q11 = (x1y1), Q12 = (x1y2), Q21 = (x2y1), and Q22 = (x2y2) olevien arvojen f(x1, y1) = f11, f(x1, y2) = f12, f(x2, y1) = f21 ja f(x2, y2) = f22 avulla (viereinen kuva).

Aluksi interpoloidaan lineaarisesti x-akselin suuntaan. Kohdassa x, ylä- ja alasivulla, sijaitsevat pisteet R1 = (x, y1) ja R2 = (x, y2). Näihin pisteisiin interpoloidaan arvot f(x,  y1) = fx1 ja f(x,  y2) = fx2

fx1=f(x,y1)x2xx2x1f11+xx1x2x1f21fx2=f(x,y2)x2xx2x1f12+xx1x2x1f22

Viimeisessä vaiheessa interpoloidaan lineaarisesti pisteen P = (xy) arvo f(x, y)

f(x,y)y2yy2y1f(x,y1)+yy1y2y1f(x,y2)y2yy2y1(x2xx2x1f11+xx1x2x1f21)+yy1y2y1(x2xx2x1f12+xx1x2x1f22)=1(x2x1)(y2y1)(f11(x2x)(y2y)+f21(xx1)(y2y)+f12(x2x)(yy1)+f22(xx1)(yy1))

Yksikköneliössä: pinnansovitus

Nelikulmaisessa bilineaarisessa interpoloinnissa syntyy pinta, jonka laatu selviää sieventämällä edellisiä lausekkeita. Nisstä saadaan

fxy=f(x,y)f00+(f10f00)x+(f01f00)y+(f11f01f10+f00)xy.

Tämä yhtälö voidaan kirjoittaa kompaktiin muotoon sijoittamalla muuttujien eteen vain kertoimet

f(x,y)a00+a10x+a01y+a11xy, [4]

missä kertoimet ovat

a00=f00 ja
a10=f10f00 ja
a01=f01f00 ja
a11=f11f01f10+f00.

Muodostunutta pintaa kutsutaan hyperboliseksi paraboloidiksi, mikä se yleisesti onkin. Joskus funktion arvot ovat sellaiset, että pinta onkin taso.

Suorakulmiossa: pinnansovitus

Vaikka pinnansovitus ei ole bilineaarinen interpolaatio, esitetään vaihtoehtoisena ratkaisutapana samassa yhteydessä. Kun valitaan tasolta mitkä tahansa neljä kulmapistettä (x1,y1),(x2,y1),(x1,y2) ja (x2,y2), voidaan niiden kautta sovittaa kulkemaan tasopinta

f(x,y)=ax+by+cxy+d.

Tasopinnan lausekkeen kertoimet voidaan määrittää ratkaisemalla yhtälöryhmä, jossa lausekkeeseen on sijoitettu koordinaatit ja jossa funktion arvoiksi merkitään kulmapisteiden funktion arvot. Yhtälöryhmä on tällöin

{f(x1,y1)=ax1+by1+cx1y1+df(x2,y1)=ax2+by1+cx2y1+df(x1,y2)=ax1+by2+cx1y2+df(x2,y2)=ax2+by2+cx2y2+d

Sovellus: Digitaalisen valokuvan käsittely

Digitaalista valokuvaa pienennettäessä voidaan neliön vierekkäiset neljä kuvapikseliä kutistaa yhdeksi pikseliksi bilineaarisella interpolaatiolla. Pikselien numeeriset arvot interpoloidaan yhdeksi numeeriseksi arvoksi, joka sijoitetaan kopiokuvaan vastaavalle paikalle pienennöksessä. Valokuvia suurennettaessa osa pikseleistä kopioidaan alkuperäisestä valokuvasta ja osa pikseleistä luodaan tyhjinä. Tyhjät pikselit täytetään interpoloimalla viereisiä pikseleitä bilineaarisesti. Samalla voidaan interpoloida kopioituja pikseleitä uudelleen sahalaitaisuuden välttämiseksi.[6][7]

Katso myös

Lähteet

Malline:Viitteet

  1. 1,0 1,1 1,2 1,3 1,4 Viittausvirhe: Virheellinen <ref>-elementti; viitettä dj ei löytynyt
  2. Viittausvirhe: Virheellinen <ref>-elementti; viitettä Interpolant ei löytynyt
  3. Viittausvirhe: Virheellinen <ref>-elementti; viitettä Interpolation ei löytynyt
  4. 4,0 4,1 4,2 4,3 Viittausvirhe: Virheellinen <ref>-elementti; viitettä kddmsd ei löytynyt
  5. Viittausvirhe: Virheellinen <ref>-elementti; viitettä hi ei löytynyt
  6. Viittausvirhe: Virheellinen <ref>-elementti; viitettä uipt ei löytynyt
  7. Viittausvirhe: Virheellinen <ref>-elementti; viitettä CiC ei löytynyt