Mercurial > repos > public > sbplib
annotate +scheme/Utux2d.m @ 1021:cc61dde120cd feature/advectionRV
Add upwind dissipation to the operator inside Utux2d
author | Vidar Stiernström <vidar.stiernstrom@it.uu.se> |
---|---|
date | Wed, 19 Dec 2018 20:00:27 +0100 |
parents | f029b97dbc72 |
children | 234c1c02ea39 |
rev | line source |
---|---|
950
cab047de7f5d
Rename *2D schemes to *2d
Jonatan Werpers <jonatan@werpers.com>
parents:
948
diff
changeset
|
1 classdef Utux2d < scheme.Scheme |
591 | 2 properties |
3 m % Number of points in each direction, possibly a vector | |
4 h % Grid spacing | |
5 grid % Grid | |
6 order % Order accuracy for the approximation | |
7 v0 % Initial data | |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
8 |
591 | 9 a % Wave speed a = [a1, a2]; |
743
f4595f14d696
Change schemes to work for special coefficients.
Martin Almquist <malmquist@stanford.edu>
parents:
666
diff
changeset
|
10 % Can either be a constant vector or a cell array of function handles. |
591 | 11 |
12 H % Discrete norm | |
595 | 13 H_x, H_y % Norms in the x and y directions |
14 Hi, Hx, Hy, Hxi, Hyi % Kroneckered norms | |
591 | 15 |
16 % Derivatives | |
17 Dx, Dy | |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
18 |
1019
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
19 % Dissipation Operators |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
20 DissOpx, DissOpy |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
21 |
591 | 22 % Boundary operators |
23 e_w, e_e, e_s, e_n | |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
24 |
591 | 25 D % Total discrete operator |
26 end | |
27 | |
28 | |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
29 methods |
1021
cc61dde120cd
Add upwind dissipation to the operator inside Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
1019
diff
changeset
|
30 function obj = Utux2d(g ,order, opSet, a, fluxSplitting) |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
31 |
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
32 default_arg('a',1/sqrt(2)*[1, 1]); |
591 | 33 default_arg('opSet',@sbp.D2Standard); |
1021
cc61dde120cd
Add upwind dissipation to the operator inside Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
1019
diff
changeset
|
34 default_arg('fluxSplitting',[]); |
743
f4595f14d696
Change schemes to work for special coefficients.
Martin Almquist <malmquist@stanford.edu>
parents:
666
diff
changeset
|
35 |
948
3dd7f87c9a1b
Use assertType(...) instead of assert(isa(...))
Jonatan Werpers <jonatan@werpers.com>
parents:
942
diff
changeset
|
36 assertType(g, 'grid.Cartesian'); |
743
f4595f14d696
Change schemes to work for special coefficients.
Martin Almquist <malmquist@stanford.edu>
parents:
666
diff
changeset
|
37 if iscell(a) |
f4595f14d696
Change schemes to work for special coefficients.
Martin Almquist <malmquist@stanford.edu>
parents:
666
diff
changeset
|
38 a1 = grid.evalOn(g, a{1}); |
f4595f14d696
Change schemes to work for special coefficients.
Martin Almquist <malmquist@stanford.edu>
parents:
666
diff
changeset
|
39 a2 = grid.evalOn(g, a{2}); |
f4595f14d696
Change schemes to work for special coefficients.
Martin Almquist <malmquist@stanford.edu>
parents:
666
diff
changeset
|
40 a = {spdiag(a1), spdiag(a2)}; |
f4595f14d696
Change schemes to work for special coefficients.
Martin Almquist <malmquist@stanford.edu>
parents:
666
diff
changeset
|
41 else |
f4595f14d696
Change schemes to work for special coefficients.
Martin Almquist <malmquist@stanford.edu>
parents:
666
diff
changeset
|
42 a = {a(1), a(2)}; |
f4595f14d696
Change schemes to work for special coefficients.
Martin Almquist <malmquist@stanford.edu>
parents:
666
diff
changeset
|
43 end |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
44 |
591 | 45 m = g.size(); |
46 m_x = m(1); | |
47 m_y = m(2); | |
48 m_tot = g.N(); | |
49 | |
595 | 50 xlim = {g.x{1}(1), g.x{1}(end)}; |
51 ylim = {g.x{2}(1), g.x{2}(end)}; | |
591 | 52 obj.grid = g; |
53 | |
54 % Operator sets | |
55 ops_x = opSet(m_x, xlim, order); | |
56 ops_y = opSet(m_y, ylim, order); | |
57 Ix = speye(m_x); | |
58 Iy = speye(m_y); | |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
59 |
591 | 60 % Norms |
61 Hx = ops_x.H; | |
62 Hy = ops_y.H; | |
63 Hxi = ops_x.HI; | |
64 Hyi = ops_y.HI; | |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
65 |
595 | 66 obj.H_x = Hx; |
67 obj.H_y = Hy; | |
591 | 68 obj.H = kron(Hx,Hy); |
69 obj.Hi = kron(Hxi,Hyi); | |
70 obj.Hx = kron(Hx,Iy); | |
71 obj.Hy = kron(Ix,Hy); | |
72 obj.Hxi = kron(Hxi,Iy); | |
73 obj.Hyi = kron(Ix,Hyi); | |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
74 |
591 | 75 % Derivatives |
1019
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
76 if (isequal(opSet,@sbp.D1Upwind)) |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
77 Dx = (ops_x.Dp + ops_x.Dm)/2; |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
78 Dy = (ops_y.Dp + ops_y.Dm)/2; |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
79 DissOpx = (ops_x.Dm - ops_x.Dp)/2; |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
80 DissOpy = (ops_y.Dm - ops_y.Dp)/2; |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
81 obj.Dx = kron(Dx,Iy); |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
82 obj.Dy = kron(Ix,Dy); |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
83 obj.DissOpx = kron(DissOpx,Iy); |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
84 obj.DissOpy = kron(Ix,DissOpy); |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
85 else |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
86 Dx = ops_x.D1; |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
87 Dy = ops_y.D1; |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
88 obj.Dx = kron(Dx,Iy); |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
89 obj.Dy = kron(Ix,Dy); |
f029b97dbc72
Support upwind opSet in Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
950
diff
changeset
|
90 end |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
91 |
591 | 92 % Boundary operators |
93 obj.e_w = kr(ops_x.e_l, Iy); | |
94 obj.e_e = kr(ops_x.e_r, Iy); | |
95 obj.e_s = kr(Ix, ops_y.e_l); | |
96 obj.e_n = kr(Ix, ops_y.e_r); | |
97 | |
98 obj.m = m; | |
99 obj.h = [ops_x.h ops_y.h]; | |
100 obj.order = order; | |
595 | 101 obj.a = a; |
1021
cc61dde120cd
Add upwind dissipation to the operator inside Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
1019
diff
changeset
|
102 |
cc61dde120cd
Add upwind dissipation to the operator inside Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
1019
diff
changeset
|
103 if (isequal(opSet,@sbp.D1Upwind)) |
cc61dde120cd
Add upwind dissipation to the operator inside Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
1019
diff
changeset
|
104 obj.D = -(a{1}*obj.Dx + a{2}*obj.Dy + fluxSplitting{1}*obj.DissOpx + fluxSplitting{2}*obj.DissOpy); |
cc61dde120cd
Add upwind dissipation to the operator inside Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
1019
diff
changeset
|
105 else |
cc61dde120cd
Add upwind dissipation to the operator inside Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
1019
diff
changeset
|
106 obj.D = -(a{1}*obj.Dx + a{2}*obj.Dy); |
cc61dde120cd
Add upwind dissipation to the operator inside Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
1019
diff
changeset
|
107 end |
cc61dde120cd
Add upwind dissipation to the operator inside Utux2d
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
1019
diff
changeset
|
108 |
591 | 109 end |
110 % Closure functions return the opertors applied to the own domain to close the boundary | |
111 % Penalty functions return the opertors to force the solution. In the case of an interface it returns the operator applied to the other doamin. | |
112 % boundary is a string specifying the boundary e.g. 'l','r' or 'e','w','n','s'. | |
113 % type is a string specifying the type of boundary condition if there are several. | |
114 % data is a function returning the data that should be applied at the boundary. | |
115 % neighbour_scheme is an instance of Scheme that should be interfaced to. | |
116 % neighbour_boundary is a string specifying which boundary to interface to. | |
117 function [closure, penalty] = boundary_condition(obj,boundary,type) | |
118 default_arg('type','dirichlet'); | |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
119 |
591 | 120 sigma = -1; % Scalar penalty parameter |
121 switch boundary | |
122 case {'w','W','west','West'} | |
743
f4595f14d696
Change schemes to work for special coefficients.
Martin Almquist <malmquist@stanford.edu>
parents:
666
diff
changeset
|
123 tau = sigma*obj.a{1}*obj.e_w*obj.H_y; |
591 | 124 closure = obj.Hi*tau*obj.e_w'; |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
125 |
591 | 126 case {'s','S','south','South'} |
743
f4595f14d696
Change schemes to work for special coefficients.
Martin Almquist <malmquist@stanford.edu>
parents:
666
diff
changeset
|
127 tau = sigma*obj.a{2}*obj.e_s*obj.H_x; |
591 | 128 closure = obj.Hi*tau*obj.e_s'; |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
129 end |
591 | 130 penalty = -obj.Hi*tau; |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
131 |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
132 end |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
133 |
942
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
134 % type Struct that specifies the interface coupling. |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
135 % Fields: |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
136 % -- couplingType String, type of interface coupling |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
137 % % Default: 'upwind'. Other: 'centered' |
942
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
138 % -- interpolation: type of interpolation, default 'none' |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
139 % -- interpolationDamping: damping on upstream and downstream sides, when using interpolation. |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
140 % Default {0,0} gives zero damping. |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
141 function [closure, penalty] = interface(obj,boundary,neighbour_scheme,neighbour_boundary,type) |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
142 |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
143 defaultType.couplingType = 'upwind'; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
144 defaultType.interpolation = 'none'; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
145 defaultType.interpolationDamping = {0,0}; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
146 default_struct('type', defaultType); |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
147 |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
148 switch type.interpolation |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
149 case {'none', ''} |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
150 [closure, penalty] = interfaceStandard(obj,boundary,neighbour_scheme,neighbour_boundary,type); |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
151 case {'op','OP'} |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
152 [closure, penalty] = interfaceNonConforming(obj,boundary,neighbour_scheme,neighbour_boundary,type); |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
153 otherwise |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
154 error('Unknown type of interpolation: %s ', type.interpolation); |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
155 end |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
156 end |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
157 |
942
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
158 function [closure, penalty] = interfaceStandard(obj,boundary,neighbour_scheme,neighbour_boundary,type) |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
159 couplingType = type.couplingType; |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
160 |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
161 % Get neighbour boundary operator |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
162 switch neighbour_boundary |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
163 case {'e','E','east','East'} |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
164 e_neighbour = neighbour_scheme.e_e; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
165 case {'w','W','west','West'} |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
166 e_neighbour = neighbour_scheme.e_w; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
167 case {'n','N','north','North'} |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
168 e_neighbour = neighbour_scheme.e_n; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
169 case {'s','S','south','South'} |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
170 e_neighbour = neighbour_scheme.e_s; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
171 end |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
172 |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
173 switch couplingType |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
174 |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
175 % Upwind coupling (energy dissipation) |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
176 case 'upwind' |
605
0f9d20dbb7ce
Add centered interface coupling in addition to upwind
Martin Almquist <malmquist@stanford.edu>
parents:
595
diff
changeset
|
177 sigma_ds = -1; %"Downstream" penalty |
0f9d20dbb7ce
Add centered interface coupling in addition to upwind
Martin Almquist <malmquist@stanford.edu>
parents:
595
diff
changeset
|
178 sigma_us = 0; %"Upstream" penalty |
0f9d20dbb7ce
Add centered interface coupling in addition to upwind
Martin Almquist <malmquist@stanford.edu>
parents:
595
diff
changeset
|
179 |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
180 % Energy-preserving coupling (no energy dissipation) |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
181 case 'centered' |
605
0f9d20dbb7ce
Add centered interface coupling in addition to upwind
Martin Almquist <malmquist@stanford.edu>
parents:
595
diff
changeset
|
182 sigma_ds = -1/2; %"Downstream" penalty |
0f9d20dbb7ce
Add centered interface coupling in addition to upwind
Martin Almquist <malmquist@stanford.edu>
parents:
595
diff
changeset
|
183 sigma_us = 1/2; %"Upstream" penalty |
0f9d20dbb7ce
Add centered interface coupling in addition to upwind
Martin Almquist <malmquist@stanford.edu>
parents:
595
diff
changeset
|
184 |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
185 otherwise |
942
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
186 error(['Interface coupling type ' couplingType ' is not available.']) |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
187 end |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
188 |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
189 switch boundary |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
190 case {'w','W','west','West'} |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
191 tau = sigma_ds*obj.a{1}*obj.e_w*obj.H_y; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
192 closure = obj.Hi*tau*obj.e_w'; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
193 penalty = -obj.Hi*tau*e_neighbour'; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
194 case {'e','E','east','East'} |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
195 tau = sigma_us*obj.a{1}*obj.e_e*obj.H_y; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
196 closure = obj.Hi*tau*obj.e_e'; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
197 penalty = -obj.Hi*tau*e_neighbour'; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
198 case {'s','S','south','South'} |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
199 tau = sigma_ds*obj.a{2}*obj.e_s*obj.H_x; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
200 closure = obj.Hi*tau*obj.e_s'; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
201 penalty = -obj.Hi*tau*e_neighbour'; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
202 case {'n','N','north','North'} |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
203 tau = sigma_us*obj.a{2}*obj.e_n*obj.H_x; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
204 closure = obj.Hi*tau*obj.e_n'; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
205 penalty = -obj.Hi*tau*e_neighbour'; |
605
0f9d20dbb7ce
Add centered interface coupling in addition to upwind
Martin Almquist <malmquist@stanford.edu>
parents:
595
diff
changeset
|
206 end |
610
b7b3c11fab4d
Add interpolation to scheme
Martin Almquist <malmquist@stanford.edu>
parents:
605
diff
changeset
|
207 |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
208 end |
610
b7b3c11fab4d
Add interpolation to scheme
Martin Almquist <malmquist@stanford.edu>
parents:
605
diff
changeset
|
209 |
942
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
210 function [closure, penalty] = interfaceNonConforming(obj,boundary,neighbour_scheme,neighbour_boundary,type) |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
211 |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
212 % User can request special interpolation operators by specifying type.interpOpSet |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
213 default_field(type, 'interpOpSet', @sbp.InterpOpsOP); |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
214 |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
215 interpOpSet = type.interpOpSet; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
216 couplingType = type.couplingType; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
217 interpolationDamping = type.interpolationDamping; |
610
b7b3c11fab4d
Add interpolation to scheme
Martin Almquist <malmquist@stanford.edu>
parents:
605
diff
changeset
|
218 |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
219 % Get neighbour boundary operator |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
220 switch neighbour_boundary |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
221 case {'e','E','east','East'} |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
222 e_neighbour = neighbour_scheme.e_e; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
223 case {'w','W','west','West'} |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
224 e_neighbour = neighbour_scheme.e_w; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
225 case {'n','N','north','North'} |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
226 e_neighbour = neighbour_scheme.e_n; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
227 case {'s','S','south','South'} |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
228 e_neighbour = neighbour_scheme.e_s; |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
229 end |
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
230 |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
231 switch couplingType |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
232 |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
233 % Upwind coupling (energy dissipation) |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
234 case 'upwind' |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
235 sigma_ds = -1; %"Downstream" penalty |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
236 sigma_us = 0; %"Upstream" penalty |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
237 |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
238 % Energy-preserving coupling (no energy dissipation) |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
239 case 'centered' |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
240 sigma_ds = -1/2; %"Downstream" penalty |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
241 sigma_us = 1/2; %"Upstream" penalty |
666
2d85f17a8aec
Add possibility for damping terms at interpolation interface.
Martin Almquist <malmquist@stanford.edu>
parents:
610
diff
changeset
|
242 |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
243 otherwise |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
244 error(['Interface coupling type ' couplingType ' is not available.']) |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
245 end |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
246 |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
247 int_damp_us = interpolationDamping{1}; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
248 int_damp_ds = interpolationDamping{2}; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
249 |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
250 % u denotes the solution in the own domain |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
251 % v denotes the solution in the neighbour domain |
942
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
252 % Find the number of grid points along the interface |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
253 switch boundary |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
254 case {'w','e'} |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
255 m_u = obj.m(2); |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
256 case {'s','n'} |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
257 m_u = obj.m(1); |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
258 end |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
259 m_v = size(e_neighbour, 2); |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
260 |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
261 % Build interpolation operators |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
262 intOps = interpOpSet(m_u, m_v, obj.order, neighbour_scheme.order); |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
263 Iu2v = intOps.Iu2v; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
264 Iv2u = intOps.Iv2u; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
265 |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
266 I_local2neighbour_ds = intOps.Iu2v.bad; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
267 I_local2neighbour_us = intOps.Iu2v.good; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
268 I_neighbour2local_ds = intOps.Iv2u.good; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
269 I_neighbour2local_us = intOps.Iv2u.bad; |
914
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
270 |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
271 I_back_forth_us = I_neighbour2local_us*I_local2neighbour_us; |
50cafc4b9e40
Make default_field overwrite if field exists but is empty. Refactor interface method in Utux2d.
Martin Almquist <malmquist@stanford.edu>
parents:
910
diff
changeset
|
272 I_back_forth_ds = I_neighbour2local_ds*I_local2neighbour_ds; |
666
2d85f17a8aec
Add possibility for damping terms at interpolation interface.
Martin Almquist <malmquist@stanford.edu>
parents:
610
diff
changeset
|
273 |
2d85f17a8aec
Add possibility for damping terms at interpolation interface.
Martin Almquist <malmquist@stanford.edu>
parents:
610
diff
changeset
|
274 |
942
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
275 switch boundary |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
276 case {'w','W','west','West'} |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
277 tau = sigma_ds*obj.a{1}*obj.e_w*obj.H_y; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
278 closure = obj.Hi*tau*obj.e_w'; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
279 penalty = -obj.Hi*tau*I_neighbour2local_ds*e_neighbour'; |
666
2d85f17a8aec
Add possibility for damping terms at interpolation interface.
Martin Almquist <malmquist@stanford.edu>
parents:
610
diff
changeset
|
280 |
942
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
281 beta = int_damp_ds*obj.a{1}... |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
282 *obj.e_w*obj.H_y; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
283 closure = closure + obj.Hi*beta*I_back_forth_ds*obj.e_w' - obj.Hi*beta*obj.e_w'; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
284 case {'e','E','east','East'} |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
285 tau = sigma_us*obj.a{1}*obj.e_e*obj.H_y; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
286 closure = obj.Hi*tau*obj.e_e'; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
287 penalty = -obj.Hi*tau*I_neighbour2local_us*e_neighbour'; |
666
2d85f17a8aec
Add possibility for damping terms at interpolation interface.
Martin Almquist <malmquist@stanford.edu>
parents:
610
diff
changeset
|
288 |
942
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
289 beta = int_damp_us*obj.a{1}... |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
290 *obj.e_e*obj.H_y; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
291 closure = closure + obj.Hi*beta*I_back_forth_us*obj.e_e' - obj.Hi*beta*obj.e_e'; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
292 case {'s','S','south','South'} |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
293 tau = sigma_ds*obj.a{2}*obj.e_s*obj.H_x; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
294 closure = obj.Hi*tau*obj.e_s'; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
295 penalty = -obj.Hi*tau*I_neighbour2local_ds*e_neighbour'; |
666
2d85f17a8aec
Add possibility for damping terms at interpolation interface.
Martin Almquist <malmquist@stanford.edu>
parents:
610
diff
changeset
|
296 |
942
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
297 beta = int_damp_ds*obj.a{2}... |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
298 *obj.e_s*obj.H_x; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
299 closure = closure + obj.Hi*beta*I_back_forth_ds*obj.e_s' - obj.Hi*beta*obj.e_s'; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
300 case {'n','N','north','North'} |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
301 tau = sigma_us*obj.a{2}*obj.e_n*obj.H_x; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
302 closure = obj.Hi*tau*obj.e_n'; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
303 penalty = -obj.Hi*tau*I_neighbour2local_us*e_neighbour'; |
666
2d85f17a8aec
Add possibility for damping terms at interpolation interface.
Martin Almquist <malmquist@stanford.edu>
parents:
610
diff
changeset
|
304 |
942
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
305 beta = int_damp_us*obj.a{2}... |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
306 *obj.e_n*obj.H_x; |
35701c85e356
Make Utux2D work with new interface type etc.
Martin Almquist <malmquist@stanford.edu>
parents:
914
diff
changeset
|
307 closure = closure + obj.Hi*beta*I_back_forth_us*obj.e_n' - obj.Hi*beta*obj.e_n'; |
591 | 308 end |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
309 |
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
310 |
591 | 311 end |
905
459eeb99130f
Include type as (optional) input parameter in the interface method of all schemes.
Martin Almquist <malmquist@stanford.edu>
parents:
743
diff
changeset
|
312 |
591 | 313 function N = size(obj) |
314 N = obj.m; | |
315 end | |
316 | |
317 end | |
318 | |
319 methods(Static) | |
320 % Calculates the matrices needed for the inteface coupling between boundary bound_u of scheme schm_u | |
321 % and bound_v of scheme schm_v. | |
322 % [uu, uv, vv, vu] = inteface_coupling(A,'r',B,'l') | |
323 function [uu, uv, vv, vu] = interface_coupling(schm_u,bound_u,schm_v,bound_v) | |
324 [uu,uv] = schm_u.interface(bound_u,schm_v,bound_v); | |
325 [vv,vu] = schm_v.interface(bound_v,schm_u,bound_u); | |
326 end | |
327 end | |
328 end |