• Nie Znaleziono Wyników

Interpolacja funkcjami sklejanymi poprzez wyznaczenie wartości drugich pochodnych w węzłach.

N/A
N/A
Protected

Academic year: 2021

Share "Interpolacja funkcjami sklejanymi poprzez wyznaczenie wartości drugich pochodnych w węzłach."

Copied!
4
0
0

Pełen tekst

(1)

Interpolacja funkcjami sklejanymi poprzez wyznaczenie wartości drugich pochodnych w węzłach.

Tomasz Chwiej 19 kwietnia 2020

Naszym zadaniem będzie napisanie programu do interpolacji przy pomocy funkcji sklejanych będących wielomianami 3 stopnia poprzez wyznaczenie wartości drugich pochodnych w węzłach.

1 Wstęp

Aby rozwiązać problem, należy rozwiązać układ równań liniowych (szczegóły na wykładzie)

A ⃗m = ⃗d (1)

którego generatorem jest:

µimi−1+ 2mi+ λimi+1= di (2) gdzie: mito poszukiwane wartości drugich pochodnych w węzłach (indeksowanychi = 0, 1, . . . , n− 1).

Pozostałe oznaczenia to:

λi = hi+1

hi+ hi+1, µi = 1− λi (3)

elementy wektora wyrazów wolnych

di = 6 hi+ hi+1

(yi+1− yi

hi+1 yi− yi−1

hi

)

(4)

oraz położenia węzłów: x1, x2, . . . , xn i odległości międzywęzłowe

hi = xi− xi−1 (5)

W projekcie mamy narzucone warunki na drugie pochodne na brzegach, czyli:

m0 = α, mn−1 = β (6)

Po wprowadzeniu warunków brzegowych do układu równań (wykład), przyjmuje on postać:

1 0 0 · · · · 0 µ1 2 λ1 · · · · 0 0 µ2 2 λ2 · · · 0 ... . .. ... ... ... 0 · · · µn−2 2 λn−2

0 · · · · 0 0 1

m0 m1 ... ... mn−2 mn−1

=

α d1 ... ... dn−2

β

(7)

1

(2)

Po jego rozwiązaniu wartość funkcji interpolującej dla x ∈ [xi−1, xi] (numer podprzedziału:

i− 1) wyznaczamy według poniższego przepisu:

si−1(x) = mi−1(xi − x)3

6hi + mi(x− xi−1)3

6hi + Ai(x− xi−1) + Bi (8) gdzie stałe całkowania mają postać:

Ai = yi− yi−1

hi −hi

6(mi− mi−1) (9)

Bi = yi−1− mi−1h2i

6 (10)

2 Zadania do wykonania

1. Napisać procedurę do wyznaczania wartości drugich pochodnych w węzłach. Do procedury należy przekazać: a) wektor z położeniami węzłów xw, b) wektor z wartościami funkcji yw, c) liczbę węzłów n, d) wektor do którego procedura zapisze wartości drugich pochodnych m, e) wartości drugich pochodnych w skrajnych węzłach (alfa i beta)

v o i d wyznacz M ( d o u b l e ∗xw, d o u b l e ∗yw, d o u b l e ∗m , i n t n , d o u b l e alf a , d o u b l e beta )

Uwaga: Węzły indeksujemy od 0 do n-1. Do rozwiązania układu równań można wykorzy- stać procedurę rozkładu LU z biblioteki GSL.

2. Napisać procedurę do wyznaczania wartości funkcji w położeniu międzywęzłowym. Część argumentów będzie identyczna jak dla procedury wyznacz M , ale dodajemy jeszcze ak- tualną wartość argumentu x [zgodnie z wzorem (8)]:

d o u b l e wyznacz Sx ( d o u b l e ∗xw, d o u b l e ∗yw, d o u b l e ∗m , i n t n , double x){

z n a j d z p i e r w s z y p o d p r z e d z i a ł ( i−1): xw[i− 1] <= x <= xw[i]

Sx=wzór ( 8 ) r e t u r n Sx ; }

3. Utworzyć wektor zawierający położenia n równoodległych wezłów i wektor odpowiada- jących im wartości funkcji. Położenia węzłów można wygenerować zgodnie z poniższym wzorem

xw[i] = xmin+ ∆x· i, i = 0, 1, . . . n− 1, ∆x = xmax− xmin

