Mercurial > repos > public > sbplib
comparison +sbp/D2Standard.m @ 263:21a180acbd49 operator_remake
Renamed standard class to D2Standard etc, Rewrote class properties.
| author | Martin Almquist <martin.almquist@it.uu.se> |
|---|---|
| date | Thu, 08 Sep 2016 17:50:30 +0200 |
| parents | |
| children | 8a625c5a3633 |
comparison
equal
deleted
inserted
replaced
| 262:23051a86faa4 | 263:21a180acbd49 |
|---|---|
| 1 classdef D2Standard < sbp.OpSet | |
| 2 properties | |
| 3 D1 % SBP operator approximating first derivative | |
| 4 H % Norm matrix | |
| 5 HI % H^-1 | |
| 6 Q % Skew-symmetric matrix | |
| 7 e_1 % Left boundary operator | |
| 8 e_m % Right boundary operator | |
| 9 D2 % SBP operator for second derivative | |
| 10 M % Norm matrix, second derivative | |
| 11 S_1 % Left boundary first derivative | |
| 12 S_m % Right boundary first derivative | |
| 13 m % Number of grid points. | |
| 14 h % Step size | |
| 15 x % grid | |
| 16 borrowing % Struct with borrowing limits for different norm matrices | |
| 17 | |
| 18 end | |
| 19 | |
| 20 methods | |
| 21 function obj = D2Standard(m,L,order) | |
| 22 | |
| 23 obj.h = L/(m-1); | |
| 24 obj.x = linspace(0,L,m)'; | |
| 25 | |
| 26 if order == 2 | |
| 27 [obj.H, obj.HI, obj.D1, obj.D2, obj.e_1,... | |
| 28 obj.e_m, obj.M, obj.Q, obj.S_1, obj.S_m] =... | |
| 29 sbp.implementations.ordinary2(m,obj.h); | |
| 30 obj.borrowing.M.S = 0.4000; | |
| 31 elseif order == 4 | |
| 32 [obj.H, obj.HI, obj.D1, obj.D2, obj.e_1,... | |
| 33 obj.e_m, obj.M, obj.Q, obj.S_1, obj.S_m] =... | |
| 34 sbp.implementations.ordinary4(m,obj.h); | |
| 35 obj.borrowing.M.S = 0.2508; | |
| 36 elseif order == 6 | |
| 37 [obj.H, obj.HI, obj.D1, obj.D2, obj.e_1,... | |
| 38 obj.e_m, obj.M, obj.Q, obj.S_1, obj.S_m] =... | |
| 39 sbp.implementations.ordinary6(m,obj.h); | |
| 40 obj.borrowing.M.S = 0.1878; | |
| 41 elseif order == 8 | |
| 42 [obj.H, obj.HI, obj.D1, obj.D2, obj.e_1,... | |
| 43 obj.e_m, obj.M, obj.Q, obj.S_1, obj.S_m] =... | |
| 44 sbp.implementations.ordinary8(m,obj.h); | |
| 45 obj.borrowing.M.S = 0.0015; | |
| 46 elseif order == 10 | |
| 47 [obj.H, obj.HI, obj.D1, obj.D2, obj.e_1,... | |
| 48 obj.e_m, obj.M, obj.Q, obj.S_1, obj.S_m] =... | |
| 49 sbp.implementations.ordinary10(m,obj.h); | |
| 50 obj.borrowing.M.S = 0.0351; | |
| 51 elseif order == 12 | |
| 52 [obj.H, obj.HI, obj.D1, obj.D2, obj.e_1,... | |
| 53 obj.e_m, obj.M, obj.Q, obj.S_1, obj.S_m] =... | |
| 54 sbp.implementations.ordinary12(m,obj.h); | |
| 55 obj.borrowing.M.S = []; % Need to compute! | |
| 56 else | |
| 57 error('Invalid operator order %d.',order); | |
| 58 end | |
| 59 | |
| 60 obj.m = m; | |
| 61 | |
| 62 end | |
| 63 end | |
| 64 | |
| 65 | |
| 66 end | |
| 67 | |
| 68 | |
| 69 | |
| 70 | |
| 71 |
