Równania różniczkowe: równania funkcyjne opisujące relacje spełniane przez pochodne nieznanej (poszukiwanej) funkcji cząstkowe: funkcja więcej niż jednej.

1 Równania różniczkowe: równania funkcyjne opisujące rela...
Author: Seweryna Malinowska
0 downloads 0 Views

1 Równania różniczkowe: równania funkcyjne opisujące relacje spełniane przez pochodne nieznanej (poszukiwanej) funkcji cząstkowe: funkcja więcej niż jednej zmienna, np.: czas i położenie u x t t+dt np. wychylenie u(x,t) struny w położeniu x i czasie t równania cząstkowe: nie zawsze jedną ze zmiennych jest czas, ale zawsze opisują obiekty rozciągłe druga zasada dynamiki Newtona dla struny

2 równania różniczkowe zwyczajne: jedna zmienna niezależna np. czas dla elementów punktowych, nierozciągłych v(t) RC L napięciowe prawo Kirchoffa równanie liniowe drugiego rzędu r=(x,y) układ równań: ruch w polu centralnym (nieliniowe) równania Lotki-Volterry z – populacja zajęcy, w– wilków  naturalne tempo wzrostu pop. zajęcy (pod nieobecność w),  – zaniku wilków bez z  parametry oddziaływania populacji układ równań nieliniowych 2 rzędu – problem początkowy po zadaniu x(t=0),y(t=0), x’(t=0), y’(t=0). układ r. 1 rzędu nieliniowe

3 zwyczajne zagadnienie brzegowe (zamiast czasu, położenie w 1D -element rozciągły opisany jedną współrzędną) np. równanie Eulera-Bernoulliego: wygięcie jednorodnego elastycznego pręta pod wpływem rozłożonego obciążenia w(x) lewy koniec: zamocowany i podparty prawy koniec: swobodny zwyczajne rzędu drugiego lub wyższego + warunki na funkcje i pochodne na końcach przedziału

4 Zaczynamy od rozwiązywania równań zwyczajnych 1)prostsza analiza niż dla cząstkowych 2)wprowadzimy pojęcia zbieżności, dokładności, stabilności itd. przydatne do metod rozwiązywania równań cząstkowych 3)jedna z metod rozwiązywania równań cząstkowych (metoda linii) - sprowadzamy równanie cząstkowe do układu równań zwyczajnych

5 Metoda linii: układy równań różniczkowych zwyczajnych - po dyskretyzacji przestrzennej cząstkowego równania różniczkowego równanie adwekcji x x 1 x 2 x 3 x 4 x 5 centralny iloraz na pochodną przestrzenną u n (t)=u(x n,t) xx układ N równań zwyczajnych t

6 zwyczajne równania różniczkowe rzędu pierwszego [oraz ich układy] warianty: liniowe (układy równań liniowych rozwiązuje się analitycznie) inna forma – nieliniowe  =0 –jednorodne jeśli f=f(t) (nie zależy od y) rozwiązanie – całka nieoznaczona jeśli f=f(y) (nie zależy od t) równanie autonomiczne (nie podlega zaburzeniom zależnym od t)

7 zagadnienie początkowe: równanie różniczkowe + warunek początkowy jeśli f=f(t) rozwiązanie: całka oznaczona

8 Równanie różniczkowe zwyczajne dowolnego rzędu można sprowadzić do układu równań pierwszego rzędu wystarczy jeśli potrafimy efektywnie rozwiązać układ równań rzędu pierwszego Przykład: Zmiana oznaczeń Definicja traktowana jako jedno z równań do rozwiązania Równanie na najwyższą pochodną - jedyne „niedefinicyjne” Układ równań do rozwiązania

