Chyby, podmíněnost a stabilita

Podobne dokumenty
Numerické metody 8. května FJFI ČVUT v Praze

Numerické metody a statistika

Komplexní analýza. Martin Bohata. Katedra matematiky FEL ČVUT v Praze Martin Bohata Komplexní analýza Mocninné řady 1 / 18

Reprezentace dat. BI-PA1 Programování a Algoritmizace I. Ladislav Vagner

Elementární funkce. Edita Pelantová. únor FJFI, ČVUT v Praze. katedra matematiky, FJFI, ČVUT v Praze

Numerické metody minimalizace

Lineární algebra - iterační metody

(1) Derivace. Kristýna Kuncová. Matematika B2 17/18. Kristýna Kuncová (1) Derivace 1 / 35

Kristýna Kuncová. Matematika B2 18/19

MATEMATIKA 3 NUMERICKÉ METODY. Katedra matematiky a didaktiky matematiky Technická univerzita v Liberci

Edita Pelantová, katedra matematiky / 16

Matematika (KMI/PMATE)

Necht je funkce f spojitá v intervalu a, b a má derivaci v (a, b). Pak existuje bod ξ (a, b) tak, že f(b) f(a) b a. Geometricky

1 Soustava lineárních rovnic

Kapitola 4: Soustavy diferenciálních rovnic 1. řádu

Úvodní informace. 18. února 2019

MATEMATIKA 3. Katedra matematiky a didaktiky matematiky Technická univerzita v Liberci

Aproximace funkcí 1,00 0,841 1,10 0,864 1,20 0,885. Body proložíme lomenou čarou.

Kristýna Kuncová. Matematika B3

Matematika 2, vzorová písemka 1

Cauchyova úloha pro obyčejnou diferenciální rovnici

Funkce zadané implicitně. 4. března 2019

Operace s funkcemi [MA1-18:P2.1] funkční hodnota... y = f(x) (x argument)

Linea rnı (ne)za vislost

x2 + 2x 15 x 2 + 4x ) f(x) = x 2 + 2x 15 x2 + x 12 3) f(x) = x 3 + 3x 2 10x. x 3 + 3x 2 10x x 2 + x 12 10) f(x) = log 2.

DFT. verze:

Co nám prozradí derivace? 21. listopadu 2018

Vybrané kapitoly z matematiky

Kristýna Kuncová. Matematika B2

Inverzní Z-transformace

Stavový popis Stabilita spojitých systémů (K611MSAP) Katedra aplikované matematiky Fakulta dopravní ČVUT. čtvrtek 20. dubna 2006

5. a 12. prosince 2018

(13) Fourierovy řady

Diferenciální rovnice základní pojmy. Rovnice se

Matematika 1 Jiˇr ı Fiˇser 24. z aˇr ı 2013 Jiˇr ı Fiˇser (KMA, PˇrF UP Olomouc) KMA MAT1 24. z aˇr ı / 52

TGH01 - Algoritmizace

TGH01 - Algoritmizace

Petr Hasil. c Petr Hasil (MUNI) Nekonečné řady MA III (M3100) 1 / 187

Průvodce studiem V této kapitole se budeme zabývat diferenciálním počtem pro funkce více

Komplexní analýza. Martin Bohata. Katedra matematiky FEL ČVUT v Praze Martin Bohata Komplexní analýza Úvod 1 / 32

Matematická analýza II pro kombinované studium. Konzultace první a druhá. RNDr. Libuše Samková, Ph.D. pf.jcu.cz

Petr Beremlijski, Marie Sadowská

podle přednášky doc. Eduarda Fuchse 16. prosince 2010

Katedra aplikované matematiky FEI VŠB Technická univerzita Ostrava

Anna Kratochvílová Anna Kratochvílová (FJFI ČVUT) PDR ve zpracování obrazu / 17

Kristýna Kuncová. Matematika B2 18/19. Kristýna Kuncová (1) Vzorové otázky 1 / 36

Statistika (KMI/PSTAT)

Obsah. Limita posloupnosti a funkce. Petr Hasil. Limita posloupnosti. Pro a R definujeme: Je-li a < 0, pak a =, a ( ) =. vlastní body.

