Mercurial > repos > public > sbplib
annotate +scheme/Beam.m @ 577:e45c9b56d50d feature/grids
Add an Empty grid class
The need turned up for the flexural code when we may or may not have a grid for the open water and want to plot that solution.
In case there is no open water we need an empty grid to plot the empty gridfunction against to avoid errors.
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Thu, 07 Sep 2017 09:16:12 +0200 |
parents | dfb27a7e801f |
children | 4ced7d47bd1f |
rev | line source |
---|---|
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
1 classdef Beam < scheme.Scheme |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
2 properties |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
3 order % Order accuracy for the approximation |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
4 grid |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
5 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
6 D % non-stabalized scheme operator |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
7 alpha |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
8 |
242 | 9 h |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
10 H % Discrete norm |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
11 Hi |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
12 |
328
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
13 e_l, e_r |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
14 d1_l, d1_r |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
15 d2_l, d2_r |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
16 d3_l, d3_r |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
17 gamm |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
18 delt |
242 | 19 alphaII |
20 alphaIII | |
240
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
21 |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
22 opt |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
23 end |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
24 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
25 methods |
240
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
26 function obj = Beam(grid, order, alpha, opsGen, opt) |
236
8592358a3935
Beam: Added tuning as a parameter to contructor.
Jonatan Werpers <jonatan@werpers.com>
parents:
235
diff
changeset
|
27 default_arg('alpha', -1); |
240
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
28 |
328
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
29 % default_arg('opsGen', @sbp.D4); |
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
30 default_arg('opsGen', @sbp.D4Variable); % Supposed to be better |
240
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
31 |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
32 opt_default.interface_l.tuning = 1.1; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
33 opt_default.interface_l.tau = []; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
34 opt_default.interface_l.sig = []; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
35 opt_default.interface_r.tuning = 1.1; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
36 opt_default.interface_r.tau = []; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
37 opt_default.interface_r.sig = []; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
38 default_struct('opt', opt_default); |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
39 |
176
d095b5396103
Fixed some bugs in Beam schemes.
Jonatan Werpers <jonatan@werpers.com>
parents:
175
diff
changeset
|
40 if ~isa(grid, 'grid.Cartesian') || grid.D() ~= 1 |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
41 error('Grid must be 1d cartesian'); |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
42 end |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
43 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
44 obj.grid = grid; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
45 obj.order = order; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
46 obj.alpha = alpha; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
47 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
48 m = grid.m; |
176
d095b5396103
Fixed some bugs in Beam schemes.
Jonatan Werpers <jonatan@werpers.com>
parents:
175
diff
changeset
|
49 h = grid.scaling(); |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
50 |
328
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
51 x_lim = {grid.x{1}(1), grid.x{1}(end)}; |
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
52 ops = opsGen(m, x_lim, order); |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
53 |
328
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
54 D4 = ops.D4; |
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
55 obj.H = ops.H; |
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
56 obj.Hi = ops.HI; |
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
57 obj.e_l = ops.e_l; |
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
58 obj.e_r = ops.e_r; |
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
59 obj.d1_l = ops.d1_l; |
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
60 obj.d1_r = ops.d1_r; |
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
61 obj.d2_l = ops.d2_l; |
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
62 obj.d2_r = ops.d2_r; |
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
63 obj.d3_l = ops.d3_l; |
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
64 obj.d3_r = ops.d3_r; |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
65 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
66 obj.D = alpha*D4; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
67 |
328
31d6698c1edf
Clean up and fixing of new operators
Jonatan Werpers <jonatan@werpers.com>
parents:
245
diff
changeset
|
68 alphaII = ops.borrowing.N.S2/2; |
240
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
69 alphaIII = ops.borrowing.N.S3/2; |
239
ba56e0d621f2
Beam: Added ability to pick alphaII and alphaIII to control tau and sigma.
Jonatan Werpers <jonatan@werpers.com>
parents:
236
diff
changeset
|
70 |
ba56e0d621f2
Beam: Added ability to pick alphaII and alphaIII to control tau and sigma.
Jonatan Werpers <jonatan@werpers.com>
parents:
236
diff
changeset
|
71 obj.gamm = h*alphaII; |
ba56e0d621f2
Beam: Added ability to pick alphaII and alphaIII to control tau and sigma.
Jonatan Werpers <jonatan@werpers.com>
parents:
236
diff
changeset
|
72 obj.delt = h^3*alphaIII; |
242 | 73 obj.alphaII = alphaII; |
74 obj.alphaIII = alphaIII; | |
75 obj.h = h; | |
240
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
76 obj.opt = opt; |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
77 end |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
78 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
79 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
80 % Closure functions return the opertors applied to the own doamin to close the boundary |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
81 % Penalty functions return the opertors to force the solution. In the case of an interface it returns the operator applied to the other doamin. |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
82 % boundary is a string specifying the boundary e.g. 'l','r' or 'e','w','n','s'. |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
83 % type is a string specifying the type of boundary condition if there are several. |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
84 % neighbour_scheme is an instance of Scheme that should be interfaced to. |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
85 % neighbour_boundary is a string specifying which boundary to interface to. |
220
5df8d20281fe
Made scheme boundary_condition return a cell array of penalties if there are several of them.
Jonatan Werpers <jonatan@werpers.com>
parents:
176
diff
changeset
|
86 function [closure, penalty] = boundary_condition(obj,boundary,type) |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
87 default_arg('type','dn'); |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
88 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
89 [e, d1, d2, d3, s] = obj.get_boundary_ops(boundary); |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
90 gamm = obj.gamm; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
91 delt = obj.delt; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
92 |
545 | 93 |
94 % TODO: Can this be simplifed? Can I handle conditions on u on its own, u_x on its own ... | |
95 | |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
96 switch type |
339
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
97 case {'dn', 'clamped'} % Dirichlet-neumann boundary condition |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
98 alpha = obj.alpha; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
99 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
100 % tau1 < -alpha^2/gamma |
220
5df8d20281fe
Made scheme boundary_condition return a cell array of penalties if there are several of them.
Jonatan Werpers <jonatan@werpers.com>
parents:
176
diff
changeset
|
101 % tuning = 2; |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
102 tuning = 1.1; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
103 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
104 tau1 = tuning * alpha/delt; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
105 tau4 = s*alpha; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
106 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
107 sig2 = tuning * alpha/gamm; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
108 sig3 = -s*alpha; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
109 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
110 tau = tau1*e+tau4*d3; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
111 sig = sig2*d1+sig3*d2; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
112 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
113 closure = obj.Hi*(tau*e' + sig*d1'); |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
114 |
223
96dedf892910
Fixed sign error in beam BC penalties.
Jonatan Werpers <jonatan@werpers.com>
parents:
220
diff
changeset
|
115 penalty{1} = -obj.Hi*tau; |
96dedf892910
Fixed sign error in beam BC penalties.
Jonatan Werpers <jonatan@werpers.com>
parents:
220
diff
changeset
|
116 penalty{2} = -obj.Hi*sig; |
339
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
117 |
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
118 |
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
119 case {'free'} |
340
25ae8333ce2b
scheme.Beam: Fixed stability of free bc.
Jonatan Werpers <jonatan@werpers.com>
parents:
339
diff
changeset
|
120 a = obj.alpha; |
339
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
121 |
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
122 tau = s*a*d1; |
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
123 sig = -s*a*e; |
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
124 |
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
125 closure = obj.Hi*(tau*d2' + sig*d3'); |
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
126 penalty{1} = -obj.Hi*tau; |
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
127 penalty{1} = -obj.Hi*sig; |
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
128 |
3135e13ae509
Implemented free BC. Not tested yet.
Jonatan Werpers <jonatan@werpers.com>
parents:
329
diff
changeset
|
129 |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
130 otherwise % Unknown, boundary condition |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
131 error('No such boundary condition: type = %s',type); |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
132 end |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
133 end |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
134 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
135 function [closure, penalty] = interface(obj,boundary,neighbour_scheme,neighbour_boundary) |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
136 % u denotes the solution in the own domain |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
137 % v denotes the solution in the neighbour domain |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
138 [e_u,d1_u,d2_u,d3_u,s_u] = obj.get_boundary_ops(boundary); |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
139 [e_v,d1_v,d2_v,d3_v,s_v] = neighbour_scheme.get_boundary_ops(neighbour_boundary); |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
140 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
141 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
142 alpha_u = obj.alpha; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
143 alpha_v = neighbour_scheme.alpha; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
144 |
242 | 145 |
240
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
146 switch boundary |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
147 case 'l' |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
148 interface_opt = obj.opt.interface_l; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
149 case 'r' |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
150 interface_opt = obj.opt.interface_r; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
151 end |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
152 |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
153 |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
154 if isempty(interface_opt.tau) && isempty(interface_opt.sig) |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
155 gamm_u = obj.gamm; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
156 delt_u = obj.delt; |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
157 |
240
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
158 gamm_v = neighbour_scheme.gamm; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
159 delt_v = neighbour_scheme.delt; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
160 |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
161 tuning = interface_opt.tuning; |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
162 |
240
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
163 tau1 = ((alpha_u/2)/delt_u + (alpha_v/2)/delt_v)/2*tuning; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
164 sig2 = ((alpha_u/2)/gamm_u + (alpha_v/2)/gamm_v)/2*tuning; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
165 else |
242 | 166 h_u = obj.h; |
167 h_v = neighbour_scheme.h; | |
168 | |
169 switch neighbour_boundary | |
170 case 'l' | |
171 neighbour_interface_opt = neighbour_scheme.opt.interface_l; | |
172 case 'r' | |
173 neighbour_interface_opt = neighbour_scheme.opt.interface_r; | |
174 end | |
175 | |
176 tau_u = interface_opt.tau; | |
177 sig_u = interface_opt.sig; | |
178 tau_v = neighbour_interface_opt.tau; | |
179 sig_v = neighbour_interface_opt.sig; | |
180 | |
181 tau1 = tau_u/h_u^3 + tau_v/h_v^3; | |
182 sig2 = sig_u/h_u + sig_v/h_v; | |
240
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
183 end |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
184 |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
185 tau4 = s_u*alpha_u/2; |
46256fffa329
Added some stuff for default structs. Improved interface for beam.
Jonatan Werpers <jonatan@werpers.com>
parents:
239
diff
changeset
|
186 sig3 = -s_u*alpha_u/2; |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
187 phi2 = s_u*1/2; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
188 psi1 = -s_u*1/2; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
189 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
190 tau = tau1*e_u + tau4*d3_u; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
191 sig = sig2*d1_u + sig3*d2_u ; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
192 phi = phi2*d1_u ; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
193 psi = psi1*e_u ; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
194 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
195 closure = obj.Hi*(tau*e_u' + sig*d1_u' + phi*alpha_u*d2_u' + psi*alpha_u*d3_u'); |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
196 penalty = -obj.Hi*(tau*e_v' + sig*d1_v' + phi*alpha_v*d2_v' + psi*alpha_v*d3_v'); |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
197 end |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
198 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
199 % Returns the boundary ops and sign for the boundary specified by the string boundary. |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
200 % The right boundary is considered the positive boundary |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
201 function [e, d1, d2, d3, s] = get_boundary_ops(obj,boundary) |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
202 switch boundary |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
203 case 'l' |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
204 e = obj.e_l; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
205 d1 = obj.d1_l; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
206 d2 = obj.d2_l; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
207 d3 = obj.d3_l; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
208 s = -1; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
209 case 'r' |
176
d095b5396103
Fixed some bugs in Beam schemes.
Jonatan Werpers <jonatan@werpers.com>
parents:
175
diff
changeset
|
210 e = obj.e_r; |
d095b5396103
Fixed some bugs in Beam schemes.
Jonatan Werpers <jonatan@werpers.com>
parents:
175
diff
changeset
|
211 d1 = obj.d1_r; |
d095b5396103
Fixed some bugs in Beam schemes.
Jonatan Werpers <jonatan@werpers.com>
parents:
175
diff
changeset
|
212 d2 = obj.d2_r; |
d095b5396103
Fixed some bugs in Beam schemes.
Jonatan Werpers <jonatan@werpers.com>
parents:
175
diff
changeset
|
213 d3 = obj.d3_r; |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
214 s = 1; |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
215 otherwise |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
216 error('No such boundary: boundary = %s',boundary); |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
217 end |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
218 end |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
219 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
220 function N = size(obj) |
224
05304d7792dc
Fixed type in scheme.Beam
Jonatan Werpers <jonatan@werpers.com>
parents:
223
diff
changeset
|
221 N = obj.grid.N; |
175
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
222 end |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
223 |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
224 end |
8f22829b69d0
Added and upgraded schemes for the beam equation in 1d and 2d.
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
225 end |