9 O konieczności numerycznego rozwiązywania RRZ 1R: analitycznie rozwiązać można układ równań liniowych. nieliniowe: na ogół nie. V2V2 V1V1 r1r1 r2r2 V3V3 r3r3 Układ 2 ciał oddziaływujących grawitacyjnie - analitycznie rozwiązany przez Newtona Układ 3: ciał – nie posiada analitycznego rozwiązania ponadto: automaty mające reagować na otoczenie nie znają postaci analitycznej f : ta jest brana z pomiarów bez wzoru na f skazani jesteśmy na rachunki numeryczne zazwyczaj nie znamy rozwiązań analitycznych równań nieliniowych

10 Numeryczne rozwiązywanie problemu początkowego jeśli potrafimy rozwiązać układ równań rzędu pierwszego -rozwiążemy każdy różniczkowy problem początkowy

11 Dobra metoda ma zapewnić zadaną dokładność przy pomocy minimalnej liczby wywołań f (przy maksymalnym kroku czasowym) przy dyskusji metod– zakłada się, że wyliczenie f jest kosztowne – [jeśli nie jest kosztowne – nie ma problemu] Dyskretyzacja zmiennej czasowej t  t n+1  t n+2 n n+1 n+2 itd. Numeryczne rozwiązywanie problemu początkowego dyskretyzacja zmiennej czasowej sprowadza równania różniczkowe do różnicowych (metoda różnic skończonych)

12 im więcej znamy pochodnych w punkcie t tym większe otoczenie t możemy dobrze przybliżyć obciętym rozwinięciem Taylora tw. Taylora - między t a  t istnieje taki punkt , że ograniczenie na resztę: maksymalna wartość czwartej pochodnej u w okolicy t stąd O(  t 4 )

13 u=exp(-t 2 /2) Rząd błędu obcięcia w rozwinięciu Taylora u(0)=1u=exp(-t 2 /2) rozwijane wokół t=0 [w roz.T.  t=t]

14 Jawny schemat Eulera

15 błąd lokalny schematu różnicowego: odchylenie wyniku numerycznego od dokładnego, które pojawia się w pojedynczym kroku całkowania Jawny schemat Eulera można wyliczyć bo znamy t i u(t) błąd lokalny jawnego Eulera w kroku t n-1  t n wg tw. Taylora ln =ln = przepis na pojedynczy krok z u(t) do u(t+  t )

16 Jawny schemat Eulera... krok wcale nie musi być taki sam dla każdego n, ale tak przyjmiemy do analizy stosowany wielokrotnie:

17 Jawny schemat Eulera dokładny u(t)=exp(t) dla du/dt=u Jawny schemat Eulera tt tt tt W rozwiązaniu dokładnym nachylenie u dane jest przez u w każdej chwili Jawnym schemat Eulera zakłada, że nachylenie jest stałe w jednym kroku czasowym i bierze je z wartości przybliżonej dla początku kroku Tylko u 0 = u (0) później u n < u(t n ) Co prowadzi do akumulacji błędów

18 każdy krok wykonywany z nachyleniem branym z chwili, w której krok się zaczyna Zmniejszamy krok  t: Błąd lokalny zmaleje, ale do ustalonej chwili T musimy wykonać więcej kroków. W każdym kroku wprowadzamy nowy błąd. Błędy się akumulują. Czy opłaca się zmniejszać kroki czasowe? Definicja: Błąd globalny – różnica między rozwiązaniem dokładnym a numerycznym w chwili t „Czy się opłaca” znaczy: Czy błąd globalny maleje gdy  t maleje ? a jeśli tak - czy maleje do zera? (czy możliwe jest dokładne rozwiązanie równania różniczkowego uzyskane jako granica schematu różnicowego) Jawny schemat Eulera dokładny u(t)=exp(t) dla du/dt=u

19 Jawny schemat Eulera Czy błąd całkowity maleje gdy  t maleje ? Czy maleje do zera? eksperyment numeryczny problem początkowy: u’= u, u(0)=1 z rozwiązaniem dokładnym u(t)=exp( t)   t=0.001 dokładny jawny Euler e (błąd globalny) = dokładny - numeryczny

