Mercurial > repos > public > sbplib
annotate +time/Rk4SecondOrderNonlin.m @ 984:0585a2ee7ee7 feature/timesteppers
Inline the rk.rungekutta_4 function.
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Tue, 08 Jan 2019 12:19:33 +0100 |
parents | f5e14e5986b5 |
children |
rev | line source |
---|---|
0 | 1 classdef Rk4SecondOrderNonlin < time.Timestepper |
2 properties | |
3 F | |
4 k | |
5 t | |
6 w | |
7 m | |
8 | |
9 D | |
10 E | |
11 S | |
12 | |
13 n | |
14 end | |
15 | |
16 | |
17 methods | |
18 function obj = Rk4SecondOrderNonlin(D, E, S, k, t0, v0, v0t) | |
1
5ae4f23d9130
Added CdiffNonlin timestepper. Probably fixed a bug with Cdiff. Added default arguments to Rk4SecondOrderNonlin.
Jonatan Werpers <jonatan@werpers.com>
parents:
0
diff
changeset
|
19 default_arg('S',0); |
5ae4f23d9130
Added CdiffNonlin timestepper. Probably fixed a bug with Cdiff. Added default arguments to Rk4SecondOrderNonlin.
Jonatan Werpers <jonatan@werpers.com>
parents:
0
diff
changeset
|
20 default_arg('E',0); |
0 | 21 |
30
cd2e28c5ecd2
Corrected parameter treatment in nonlin timesteppers.
Jonatan Werpers <jonatan@werpers.com>
parents:
28
diff
changeset
|
22 if isnumeric(S) |
cd2e28c5ecd2
Corrected parameter treatment in nonlin timesteppers.
Jonatan Werpers <jonatan@werpers.com>
parents:
28
diff
changeset
|
23 S = @(v,t)S; |
0 | 24 end |
25 | |
30
cd2e28c5ecd2
Corrected parameter treatment in nonlin timesteppers.
Jonatan Werpers <jonatan@werpers.com>
parents:
28
diff
changeset
|
26 if isnumeric(E) |
cd2e28c5ecd2
Corrected parameter treatment in nonlin timesteppers.
Jonatan Werpers <jonatan@werpers.com>
parents:
28
diff
changeset
|
27 E = @(v)E; |
0 | 28 end |
29 | |
30 obj.k = k; | |
31 obj.t = t0; | |
32 obj.w = [v0; v0t]; | |
33 | |
34 m = length(v0); | |
35 function wt = F(w,t) | |
36 v = w(1:m); | |
37 vt = w(m+1:end); | |
38 | |
39 % Def: w = [v; vt] | |
40 wt(1:m,1) = vt; | |
41 wt(m+1:2*m,1) = D(v)*v + E(v)*vt + S(v,t); | |
42 | |
43 end | |
44 | |
45 obj.F = @F; | |
46 obj.D = D; | |
47 obj.E = E; | |
48 obj.S = S; | |
49 obj.m = m; | |
13
b18d3d201a71
Fixed initialization of step counter in timesteppers.
Jonatan Werpers <jonatan@werpers.com>
parents:
1
diff
changeset
|
50 obj.n = 0; |
0 | 51 end |
52 | |
53 function [v,t] = getV(obj) | |
54 v = obj.w(1:end/2); | |
55 t = obj.t; | |
56 end | |
57 | |
58 function [vt,t] = getVt(obj) | |
59 vt = obj.w(end/2+1:end); | |
60 t = obj.t; | |
61 end | |
62 | |
63 function obj = step(obj) | |
984
0585a2ee7ee7
Inline the rk.rungekutta_4 function.
Jonatan Werpers <jonatan@werpers.com>
parents:
889
diff
changeset
|
64 w = obj.w; |
0585a2ee7ee7
Inline the rk.rungekutta_4 function.
Jonatan Werpers <jonatan@werpers.com>
parents:
889
diff
changeset
|
65 k = obj.k; |
0585a2ee7ee7
Inline the rk.rungekutta_4 function.
Jonatan Werpers <jonatan@werpers.com>
parents:
889
diff
changeset
|
66 |
0585a2ee7ee7
Inline the rk.rungekutta_4 function.
Jonatan Werpers <jonatan@werpers.com>
parents:
889
diff
changeset
|
67 k1 = obj.F(t, w); |
0585a2ee7ee7
Inline the rk.rungekutta_4 function.
Jonatan Werpers <jonatan@werpers.com>
parents:
889
diff
changeset
|
68 k2 = obj.F(t + 0.5*k, w + 0.5*k*k1); |
0585a2ee7ee7
Inline the rk.rungekutta_4 function.
Jonatan Werpers <jonatan@werpers.com>
parents:
889
diff
changeset
|
69 k3 = obj.F(t + 0.5*k, w + 0.5*k*k2); |
0585a2ee7ee7
Inline the rk.rungekutta_4 function.
Jonatan Werpers <jonatan@werpers.com>
parents:
889
diff
changeset
|
70 k4 = obj.F(t + k, w + k*k3); |
0585a2ee7ee7
Inline the rk.rungekutta_4 function.
Jonatan Werpers <jonatan@werpers.com>
parents:
889
diff
changeset
|
71 |
0585a2ee7ee7
Inline the rk.rungekutta_4 function.
Jonatan Werpers <jonatan@werpers.com>
parents:
889
diff
changeset
|
72 obj.w = w + k*(1/6)*(k1+2*(k2+k3)+k4); |
0 | 73 obj.t = obj.t + obj.k; |
74 obj.n = obj.n + 1; | |
75 end | |
76 end | |
77 | |
78 | |
79 methods (Static) | |
80 function k = getTimeStep(lambda) | |
81 k = rk4.get_rk4_time_step(lambda); | |
82 end | |
83 end | |
84 | |
85 end |