Mercurial > repos > public > sbplib
comparison +time/+rk/butcherTableauFromStr.m @ 990:1066bb31bc95 feature/timesteppers
Create class for butcher tableau
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Wed, 09 Jan 2019 09:09:15 +0100 |
parents | a32856fc2ad2 |
children |
comparison
equal
deleted
inserted
replaced
989:e41c93d7ab08 | 990:1066bb31bc95 |
---|---|
4 % @return s - number of stages | 4 % @return s - number of stages |
5 % @return a - coefficents for intermediate stages | 5 % @return a - coefficents for intermediate stages |
6 % @return b - weights for summing stages | 6 % @return b - weights for summing stages |
7 % @return c - time step coefficents for intermediate stages | 7 % @return c - time step coefficents for intermediate stages |
8 function [s,a,b,c] = butcherTableauFromStr(method) | 8 function [s,a,b,c] = butcherTableauFromStr(method) |
9 switch method | 9 try |
10 case "tvd-3" | 10 bt = time.rk.ButcherTableau.(method); |
11 % TVD (Total Variational Diminishing) | 11 catch |
12 s = 3; | |
13 a = zeros(s,s-1); | |
14 a(2,1) = 1; | |
15 a(3,1) = 1/4; a(3,2) = 1/4; | |
16 b = [1/6, 1/6, 2/3]; | |
17 c = [0 1 1/2]; | |
18 case "rk4" | |
19 % Standard RK4 | |
20 s = 4; | |
21 a = zeros(s,s-1); | |
22 a(2,1) = 1/2; | |
23 a(3,1) = 0; a(3,2) = 1/2; | |
24 a(4,1) = 0; a(4,2) = 0; a(4,3) = 1; | |
25 b = [1/6 1/3 1/3 1/6]; | |
26 c = [0, 1/2, 1/2, 1]; | |
27 case "rk4-3/8" | |
28 % 3/8 RK4 (Kuttas method). Lower truncation error, more flops. | |
29 % Irreducible, unlike standard rk4. | |
30 s = 4; | |
31 a = zeros(s,s-1); | |
32 a(2,1) = 1/3; | |
33 a(3,1) = -1/3; a(3,2) = 1; | |
34 a(4,1) = 1; a(4,2) = -1; a(4,3) = 1; | |
35 b = [1/8 3/8 3/8 1/8]; | |
36 c = [0, 1/3, 2/3, 1]; | |
37 case "rk6" | |
38 % Runge-Kutta 6 from Alshina07 | |
39 s = 7; | |
40 a = zeros(s,s-1); | |
41 a(2,1) = 4/7; | |
42 a(3,1) = 115/112; a(3,2) = -5/16; | |
43 a(4,1) = 589/630; a(4,2) = 5/18; a(4,3) = -16/45; | |
44 a(5,1) = 229/1200 - 29/6000*sqrt(5); a(5,2) = 119/240 - 187/1200*sqrt(5); a(5,3) = -14/75 + 34/375*sqrt(5); a(5,4) = -3/100*sqrt(5); | |
45 a(6,1) = 71/2400 - 587/12000*sqrt(5); a(6,2) = 187/480 - 391/2400*sqrt(5); a(6,3) = -38/75 + 26/375*sqrt(5); a(6,4) = 27/80 - 3/400*sqrt(5); a(6,5) = (1+sqrt(5))/4; | |
46 a(7,1) = -49/480 + 43/160*sqrt(5); a(7,2) = -425/96 + 51/32*sqrt(5); a(7,3) = 52/15 - 4/5*sqrt(5); a(7,4) = -27/16 + 3/16*sqrt(5); a(7,5) = 5/4 - 3/4*sqrt(5); a(7,6) = 5/2 - 1/2*sqrt(5); | |
47 b = [1/12 0 0 0 5/12 5/12 1/12]; | |
48 c = [0, 4/7, 5/7, 6/7, (5-sqrt(5))/10, (5+sqrt(5))/10, 1]; | |
49 otherwise | |
50 error('Runge-Kutta method %s is not implemented', method) | 12 error('Runge-Kutta method %s is not implemented', method) |
13 end | |
14 | |
15 assert(bt.isExplicit()); | |
16 | |
17 s = bt.nStages(); | |
18 a = bt.a(:,1:end-1); | |
19 b = bt.b; | |
20 c = bt.c; | |
51 end | 21 end |