20 Jawny schemat Eulera Czy błąd globalny maleje gdy  t maleje ? Czy maleje do zera? eksperyment numeryczny problem początkowy: u’= u, u(0)=1 z rozwiązaniem dokładnym u(t)=exp( t) zmniejszajmy krok czasowy, jaki wynik w chwili t=0.01 ? [1/e=.3678794] n  t u n exp(  )  u n 1010 -3 0.348671.920  10 -2 10 2 10 -4 0.366031.847  10 -3 10 3 10 -5 0.367691.840  10 -4 10 4 10 -6 0.367841.839  10 -5 błąd globalny w chwili t=0.01 wydaje się zmieniać liniowo z krokiem czasowym  interpretacja: błąd lokalny rzędu  t 2 popełniony n = t/  t razy daje błąd globalny rzędu  t

21 Definicja: Metody różnicowa jest zbieżna jeśli błąd globalny e znika do zera w chwili T gdy z  t do 0 zmniejszajmy krok czasowy, jaki wynik w chwili t=0.01 ? [1/e=.3678794] n  t u n exp(  )  u n 1010 -3 0.348671.920  10 -2 10 2 10 -4 0.366031.847  10 -3 10 3 10 -5 0.367691.840  10 -4 10 4 10 -6 0.367841.839  10 -5 błąd globalny w chwili t=0.01 wydaje się zmieniać liniowo z krokiem czasowym

22 czy jawny schemat Eulera jest zbieżny? sprawdźmy analitycznie propagacje błędu (błąd globalny) dla ogólniejszego problemu modelowego. problem modelowy: ogólne liniowe niejednorodne o stałych współczynnikach zmiana y proporcjonalna do wartości y i niejednorodności  rozwiązanie analityczne dla =0 rozwiązanie analityczne dla  =0

23 czy jawny schemat Eulera jest zbieżny? sprawdźmy analitycznie propagacje błędu (błąd globalny) dla ogólniejszego problemu modelowego. problem modelowy: ogólne liniowe niejednorodne o stałych współczynnikach zmiana y proporcjonalna do wartości y i niejednorodności  rozwiązanie analityczne dla =0 rozwiązanie analityczne dla  =0 ogólne rozwiązanie analityczne:

24 czy jawny schemat Eulera jest zbieżny? sprawdźmy analitycznie propagacje błędu (błąd globalny) dla ogólniejszego problemu modelowego. problem modelowy: ogólne liniowe niejednorodne o stałych współczynnikach zmiana y proporcjonalna do wartości y i niejednorodności  rozwiązanie analityczne: warunek początkowy wzmacniany z czynnikiem exp( t) ten sam czynnik [tzw. propagator] wzmacnia niejednorodność  niejednorodność wchodzi do rozwiązania tak jak warunek początkowy – z opóźnieniem odpowiadającym chwili w której się pojawia Zasada Duhamel  t=0 t

25 oznaczenia y n = rozwiązanie równania różnicowego w chwili t n =  t n y(t n ) = rozwiązanie dokładne r. różniczkowego schemat Eulera: odpowiedni wzór dla rozwiązania dokładnego z równania różniczkowego Aby wyliczyć błąd globalny e n+1 =y(t n+1 )-y n+1 odejmujemy stronami podkreślone wzory

26 e n+1 =y(t n+1 )-y n+1 gdzieś między t n a t n+1 błąd globalny w kroku n+1= błąd globalny w kroku n wzmocniony o czynnik (1+  t) i powiększony o nowy błąd lokalny cofnijmy się do chwili początkowej wnwn w n-1 (Euler) (dokładny)

27 dyskretna zasada Duhamel: błąd początkowy wzmacniany jak (1+  t) liczba kroków błąd który pojawia się w kroku i-tym wzmacniany w ten sam sposób, co początkowy błędy jawnego Eulera wzmacniane jak rozwiązanie dokładne w odpowiada  e odpowiada y (1+  t) n odpowiada exp( t n )