Definice Řekneme, že PDA M = (Q,Σ,Γ,δ,q 0,Z 0,F) je. 1. pro všechna q Q a Z Γ platí: kdykoliv δ(q,ε,z), pak δ(q,a,z) = pro všechna a Σ;

1 Definice. A B A B vlastní podmnožina. 4. Relace R mezi množinami A a B libovolná R A B. Je-li A = B relace na A

Numerické metody KI/NME. Doc. RNDr. Jiří Felcman, CSc. RNDr. Petr Kubera, Ph.D.

Určitý (Riemannův) integrál a aplikace. Nevlastní integrál. 19. prosince 2018

Okrajový problém podmínky nejsou zadány v jednom bodu nejčastěji jsou podmínky zadány ve 2 bodech na okrajích, ale mohou být

(2) Funkce. Kristýna Kuncová. Matematika B2. Kristýna Kuncová (2) Funkce 1 / 25

Metody, s nimiž se seznámíme v této kapitole, lze použít pro libovolnou

Kapitola 2. Nelineární rovnice

Automatové modely. Stefan Ratschan. Fakulta informačních technologíı. Evropský sociální fond Praha & EU: Investujeme do vaší budoucnosti

Univerzita Palackého v Olomouci

Geometrická nelinearita: úvod

7. Aplikace derivace

Internet a zdroje. (Zdroje na Internetu) Mgr. Petr Jakubec. Katedra fyzikální chemie Univerzita Palackého v Olomouci Tř. 17.

Kombinatorika a grafy I

Odpřednesenou látku naleznete v kapitolách skript Abstraktní a konkrétní lineární algebra.

Teorie. kuncova/ Definice 1. Necht f je reálná funkce a a R. Jestliže existuje.

Obsah. 1 Konstrukce (definice) Riemannova integrálu Výpočet Newtonova Leibnizova věta Aplikace výpočet objemů a obsahů 30

Laplaceova transformace

Algebra I Cvičení. Podstatná část příkladů je převzata od kolegů, jmenovitě Prof. Kučery, Doc. Poláka a Doc. Kunce, se

B0B99PRPA Procedurální programování

(a). Pak f. (a) pro i j a 2 f

Výzvy, které před matematiku staví

1 Dedekindovy řezy (30 bodů)

Stochastické modelování v ekonomii a financích Konzistence odhadu LWS. konzistence OLS odhadu. Předpoklady pro konzistenci LWS

David Nádhera Kontinuace implicitně zadané křivky

Matematika III Stechiometrie stručný

prof. RNDr. Roman Kotecký DrSc., Dr. Rudolf Blažek, PhD Pravděpodobnost a statistika Katedra teoretické informatiky Fakulta informačních technologií

kontaktní modely (Winklerův, Pasternakův)

Paralelní implementace a optimalizace metody BDDC

NÁVOD K POUŽITÍ KEZELÉSI KÉZIKÖNYV INSTRUKCJA OBSŁUGI NÁVOD NA POUŽÍVANIE. Česky. Magyar. Polski. Slovensky

Martin Pergel. 26. února Martin Pergel

Martin Dlask (KSI FJFI) 3. března 2016

Kvalitativní analýza nelineárních rovnic typu reakce-difuze

Logika V. RNDr. Kateřina Trlifajová PhD. Katedra teoretické informatiky Fakulta informačních technologíı BI-MLO, ZS 2011/12

Powyższe reguły to tylko jedna z wersji gry. Istnieje wiele innych wariantów, można też ustalać własne zasady. Miłej zabawy!

Západočeská univerzita v Plzni Fakulta aplikovaných věd Katedra matematiky

Obsah. 1.2 Integrály typu ( ) R x, s αx+β

Sb ırka pˇr ıklad u z matematick e anal yzy II Petr Tomiczek

Matematická analýza pro učitele (text je v pracovní verzi)

Katedra aplikované matematiky FEI VŠB Technická univerzita Ostrava

Základní elektrotechnická terminologie,

Nekomutativní Gröbnerovy báze

Teorie plasticity. Varianty teorie plasticity. Pružnoplastická matice tuhosti materiálu

Škola matematického modelování 2017

Internetová matematická olympiáda 8. ročník, Baví se student Fakulty strojního inženýrství VUT v Brně (FSI) s kamarádem:

Pojem množiny nedefinujeme, pouze připomínáme, že množina je. Nejprve shrneme pojmy a fakta, které znáte ze střední školy.

Matematika prˇedna sˇka Lenka Prˇibylova 7. u nora 2007 c Lenka Prˇibylova, 200 7

Obsah. Petr Hasil. (konjunkce) (disjunkce) A B (implikace) A je dostačující podmínka pro B; B je nutná podmínka pro A A B: (A B) (B A) A (negace)

Ústav teorie informace a automatizace. Tato prezentace je k dispozici na:

návod k použití instrukcja obsługi

6 Dedekindovy řezy (30 bodů)

1 Předmluva Značení... 3

Transkrypt:

Chyby, podmíněnost a stabilita Numerické metody 4. března 2018 FJFI ČVUT v Praze 1

Úvod Čísla v počítači Chyby Citlivost Stabilita 1

Čísla v počítači

Čísla v počítači - Celá čísla jméno bity rozsah typy byte 8 128 až 127 short 16 32 768 až 32 767 long 32 (2 31 ) až 2 31 1 int8 t (C/C++), shortint (Pascal), int8 (Matlab/Python) int (C/C++), Smallint (Pascal), int16 (Matlab/Python) long (C/C++), integer (Pascal), int32 (Matlab/Python) Tabulka 1: Přehled vybraných typů celých čísel výhody: přesné výpočty, rychlé nevýhody: omezený rozsah, omezené operace 2

