Interpoleerimine
Interpoleerimine ehk interpolatsioon on arvutusmatemaatikas kasutatav meetod funktsiooni vahepealsete väärtuste hindamiseks ette antud diskreetsete väärtuste alusel.[1]
Inseneerias ja praktilistes teadustes kirjeldatakse süsteeme diskreetsete funktsioonide ja tabelitega, mis on saadud katsetulemuste põhjal.[2] Erinevalt pidevatest funktsioonidest ei kirjelda aga diskreetsed funktsioonid kõiki võimalikke muutujate väärtusi ning tihti on vaja kahe diskreetse punkti vahele jäävat väärtust hinnata interpolatsiooni teel.
Vahel kasutatakse interpolatsiooni ka keeruliste funktsioonide lihtsustamiseks, et vähendada arvutustele kuluvat aega ja ressursse.[3] Sellisel juhul tuleb hinnata, kas lihtsustamisest saadav arvutusressursside kokkuhoid kaalub üles interpolatsioonist tekkiva vea.
Interpolatsioonimeetodid
muudaLihtsaim viis interpolatsiooni idee kirjeldamiseks on teha seda näite varal. Seetõttu genereerime diskreetsete punktide kogumi:
0 | 0 | ||||
1 | 0 | . | 8415 | ||
2 | 0 | . | 9093 | ||
3 | 0 | . | 1411 | ||
4 | −0 | . | 7568 | ||
5 | −0 | . | 9589 | ||
6 | −0 | . | 2794 |
Lähima naabri interpolatsioon
muudaLihtsaimaks interpoleerimise viisiks on lähima andmepunkti väärtuse valimine.[4]
Üldjuhul eelistatakse sellele meetodile lineaarset interpolatsiooni, sest lihtsates süsteemides on tolle rakendamine sama raskusastmega ning tunduvalt täpsem, kuid mitme muutujaga funktsioonides võib osutuda lähima naabri interpolatsioon kasulikuks oma lihtsuse ja kiiruse tõttu.
Lähima naabri interpolatsioon leiab kõige rohkem kasutust pilditöötluses.
Lineaarne interpolatsioon
muudaLineaarse interpoleerimise meetodi kasutamisel lähendatakse kahe andmepunkti vaheline funktsioon sirgega ning arvutatakse interpolant kasutades nende punktide koordinaate (x0,y0) ja (x1,y1)[3]:
Lineaarne interpoleerimine on kiire ja lihtne, kuid tihtipeale ei ole interpoleeritavate funktsioonide puhul tegemist lineaarsete sõltuvustega. See tähendab, et lineaarne interpolatsioon üle suurte vahekauguste ei pruugi olla piisavalt täpne.
Nii konstrueeritud interpolandid ei ole diferentseeritavad nende üleminekukohtades.
Polünoomne interpolatsioon
muudaPolünoomse interpolatsiooni puhul võetakse arvesse kõiki teadaolevaid n andmepunkti ning tuletatakse nende alusel n-1 astme polünoom, mis neid kõiki läbib. Tuleb välja, et see polünoom on üheselt määratud.[1] Sellisel viisil koostatud pidev funktsioon on igas oma punktis diferentseeritav ning on tõenäolisem, et saadav tulemus on täpsem.
Antud juhul saaksime interpolandiks kuuenda astme polünoomi kujul:
Polünoomse interpolatsiooni suurimaks miinuseks on selle suur arvutuslik keerukus. Lisaks on täheldatud polünoomse interpolatsiooni puhul Runge fenomeni kus kõrgemate astmete polünoomid kalduvad võnkuma[2] ning tekitavad lainelisi artefakte.
Kuigi polünoom on diferentseeritav ning seetõttu saame me hinnata funktsiooni lokaalseid miinimume ja maksimume võivad need väärtused väljuda süsteemi teoreetilisest muutumispiirkonnast, mis võib omakorda tekitada probleeme väärtuste edasisel kasutamisel.
Lisaks kõigele eelmainitule ei pruugi polünoomse interpolatsiooni kasutamisel kahe punkti vahelise kõvera kuju kokku sobida katsete käigus tuletatud teadmistega süsteemi omadustest. See käitumine on omakorda võimendatud Runge fenomeni poolt funktsiooni otspunktides.
Seda käitumist on püütakse leevendada kasutades n-1 järku polünoomide asemel Splain-interpolatsiooni või Tšebõševi polünoome.
Splain-interpolatsioon
muudaSplain-interpolatsiooni puhul rakendatakse madalama astme polünoome igas vahemikus eraldi. Mida kõrgem on splaini sileduaste seda rohkem on võimalik vahemikku valitud polünoomi diferentseerida.[1]
Praktikas on väga levinud kuupslainid siledusastmega 2.[1] See tähendab, et vahemikesse on valitud kuuppolünoomid, mida on võimalik diferentseerida vähemalt kaks korda. Antud juhul oleks näitefunktsiooni splain-interpolant järgmine:
Sarnaselt polünoomse interpolatsiooniga on splain-interpolandi kuju palju loomulikum ja täpsem. Samas on madalama astme polünoome kergem kasutada arvutustes ning olenevalt polünoomide keerukusest on väiksem tõenäosus Runge fenomeni esinemiseks.
Interpolatsioon signaalitöötluses
muudaDigitaalses signaalitöötluses teostatakse interpolatsiooni üldiselt signaali diskreetimissageduse tõstmiseks kasutades erinevaid filtreid ja konvolutsiooni.
Igapäevaelus on võimalik interpolatsiooniga kokku puutuda piltide skaleerimisel, kus vahepealsete tundmatute pikslite värviväärtused arvutatakse naabruses olevate pikslite väärtuste põhjal.
Viited
muuda- ↑ 1,0 1,1 1,2 1,3 Janno, Jaan. "Interpoleerimine" (PDF). Vaadatud 18.04.2022.
- ↑ 2,0 2,1 Kiisk, Valter. "Interpoleerimine". kodu.ut.ee. Vaadatud 18.04.2022.
- ↑ 3,0 3,1 Käerdi, Helmo (2006). Arvutusmeetodid (2. trükk). Lk 7-8.
- ↑ "I – Nearest Neighbour Interpolation". Vaadatud 08.05.2022.