n− 1 (11)

gdzie: xmin to lewy kraniec przedziału interpolacji a xmax to prawy kraniec.

4. Napisać program do interpolacji funkcjami sklejanymi, który będzie korzystał z dwóch powyższych procedur. Przy użyciu swojego programu przeprowadzić interpolację funkcji

f1(x) = 1

1 + x2 (12)

oraz

f2(x) = cos(2x) (13)

(3)

Przyjąć warunki z drugą pochodną równą 0 na obu krańcach przedziału interpolacji

α = β = 0 (14)

Wykonać interpolację dla f1(x) oraz f2(x) w przedziale x ∈ [−5, 5], dla liczby węzłów:

n = 5, 8, 21. Sporządzić wykresy funkcji interpolowanej [f (x)] i interpolującej [s(x)] dla każdego przypadku na jednym rysunku (będzie 6 rysunków).

5. Dla funkcji f1(x) oraz n = 10 węzłów w przedziale x∈ [−5, 5] należy wyznaczyć wartości drugich pochodnych i porównać je z ”dokładniejszymi” wartościami liczonymi zgodnie z wzorem:

d2f

dx2 f (x− δx) − 2f(x) + f(x + δx)

(δx)2 (15)

Przyjąć δx = 0.01. Wykonać wykres wartości drugich pochodnych w zależności od poło- żenia węzłów pokazujący porównanie obu sposobów obliczania drugich pochodnych.

W sprawozdaniu we wstępie proszę opisać podstawy metody, proszę określić jakość interpolacji (czy obserwujemy efekt Rungego? co się dzieje w pobliżu krańców przedziału interpolacji?), jak ilość węzłów wpływa na interpolację? Wyniki proszę komentować wskazując także na różnice zauważone pomiędzy interpolacją Lagrange’a a interpolacją sklejkami kubicznymi.

3 Przykładowe wyniki dla funkcji f

2

(x)

(4)

(a)

-1.2 -1 -0.8 -0.6 -0.4 -0.2 0 0.2 0.4 0.6 0.8 1

-6 -4 -2 0 2 4 6

f2(x), n=4 F(x), n=4

(b)

-1 -0.8 -0.6 -0.4 -0.2 0 0.2 0.4 0.6 0.8 1

-6 -4 -2 0 2 4 6

f2(x), n=6 F(x), n=6

(c)

-1 -0.8 -0.6 -0.4 -0.2 0 0.2 0.4 0.6 0.8 1

-6 -4 -2 0 2 4 6

f2(x), n=9 F(x), n=9

(d)

-1 -0.8 -0.6 -0.4 -0.2 0 0.2 0.4 0.6 0.8 1

-6 -4 -2 0 2 4 6

f2(x), n=21 F(x), n=21

Rysunek 1: Interpolacja funkcji f2(x) dla n = 4, 6, 9, 21.

Cytaty

Powiązane dokumenty

Wiem, kiedy wykonana jest praca mechaniczna a kiedy jest równa zero Znam wzór na obliczenie pracy mechanicznej.. Znam

Termin ostatniego (drugiego) zaliczenia będzie podany później na stronie katedry po uzgodnieniu rezerwacji sali:?. Orientacyjnie 11.02.2017

Na wykresie przedstawionym na rysunku 7 zaprezentowano przebieg zmian wartości wektora prędkości w czasie, zmierzonego za pomocą anemometru MA1. Dane z anemometru MA1 cechują

Uogólnieniem interpolacji Lagrange’a jest interpolacja l’Hermitte’a, w której w węzłach obok wartości funkcji mogą być również dane wartości pochodnych...

Proszę o zapoznanie się z zagadnieniami i materiałami, które znajdują się w zamieszczonych poniżej linkach, oraz w książce „Obsługa diagnozowanie oraz naprawa elektrycznych

2) Interpolacja funkcji, której przebieg znacznie różni się od przebiegu wielomianu interpolacyjnego, może nie dawać dobrych wyników przy dużej liczbie węzłów..

Do probówki wlać około 0.5 cm 3 nasyconego roztworu siarczanu żelazawego, parę kropli badanego roztworu zawierającego jony NO 2 − , a następnie powoli po ściance

Interpolacja funkcjami sklejanymi stopnia pierwszego.. Interpolacja funkcjami sklejanymi