28 Czy metoda zbieżna? ? załóżmy, że potrafimy wstawić warunek początkowy bezbłędnie : e 0 = 0 Zakładamy, że arytmetyka jest dokładna

29 pierwsze dwa wyrazy r.T. reszta +  t 2 | |^2 /2 exp(  n ) ? Pokazaliśmy, że metoda Eulera zbieżna dla problemu modelowego. Można pokazać, że zbieżna jest dla każdej f (ciągłej w sensie Lipschitza) Jej rząd zbieżności (dokładności) pierwszy

30 rząd zbieżności (dokładności) określa jakość metody: jak szybko błąd globalny dla chwili T zmierza do zera w funkcji  t jawna metoda Eulera = pierwszy rząd dokładności O(  t) jest to minimalny rząd dokładności dla użytecznej metody zmniejszajmy krok czasowy, jaki wynik w chwili t=0.01 ? [1/e=.3678794] n  t u n exp(  )  u n 1010 -3 0.348671.920  10 -2 10 2 10 -4 0.366031.847  10 -3 10 3 10 -5 0.367691.840  10 -4 10 4 10 -6 0.367841.839  10 -5

31 Definicja: Metody różnicowa jest zbieżna jeśli błąd globalny znika do zera w chwili T gdy z  t do 0 zbieżność a błędy zaokrągleń (skończona dokładność arytmetyki zmiennoprzecinkowej)

32 błędy zaokrągleń a zbieżność pojedyncza precyzja: 32 bity podwójna : 64 bity arytmetyka 21 – bitowa do tej pory zakładaliśmy, że błędy zaokrągleń nie ma (że arytmetyka dokładna) arytmetyka zmiennoprzecinkowa nie jest dokładna. błąd minimalny zmniejszanie kroku czasowego nie poprawi już wyniku

33 błędy zaokrągleń a metody różnicowe rozwiązanie równania różniczkowego w chwili t n rozwiązanie równania różnicowego z dokładną arytmetyką rozwiązanie uzyskane z arytmetyką skończonej dokładności błąd całkowity błąd globalny (jak wcześniej zdefiniowano) błąd zaokrąglenia oszacowanie od góry błędu całkowitego

34 błąd zaokrągleń rzędu liczby wykonanych kroków, czyli 1/dt błąd globalny dla schematu Eulera błędy zaokrągleń a metody różnicowe oszacowanie od góry błędu całkowitego optymalny krok czasowy remedium: używać się schematów o wyższym rzędzie zbieżności niż pierwszy błędy zaokrągleń dają o sobie znać gdy wykonamy zbyt wiele kroków dt błąd

35 Definicja: Metody różnicowa jest zbieżna jeśli błąd globalny znika do zera w chwili T gdy z  t do 0 błąd zaokrągleń błąd globalny dla schematu Eulera błędy zaokrągleń a metody różnicowe oszacowanie od góry błędu całkowitego optymalny krok czasowy błąd całkowity błąd globalny błąd zaokrąglenia uwaga: definicja zbieżności dotyczy błędu globalnego a nie całkowitego

36 Wróćmy do eksperymentu numerycznego i zwiększmy krok czasowy do  t=0.05 do bezwzględnej stabilności zasygnalizować sztywność (do której powrócimy) wsteczny Euler sposoby iteracji dla wstecznego Eulera problem początkowy: u’=-100u, u(0)=1 z rozwiązaniem dokładnym u(t)=exp(  t) t n u n 01 0.05-4 0.18 0.15-16 0.2256 0.25-1024 0.34096 iteracja się rozbiega  wniosek: wyniki metody zbieżnej mogą eksplodować dla zbyt dużego kroku czasowego

