Interpolacija
Ovaj članak ili neki od njegovih odlomaka nije dovoljno potkrijepljen izvorima (literatura, veb-sajtovi ili drugi izvori). |
U matematičkoj podoblasti numerička analiza, interpolacija je metod konstruisanja novih tački na grafikonu unutar ranga diskretnog skupa poznatih tačaka na grafikonu.
U inženjerstvu i nauci, barata se mnoštvom brojeva i tačaka na grafikonima, koje su dobijene uzorkovanjem ili eksperimentisanjem, te se nastoji konstruisati funkcija koja približno pristaje svim tačkama na grafikonu. Ovo se naziva prilagođavanje krive ili regresiona analiza. Interpolacija je poseban slučaj prilagođavanja krive, u kojem funkcija mora tačno proći kroz zadane tačke na grafikonu.
Drugačiji problem, koji je usko vezan za interpolaciju, je aproksimacija komplikovane funkcije preko jednostavnije funkcije. Pretpostavimo da poznajemo funkciju, ali da je ona previše kompleksna kako bi je efikasno izračunali. Tada možemo izabrati nekoliko poznatih tačaka iz komplikovane funkcije, praveći preglednu tablicu, te pokušavamo interpolisati te tačke kako bi konstruisali jednostavniju funkciju. Naravno, kada koristimo jednostavniju funkciju kako bi izračunali nove tačke na grafikonu, obično ne dobijamo isti rezultat kao što bi dobili kod originalne funkcije, ali u zavisnosti od domena problema i metoda interpolacije kojeg smo koristili, dobijena jednostavnost može nadoknaditi grešku.
Potrebno je spomenuti da postoji i druga veoma različita vrsta interpolacije u matematici, naziva "interpolacija operatora". Kao klasične rezultate u interpolaciji operatora imamo Riesz-Thorinov teorem i Marcinkiewiczov teorem. Postoje i neki drugi rezultati, koje sada nećemo spominjati.
Definicjja
urediI riječi 'interpolacija, inter znači "između", a polacija (pol) znači taćka ili čvor. Bilo koje sredstvo izračunavanja nove tačke između dvije ili više već postojećih tačaka, naziva se interpolacija.
Postoji mnogo načina d a se to uradi, od kojih mnogi uključuju prilagođavanje neke vrste funkcije zadanim podacima i izračunavanje te funkcije u željenoj tački. Ovo ne isključuje druga sredstva, kao što su statističke metode izračunavanja interpolisanih podataka.
Jedan od najjednostavnijih oblika interpolacije je uzimanje aritmetičke sredine vrijednosti dvije susjedne tačke, kako bi našli vrijednost tačke između njih. Ovo daje isti rezultat kao i linerna funkcija izračunata u sredini te dvije zadane tačke.
Za dati niz n različitih brojeva xk, koji se nazivaju čvorovi i za svaki xk drugi broj yk, tražimo funkciju f tako da je
Par xk,yk naziva se tačka na grafikonu, a f se naziva interpolant za te tačke na grafikonu.
Kada su brojevi yk dati preko poznate funkcije f, ponekad to pišemo kao fk.
Primjer
urediNa primjer, pretpostavimo da imamo slijedeću tabelu, koja daje neke vrijednosti funkcije f.
x | f(x) | ||||
---|---|---|---|---|---|
0 | 0 | ||||
1 | 0 | , | 8415 | ||
2 | 0 | , | 9093 | ||
3 | 0 | , | 1411 | ||
4 | −0 | , | 7568 | ||
5 | −0 | , | 9589 | ||
6 | −0 | , | 2794 |
Interpolacija nam daje mogućnost da procijenimo vrijednost funkcije u nekim srednjim tačkmama, kao što je x = 2,5.
Postoji mnogo različitih metoda interpolacije, od kojih su neke opisane u tekstu ispod. Treba voditi računa, kada birate najprikladniji algoritam, na slijedeće: Kako je metod tačan? Koliko je težak? Koliko je gladak interpolant? Koliko je potrebno tačaka na grafikonu?
Interpolacija izlomljene konstante
urediNajjednostavniji metod interpolacije da da se locira najbliža tačka na grafikonu, te da joj se pridruži neka vrijednost. U jednoj dimenziji, rijetko postoje dobri razlozi da se koristi ovaj tip nad linearnom interpolacijom, koja je skoro uvijek jednoako teška, ali u više dimenzija, kod multivarijatne interpolacije, interpolacija izlomljene konstantethis može imati prednost zbog svoje brzine i jednostavnosti.
Linearna interpolacija
urediJedan od najjednostavnijih metoda je linearna interpolacija. Razmotrimo gornji primjer pronalaženja vrijednosi f(2,5). Pošto je 2,5 srednja vrijednost između 2 i 3, opravdano, za vrijednost f(2,5), možemo uzeti srednju vrijednost između f(2) = 0,9093 i f(3) = 0,1411, iz čega dobijamo vrijednost 0,5252.
Općenito, linearna interpolacija uzima dvije tačke na grafikonu, recimo (xa,ya) i (xb,yb), a interpolant je dat kao:
- u tački (x,y).
Linearna interpolacija je brza i lagana, ali nije precizna. Još jedna nepovoljnost je ta što interpolant nije diferencijabilan u tački xk.
Slijedeća procjena greške pokazuje da linerana interpolacija nije preciznat. Označimo funkciju koju želimo interpolisati sa g, te pretpostavimo da x leži između xa i xb i da je g dva puta neprekidno diferencijabilna. Tada greška pri linearnoj interpolaciji iznosi
Riječima, greška je proporcionalna kvadratu udaljenosti između tačaka na grafikonu. Greška kod nekih drugih metoda, uključujući polinomsku i splajn interpolaciju (opisane u tekstu ispod), je proporcionalna višim stepenima udaljenosti između tačaka na grafikonu. Ovi metodi, također, daje "glađe" interpolante.
Polinomska interpolacija
urediPolinomska interpolacija je generalizacija linearne interpolacije. Prethodno smo vidjeli da je linerani interpolant linearna funkcija. U ovom slučaju, zamijenimo taj interpolant sa polinomom višeg stepena.
Razmotrimo ponovo prethodni problem. Slijedeći polinom šestog stepena prolazi kroz svih sedam tačaka:
Zamjenom x = 2,5, dobijamo da je f(2,5) = 0,5965.
Općenito, ako imamo n tačaka na grafikonu, postoji tačno jedan polinom najvišeg stepna n−1 koji prolazi kroz sve tačke na grafikonu. Interpolacijska greška proporcionalna je udaljenosti između tačaka na stepen od n. Dalje, interpolant je polinom, te je zbog toga beskonačno puta diferencijabilan. Tako vidimo da polinomska interplacija rješava sve probleme linearne interpolacije.
Međutim, polinomska interpolacija, također, ima i nedostatke. Izračunavanje interpolacionog polinoma prilično je teško (pogledajte teorija kompleksnosti izračunavanja) u poređenju sa linearnom interpolacijom. Dalje, polinomska interpolacija i nije tako tačna, posebno na krajnjim tačkama (pogledajte Rungeov fenomen). Ovi nedostaci mogu se izbjeći korištenjem splajn interpolacije.
Splajn interpolacija
urediZapamtite da linearna interpolacija koristi linearne funkcije za svaki od intervala [xk,xk+1]. Splajn interpolacija koristi polinome nižeg stepena u svakom od intervala, te bira dijelove polinoma tako da je oni međusobno glatko uklapaju. Rezultirajuća funkcija naziva se splajn.
Na primjer, prirodni kubni splajn je izlomljena kubna funkcija koja je dva puta neprekidno diferencijabilna. Dalje, njena druga derivacija je nula u krajnjim tačkama. Prirodni kubni splajn koji interpoliše tačke u tabeli ispod dat je sa
U ovom slučaju dobijamo f(2,5)=0,5972.
Kao i polinomna interpolacija, splin interpolacija izaziva manju grešku od linearne interpolacije i interpolant je glađa. Međutim, interpolant je lakše procijeniti nego polinome visokog stupnja koji se koriste u polinomnoj interpolaciji. Interpolant također ne pati od Rungeovog fenomena.
Interpolacija preko Gaussovih procesa
urediGaussov proces je moćan alat za nelinearnu interpolaciju. Mnogi popularni interpolacijski alati su zapravo ekvivalentni određenim Gausovim procesima. Gausovi procesi se mogu koristiti ne samo za postavljanje interpolanta koji prolazi upravo kroz date tačke podataka, već i za regresiju, tj. za uklapanje krivulje kroz mnogobrojne podatke. U geostatističkoj zajednici Gaussova regresija procesa je poznata i pod nazivom Kriging.
Ostali oblici interpolacije
urediOstali oblici interpolacije mogu se konstruisati odabirom različite klase interpolanata. Naprimjer, racionalna interpolacija je interpolacija pomoću racionalne funkcije s, a trigonometrijska interpolacija je interpolacija pomoću trigonometrijskog polinoma s. Diskretna Fourierova transformacija je poseban slučaj trigonometrijske interpolacije. Druga mogućnost je da se koriste wavelet.
Whittaker-Shannonova formula za interpolaciju može se koristiti ako je broj točaka podataka beskonačan. Višerazmjerna interpolacija je interpolacija funkcije više promjenljivih. Metode uključuju dvolinearnu interpolaciju i dvokubičnu interpolaciju u dvije dimenzije, i trilinearnu interpolaciju u tri dimenzije. Ponekad ne znamo samo vrijednost funkcije koju želimo da interpoliramo u nekim tačkama, već i njen derivat. To dovodi do Hermitove interpolacije problema.
Slični koncepti
urediNaziv ekstrapolacija se koristi ako želimo pronaći dodatne tačke na grafikonu izvan okvira poznatih tačaka na tom grafikonu. U promjemima prilagođavanja krive, ograničenje da interpolant mora proći tačno kroz tačke na grafikonu je ublaženo. Jedini zahtijev je da se tim tačkama priđe što je bliže moguće. To zahtijeva parametrizaciju potencijalnih interpolanata, te postojanja sredstva za mjerenje greške koju pri tome pravimo. U najjednostavnijem slučaju, to vodi do aproksimacije najmanjeg kvadrata.
Teorija aproksimacije proučava kako pronaći najbolju aproksimaciju za datu funkciju preko druge funkcije iz predodređene klase, te koliko je valjana ta aproksimacija. Iz ovoga dobijamo granicu kako dobro interpolant može aproksimovati nepoznatu funkciju.
Reference
uredi- David Kidner, Mark Dorey and Derek Smith (1999). What's the point? Interpolation and extrapolation with a regular grid DEM. IV International Conference on GeoComputation, Fredericksburg, VA, USA.
- Kincaid, David (2002). Numerical Analysis (3rd edition). Brooks/Cole. ISBN 0-534-38905-8. Nepoznati parametar
|coauthors=
zanemaren (prijedlog zamjene:|author=
) (pomoć) Chapter 6. - Schatzman, Michelle (2002). Numerical Analysis: A Mathematical Introduction. Clarendon Press, Oxford. ISBN 0-19-850279-6. Chapters 4 and 6.
Vanjski linkovi
uredi- GaussianProcesses.com: Teorija i primjene Gaussovog procesa
- DotPlacer applet : Animacija koja pokazuje razne metode ainterpolacije