Čísla v počítači - Čísla s plovoucí čárkou číslo s plovoucí čárkou (floating-point), jinak tedy reálné číslo (s konečný počtem platných cifer): ± }{{} znaménko 1.2345678 }{{} }{{} 10 2 platné cifry exponent je nutné definovat speciální aritmetiku 3

Čísla v počítači - Standard IEEE standard IEEE (Institute of Electrical and Electronics Engineers) 754 definuje 1. aritmetický formát 2. výměné formáty 3. zaokrouhlovací pravidla 4. operace 5. výjimky 4

Čísla v počítači - IEEE formát Každé konečné reálné číslo (tedy číslo s plovoucí čárkou) se zkládá ze tří celých čísel 1. s znaménko (a sign) - jednička nebo nula 2. c mantisa (a significand/a coefficient) 3. q exponent (an exponent) společně s daným základem b (a radix) (2 nebo 10) lze takové číslo zapsat jako ( 1) s c b q. Speciálně jsou vyhrazené kombinace pro obě nekonečna (± ) a pro nedefinované číslo (not a number - NaN). Často se provadí tzv. normalizace, kde řekneme, že každá mantisa má na začátku 1. Tedy se musí definovat i speciálně nula (ta není normalizovaná). 5

Čísla v počítači - Typy jméno bity základ b mantisa c exponent q platné číslice single 32 2 24 8 7 8 double 64 2 53 11 15 16 Tabulka 2: Přehled vybraných typů celých čísel 6

Čísla v počítači - Operace Operace, které platí i v aritmetice s plovoucí čárkou (pro x, y a z jako reálné čísla s plovoucí čárkou) 1 x = x, 0 x = 0, x y = y x, x + x = 2x, a které nemusí vždy platit x 1 x = 1, (x + y) + z = x + (y + z). 7

Čísla v počítači - Strojové epsilon Strojové epsilon ε je definované jako počet platných cifer ale v dvojkové soustavě (těžko představitelné) (2 c, kde c je mantisa) rozdíl čísla 1 a nejbližšího většího čísla než 1. Udává relativní změnu posobě jdoucích čísel. Rozdělení čísel při základu 2 (při změně exponentu se mění násobek ε)..., 1, 1+ε, 1+2ε,..., 2 ε, 2, 2+2ε, 2+4ε,..., 4 2ε, 4, 4+4ε,... Strojové epsilon pro single precision ε sp = 2 24 5.96 10 8, double precision ε dp = 2 53 1.11 10 16. 8

Čísla v počítači - Odhad strojového epsilonu - algoritmus 1. definujeme jednicka := 1.0 a epsilon := 0.1 2. dokud jednicka + epsilon > jednicka 2.1 zmenšíme epsilon dvakrát, epsilon := epsilon/2 3. výsledný odhad strojového epsilon 2*epsilon (jelikož poslední epsilon už nezměnilo jedničku, tak se musíme vrátit o jedno zpět) Naprogramujte tento algoritmus a porovnejte výsledek se správným strojovým epsilonem. 9

Čísla v počítači - Odhad strojového epsilonu - výsledek Výsledný program je ke stažený zde. Výstup je následný Vidíme, že odhad je to relativně solidní. 10

Čísla v počítači - Nejmenší kladné číslo Druhým zajímavým údajem může být nejmenší kladné číslo. Každé menší číslo bude zaokrouhleno na nulu. Kvůli normalizaci bude začínat jedničkou a bude mít největší možný záporný exponent. Nejmenší číslo pro single precision min sp = 2 150 1.1 10 38, double precision min dp = 2 1074 5.0 10 324. 11

Čísla v počítači - Odhad nejmenšího kladného čísla - algoritmus 1. definujeme mozne nejmensi := 1.0 2. dokud mozne nejmensi > 0.0 2.1 zapamatujeme si nejmensi jako poslední možné, nejmensi := mozne nejmensi 2.2 zmenšíme mozne nejmensi dvakrát, mozne nejmensi := mozne nejmensi/2 3. výsledný odhad nejmenšího kladného čísla nejmensi Naprogramujte tento algoritmus a porovnejte výsledek se správným nejmenším číslem. 12

Čísla v počítači - Odhad nejmenšího kladného čísla - výsledek Výsledný program je ke stažený zde. Výstup je následný Námi zjištěné nejmenší kladné číslo a udávané Matlabem se liší. Je ale schopen rozeznat to naše (které nezaokrouhĺı na nulu). 13

Chyby

Chyby - Typy chyb Chybu při převodu z matematického modelu na numerický označujeme také jako chybu metody (truncation error). 14

Chyby - Zaokrouhlovací Při řešení úlohy na počítači (tedy s čísly s pohyblivou čárkou/s konečnou přesností) dochází k zaokrouhlovacím chybám (roundoff errors). Důležité je, aby se tato chyba nestala v metodě osudnou. Definujeme u jako polovinu strojové přesnosti, tedy u := ε/2. 15

Chyby - Operace Operace +,, a / se provedou přesně a výsledek je zaokrouhlen, tak aby byl opět v daném typu. Tedy platí 1. fl(x ± y) = (x ± y)(1 + ε 1 ), ε 1 < u, 2. fl(x y) = (x y)(1 + ε 2 ), ε 2 < u, 3. fl(x/y) = (x/y)(1 + ε 3 ), ε 3 < u, kde fl je zaokrouhlení do daného typu. 16

Chyby - Absolutní a relativní Mějme x přesnou hodnotu a x přibližnou, pak značíme absolutní chybu A(x) := x x a její horní dohad a(x) A(x), relativní chybu R(x) := x x x r(x) R(x). a její horní odhad 17

Chyby - Chyby operací Odhad absolutní a relativní chyby sčítání, resp. odčítání je a(x ± y) = a(x) + a(y) r(x ± y) = a(x) + a(y), x ± y pro násobení a(x y) = x a(y) + y a(x) r(x y) = r(x) + r(y) a dělení a(x/y) = x a(y) + y a(x)a(x) + a(y) y 2 r(x/y) = r(x)+r(y). 18

Chyby - Kritické operace Je vidět, že sčítání, násobení a dělení nemůže výrazně změnit relativní chybu. Oproti tomu, pokud při odčítání budeme pracovat s podobnými čísly, může chyba růst hodně. Tedy pokud x y, pak r(x y). 19

Chyby - Rekurentní vzorec Definujeme následnou rekurentní posloupnost a n+1 := 34 11 a n 3 11 a n 1 s počátečními hodnotami a 0 = 1 a a 1 = 1 11. Najděte předpis pro n-tý člen. Porovnejte výsledky rekurentního vzorce a vzorce pro n-tý člen pro n {5, 10, 20, 30}. 20

Chyby - Rekurentní vzorec - výsledek Program naleznete zde. Závislost relativního rozdílu rekurentního vzorce a vzorce pro n-tý člen na n Vidíme, že chyba roste exponenciálně (jelikož osa y je logaritmická). To je dáno právě odčítáním podobných čísel. 21

Chyby - Závislost chyby na délce kroku Nyní zkusíme spočítat derivaci funkce f(x) := sin(x). Tedy analyticky f (x) := cos(x). Použijeme dopřednou a centrální diferenci a vykresĺıme relativní chybu v závislosti na délce kroku h. 22

Chyby - Závislost chyby na délce kroku - výsledek Program naleznete zde. Chování dopředné a centrální diference v závislosti na délce kroku h Vidíme, že do určité hodnoty h je centrální diference (tedy metoda vyššího řádu) lepší, ale jakmile se dostane do kriticky krátkého h, chyba se začne zvětšovat. Vlevo se jedná o chybu zaokrouhlovací, napravo o chybu metody. 23

Citlivost

Citlivost - Definice Citlivost (jinak také podmíněnost) je vlastnost dané úlohy popisující vliv malé změny vstupních dat na změnu řešení. Matematicky: Mějme dvě vstupní data x a x a k nim příslušné řešení y, resp. ỹ, pak pokud je číslo podmíněnosti úlohy dané C p = y ỹ y x x x musí malé, úloha je dobře podmíněná, v opačném případě je špatně podmíněná. 24

Citlivost - Dobře a špatně podmíněná úloha Tedy pokud C p 1 je úloha dobře podmíněná, pokud C p > 100 úloha je špatně podmíněná. Často i řešíme špatně podmíněné úlohy, je ale potřeba volit speciální metody, které jsou odolné. Pro C p > ε 1 není úloha řešitelná v dané přesnosti. 25

Stabilita

Stabilita - Definice Stabilní metoda je taková, kde chyba roste s počtem kroků maximálně lineárně. U nestabilní metody dojde k akumulaci chyb, až dojde ke katastrofální ztrátě přesnosti. Nestabilita může být dána jak zaokrouhlovací chybou tak i chybou metody. Často se vyskytuje při řešení diferenciálních rovnic. 26

Stabilita - Pád meteoritu Meteorit, který padá skrze atmosféru, je bržděn exponenciálně. Jeho rychlost je dána diferenciální rovnicí Její analytické řešení je dv dt = v(t). v(t) = C exp( t), kde C je konstanta závislá pouze od počáteční podmínky. Podívejte se na řešení této rovnice numericky pomocí dopředné a centrální diference s počátečními podmínkou v(t = 0) = 1. 27

Stabilita - Pád meteoritu - výsledek Program naleznete zde. Porovnání chování centrální diference oproti dopředné v průběhu času (řešení rovnice) Vidíme, že metoda centrální diference je nestabilní a její chyba časem roste exponenciálně (opět je osa y v pravém grafu logaritmická). Oproti tomu dopředná diference je stabilní, i když je na začátku horší než metoda první. 28

Navíc

Navíc - Důkaz neplatnosti asociativity Mějme n N a řekněme, že chceme sečíst následující řádu S n = n i=0 ( ) 10 i. 11 Pokud by tato aritmetika byla asociativní, nezáleželo by, jestli sčítáme sestupně nebo vzestupně. Naprogramujte vzestupný i sestupný součet a výsledek porovnejte pro n {10, 100, 200}. (Zkuste to pro single i double přesnost). 29

Navíc - Důkaz neplatnosti asociativity - výsledek Program v double precision naleznete zde. Výstup pro n = 200 Vidíme, že rozdíl je až na 16. pozici (tedy, která už nemusí být směrodatná). Tedy tento algoritmus je v double precision asociativní. Program v single precision naleznete zde. Výstup pro n = 200 Oproti tomu v single precision je rozdíl už na druhé platné cifře, tedy tady asociativita neplatí a záleží jak sčítáme. 30

Navíc - Výpočet funkční hodnoty Máme funkci f(x) := 1 cos(x) x 2. Vykresĺıme chování takovéto funkce v okoĺı 0. 31

Navíc - Výpočet funkční hodnoty - výsledek Program naleznete zde. Vykreslení funkce na intervalu 0.1; 0.1 pro tisíc bodů (levý obrázek) a pro milión bodů (pravý obrázek) (resp. jeho detail) Vidíme, že okolo nuly, kde je funkční hodnota cos(x) bĺızká jedničce, dochází k nestabilitě, jelikož odčítáme dvě podobná čísla. 32