37 bezwzględna stabilność schematu różnicowego schemat różnicowy dla du/dt = f (dla danego f) i dla danego kroku czasowego jest bezwzględnie stabilny jeśli kolejne generowane przez niego wartości pozostają skończone. Uwaga: Zbieżność jest cechą schematu niezależnie od f Bezwzględna stabilność określa się dla konkretnego równania W charakterystyce schematów Najczęściej stabilność bezwzględna: określana jest dla autonomicznego problemu liniowego

38 Weźmy = -1, u(0)=1, rozwiązanie dokładne u(t)=exp(-t) Przepis Eulera: u n+1 =u n -  tu n 0246810 0.0 0.2 0.4 0.6 u ( t ) dokładny  t=0.5  t=0.9  t=1 : wszędzie 0 0246810 -4 -2 0 2 4 6 u ( t )  t=1.2  t=2  t=2.5 uwaga: rozwiązanie bezwzględnie stabilne (np.  t=1 lub  t=2) może być bardzo niedokładne lub wręcz - jakościowo złe = tutaj stałe i niemonotoniczne odpowiednio t t Schemat bezwzględnie stabilny dla  t  2

39 bezwzględna stabilność jawnej metody Eulera wsp. wzmocnienia wyniki pozostaną skończone dla n   jeśli: u n = u n-1 +  t u n-1

40 region bezwzględnej stabilności metody: zbiór z=  t, dla których metoda jest bezwzględnie stabilna region bezwzględnej stabilności jawnej metody Eulera: z=  t zbiór punktów odległych od (-1,0) o nie więcej niż 1 koło o środku w (-1,0) i promieniu 1 niestabilność bezwzględna metody dla prawej połowy p. Gaussa = nic dziwnego rozwiązanie dokładne y 0 exp( t) eksploduje do nieskończoności gdy t .  t Re( )  t Im ( ) -2 1 Zmienna zespolona

41 pozbyć się ograniczenia na krok czasowy: niejawna metoda Eulera jawnametoda Euleraniejawna metoda Eulera jawna metoda Eulerafunkcjonuje jak równanie nieliniowe (funkcjonuje jak podstawienie) „metoda odważna”„metoda ostrożna” zmiana u zgodna z prawą stroną w punkcie docelowym

42 niejawna metoda Eulera: problem początkowy: u’=-100u, u(0)=1 z rozwiązaniem dokładnym u(t)=exp(  t) t n u n 01 0.05-4 0.18 0.15-16 0.2256 0.25-1024 0.34096 jawny Euler niejawny Euler t n u n e(t n ) 010 0.05.166(6)-.15992 0.1.027(7)-.02773 0.15.004(629)-.00462 0.2.0007716 0.25.0001286 0.3.00002143 itd.. exp(-100 t n ) gaśnie znacznie szybciej niż 1/6 n mało dokładne, ale zawsze to lepiej niż eksplodująca oscylacja jawnego Eulera

43 niejawna metoda Eulera: region bezwzględnej stabilności  t Re( )  t Im ( ) 1 rejon bezwzględnej stabilności: dopełnienie pustego koła o środku w (1,0) i promieniu 1

44 1  t Re( )  t Im ( ) =1 – zakres niestabilności  t  (0,2) Niejawny schemat Eulera exp(t) nsE  t=0.1 nsE  t=0.8 Zbliżamy się do  t=1 – wyniki schematu rosną coraz szybciej Dla  t=1 – nieskończoność w pierwszym kroku  t=1.2  t=1.5  t=2 1,-1,1,-1 itd

45  t Re( )  t Im ( ) 1  t Re( )  t Im ( ) -2 1 metoda Eulera jawna niejawna metoda Eulera regiony stabilności metod Eulera

46  t Re( )  t Im ( ) 1 niejawna metoda Eulera: region bezwzględnej stabilności Re( )

47 jak rozwiązać, gdy nie można rozwikłać równania (f nieliniowe względem u) lub gdy f nieznane w formie wzoru 1)iteracja funkcjonalna iterować do zbieżności jeśli się zbiegnie u  =u  -1 i mamy rozwiązanie równania nieliniowego

