Mercurial > repos > public > sbplib
annotate +time/+rk/get_rk4_time_step.m @ 888:8732d6bd9890 feature/timesteppers
Add general Runge-Kutta class
- Add a general Runge-Kutta class which time integrates the solution based on coefficients obtained from a Butcher tableau
- Add butcher tableau which returns coefficents for the specified Runge-Kutta method
- Remove RungKutta4proper, since obsolete
author | Vidar Stiernström <vidar.stiernstrom@it.uu.se> |
---|---|
date | Thu, 15 Nov 2018 17:10:01 -0800 |
parents | 50d5a3843099 |
children | 1a265a376b36 |
rev | line source |
---|---|
0 | 1 % Calculate the size of the largest time step given the largest evalue for a operator with pure imaginary e.values. |
2 function k = get_rk4_time_step(lambda,l_type) | |
3 default_arg('l_type','complex') | |
4 | |
5 rad = abs(lambda); | |
6 if strcmp(l_type,'real') | |
7 % Real eigenvalue | |
8 % kl > -2.7852 | |
9 k = 2.7852/rad; | |
10 | |
11 elseif strcmp(l_type,'imag') | |
12 % Imaginary eigenvalue | |
13 % |kl| < 2.8284 | |
14 k = 2.8284/rad; | |
15 elseif strcmp(l_type,'complex') | |
16 % |kl| < 2.5 | |
17 k = 2.5/rad; | |
18 else | |
19 error('l_type must be one of ''real'',''imag'' or ''complex''.') | |
20 end | |
21 end |