Bilineaarinen interpolaatio

Wikipediasta
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[muokkaa | muokkaa wikitekstiä]

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

[4]

Kun interpolaatio viedään toiseen väliin , missä ja , saadaan sisäpisteen arvoksi

[5]

Bilineaarinen interpolaatio kolmiossa[muokkaa | muokkaa wikitekstiä]

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[muokkaa | muokkaa wikitekstiä]

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

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

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)

Yksikkökolmiossa: tasopinnan sovitys[muokkaa | muokkaa wikitekstiä]

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:

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

[4]

missä vakiot ovat

,
ja

Bilineaarinen interpolaatio nelikulmiossa[muokkaa | muokkaa wikitekstiä]

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[muokkaa | muokkaa wikitekstiä]

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

Kun interpoloidaan pystysuoraan f(xy) = fxy, saadaan

Suorakulmiossa: bilineaarisesti[muokkaa | muokkaa wikitekstiä]

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

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

Yksikköneliössä: pinnansovitus[muokkaa | muokkaa wikitekstiä]

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

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

[4]

missä kertoimet ovat

ja
ja
ja

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

Suorakulmiossa: pinnansovitus[muokkaa | muokkaa wikitekstiä]

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

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

Sovellus: Digitaalisen valokuvan käsittely[muokkaa | muokkaa wikitekstiä]

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[muokkaa | muokkaa wikitekstiä]

Lähteet[muokkaa | muokkaa wikitekstiä]

  1. a b c d e Jacobs, David W.: Interpolation, Marylandin yliopisto, USA
  2. Stover, Christopher: Interpolant (Math World – A Wolfram Web Resource) Wolfram Research. (englanniksi)
  3. Weisstein, Eric W.: Interpolation (Math World – A Wolfram Web Resource) Wolfram Research. (englanniksi)
  4. a b c d Kidner, David, Dorey, Mark & Smith, Derek: What's the point? Interpolation and extrapolation with a regular grid DEM (Arkistoitu – Internet Archive), Glamorganin yliopisto, Wales, Englanti, 1999 (englanniksi)
  5. Hemmo-Iivonen, Katariina et al.: Pyramidi 12 – Numeerisia ja algebrallisia menetelmiä. (lukion pitkä matematiikka). Helsinki: Tammi. ISBN 978-951-26-5406-2.
  6. VisionSystems: "Understanding image-interpolation techniques"[vanhentunut linkki], 2007
  7. Cambridge in Color: Digital Image Interpolation