48 problem początkowy: u’=-100u, u(0)=1, dt=0.05 z rozwiązaniem dokładnym u(t)=exp(  t) iteracja funkcjonalna przykład 1, -4, 21, -104, 521, -2604,... kolejne oszacowania: iteracja się nie zbiega  cały zysk z niejawności stracony bo nie potrafimy wykonać kroku t n u n e(t n ) 010 0.05.166(6)-.15992 0.1.027(7)-.02773 0.15.004(629)-.00462 0.2.0007716 0.25.0001286 0.3.00002143

49 iteracja funkcjonalna przykład dt=0.01 (1,0,1,0,1,0) dt=0.001 1, 0.9, 0.91, 0.909, 0.9091, 0.90909, 0.909091,... 0.90909090909 iteracja funkcjonalna się zbiega gdy  t max|f u (t,u)|  1 (w otoczeniu u) iteracja się nie zbiega . zmniejszymy krok dt, zaczynając iterację od u n-1 będziemy bliżej rozwiązania. Może się zbiegnie. u’=-100u,  t 100 < 1 uwaga: w tej sytuacji jawny Euler jest bezwzględnie stabilny dla 2-krotnie większego kroku!  dla jawnego Eulera  t 100 < 2] Z iteracją funkcjonalną stosować wstecznego Eulera nie ma sensu.

50 iteracja funkcjonalna – zapewniamy zbieżność modyfikując przepis iteracyjny zamiast: „mieszając” nowe i stare rozwiązania z wagą w, 0  w  1 jeśli się zbiegnie – to do rozwiązania schematu niejawnego 1, -4, 21, -104, 521, -2604,... problem początkowy: u’=-100u, u(0)=1, dt=0.05 z rozwiązaniem dokładnym u(t)=exp(  t) oscylująca rozbieżność - stłumimy ją: Zabieg podobny do “podrelaksacji”

51 problem początkowy: u’=-100u, u(0)=1, dt=0.05 z rozwiązaniem dokładnym u(t)=exp(  t) iterujemy u(dt) w=0.1 w=0.2 w=0.3 wybierając w odpowiedni sposób wagę w: potrafimy ustabilizować iterację i doprowadzić ją do zbieżności.

52 dt=0.01 (1,0,1,0,1,0) dt=0.001 1, 0.9, 0.91, 0.909, 0.9091, 0.90909, 0.909091,... 0.90909090909 w=0 w=1 0.8,0.68, 0.608, 0.5648, 0.53888, 0.5233, 0.51399, 0.50839, 0.50503, 0.503, 0.5018, 0.5010, 0.50065, 0.50039,..., 1/2 w=.2 (optymalne dla dt=0.05) tutaj optymalne byłoby w=1/2 (zbieżność w jednej iteracji) dla w=.7 0.3,0.58,0.468,0.512,0.4948,0.5003,0.4998 w=0.2

53 dt=0.01 (1,0,1,0,1,0) dt=0.001 1, 0.9, 0.91, 0.909, 0.9091, 0.90909, 0.909091,... 0.90909090909 w=0 w=1 0.8,0.68, 0.608, 0.5648, 0.53888, 0.5233, 0.51399, 0.50839, 0.50503, 0.503, 0.5018, 0.5010, 0.50065, 0.50039,..., 1/2 w=.2 (optymalne dla dt=0.05) tutaj optymalne byłoby w=.5 (zbieżność w jednej iteracji natychmiastowa) dla w=.7 0.3,0.58,0.468,0.512,0.4948,0.5003,0.4998 w=0.2 Problem: 1) w trzeba odpowiednio dobrać (mniejszy krok czasowy, w bliższe 1) 2) dla źle dobranego w iteracja może być wolnozbieżna Proces optymalizacji (np. dynamicznej) w może być kłopotliwy.