You do not have permission to edit this page, for the following reason:

You are not allowed to execute the action you have requested.


You can view and copy the source of this page.

x
 
1
Published in ''Comput. Meth. Appl. Mech. Engng.'', Vol. 195 (13-16), pp. 1793–1825, 2006<br />
2
doi: 10.1016/j.cma.2005.05.036
3
4
5
==Abstract==
6
7
A finite element method (FEM) for steady-state convective-diffusive problems presenting sharp gradients of the solution both in the interior of the domain and in boundary layers is presented. The necessary stabilization of the numerical solution is provided by the Finite Calculus (FIC) approach. The FIC method is based in the solution by the Galerkin FEM of a modified set of governing equations which include characteristic length parameters. It is shown that the FIC balance equation for the multidimensional convection-diffusion problem written in the principal curvature axes of the solution, introduces an orthotropic diffusion which stabilizes the numerical solution both in smooth regions as well in the vicinity of sharp gradients. The dependence of the stabilization terms with the principal curvature directions of the solution makes the method non linear. Details of the iterative scheme to obtain stabilized results are presented together with examples of application which show the efficiency and accuracy of the approach.
8
9
==1 INTRODUCTION==
10
11
It is well known that the standard Galerkin FEM solution of the steady-state convective-diffusive equation is unstable for values of the Peclet number greater than one (see Volume 3 in <span id='citeF-1'></span>[[#cite-1|[1]]]). A number of numerical schemes have been proposed in order to guarantee that the numerical solution is stable, that is, that the solution has a physical meaning. In the first attempts to solve this problem the underdiffusive character of the Galerkin FEM (and the analogous central finite difference scheme) for convective-diffusive problems was corrected by adding “artificial diffusion terms” to the governing equations <span id='citeF-1'></span>[[#cite-1|[1,2]]]. The relationship of this approach with the upwind finite difference method <span id='citeF-2'></span>[[#cite-2|[2]]] lead to the derivation of a variety of Petrov-Galerkin FEM. All these methods can be interpreted as extensions of the standard Galerkin variational form of the FEM by adding residual-based integral terms computed over the element domains. Among the many stabilization methods of this or similar kind we name the Upwind FEM <span id='citeF-3'></span>[[#cite-3|[3,4]]], the Streamline Upwind Petrov-Galerkin (SUPG) method <span id='citeF-5'></span>[[#cite-5|[5-9]]], the Taylor-Galerkin method <span id='citeF-12'></span>[[#cite-12|[10,11]], the generalized Galerkin method <span id='citeF-17'></span>[[#cite-17|[12,13]]], the Galerkin Least Square method and related approaches <span id='citeF-19'></span>[[#cite-19|[14-16]]], the Characteristic Galerkin method <span id='citeF-22'></span>[[#cite-22|[17,18]]], the Characteristic Based Split method <span id='citeF-24'></span>[[#cite-24|[19]]], the  Subgrid Scale method <span id='citeF-25'></span>[[#cite-25|[20-23]]], the Residual Free Bubbles method <span id='citeF-37'></span>[[#cite-37|[24]]], the Discontinuous Enrichment Method <span id='citeF-39'></span>[[#cite-39|[25]]] and the Streamline Upwind with Boundary Terms method <span id='citeF-40'></span>[[#cite-40|[26]]].  Basically all the methods make use of a single stabilization parameter which suffices to stabilize the numerical solution along the velocity (streamline) direction. The computation of the streamline stabilization parameter for multidimensional problems is usually based on extensions of the optimal value of the parameter for the simpler 1D case. Specific attempts to design the stability parameter for multidimensional problems in the context of the Petrov-Galerkin formulation have been recently reported <span id='citeF-41'></span>[[#cite-41|[27-31]]]. In general all the stabilized methods above mentioned yield good results for 1D-type problems where the velocity vector is aligned with the direction of the gradient of the solution. However, the use of a single stabilization parameter is  insufficient to provide stabilized solutions in the vicinity of sharp gradients not aligned with the velocity direction, which may appear at the interior of the domain or at boundary layers. The usual remedy for these situations is to use the so called “shock capturing” or “discontinuity-capturing” schemes <span id='citeF-49'></span>[[#cite-49|[32-36]]]. These methods basically add additional transverse diffusion terms in selected elements in order to correct the undershoots and overshoots yielded by the Petrov-Galerkin solution in the sharp gradient zones. Usually the new shock capturing diffusion terms depend on the gradient of the solution and the scheme becomes non linear.
12
13
The aim of this work is to develop a general finite element formulation which can provide stabilized numerical results for all range of convective-diffusive problems. The new formulation therefore has the necessary intrinsic features to deal with streamline-type instabilities, as well as with the typical undershoots and overshoots in the vicinity of sharp gradients at different angles with the velocity direction. The new formulation thus provides a unified theoretical and computational framework incorporating all the ingredients of the traditional Petrov-Galerkin and shock-capturing methods.
14
15
The formulation proposed is based in the so called Finite Calculus (FIC) approach <span id='citeF-50'></span>[[#cite-50|[37,38]]]. The FIC method is based in expressing the equation of balance of fluxes in a domain of finite size. This introduces additional stabilizing terms in the differential equations of the infinitessimal theory which are a function of the balance domain dimensions. These dimensions are termed ''characteristic length parameters'' and play a key role in the stabilization process.
16
17
The modified governing equations lead to stabilized numerical schemes using whatever numerical method. It is interesting that many of the stabilized FEM can be recovered using the FIC formulation. The FIC method has been successfully applied to problems of convection-diffusion <span id='citeF-50'></span>[[#cite-50|[37-41]]], convection-diffusion-absorption [42,43], incompressible fluid flow <span id='citeF-47'></span>[[#cite-47|[44-47]]] and incompressible solid mechanics [48,49].
18
19
The key to the stabilization in the FIC method is to choose adequately the characteristic length parameters  for each element. For 1D problems the standard optimal  and critical values of the single stabilization parameter can be found, as shown in Section 3. For 2D/3D problems the characteristic length parameters along each space direction are grouped in a characteristic length vector <math display="inline">h</math>. Here the key issue is to choose correctly the direction of this vector. It is interesting that if the direction of <math display="inline">h</math> is taken parallel to that of the velocity, then the resulting FIC stabilized equations ''coincide'' with that of the standard SUPG method <span id='citeF-50'></span>[[#cite-50|[37,38]]].
20
21
In previous work of the authors, transverse sharp gradients to the velocity direction were accurately captured  by computing iteratively the direction and modulus of vector <math display="inline">h</math> which minimizes a residual norm <span id='citeF-50'></span>[[#cite-50|[37-41]]]. In <span id='citeF-51'></span>[[#cite-51|[38]]] accurate stabilized solutions for convection-diffusion problems with sharp gradients were obtaining by spliting the characteristic lenght vector <math display="inline">{h}</math> as the sum of two vectors. The first vector is chosen aligned with the velocity direction, hence yielding the standard SUPG terms, while the second vector is taken parallel to the direction of the gradient of the solution.
22
23
In this work a slightly different and more consistent method is proposed. We have found that the key to the general stabilization algorithm for convection-diffusion problems is to express the  FIC balance equation taking as  coordinate axes the principal curvature directions of the solution. These equations contain the necessary additional diffusion to stabilize the numerical solution ''in all situations''. It is interesting that when one of the principal curvature directions coincides with the velocity direction, then the  classical SUPG method is recovered.
24
25
The content of the paper is organized as follows. In the next section, the basic FIC equations for the multidimensional steady-state convective-diffusive problem are given.  The general equation is particularized for the simple 1D problem and the optimal and critical values of the 1D stabilization parameter are obtained. Then the form of the FIC balance equation written in the principal curvature axes is presented. The computation of the stabilization parameters is detailed and the general iterative solution scheme is explained. The formulation is  particularized for linear elements (four node quadrilaterals and three node triangles) where the computation of the curvature directions requires a derivative recovery algorithm. Very good results have been obtained by approximating the main principal curvature direction within the element by the gradient direction at the element center, which is a much more economical approach. A number of examples showing the accuracy and efficiency of the method  are presented. Convergence of the iterative scheme in problems with arbitrary sharp gradients was found in most cases in just two iterations.
26
27
==2 FIC GOVERNING EQUATIONS FOR STEADY-STATE CONVECTION-DIFFUSIVE PROBLEMS==
28
29
The basic FIC equations are obtained by expressing the balance of fluxes in interior and boundary domains of finite size and retaining one order higher terms in the Taylor expansions than those retained in the infinitessimal theory. The resulting governing equations are
30
31
{| class="formulaSCP" style="width: 100%; text-align: left;" 
32
|-
33
| 
34
{| style="text-align: left; margin:auto;width: 100%;" 
35
|-
36
| style="text-align: center;" | <math>r - \underline{{1\over 2} {h}^T {\boldsymbol \nabla }r}{1\over 2} {h}^T {\boldsymbol \nabla }r =0 \qquad \hbox{in } \Omega  </math>
37
|}
38
| style="width: 5px;text-align: right;white-space: nowrap;" | (1)
39
|}
40
41
with the boundary conditions
42
43
{| class="formulaSCP" style="width: 100%; text-align: left;" 
44
|-
45
| 
46
{| style="text-align: left; margin:auto;width: 100%;" 
47
|-
48
| style="text-align: center;" | <math>\phi - \phi ^p = 0\qquad \hbox{on}~~\Gamma _\phi </math>
49
|}
50
| style="width: 5px;text-align: right;white-space: nowrap;" |  (2a)
51
|}
52
53
{| class="formulaSCP" style="width: 100%; text-align: left;" 
54
|-
55
| 
56
{| style="text-align: left; margin:auto;width: 100%;" 
57
|-
58
| style="text-align: center;" | <math>{\textbf n}^T {D} {\boldsymbol \nabla }\phi +q_n^p - \underline{{1\over 2}{\textbf h}^T {\textbf n}  r}{1\over 2}{h}^T {n}  r= 0\qquad \hbox{on}~~\Gamma _q </math>
59
|}
60
| style="width: 5px;text-align: right;white-space: nowrap;" |  (2b)
61
|}
62
63
where <math display="inline">\Gamma _\phi </math> and <math display="inline">\Gamma _q</math> are the Dirichlet and Neumann boundaries where the variable <math display="inline">\phi </math> and the outgoing normal diffusive flux are prescribed to values <math display="inline">\phi ^p</math> and <math display="inline">q_n^p</math>, respectively. The modified equation (2b) is obtained by invoking higher order balance of fluxes in a finite domain next to the Neumann boundary <span id='citeF-50'></span>[[#cite-37|[37,38]]]. In above equations
64
65
{| class="formulaSCP" style="width: 100%; text-align: left;" 
66
|-
67
| 
68
{| style="text-align: left; margin:auto;width: 100%;" 
69
|-
70
| style="text-align: center;" | <math>r := -{\textbf u}^T {\boldsymbol \nabla } \phi + {\boldsymbol \nabla }^T {D} {\boldsymbol \nabla }\phi + Q </math>
71
|}
72
| style="width: 5px;text-align: right;white-space: nowrap;" | (3)
73
|}
74
75
where <math display="inline">u</math> is the divergence-free velocity vector, <math display="inline">{\textbf D}</math> is the diffusion matrix, <math display="inline">{\boldsymbol \nabla }</math> is the gradient operator, <math display="inline">Q</math> is the external source term and <math display="inline">{\textbf n}</math> is the normal vector. Vector <math display="inline">{\textbf h}</math>  is the ''characteristic length'' vector. For 2D problems <math display="inline">{\textbf h}=[h_x, h_y]^T</math>, where <math display="inline">h_x</math> and <math display="inline">h_y</math> are characteristic distances along the sides of the rectangular domain where higher order balance of fluxes is enforced <span id='citeF-50'></span>[[#cite-37|[37,38]]].
76
77
The underlined terms in Equations (1) and (2b) introduce the necessary stabilization in the numerical solution of the convective-diffusive problem  <span id='citeF-50'></span>[[#cite-37|[37-41]]]. The finite element formulation will be presented next.
78
79
===2.1 Finite element discretization===
80
81
A finite element interpolation of the unknown <math display="inline">\phi </math> can be written as
82
83
{| class="formulaSCP" style="width: 100%; text-align: left;" 
84
|-
85
| 
86
{| style="text-align: left; margin:auto;width: 100%;" 
87
|-
88
| style="text-align: center;" | <math>\phi \simeq \hat \phi =\sum N_i \phi _i </math>
89
|}
90
| style="width: 5px;text-align: right;white-space: nowrap;" | (4)
91
|}
92
93
where <math display="inline">N_i</math> are the shape functions and <math display="inline"> \phi _i</math> are the nodal values of the approximate function <math display="inline">\hat \phi </math> <span id='citeF-1'></span>[[#cite-1|[1]]].
94
95
Application of the Galerkin FE method to Equations (1) and (2b) gives, after integrating by parts the term <math display="inline"> {h}^T{\boldsymbol \nabla }\hat r</math>
96
97
{| class="formulaSCP" style="width: 100%; text-align: left;" 
98
|-
99
| 
100
{| style="text-align: left; margin:auto;width: 100%;" 
101
|-
102
| style="text-align: center;" | <math>\int _\Omega N_i \hat r d\Omega - \int _{\Gamma _q} N_i ({\textbf n}^T {\textbf D} {\boldsymbol \nabla }\hat \phi +q_n^p)d\Gamma + \sum \limits _e {1\over 2}  \int _{\Omega ^e} ({\textbf h}^T{\boldsymbol \nabla } N_i + N_i {\boldsymbol \nabla }^T {\textbf h})\hat r d\Omega =0 </math>
103
|}
104
| style="width: 5px;text-align: right;white-space: nowrap;" | (5)
105
|}
106
107
The last integral in Equation (5) has been expressed as a sum of the element contributions to allow for interelement discontinuities in the term <math display="inline">{\boldsymbol \nabla }\hat r</math> of Eq.(1), where <math display="inline">\hat r = r (\hat \phi )</math> is the residual of the FE approximation of the infinitesimal governing equation.
108
109
Note that the residual terms have disappeared from the Neumann boundary <math display="inline">\Gamma _q</math>. This is due to the consistency between the FIC terms in Eqs.(1) and (2b).
110
111
Integrating by parts the diffusive terms in the first integral of Eq.(5) leads to
112
113
{| class="formulaSCP" style="width: 100%; text-align: left;" 
114
|-
115
| 
116
{| style="text-align: left; margin:auto;width: 100%;" 
117
|-
118
| style="text-align: center;" | <math>\int _\Omega N_i [{\textbf u}^T \nabla \hat \phi + {\boldsymbol \nabla }^T N_i {\textbf D}{\boldsymbol \nabla }\hat \phi ] d\Omega - \sum \limits _e {1\over 2} \int _{\Omega ^e} ({\textbf h}^T{\boldsymbol \nabla } N_i + N_i {\boldsymbol \nabla }^T {\textbf h})\hat r  d\Omega - \int _\Omega N_i Q d\Omega +\int _{\Gamma _q} N_i q_n^p d\Gamma =0 </math>
119
|}
120
| style="width: 5px;text-align: right;white-space: nowrap;" | (6)
121
|}
122
123
In matrix form
124
125
{| class="formulaSCP" style="width: 100%; text-align: left;" 
126
|-
127
| 
128
{| style="text-align: left; margin:auto;width: 100%;" 
129
|-
130
| style="text-align: center;" | <math>{\textbf K}{\textbf a}={\textbf f} </math>
131
|}
132
| style="width: 5px;text-align: right;white-space: nowrap;" | (7)
133
|}
134
135
Matrix <math>{\textbf K}</math> and vector <math>{\textbf f}</math> are assembled from the element contributions given by
136
137
{| class="formulaSCP" style="width: 100%; text-align: left;" 
138
|-
139
| 
140
{| style="text-align: left; margin:auto;width: 100%;" 
141
|-
142
| style="text-align: center;" | <math>K_{ij}^e = \int _{\Omega ^e} [N_i{\textbf u}^T {\boldsymbol \nabla }N_j + {\boldsymbol \nabla }^T N_i ({\textbf D} + {1\over 2}{\textbf h}{\textbf u}^T){\boldsymbol \nabla } N_j + N_i ({\boldsymbol \nabla }^T {\textbf h}) {\textbf u}^T {\boldsymbol \nabla } N_j ]d\Omega -</math>
143
|-
144
| style="text-align: center;" | <math> - {1\over 2} \int _{\Omega ^e} ({\textbf h}^T {\boldsymbol \nabla } N_i + N_i {\boldsymbol \nabla }^T {\textbf h}) {\boldsymbol \nabla }^T ({D} {\boldsymbol \nabla } N_j)d\Omega </math>
145
| style="width: 5px;text-align: right;white-space: nowrap;" | (8.a)
146
|-
147
| style="text-align: center;" | <math> f_i^e = \int _{\Omega ^e} [N_i + {1\over 2} ({\textbf h}^T{\boldsymbol \nabla } N_i +N_i {\boldsymbol \nabla }^T {\textbf h}) ] Qd\Omega - \int _{\Gamma _q^e}N_i q_n^p d\Gamma  </math>
148
| style="width: 5px;text-align: right;white-space: nowrap;" | (8.b)
149
|}
150
|}
151
152
Note that the method is equivalent to modifying the original diffusion matrix <math display="inline">D</math> by <math display="inline">{D}_G</math> with
153
154
{| class="formulaSCP" style="width: 100%; text-align: left;" 
155
|-
156
| 
157
{| style="text-align: left; margin:auto;width: 100%;" 
158
|-
159
| style="text-align: center;" | <math>{\textbf D}_G = {\textbf D} +\bar {\textbf D} \quad \hbox{and}\quad \bar {\textbf D} = {1\over 2} {\textbf h}{\textbf u}^T </math>
160
|}
161
| style="width: 5px;text-align: right;white-space: nowrap;" | (9)
162
|}
163
164
In Eq.(9) <math display="inline">\bar {\textbf D}</math> is the ''balancing diffusion matrix'' introduced by the FIC method.
165
166
We note that the Galerkin/FIC formulation is residual based, i.e. the stabilization term is a function of the FEM residual which progressively vanishes as the numerical results approaches the “exact” solution (see Eq.(5)). This preserves the consistency of the Galerkin method in order to obtain improved convergence rates with finite elements of any interpolation order. In the following we will  restrict the application of the method to linear elements only.
167
168
Note  that when linear elements are used the second integral of Equation (8a) vanishes. The same happens with the term <math display="inline">{\textbf h}^T{\boldsymbol \nabla } N_i Q</math> of the first integral of Equation (8b) when <math display="inline">N_i</math> is linear and <math display="inline">Q</math> is constant. Finally, all terms involving the derivatives  of <math display="inline">\textbf h</math> vanish if <math display="inline">\textbf h</math> is constant over the element. The evaluation of these integrals is mandatory in any other case.
169
170
===2.2 Equivalence with the SUPG method===
171
172
Let us now assume that the direction of vector <math display="inline">h</math> is ''parallel'' to that of the velocity <math display="inline">\textbf u</math>, i.e. <math display="inline">{\textbf h}= h{{\textbf u}\over \vert {\textbf u}\vert }</math> where <math display="inline">h</math> is a characteristic length. Under these conditions, Eq.(5) reads (assuming <math display="inline">{\boldsymbol \nabla }^T{\textbf h}=0</math>)
173
174
{| class="formulaSCP" style="width: 100%; text-align: left;" 
175
|-
176
| 
177
{| style="text-align: left; margin:auto;width: 100%;" 
178
|-
179
| style="text-align: center;" | <math>\int _\Omega N_i \hat r d\Omega - \int _{\Gamma _q} N_i ({\textbf n}^T {D} {\boldsymbol \nabla }\hat \phi +q_n^p)d\Omega{+} \sum \limits _e \int _{\Omega ^e} {h\over 2\vert {\textbf u}\vert  }   {\textbf u}^T{\boldsymbol \nabla } N_i \hat rd\Omega =0 </math>
180
|}
181
| style="width: 5px;text-align: right;white-space: nowrap;" | (10)
182
|}
183
184
Equation (10) coincides precisely with the SUPG method. The ratio <math display="inline">\displaystyle{h\over 2\vert {\textbf u}\vert  }</math> has dimensions of time and it is usually termed element ''intrinsic time'' parameter <math display="inline">\tau </math>.
185
186
The balancing diffusion matrix <math display="inline">\bar {\textbf D}</math> of Eq.(9) is now given by
187
188
{| class="formulaSCP" style="width: 100%; text-align: left;" 
189
|-
190
| 
191
{| style="text-align: left; margin:auto;width: 100%;" 
192
|-
193
| style="text-align: center;" | <math>\bar {\textbf D} ={h\over 2\vert {\textbf u}\vert }{\textbf u}{\textbf u}^T=\tau {\textbf u}{\textbf u}^T </math>
194
|}
195
| style="width: 5px;text-align: right;white-space: nowrap;" | (11)
196
|}
197
198
It can be shown that the definition of <math display="inline">\bar {\textbf D}</math> of Eq.(11) is equivalent to introducing an artificial diffusion of value <math display="inline">{h\vert {\textbf u}\vert \over 2}</math> along the streamlines <span id='citeF-1'></span>[[#cite-1|[1,7,9]]] and this explains the name of the SUPG method. The element characteristic length <math display="inline">h</math> (or the value of <math display="inline">\tau </math>) is computed in practice  by  heuristic linear and non-linear extensions of the optimal expression for the 1D problem <span id='citeF-5'></span>[[#cite-5|[5-9,27-31]]].
199
200
In the following sections we will denote by the standard SUPG method to the stabilization procedure leading to a balancing diffusion matrix <math display="inline">\bar {\textbf D}</math> given by Eq.(11).
201
202
It is important to note that the SUPG expression is a ''particular case'' of the more general FIC formulation. This explains the limitations of the SUPG method to provide stabilized numerical results in the vicinity of sharp gradients of the solution transverse to the flow direction and the need to introduce in these cases additional shock capturing terms (see Section 5). However, in the FIC formulation the direction of <math display="inline">{\textbf h}</math> is arbitrary and not necessarily coincident with that of <math display="inline">{\textbf u}</math>. The components of <math display="inline">{\textbf h}</math>  introduce the necessary stabilization along the streamlines and the transverse directions to the flow. In this manner, the FIC method reproduces the best-features of the so-called stabilized discontinuity-capturing schemes <span id='citeF-49'></span>[[#cite-32|[32-36]]].
203
204
==3 COMPUTATION OF THE CHARACTERISTIC LENGTH FOR THE 1D CONVECTION-DIFFUSION EQUATION==
205
206
The computation of the characteristic length is a crucial step as its value affect to the stability and accuracy of the numerical solution.
207
208
Before we face the general multidimensional problem, some based concepts of the computation of the characteristic length for the 1D convection-diffusion equation are briefly given.
209
210
The FIC equation for the 1D steady-state convection-diffusion problem is written as
211
212
{| class="formulaSCP" style="width: 100%; text-align: left;" 
213
|-
214
| 
215
{| style="text-align: left; margin:auto;width: 100%;" 
216
|-
217
| style="text-align: center;" | <math>r - {h\over 2}\frac{d r}{dx}=0 </math>
218
|}
219
| style="width: 5px;text-align: right;white-space: nowrap;" | (12)
220
|}
221
222
with
223
224
{| class="formulaSCP" style="width: 100%; text-align: left;" 
225
|-
226
| 
227
{| style="text-align: left; margin:auto;width: 100%;" 
228
|-
229
| style="text-align: center;" | <math>r:=-u \phi'  +k \phi''{+}Q </math>
230
|}
231
| style="width: 5px;text-align: right;white-space: nowrap;" | (13)
232
|}
233
234
where primes denote differentiation with respect to the independent space variable <math display="inline">x</math>.
235
236
The element matrices of Eqs.(8) are now written for ''two node linear elements'' as
237
238
{| class="formulaSCP" style="width: 100%; text-align: left;" 
239
|-
240
| 
241
{| style="text-align: left; margin:auto;width: 100%;" 
242
|-
243
| style="text-align: center;" | <math>K_{ij}^e = \int _{l^e} \left(N_i u N_j^\prime + N_i^\prime \left(k+{hu\over 2}\right)N_j^\prime \right)dx</math>
244
| style="width: 5px;text-align: right;white-space: nowrap;" | (14.a)
245
|-
246
| style="text-align: center;" | <math> f_i^e = \int _{l^e} \left(N_i + {h\over 2} N_j^\prime \right)Qdx - [N_i q^p]_{x_L} </math>
247
| style="width: 5px;text-align: right;white-space: nowrap;" | (14.b)
248
|}
249
|}
250
251
where <math display="inline">l^e</math> is the element length and <math display="inline">x_L</math> is the coordinate of the end point of the 1D domain where the outgoing flux is prescribed to a value <math display="inline">q^p</math>. In Eq.(14a) the space derivatives of <math display="inline">h</math> have been neglected as <math display="inline">h</math> is assumed to be constant within each element.
252
253
Note that the  FIC method introduces a diffusion of value <math display="inline">{hu\over 2}</math>. This term is analogous to that provided by artificial diffusion and upwinding methods <span id='citeF-1'></span>[[#cite-1|[1,2]]].
254
255
The characteristic length parameter <math display="inline">h</math> for each element can  be made proportional to the element length as <math display="inline">h= \alpha l^e</math> where <math display="inline">\alpha </math> is an element stabilization parameter. A typical stencil for a mesh of uniform size 1D elements of length <math display="inline">l^e =l</math> is written as
256
257
{| class="formulaSCP" style="width: 100%; text-align: left;" 
258
|-
259
| 
260
{| style="text-align: left; margin:auto;width: 100%;" 
261
|-
262
| style="text-align: center;" | <math>- u {\phi _{i+1} - \phi _{i-1}\over 2} + \left(k+\alpha {ul\over 2}\right)\left(   {\phi _{i+1} - 2\phi _i + \phi _{i-1}\over l}  \right)=0 </math>
263
|}
264
| style="width: 5px;text-align: right;white-space: nowrap;" | (15)
265
|}
266
267
Injecting into Eq.(15) the exact analytical solution <math display="inline">\phi _i = A+Be^{{u\over k}x_i}</math> where <math display="inline">A</math> and <math display="inline">B</math> are contants, gives the optimal value of <math display="inline">\alpha =\alpha _{opt}</math> yielding the exact solution at the nodes with
268
269
{| class="formulaSCP" style="width: 100%; text-align: left;" 
270
|-
271
| 
272
{| style="text-align: left; margin:auto;width: 100%;" 
273
|-
274
| style="text-align: center;" | <math>\alpha _{opt} =\coth \gamma - {1\over \gamma } </math>
275
|}
276
| style="width: 5px;text-align: right;white-space: nowrap;" | (16)
277
|}
278
279
where <math display="inline">\gamma = {ul\over 2k}</math> is the element Peclet number.
280
281
A critical value of <math display="inline">\alpha </math> ensuring physically correct results can be found by writing the stencil (15) for a two element mesh with nodes 1, 2 and 3 and Dirichlet boundary conditions <math display="inline">\phi _1=0</math> and <math display="inline">\phi _3 =\bar \phi </math>. The resulting equation reads
282
283
{| class="formulaSCP" style="width: 100%; text-align: left;" 
284
|-
285
| 
286
{| style="text-align: left; margin:auto;width: 100%;" 
287
|-
288
| style="text-align: center;" | <math>-u {\bar \phi \over 2} + \left(k+\alpha {ul\over 2}\right){\bar \phi - 2\phi _2\over l}=0 </math>
289
|}
290
| style="width: 5px;text-align: right;white-space: nowrap;" | (17)
291
|}
292
293
An unphysical (unstable) solution will imply <math display="inline">\phi _2<0</math>. This is avoided if the following  value of <math display="inline">\alpha \ge \alpha _c</math> is chosen with
294
295
{| class="formulaSCP" style="width: 100%; text-align: left;" 
296
|-
297
| 
298
{| style="text-align: left; margin:auto;width: 100%;" 
299
|-
300
| style="text-align: center;" | <math>\begin{array}{l}\alpha _c = \left(1- {1\over \vert \gamma \vert }\right)\hbox{sign} (u) \quad ,\quad \hbox{for } \vert \gamma \vert \ge 1\\ \alpha _c =0  \quad \hbox{for } \vert \gamma \vert < 1 \end{array} </math>
301
|}
302
| style="width: 5px;text-align: right;white-space: nowrap;" | (18)
303
|}
304
305
where <math display="inline">\alpha _c</math> is termed the critical stabilization parameter. It can be verified that  that <math display="inline">\alpha _c\simeq \alpha _{opt}</math> for <math display="inline">\alpha >2</math>. Note that both <math display="inline">\alpha </math> and <math display="inline">\alpha _c</math> are constant within each element, as initially assumed.
306
307
Above well know results from the finite element and finite difference literature will be useful for the general multidimensional case described next.
308
309
 '''Remark 1'''. The stabilizing diffusion of Eq.(15) can be expressed in terms of the equivalent intrinsic time parameter <math display="inline">\tau </math> by replacing the term <math display="inline">\alpha {ul\over 2}</math> by <math display="inline">\tau u^2</math> where <math display="inline">\tau = \alpha {l\over 2u}</math>. The optimal and critical values of <math display="inline">\tau </math> are therefore obtained by dividing by <math display="inline">{l\over 2u}</math> the expressions of <math display="inline">\alpha _{opt}</math> and <math display="inline">\alpha _c</math> of Eqs.(16) and (18), respectively.
310
311
==4 COMPUTATION OF THE CHARACTERISTIC LENGTH VECTOR==
312
313
We present here a general procedure to compute the characteristic length vector <math display="inline">h</math> for convection-diffusion problems. For the sake of preciseness the method is explained for 2D problems although it is equally applicable to 3D problems.
314
315
<div id='img-1'></div>
316
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
317
|-
318
|[[Image:Draft_Samper_426828278-Figure1.png|351px|Global axes (x,y) and principal curvature axes (ξ,η)]]
319
|- style="text-align: center; font-size: 75%;"
320
| colspan="1" | '''Figure 1:''' Global axes (<math>x,y</math>) and principal curvature axes (<math>\xi ,\eta </math>)
321
|}
322
323
324
Let us write down the FIC balance equation  in the principal curvature axes of the solution <math display="inline">\xi ,\eta </math> (Figure 1). For simplicity we consider the 2D sourceless case (<math display="inline">Q=0</math>) with an isotropic diffusion defined by a constant diffusion parameter <math display="inline">k</math>.  The FIC balance equation is
325
326
{| class="formulaSCP" style="width: 100%; text-align: left;" 
327
|-
328
| 
329
{| style="text-align: left; margin:auto;width: 100%;" 
330
|-
331
| style="text-align: center;" | <math>-u_\xi {\partial \phi  \over \partial \xi }-u_\eta {\partial \phi  \over \partial \eta }+k \left({\partial ^2\phi \over \partial \xi ^2}+ {\partial ^2\phi \over \partial \eta ^2}\right)- {h_\xi \over 2} {\partial  \over \partial \xi }\left[-u_\xi {\partial \phi  \over \partial \xi }-u_\eta {\partial \phi  \over \partial \eta }+ k \left({\partial ^2\phi \over \partial \xi ^2}+ {\partial ^2\phi \over \partial \eta ^2}\right)\right]</math>
332
|-
333
| style="text-align: center;" | <math>  - {h_\eta \over 2} {\partial  \over \partial \eta } \left[-u_\xi {\partial \phi  \over \partial \xi }-u_\eta {\partial \phi  \over \partial \eta }+ k \left({\partial ^2\phi \over \partial \xi ^2}+ {\partial ^2\phi \over \partial \eta ^2}\right)\right]=0 </math>
334
|}
335
| style="width: 5px;text-align: right;white-space: nowrap;" | (19)
336
|}
337
338
where <math display="inline">u_\xi , u_\eta </math> are the velocities along the principal axes of curvature <math display="inline">\xi </math> and <math display="inline">\eta </math>, respectively.
339
340
As <math display="inline">\xi </math> and <math display="inline">\eta </math> are the principal curvature axes of the solution then
341
342
{| class="formulaSCP" style="width: 100%; text-align: left;" 
343
|-
344
| 
345
{| style="text-align: left; margin:auto;width: 100%;" 
346
|-
347
| style="text-align: center;" | <math>{\partial ^2\phi \over \partial \xi \partial \eta }= {\partial ^2\phi \over \partial \eta \partial \xi }=0 </math>
348
|}
349
| style="width: 5px;text-align: right;white-space: nowrap;" | (20)
350
|}
351
352
Introducing this simplification into Eq.(19) we can rewrite this equation as
353
354
{| class="formulaSCP" style="width: 100%; text-align: left;" 
355
|-
356
| 
357
{| style="text-align: left; margin:auto;width: 100%;" 
358
|-
359
| style="text-align: center;" | <math> -u_\xi {\partial \phi  \over \partial \xi }-u_\eta {\partial \phi  \over \partial \eta }+\left(k + {u_\xi h_\xi \over 2}\right){\partial ^2\phi \over \partial \xi ^2} + \left(k + {u_\eta h_\eta \over 2}\right){\partial ^2\phi \over \partial \eta ^2}  - {k\over 2} \left(h_\xi {\partial ^3 \phi \over \partial \xi ^3}+  h_\eta  {\partial ^3 \phi \over \partial \eta ^3}\right)=0</math>
360
|}
361
| style="width: 5px;text-align: right;white-space: nowrap;" | (21)
362
|}
363
364
365
We can see clearly from Eq.(21) that the FIC governing equations introduce orthotopic diffusion parameters  of values <math display="inline">{u_\xi h_\xi \over 2}</math> and <math display="inline"> {u_\eta h_\eta \over 2}</math> along the <math display="inline">\xi </math> and <math display="inline">\eta </math> axes, respectively. Also note that the last term of Eq.(21) will vanish after discretization for linear elements.
366
367
Eq.(21) can be rewritten in matrix form (neglecting the last term) as
368
369
{| class="formulaSCP" style="width: 100%; text-align: left;" 
370
|-
371
| 
372
{| style="text-align: left; margin:auto;width: 100%;" 
373
|-
374
| style="text-align: center;" | <math>- {\textbf u}^{\prime T} {\boldsymbol \nabla }^\prime \phi + {\boldsymbol \nabla }^{\prime T} ({\textbf D}+\bar {\textbf D}^\prime ) {\boldsymbol \nabla }^{\prime }\phi =0 </math>
375
|}
376
| style="width: 5px;text-align: right;white-space: nowrap;" | (22)
377
|}
378
379
where <math display="inline">{\textbf u}^\prime =[u_\xi , u_\eta ]^T</math>, <math display="inline">{\boldsymbol \nabla }^\prime = \left[{\partial \over \partial \xi }, {\partial \over \partial \eta }\right]^T</math>, <math display="inline">\textbf D</math> is the “physical” isotropic diffusion matrix and <math display="inline">\bar {\textbf D}'</math> is the balancing diffusion matrix in the local axes <math display="inline">\xi </math> and <math display="inline">\eta </math>. The form of these matrices is
380
381
{| class="formulaSCP" style="width: 100%; text-align: left;" 
382
|-
383
| 
384
{| style="text-align: left; margin:auto;width: 100%;" 
385
|-
386
| style="text-align: center;" | <math>{\textbf D}= \left[\begin{array}{cc}k &0\\0&k\end{array}\right]\qquad \hbox{and} \qquad \bar {\textbf D}^\prime = \left[\begin{array}{cc}\displaystyle{u_\xi h_\xi \over 2} & 0\\ 0 & \displaystyle{u_\eta h_\eta \over 2}\end{array}\right] </math>
387
|}
388
| style="width: 5px;text-align: right;white-space: nowrap;" | (23)
389
|}
390
391
The velocities  along the principal curvature axes <math display="inline">u_\xi </math> and <math display="inline">u_\eta </math> can be obtained by projecting the cartesian velocities into the principal curvature axes <math display="inline">\xi </math> and <math display="inline">\eta </math> as
392
393
{| class="formulaSCP" style="width: 100%; text-align: left;" 
394
|-
395
| 
396
{| style="text-align: left; margin:auto;width: 100%;" 
397
|-
398
| style="text-align: center;" | <math>{\textbf u}'=\left\{\begin{array}{c}u_\xi \\ u_\eta \end{array}\right\}= {\textbf T} {\textbf u}  \quad \hbox{with}\quad {\textbf T}= \left[\begin{array}{cc}c_\alpha & s_\alpha \\ - s_\alpha & c_\alpha \end{array}\right]\quad ,\quad {\textbf u}=\left\{\begin{array}{c}u\\v\end{array}\right\} </math>
399
|}
400
| style="width: 5px;text-align: right;white-space: nowrap;" | (24)
401
|}
402
403
where <math display="inline">c_\alpha =\cos \alpha </math>, <math display="inline">s_\alpha =\sin \alpha </math> and <math display="inline">\alpha </math> is the angle which the <math display="inline">\xi </math> axis forms with the <math display="inline">x</math> axis (Figure 1). Note that as the solution is continuous the principal curvature directions <math display="inline">\xi </math> and <math display="inline">\eta </math> are orthogonal.
404
405
The characteristic length distances <math display="inline">h_\xi </math> and <math display="inline">h_\eta </math> are defined as
406
407
{| class="formulaSCP" style="width: 100%; text-align: left;" 
408
|-
409
| 
410
{| style="text-align: left; margin:auto;width: 100%;" 
411
|-
412
| style="text-align: center;" | <math>h_\xi =\alpha _\xi l_\xi \quad \hbox{and}\quad h_\eta =\alpha _\eta l_\eta  </math>
413
|}
414
| style="width: 5px;text-align: right;white-space: nowrap;" | (25)
415
|}
416
417
where <math display="inline">l_\xi </math> and <math display="inline">l_\eta </math> are typical element dimensions along the <math display="inline">\xi </math> and <math display="inline">\eta </math> axes, respectively and <math display="inline">\alpha _\xi </math> and <math display="inline">\alpha _\eta </math> are the corresponding stabilization parameters.
418
419
The values of <math display="inline">\alpha _\xi </math> and <math display="inline">\alpha _\eta </math> are  computed by considering the solution of two uncoupled 1D problems along the <math display="inline">\xi </math> and <math display="inline">\eta </math> directions. This gives from Eq.(16)
420
421
{| class="formulaSCP" style="width: 100%; text-align: left;" 
422
|-
423
| 
424
{| style="text-align: left; margin:auto;width: 100%;" 
425
|-
426
| style="text-align: center;" | <math>\alpha _\xi = \coth \gamma _\xi - {1\over \gamma _\xi } \quad ,\quad \gamma _\xi = {u_\xi l_\xi \over 2k}</math>
427
| style="width: 5px;text-align: right;white-space: nowrap;" | (26.a)
428
|-
429
| style="text-align: center;" | <math> \alpha _\eta = \coth \gamma _\eta - {1\over \gamma _\eta } \quad ,\quad \gamma _\eta = {u_\eta l_\eta \over 2k} </math>
430
| style="width: 5px;text-align: right;white-space: nowrap;" | (26.b)
431
|}
432
|}
433
434
The lengths <math display="inline">l_\xi </math> and <math display="inline">l_\eta </math> are taken as the maximum projection of the velocities <math display="inline">u_\xi </math> and <math display="inline">u_\eta </math> along the element sides (for triangles) and the element diagonals (for quadrilaterals), i.e.
435
436
{| class="formulaSCP" style="width: 100%; text-align: left;" 
437
|-
438
| 
439
{| style="text-align: left; margin:auto;width: 100%;" 
440
|-
441
| style="text-align: center;" | <math>l_i =\max ({d}_j^T {u}_i)\quad ,\quad i=\xi ,\eta  </math>
442
|}
443
| style="width: 5px;text-align: right;white-space: nowrap;" | (27.a)
444
|}
445
446
with
447
448
{| class="formulaSCP" style="width: 100%; text-align: left;" 
449
|-
450
| 
451
{| style="text-align: left; margin:auto;width: 100%;" 
452
|-
453
| style="text-align: center;" | <math>\begin{array}{ll}j=1,2,3 \hbox{ (for triangles) and }\\ j=1,2 \hbox{ (for quadrilaterals)}\end{array} </math>
454
|}
455
| style="width: 5px;text-align: right;white-space: nowrap;" | (27.b)
456
|}
457
458
In Eq.(27a) <math display="inline">{\textbf u}_\xi </math> and <math display="inline">{\textbf u}_\eta </math> contain the global components of the  velocity vectors <math display="inline">\vec u_\xi </math> and <math display="inline">\vec u_\eta </math>, respectively. For triangles <math display="inline">{\textbf d}_j</math> are the element sides vectors, whereas for quadrilaterals <math display="inline">{\textbf d}_j</math> are the element diagonals vectors.
459
460
The next step is to transform Eq.(22) to global axes <math display="inline">x,y</math>. The resulting equation is written as
461
462
{| class="formulaSCP" style="width: 100%; text-align: left;" 
463
|-
464
| 
465
{| style="text-align: left; margin:auto;width: 100%;" 
466
|-
467
| style="text-align: center;" | <math>-{\textbf u}^T {\boldsymbol \nabla }\phi +{\boldsymbol \nabla }^T {\textbf D}_G {\boldsymbol \nabla }\phi=0 </math>
468
|}
469
| style="width: 5px;text-align: right;white-space: nowrap;" | (28)
470
|}
471
472
where the global diffusion matrix <math display="inline">{\textbf D}_G</math> is
473
474
{| class="formulaSCP" style="width: 100%; text-align: left;" 
475
|-
476
| 
477
{| style="text-align: left; margin:auto;width: 100%;" 
478
|-
479
| style="text-align: center;" | <math>{\textbf D}_G={\textbf D}+\bar{\textbf D}</math>
480
|}
481
| style="width: 5px;text-align: right;white-space: nowrap;" | (29a)
482
|}
483
484
The isotropic diffusion matrix <math display="inline">\textbf D</math> is given by Eq.(23) and  the global balancing diffusion matrix <math display="inline">\bar{\textbf D}</math> is
485
486
{| class="formulaSCP" style="width: 100%; text-align: left;" 
487
|-
488
| 
489
{| style="text-align: left; margin:auto;width: 100%;" 
490
|-
491
| style="text-align: center;" | <math>\bar {\textbf D} = {\textbf T}^T \bar {\textbf D}^\prime {\textbf T}</math>
492
|}
493
| style="width: 5px;text-align: right;white-space: nowrap;" | (29b)
494
|}
495
496
where the transformation matrix '''T''' is given in Eq.(24).
497
498
'''Remark 2'''. We can write the local balancing diffusion matrix <math display="inline">\bar{\textbf D}'</math> of Eq.(23) for <math display="inline">k_\xi{-}k_\eta >0</math>  as<br />
499
{| class="formulaSCP" style="width: 100%; text-align: left;" 
500
|-
501
| 
502
{| style="text-align: left; margin:auto;width: 100%;" 
503
|-
504
| style="text-align: center;" | <math>\bar{\textbf D}' ={1\over 2}\left[\begin{array}{cc} (k_\xi -k_\eta ) &0\\ 0&0\end{array}\right]+ {1\over 2}\left[\begin{array}{cc} k_\eta  &0\\ 0&k_\eta \end{array}\right]=\bar{\textbf D}_\xi + \bar{\textbf D}_{iso}</math>
505
|}
506
| style="width: 5px;text-align: right;white-space: nowrap;" | (30a)
507
|}
508
509
where
510
511
{| class="formulaSCP" style="width: 100%; text-align: left;" 
512
|-
513
| 
514
{| style="text-align: left; margin:auto;width: 100%;" 
515
|-
516
| style="text-align: center;" | <math>k_\xi ={u_\xi h_\xi \over 2}\quad ,\quad k_\eta ={u_\eta h_\eta \over 2}</math>
517
|}
518
| style="width: 5px;text-align: right;white-space: nowrap;" | (30b)
519
|}
520
521
If <math display="inline">k_\eta </math> is greater than <math display="inline"> k_\xi </math> a similar split is performed with <math display="inline">(k_\eta - k_\xi )</math> in the position 22 of matrix <math display="inline">\bar{\textbf D}_\xi </math> and <math display="inline">k_\eta </math> is replaced by <math display="inline">k_\xi </math>  in <math display="inline">\bar{\textbf D}_{iso}</math>.
522
523
Eq.(30a) shows that the diffusivity matrix <math display="inline">\bar{\textbf D}'</math> is equivalent to the sum of a balancing diffusion along the principal curvature direction <math display="inline">\vec {\xi }</math> (or <math display="inline">\vec {\eta }</math> if <math display="inline">k_\eta > k_\xi </math>) and an isotropic diffusion matrix <math display="inline">\bar{\textbf D}_{iso}</math>
524
525
The global balancing diffusion matrix of Eq.(29a) can therefore be written as
526
527
{| class="formulaSCP" style="width: 100%; text-align: left;" 
528
|-
529
| 
530
{| style="text-align: left; margin:auto;width: 100%;" 
531
|-
532
| style="text-align: center;" | <math>\bar {\textbf D} = \bar{\textbf D}_{iso} + {\textbf T}^T\bar{\textbf D}_\xi {\textbf T} </math>
533
|}
534
| style="width: 5px;text-align: right;white-space: nowrap;" | (31)
535
|}
536
537
Clearly, if the principal curvature direction <math display="inline">\vec {\xi }</math> is parallel to the velocity direction, then <math display="inline">u_\eta =0</math>, <math display="inline">k_\eta =0</math>, <math display="inline"> \bar{\textbf D}_{iso}={0}</math> and
538
539
{| class="formulaSCP" style="width: 100%; text-align: left;" 
540
|-
541
| 
542
{| style="text-align: left; margin:auto;width: 100%;" 
543
|-
544
| style="text-align: center;" | <math>\bar{\textbf D}= \bar{\textbf D}_\xi =\left[\begin{array}{cc}{u_\xi h_\xi \over 2} &0\\0&0\end{array}\right] </math>
545
|}
546
| style="width: 5px;text-align: right;white-space: nowrap;" | (32)
547
|}
548
549
where <math display="inline">u_\xi = \vert {u}\vert </math> and <math display="inline">h_\xi </math> is computed by Eq.(26a). Note that the method coincides with the standard SUPG approach in this case.
550
551
'''Remark 3'''. The global balance diffusion matrix <math display="inline">\bar  {\textbf D}</math> can be also computed from the expression of vector <math display="inline">\textbf h</math> in global axes as
552
553
{| class="formulaSCP" style="width: 100%; text-align: left;" 
554
|-
555
| 
556
{| style="text-align: left; margin:auto;width: 100%;" 
557
|-
558
| style="text-align: center;" | <math>\bar  {\textbf D} ={1\over 2} {\textbf h}^T {\textbf u}\quad \hbox{with }{\textbf h}=\left\{\begin{array}{c}h_x\\h_y \end{array}\right\}  = {\textbf T}^T {\textbf h}' </math>
559
|}
560
| style="width: 5px;text-align: right;white-space: nowrap;" | (33)
561
|}
562
563
where <math display="inline">{\textbf h}'=[h_\xi , h_\eta ]^T</math> and <math display="inline">{\textbf T}</math> is the transformation matrix of Eq.(24). The proof of this equivalence is given in the Appendix. In our computation however we have chosen to compute the balancing diffusion matrix <math display="inline">\bar  {\textbf D}</math> via Eqs.(23)&#8211;(29).
564
565
===4.1 Computation of the principal curvature axes for linear elements===
566
567
The principal curvature axes <math display="inline">\xi ,\eta </math> can be estimated as the eigenvectors of the curvature matrix
568
569
{| class="formulaSCP" style="width: 100%; text-align: left;" 
570
|-
571
| 
572
{| style="text-align: left; margin:auto;width: 100%;" 
573
|-
574
| style="text-align: center;" | <math>{\textbf C}= \left[\begin{array}{cc}\phi _x^{''} & \phi ^{''}_{xy}\\ \phi ^{''}_{xy} & \phi _y^{''}  \end{array}\right]\quad ,\quad \hbox{where } \phi _x^{''}={\partial ^2\phi \over \partial x^2}, \hbox{etc.} </math>
575
|}
576
| style="width: 5px;text-align: right;white-space: nowrap;" | (34)
577
|}
578
579
In general matrix '''C''' varies within each element.
580
581
Computation of the second derivatives field for linear elements is not straightforward and it requires the nodal recovery of the first derivative field. This can be performed by using a simple nodal averaging procedure or more sophisticated superconvergence patch recovery techniques for the first derivative field [50,51].
582
583
Excellent results have been obtained by the authors in this work ''by approximating the principal curvature direction <math>\vec \xi </math> by the direction of the gradient vector'' <math display="inline">{\boldsymbol \nabla } \phi </math>.
584
585
This simplification allows us to estimate the direction <math display="inline">\vec {\xi }</math> in a very economical manner as the gradient vector <math display="inline">{\boldsymbol \nabla } \phi </math> can be directly computed at any point of a linear element. Direction <math display="inline">\vec {\eta }</math> is taken orthogonal to that of <math display="inline">\vec {\xi }</math> in an anti-clockwise sense.
586
587
For linear triangles <math display="inline">{\boldsymbol \nabla } \phi </math> is constant within the element. For four node quadrilaterals <math display="inline">{\boldsymbol \nabla } \phi </math> varies linearly. We have assumed in this case that the direction of <math display="inline">\vec \xi </math> is constant within the element and equal to that of vector <math display="inline">{\boldsymbol \nabla } \phi </math> computed at the element center.
588
589
The dependence of the balancing diffusion matrix <math display="inline">\bar{\textbf D}</math> with the principal  curvature directions <math display="inline">\vec \xi </math> and <math display="inline">\vec {\eta }</math> introduces a non linearity in the solution process. A simple and effective iterative algorithm is described next.
590
591
===4.2 General iterative scheme===
592
593
A stabilized numerical solution can be found by the following algorithm.
594
595
'''Step 0'''  (SUPG step). At each integration point choose <math display="inline">{}^0{\boldsymbol \xi } ={\textbf u}</math>, i.e. the gradient direction is taken coincident with the velocity direction. Compute <math display="inline">{}^0{\boldsymbol \eta }, {}^1\bar  {\textbf D}'</math>, <math display="inline">{}^0\bar  {\textbf D}</math> and <math display="inline">{}^0{\textbf D}_G</math> from Eqs.(23&#8211;29). ''The  expression of the balancing diffusion matrix coincides  now precisely with the standard (linear) SUPG form''.
596
597
Solve for <math display="inline">{}^0\bar{\boldsymbol \phi }</math>.
598
599
Verify that the solution is stable. This can be performed by verifying that there are not undershoots or overshoots in the numerical results with respect to the expected physical values. If the SUPG solution is unstable, then implement the following iterative scheme.
600
601
For each iteration: 
602
603
'''Step 1'''  Compute at the element center. <math display="inline">{}^1{\boldsymbol \xi } = {\boldsymbol \nabla }^0\bar \phi </math>. Then compute <math display="inline">{}^1{\boldsymbol \eta } , {}^1\bar  {\textbf D}'</math>, <math display="inline">{}^1\bar  {\textbf D}</math> and <math display="inline">{}^1{\textbf D}_G</math>.
604
605
Solve for <math display="inline">{}^1\bar{\boldsymbol \phi }</math>.
606
607
'''Step 2'''  Estimate the convergence of the process. We have chosen the following convergence norm
608
609
{| class="formulaSCP" style="width: 100%; text-align: left;" 
610
|-
611
| 
612
{| style="text-align: left; margin:auto;width: 100%;" 
613
|-
614
| style="text-align: center;" | <math>\Vert \phi \Vert = {1\over N\bar \phi _{max}} \left[\sum \limits _{j=1}^n \left({}^{i}\bar \phi _j - {}^{i-1}\bar \phi _j \right)^2 \right]^{1/2} \le \varepsilon  </math>
615
|}
616
| style="width: 5px;text-align: right;white-space: nowrap;" | (35)
617
|}
618
619
where <math display="inline">N</math> is the total number of nodes in the mesh and <math display="inline">\phi _{max}</math> is the maximum prescribed value at the Dirichlet boundary (if <math display="inline">\bar \phi _{max}=0</math> then <math display="inline">\bar  \phi _{max}=1</math>). In above steps the left upper indices denote the iteration number.
620
621
In the examples shown in the next section <math display="inline">\varepsilon =10^{-3}</math> has been taken in Eq.(35).
622
623
If condition (35) is not satisfied, start a new iteration and repeat steps 1 and 2 until convergence. Indexes 0 and 1 are replaced now by <math display="inline">i-1</math> and <math display="inline">i</math>, respectively.
624
625
'''Remark 4'''. The convergence of the iterative scheme of the previous section obviously depends on the “quality” of the standard SUPG solution obtained in Step 0. Clearly when boundary layers or  sharp transverse internal layers dominate the solution, the non linearity of the processes increases. The authors have found that the convergence of the scheme can be substantially improved in some problems if the following expression for the stabilizing dissipation matrix is used in Step 1
626
627
{| class="formulaSCP" style="width: 100%; text-align: left;" 
628
|-
629
| 
630
{| style="text-align: left; margin:auto;width: 100%;" 
631
|-
632
| style="text-align: center;" | <math>{\textbf D}_G = \beta ^i \bar{\textbf D}_G + (1-\beta ) {}^{i-1}\bar{\textbf D}_G  </math>
633
|}
634
| style="width: 5px;text-align: right;white-space: nowrap;" | (36)
635
|}
636
637
where <math display="inline">\beta </math> is a relaxation factor such that <math display="inline">0\le \beta \le 1</math>.
638
639
Convergence of the iterative scheme was achieved in just two iteration in Examples 6.1&#8211;6.3 for values of <math display="inline">\beta </math> between 0.8 and 1. The best solution in Example 6.4 was found in five iterations for <math display="inline">\beta =0.3</math>. This is due to the higher non linearity of the process induced by the transverse boundary layers in this case.
640
641
'''Remark 5'''. The direct iterative scheme presented in Section 4.2 is obviously not the only option to solve the non linear equations resulting from the dependence of the stabilizing diffusion matrix with the principal curvatures of the solution.
642
643
A simple and economical alternative is to use a time relaxation technique based in the solution of a pseudo transient problem with a forward Euler scheme and a diagonal mass matrix. This technique was used by Codina in <span id='citeF-11'></span>[[#cite-9|[9,33]]] for solving a similar class of convection-diffusion problems.
644
645
==5 EQUIVALENCE WITH SUPG AND SHOCK-CAPTURING TECHNIQUES==
646
647
As mentioned earlier, the SUPG formulation based on the use of a stabilization term of the form shown in Eq.(10) has severe limitations to provide stabilized solutions (i.e. without overshoots and undershoots) in the vicinity of sharp gradients of the solution transverse to the flow direction. The usual remedy in these cases is to introduce an additional stabilization term (the shock capturing term).
648
649
In esence all shock capturing formulations are equivalent to an split of the stabilization term in two parts. One part is taken equal to the standard  linear SUPG term. This term suffices to stabilize the effect of the gradient of the solution in the direction of the velocity. The second part is introduced in order to account for  gradients of the solution along a direction not aligned with the velocity. This second term (the shock capturing or transverse diffusion term) usually involves the velocity projection along the gradient direction. This term introduces therefore a non linearity in the solution process. The usual approach is to start by computing the linear SUPG solution, check if there are sharp transverse gradients which deserve further stabilization and, if so, introduce the shock capturing term and iterate until a stabilized solution is found in the whole domain.
650
651
Despite their effectiveness, most shock capturing methods lack of a general theoretical framework and can be viewed as “ad hoc” extensions of the SUPG method. A serious drawback of these methods is that, in some cases, the amount of transverse diffusion can not be properly controlled and    hence the final solution is either underdiffusive or overdiffusive.
652
653
The general stabilized formulation we propose here includes the best features of the SUPG and shock capturing techniques. The iterative scheme in fact follows the lines of the standard shock capturing methods <span id='citeF-49'></span>[[#cite-32|[32-36]]]. The innovation in the proposed formulation  lays in the definition of the shock capturing terms, which are deduced form the FIC governing equations written in the principal curvature directions. Numerical results obtained in all examples show that the method preserves the quality of the numerical solution in all situations by introducing the necessary  streamline and transverse dissipation.
654
655
A similar shock capturing method of this kind was proposed by Oñate <span id='citeF-51'></span>[[#cite-38|[38]]] in the context of the FIC approach. There the characteristic length vector was split as the sum of a  vector along the velocity direction (the linear SUPG term) and a vector in the direction of the solution gradient (the non linear schock capturing term). Good results were obtained with this method for a variety of advection-diffusion problems <span id='citeF-51'></span>[[#cite-38|[38]]]. The formulation we present here is more general as it encompasses the SUPG method and the shock capturing strategy in a unified approach.
656
657
We have shown in Remark 2 that the proposed approach coincides with the standard SUPG method (with no discontinuity capturing) when the principal direction <math display="inline">\vec {\xi }</math> is parallel to the velocity direction. This analogy is discussed further next.
658
659
Let us split the characteristic vector <math display="inline">h</math> as the sum of two vectors along the velocity and the gradient directions respectively as
660
661
{| class="formulaSCP" style="width: 100%; text-align: left;" 
662
|-
663
| 
664
{| style="text-align: left; margin:auto;width: 100%;" 
665
|-
666
| style="text-align: center;" | <math>{\textbf h}= h_s {{\textbf u}\over \vert {\textbf u}\vert } +h_t {{\boldsymbol \nabla }\hat \phi \over \vert {\boldsymbol \nabla } \hat \phi \vert } </math>
667
|}
668
| style="width: 5px;text-align: right;white-space: nowrap;" | (37)
669
|}
670
671
where <math display="inline">h_s</math> and <math display="inline">h_t</math> are the characteristic lengths   along the velocity and gradient directions, respectively. When <math display="inline">h_s</math> is linear (i.e., independent of the solution) the first term in the r.h.s of Eq.(37) is the classical SUPG term. The second term depending on the solution gradient is the shock-capturing term.
672
673
Eq.(37) allows to solve for <math display="inline">h_s</math> and <math display="inline">h_t</math> in terms of the components of <math display="inline">{u}, {\boldsymbol \nabla } \hat \phi </math> and <math display="inline">{h}</math> as
674
675
{| class="formulaSCP" style="width: 100%; text-align: left;" 
676
|-
677
| 
678
{| style="text-align: left; margin:auto;width: 100%;" 
679
|-
680
| style="text-align: center;" | <math>h_s = {h_x \hat \phi _y^\prime - h_y \hat \phi _x^\prime \over u \hat \phi _y^\prime - v \hat \phi _x^\prime }\vert {\textbf u}\vert </math>
681
|}
682
| style="width: 5px;text-align: right;white-space: nowrap;" | (38.a)
683
|}
684
685
{| class="formulaSCP" style="width: 100%; text-align: left;" 
686
|-
687
| 
688
{| style="text-align: left; margin:auto;width: 100%;" 
689
|-
690
| style="text-align: center;" | <math>h_t = {h_y u - h_x  v\over u \hat \phi _y^\prime - v \hat \phi _x^\prime }\vert {\boldsymbol \nabla }\hat \phi \vert </math>
691
|}
692
| style="width: 5px;text-align: right;white-space: nowrap;" | (38.b)
693
|}
694
695
where <math display="inline">h_x</math> and <math display="inline">h_y</math> are computed from <math display="inline">h_\xi </math> and <math display="inline">h_\eta </math> by Eq.(33).
696
697
Eqs.(38) clearly show that in the general case the expressions of <math display="inline">h_s</math> and <math display="inline">h_t</math> are a function of the numerical solution <math display="inline">\hat \phi </math>. Hence, for arbitrary orientations of the principal curvature direction <math display="inline">\vec {\xi }</math>, the stabilized method proposed can be interpreted as the combination of a ''non linear SUPG term and a non linear shock capturing term''. The introduction of this gradient-dependent non linearity in the SUPG term is one of the distinct features of the new formulation.
698
699
When the principal curvature direction <math display="inline">\vec{\xi } </math>  is parallel to the velocity direction then <math display="inline">h_\eta =0</math> and
700
701
{| class="formulaSCP" style="width: 100%; text-align: left;" 
702
|-
703
| 
704
{| style="text-align: left; margin:auto;width: 100%;" 
705
|-
706
| style="text-align: center;" | <math>c_\alpha = {u\over \vert {\textbf u}\vert }, \quad s_\alpha ={v\over \vert {\textbf v}\vert }, \quad h_x = {uh_\xi  \over \vert {\textbf u}\vert }, \quad h_y ={vh_\xi  \over \vert {\textbf u}\vert }</math>
707
|}
708
| style="width: 5px;text-align: right;white-space: nowrap;" |  (39a)
709
|}
710
711
Hence
712
713
{| class="formulaSCP" style="width: 100%; text-align: left;" 
714
|-
715
| 
716
{| style="text-align: left; margin:auto;width: 100%;" 
717
|-
718
| style="text-align: center;" | <math>h_s =h_\xi \quad \hbox{and } h_t=0</math>
719
|}
720
| style="width: 5px;text-align: right;white-space: nowrap;" |  (39b)
721
|}
722
723
and the method coincides in this case with the standard linear SUPG approach, as expected.
724
725
A case of practical interest is when the directions of <math display="inline">\textbf u</math> and <math display="inline">{\boldsymbol \nabla }\phi </math> are ''orthogonal''. This occurs for some specific distributions of the velocity and the solution fields or in the vicinity of sharp layers when the mesh is fine enough, or it has some specific orientation. In these cases we have
726
727
{| class="formulaSCP" style="width: 100%; text-align: left;" 
728
|-
729
| 
730
{| style="text-align: left; margin:auto;width: 100%;" 
731
|-
732
| style="text-align: center;" | <math>h_\xi = 0\quad ,\quad h_\eta \not =0 \,\, \hbox{(it is computed by Eqs.(25)--(27))}\,\, ,\,\, c_\alpha = - {v\over \vert {\textbf u}\vert }\quad \hbox{and} \quad s_\alpha ={u\over \vert {\textbf u}\vert } </math>
733
|}
734
| style="width: 5px;text-align: right;white-space: nowrap;" | (40)
735
|}
736
737
Hence from Eq.(33)
738
739
{| class="formulaSCP" style="width: 100%; text-align: left;" 
740
|-
741
| 
742
{| style="text-align: left; margin:auto;width: 100%;" 
743
|-
744
| style="text-align: center;" | <math>h_x = - h_\eta   {u\over \vert {\textbf u}\vert } \quad ,\quad  h_y = - h_\eta  {v\over \vert {\textbf u}\vert } </math>
745
|}
746
| style="width: 5px;text-align: right;white-space: nowrap;" | (41.a)
747
|}
748
749
and from Eqs.(38)
750
751
{| class="formulaSCP" style="width: 100%; text-align: left;" 
752
|-
753
| 
754
{| style="text-align: left; margin:auto;width: 100%;" 
755
|-
756
| style="text-align: center;" | <math>h_s = h_\eta \quad \hbox{ and }h_t =0 </math>
757
|}
758
| style="width: 5px;text-align: right;white-space: nowrap;" | (41.b)
759
|}
760
761
Once again, the linear SUPG method is  recovered and the stabilized formulation does not introduce any additional transverse dissipation, as should be expected.
762
763
'''Remark 6'''. From above arguments we conclude that the simplified expression <math display="inline">{\textbf h}=h_s {{\textbf u} \over \vert {\textbf u}\vert }</math> with <math display="inline">h_s</math> being a non linear function of the solution leads to a non linear SUPG term. This has a similarity with the non linear SUPG formulation reported in <span id='citeF-28'></span>[[#cite-28|[28,31]]]. We have found that in general this assumption does not suffice to stabilize the solution in presence of high gradients transverse to the solution. In these cases the introduction of the term involving <math display="inline">h_t</math> in Eq.(37) is essential in order to obtain an improved solution.
764
765
==6 EXAMPLES==
766
767
The efficiency of the algorithm is verified in a number of examples of application including sharp gradients at the interior of the domain as well as in boundary layers. The examples show the ability of the algorithm to provide a stabilized and accurate solution in all cases in very few iterations. All units in the examples are  in the International System.
768
769
In the examples solved a solution is consider ''unstable'' if <math display="inline">(1+\bar \varepsilon ) \phi ^p_{max} \le \bar \phi \le (1+\bar \varepsilon ) \phi ^p_{min}</math> where <math display="inline">\phi ^p_{max}</math> and <math display="inline">\phi ^p_{min}</math> are the maximum and minimum prescribed values of <math display="inline">\bar \phi </math> at the Dirichlet boundaries. The parameter <math display="inline">\bar \epsilon </math> has been taken equal to <math display="inline">10^{-2}</math>. This condition basically ensures that the solution has no overshoots or undershoots with respect to the prescribed boundary values.
770
771
In all examples presented the classical SUPG results (with no discontinuity capturing)  are compared with those obtained with the FIC iterative scheme. Examples 6.1&#8211;6.3 were solved for a value of <math display="inline">\beta =1</math> in Eq.(36). A converged and accurate solution was obtained in all cases in just two iterations. The convergence process was quite insensitive to the value of <math display="inline">\beta </math> for values of <math display="inline">\beta </math> ranging between 0.8 and 1.0. We note that good stabilized results were also obtained in these examples using just ''one iteration''. However, a slight increase in the accuracy of the results was obtained using two iterations, while no significant increase in accuracy was reached by iterating any further.
772
773
The FIC solution reported for Example 6.4 was obtained in five iterations for a value of <math display="inline">\beta =0.3</math> in Eq.(36).
774
775
We finally note that most of the examples presented have been successfully solved in the past using different shock capturing techniques <span id='citeF-49'></span>[[#cite-32|[32-36]]]. In this paper the FIC results are compared with values obtained using the standard (linear) SUPG formulation. The basic aim of the examples presented here is to show that the FIC formulation integrates naturally the best features of both the SUPG and the shock capturing formulations.
776
777
===6.1 Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source===
778
779
Figure 2 shows the geometry of the analysis domain and the boundary conditions. The domain is a square of side equal to 10. Zero values of the variable <math display="inline">\phi </math> are prescribed at the inlet boundaries <math display="inline">x=0</math> and <math display="inline">y=0</math>, whereas <math display="inline">\phi =10</math> is prescribed at the outlet boundaries <math display="inline">x=10</math> and <math display="inline">y=10</math>. The isotropic diffusion <math display="inline">k=0.01</math> and the velocity vectors are taken parallel to the diagonal of the domain with <math display="inline">{u}={3\sqrt 2\over 2}[1,1]^T</math>. The problem has been solved with the structured mesh of <math display="inline">10\times 10</math> four node rectangles shown in the figure. The Peclet number along the velocity direction is <math display="inline">\gamma =300</math>.
780
781
<div id='img-2'></div>
782
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
783
|-
784
|[[Image:Draft_Samper_426828278-Figure2.png|551px|Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. SUPG and FIC solutions obtained with a structured mesh of 10×10 linear four node square elements]]
785
|- style="text-align: center; font-size: 75%;"
786
| colspan="1" | '''Figure 2:''' Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. SUPG and FIC solutions obtained with a structured mesh of <math>10\times 10</math> linear four node square elements
787
|}
788
789
790
Results in Figure 2 show contours of the numerical solution for the SUPG and the FIC iterative scheme proposed. FIC<math display="inline">^2</math> in the figures denotes results obtained after two iterations of the scheme described in Section 4.2. A value of <math display="inline">\beta =1.0</math> in Eq.(36) has been chosen. Note that the SUPG method yields incorrect negative values of <math display="inline">\phi </math> in the vicinity of the upper right corner, as expected, whereas the FIC<math display="inline">^2</math> results are physically correct over the domain. A plot of the distribution of the solution along the horizontal center line and the diagonal line is shown. The difference between the FIC and SUPG results along the diagonal line is clearly seen.
791
792
Figure 3 shows results  for the same problem solved with a structurerd mesh of <math display="inline">2\times 10 \times 10</math> three  node triangular elements. The effect of the stabilization process in more visible in this case as the SUPG solution has more undershoots than for four node square elements.
793
794
<div id='img-3'></div>
795
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
796
|-
797
|[[Image:Draft_Samper_426828278-Figure3.png|551px|Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. SUPG and FIC solutions obtained with a structured mesh of 2×10×10 linear three node triangles]]
798
|- style="text-align: center; font-size: 75%;"
799
| colspan="1" | '''Figure 3:''' Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. SUPG and FIC solutions obtained with a structured mesh of <math>2\times 10\times 10</math> linear three node triangles
800
|}
801
802
803
The convergence of the iterative process using square and triangular elements is plotted in Figure 4 where the evolution of the values of <math display="inline">\bar \phi </math> at three different points within the analysis domain is plotted. The evolution of the norm of Eq.(35) with the number of iterations is also shown. Note that a converged solution (<math display="inline">\varepsilon <10^{-3}</math>) is obtained in just two iterations.
804
805
806
<div id='img-4'></div>
807
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
808
|-
809
|[[Image:Draft_Samper_426828278-Figure4.png|551px|Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. Convergence of the FIC solution for square and triangular elements]]
810
|- style="text-align: center; font-size: 75%;"
811
| colspan="1" | '''Figure 4:''' Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. Convergence of the FIC solution for square and triangular elements
812
|}
813
814
815
Figures 5 and 6 show the solution of a similar problem using the same number of four node rectangular elements and linear triangles with a geometrical aspect ratio of 2:1. The SUPG solution of both cases is clearly non physical and the FIC iterative process provides again a stabilized and accurate solution in just two iterations.
816
817
<div id='img-5'></div>
818
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
819
|-
820
|[[Image:Draft_Samper_426828278-Figure5.png|551px|Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. SUPG and FIC solutions obtained with a structured mesh of 10×20 linear four node rectangular elements. Geometrical aspect ratio 2:1]]
821
|- style="text-align: center; font-size: 75%;"
822
| colspan="1" | '''Figure 5:''' Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. SUPG and FIC solutions obtained with a structured mesh of <math>10\times 20</math> linear four node rectangular elements. Geometrical aspect ratio 2:1
823
|}
824
825
<div id='img-6'></div>
826
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
827
|-
828
|[[Image:Draft_Samper_426828278-Figure6.png|551px|Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. SUPG and FIC solutions obtained with a structured mesh of 2×10×20 linear triangles. Geometrical aspect ratio 2:1]]
829
|- style="text-align: center; font-size: 75%;"
830
| colspan="1" | '''Figure 6:''' Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. SUPG and FIC solutions obtained with a structured mesh of <math>2\times 10\times 20</math> linear triangles. Geometrical aspect ratio 2:1
831
|}
832
833
===6.2 Square domain with non uniform Dirichlet conditions, downwards diagonal velocity and zero source===
834
835
The geometry of the problem and the boundary conditions are shown in Figure 7. The side of the square domain has a length equal to one. The velocity vector is <math display="inline">{u} =[5,-9]^T \times 10^{6}</math>. An isotropic diffusion of unit value is assumed. The correct solution is a uniform plateau of value <math display="inline">\phi =100</math> with an internal sharp layer in the vicinity of the left lower region where the solution drops to <math display="inline">\bar \phi =0</math>, a boundary layer at the right hand side and at partial boundary layer at the bottom side where the value of <math display="inline">\phi </math> is prescribed to zero.
836
837
<div id='img-7'></div>
838
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
839
|-
840
|[[Image:Draft_Samper_426828278-Figure7.png|551px|Square domain with non uniform Dirichlet conditions, downwards diagonal velocity and zero source. SUPG and FIC solutions obtained with a structured mesh of 20×20 linear four node square elements]]
841
|- style="text-align: center; font-size: 75%;"
842
| colspan="1" | '''Figure 7:''' Square domain with non uniform Dirichlet conditions, downwards diagonal velocity and zero source. SUPG and FIC solutions obtained with a structured mesh of <math>20\times 20</math> linear four node square elements
843
|}
844
845
846
Figures 7 and 8 show results obtained with structured meshes of <math display="inline">20\times 20</math> four node square elements and <math display="inline">2\times 20\times 20</math> linear triangles, respectively. The SUPG solution in both cases has overshoots in the vicinity of the sharp gradient zones, whereas the FIC iterative scheme yields a stabilized and accurate solution in two iterations. Again <math display="inline">\beta =1</math> in Eq.(36) was chosen. Note that the boundary layers and the internal sharp gradient zone are well captured without overshoots or undershoots with the FIC method using both types of elements.
847
848
<div id='img-8'></div>
849
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
850
|-
851
|[[Image:Draft_Samper_426828278-Figure8.png|551px|Square domain with non uniform Dirichlet conditions, downwards diagonal velocity  and zero source. SUPG and FIC solutions obtained with a structured mesh of 2×20×20 three node triangles]]
852
|- style="text-align: center; font-size: 75%;"
853
| colspan="1" | '''Figure 8:''' Square domain with non uniform Dirichlet conditions, downwards diagonal velocity  and zero source. SUPG and FIC solutions obtained with a structured mesh of <math>2\times 20\times 20</math> three node triangles
854
|}
855
856
857
The convergence of the process for both elements is shown in Figure 9.
858
859
<div id='img-9'></div>
860
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
861
|-
862
|[[Image:Draft_Samper_426828278-Figure9.png|551px|Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. Convergence of the FIC solution for square and triangular elements]]
863
|- style="text-align: center; font-size: 75%;"
864
| colspan="1" | '''Figure 9:''' Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. Convergence of the FIC solution for square and triangular elements
865
|}
866
867
868
Figures 10 and 11 show results for the same problem using coarse and refined unstructured meshes of  linear quadrilaterals and triangles, respectively. The performance of the FIC algorithm is very good  in both cases despite the difficulty to capture the sharp layers with coarse unstructured meshes.
869
870
<div id='img-10'></div>
871
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
872
|-
873
|[[Image:Draft_Samper_426828278-Figure10.png|551px|Square domain with non uniform Dirichlet conditions, downwards diagonal velocity and zero source. SUPG and FIC solutions obtained with an unstructured mesh of 432 linear four node quadrilateral elements]]
874
|- style="text-align: center; font-size: 75%;"
875
| colspan="1" | '''Figure 10:''' Square domain with non uniform Dirichlet conditions, downwards diagonal velocity and zero source. SUPG and FIC solutions obtained with an unstructured mesh of 432 linear four node quadrilateral elements
876
|}
877
878
<div id='img-11'></div>
879
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
880
|-
881
|[[Image:Draft_Samper_426828278-Figure11.png|551px|Square domain with non uniform Dirichlet conditions, downwards diagonal velocity  and zero source. SUPG and FIC solutions obtained with an unstructured mesh of 780 three node triangles]]
882
|- style="text-align: center; font-size: 75%;"
883
| colspan="1" | '''Figure 11:''' Square domain with non uniform Dirichlet conditions, downwards diagonal velocity  and zero source. SUPG and FIC solutions obtained with an unstructured mesh of 780 three node triangles
884
|}
885
886
887
The solution is improved in both cases by using a refined unstructured mesh as shown in Figures 12 and 13. Note that the overall solutions obtained with the linear triangle and unstructured meshes are slightly better than those obtained with linear quadrilaterals for a similar number of elements. The improvements are clearer in the vicinity of the boundary layer at the right hand side of the domain.
888
889
<div id='img-12'></div>
890
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
891
|-
892
|[[Image:Draft_Samper_426828278-Figure12.png|551px|Square domain with non uniform Dirichlet conditions, downwards diagonal velocity and zero source. SUPG and FIC solutions obtained with a refined unstructured mesh of 1826 linear four node quadrilaterals]]
893
|- style="text-align: center; font-size: 75%;"
894
| colspan="1" | '''Figure 12:''' Square domain with non uniform Dirichlet conditions, downwards diagonal velocity and zero source. SUPG and FIC solutions obtained with a refined unstructured mesh of 1826 linear four node quadrilaterals
895
|}
896
897
<div id='img-13'></div>
898
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
899
|-
900
|[[Image:Draft_Samper_426828278-Figure13.png|551px|Square domain with non uniform Dirichlet conditions, downwards diagonal velocity and zero source. SUPG and FIC solutions obtained with a refined unstructured mesh of 1898 linear triangles]]
901
|- style="text-align: center; font-size: 75%;"
902
| colspan="1" | '''Figure 13:''' Square domain with non uniform Dirichlet conditions, downwards diagonal velocity and zero source. SUPG and FIC solutions obtained with a refined unstructured mesh of 1898 linear triangles
903
|}
904
905
906
Figures 14 and 15 show results for a similar problem solved now with structured meshes of linear rectangles and triangles with a geometrical aspect ratio of 2:1. The correct solution in this case is a central plateau of <math display="inline"> \phi =10</math> with a boundary layer at the right hand side where the solution drops to <math display="inline">\phi =0</math>, and two sharp gradient zones at both sides of the plateau within the domain. The figures show the contours of <math display="inline">\bar \phi </math> over the analysis domain and the distribution of <math display="inline">\bar \phi </math> along the vertical and horizontal central lines. As expected the SUPG solution yields over and undershoots. Two iterations of the FIC iterative scheme again suffice to provide a correct solution  over the whole domain.
907
908
<div id='img-14'></div>
909
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
910
|-
911
|[[Image:Draft_Samper_426828278-Figure14.png|551px|Square domain with non uniform Dirichlet conditions, upwards diagonal velocity  and zero source. SUPG and FIC solutions obtained with a structured mesh of 10×20 linear four node rectangular elements. Geometrical aspect ratio 2:1]]
912
|- style="text-align: center; font-size: 75%;"
913
| colspan="1" | '''Figure 14:''' Square domain with non uniform Dirichlet conditions, upwards diagonal velocity  and zero source. SUPG and FIC solutions obtained with a structured mesh of <math>10\times 20</math> linear four node rectangular elements. Geometrical aspect ratio 2:1
914
|}
915
916
<div id='img-15'></div>
917
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
918
|-
919
|[[Image:Draft_Samper_426828278-Figure15.png|551px|Square domain with non uniform Dirichlet conditions, upwards diagonal velocity  and zero source. SUPG and FIC solutions obtained with a structured mesh of 2×10×20 three node triangles. Geometrical aspect ratio 2:1]]
920
|- style="text-align: center; font-size: 75%;"
921
| colspan="1" | '''Figure 15:''' Square domain with non uniform Dirichlet conditions, upwards diagonal velocity  and zero source. SUPG and FIC solutions obtained with a structured mesh of <math>2\times 10\times 20</math> three node triangles. Geometrical aspect ratio 2:1
922
|}
923
924
925
This problem has been chosen by many authors as a test for stabilized formulations. A comparison of the solution obtained with different shock capturing techniques was reported by Codina <span id='citeF-11'></span>[[#cite-9|[9,33]]] using a time relaxation scheme. The FIC results presented here reproduce the best results obtained for this problem with the shock capturing methods analyzed in <span id='citeF-11'></span>[[#cite-9|[9,33]]].
926
927
===6.3 Rectangular domain with Neumann and non uniform Dirichlet conditions, rotational  velocity field and zero source===
928
929
The rectangular domain of sides <math display="inline">1\times 2</math> units and the boundary conditions are shown in Figure 16. The rotational velocity field is defined by <math display="inline">{u}= 10^4 \times  [y (1-x^2),- x (1-y^2)]^T</math>. A unit isotropic diffusion is assumed. The velocity is prescribed at the domain sides shown. In the rest of the sides the Neumann boundary condition with <math display="inline">q^p_n =0</math> is assumed. The correct solution is a uniform plateau of <math display="inline">\phi =100</math> with a boundary layer at the right hand side where the solution drops towards the prescribed value of <math display="inline">\phi =0</math> and a circular sharp gradient region around the lower circular zone where the solution takes a zero value.
930
931
Figures 16 and 17 present the results obtained with the structured meshes of linear square and triangular elements respectively shown. The contours of <math display="inline">\bar \phi </math> over the domain and the distribution of the solution along an horizontal line are plotted. Results clearly show the incapacity of the SUPG method to correctly capture the boundary layer and the internal gradient region. The solution obtained with two iterations of the FIC scheme presented is physically sound and accurate over the whole analysis domain as shown in the figures. FIC results were once more obtained for a value of <math display="inline">\beta =1</math> in Eq.(36).
932
933
934
<div id='img-16'></div>
935
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
936
|-
937
|[[Image:Draft_Samper_426828278-Figure16.png|551px|Rectangular domain with Neumann and  non uniform Dirichlet conditions, rotational velocity field and zero source. SUPG and FIC solutions obtained with a structured mesh of 40×20 four node square elements]]
938
|- style="text-align: center; font-size: 75%;"
939
| colspan="1" | '''Figure 16:''' Rectangular domain with Neumann and  non uniform Dirichlet conditions, rotational velocity field and zero source. SUPG and FIC solutions obtained with a structured mesh of <math>40\times 20</math> four node square elements
940
|}
941
942
<div id='img-17'></div>
943
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
944
|-
945
|[[Image:Draft_Samper_426828278-Figure17.png|551px|Rectangular domain with Neumann and  non uniform Dirichlet conditions, rotational velocity field and zero source. SUPG and FIC solutions obtained with  a structured mesh of 2×40×20   three node triangles]]
946
|- style="text-align: center; font-size: 75%;"
947
| colspan="1" | '''Figure 17:''' Rectangular domain with Neumann and  non uniform Dirichlet conditions, rotational velocity field and zero source. SUPG and FIC solutions obtained with  a structured mesh of <math>2\times 40\times 20</math>   three node triangles
948
|}
949
950
951
Figure 18 shows results for the solution of the same problem using coarse and refined unstructured meshes of linear quadrilaterals. Note the accuracy of the FIC stabilized solution, even for the coarse mesh.
952
953
<div id='img-18'></div>
954
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
955
|-
956
|[[Image:Draft_Samper_426828278-Figure18.png|551px|]]
957
|[[Image:Draft_Samper_426828278-Figure18b.png|551px|Rectangular domain with Neumann and  non uniform Dirichlet conditions, rotational velocity field and zero source. SUPG and FIC solutions obtained with two unstructured meshes of four node quadrilaterals. (a) Coarse mesh of 892 elements. (b) Refined mesh of 2054 elements]]
958
|- style="text-align: center; font-size: 75%;"
959
| colspan="2" | '''Figure 18:''' Rectangular domain with Neumann and  non uniform Dirichlet conditions, rotational velocity field and zero source. SUPG and FIC solutions obtained with two unstructured meshes of four node quadrilaterals. (a) Coarse mesh of 892 elements. (b) Refined mesh of 2054 elements
960
|}
961
962
963
The same problem was finally solved with a unstructured mesh of 1554 linear triangles. The number of elements chosen is quite similar to that used for the structured solution (1600 elements). The solution obtained shown in Figure 19 is quite accurate over the whole domain, despite the relative coarseness of the mesh. This is another prove of the best performance of the linear triangle in unstructured meshes.
964
965
<div id='img-19'></div>
966
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
967
|-
968
|[[Image:Draft_Samper_426828278-Figure19.png|551px|Rectangular domain with Neumann and  non uniform Dirichlet conditions, rotational velocity field and zero source. SUPG and FIC solutions obtained with  an unstructured mesh of 1554 three node triangles]]
969
|- style="text-align: center; font-size: 75%;"
970
| colspan="1" | '''Figure 19:''' Rectangular domain with Neumann and  non uniform Dirichlet conditions, rotational velocity field and zero source. SUPG and FIC solutions obtained with  an unstructured mesh of 1554 three node triangles
971
|}
972
973
===6.4 Square domain with homogeneous Dirichlet condition and constant source===
974
975
The computational domain for this last example is again the unit square, discretized now with uniform meshes of 20 <math display="inline">\times </math> 20 linear quadrilateral and <math display="inline">2\times  20 \times 20</math> three node triangles. The value of <math display="inline">\phi </math> is prescribed to zero on the whole boundary. The velocity vector is <math display="inline">{u} = [1,0]^T</math> and the isotropic diffusion is <math display="inline">k=10^{-8}</math>. A uniformly distributed source <math display="inline">Q=1</math> over the whole domain has been taken.
976
977
The correct solution of this problem is a linear distribution of <math display="inline">\phi </math> increasing uniformly from a value of zero at the inlet boundary until it reaches a maximum value in the vecinity of the outlet boundary. Three boundary layers exist for this problem, one at the exit boundary and two at the two lateral sides, where the value of <math display="inline">\phi </math> drops drastically to zero. Figures 20 and 21 show results obtained with the two structured meshes of quadrilateral and triangles, respectively. The linear SUPG solution yields oscillations in the direction normal to the lateral layers, although a good resolution of the layer normal to the velocity field is obtained, as expected. The FIC solution for <math display="inline">\beta =1</math> in Eq.(36) yielded a smoooth solution near the boundary layers, free of the lateral oscillations which are present in the SUPG solution. The best FIC solution in this case was however obtained for a value of <math display="inline">\beta =0.3</math> in Eq.(36). Five iterations of the scheme were needed to obtain convergence in this case. The numerical results obtained for both meshes are shown in Figures 20 and 21.
978
979
<div id='img-20'></div>
980
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
981
|-
982
|[[Image:Draft_Samper_426828278-Figura20.png|551px|Square domain with homogeneous Dirichlet conditions and constant source. Solution for a structural mesh of 20×20 four node quadrilaterals]]
983
|- style="text-align: center; font-size: 75%;"
984
| colspan="1" | '''Figure 20:''' Square domain with homogeneous Dirichlet conditions and constant source. Solution for a structural mesh of <math>20\times 20</math> four node quadrilaterals
985
|}
986
987
<div id='img-21'></div>
988
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
989
|-
990
|[[Image:Draft_Samper_426828278-Figura21.png|551px|Square domain with homogeneous Dirichlet conditions and constant source. Solution for an unstructured mesh of 2 ×20×20 three node triangles]]
991
|- style="text-align: center; font-size: 75%;"
992
| colspan="1" | '''Figure 21:''' Square domain with homogeneous Dirichlet conditions and constant source. Solution for an unstructured mesh of <math>2 \times 20\times 20</math> three node triangles
993
|}
994
995
996
This problem was also studied by Codina <span id='citeF-11'></span>[[#cite-9|[9,33]]] with four node square elements as another benchmark to study the performance of different shock capturing methods. The FIC method proposed here has yielded accurate solutions for both quadrilateral and triangular elements, which are difficult to obtain for many of the existing stabilization procedures, as reported in <span id='citeF-11'></span>[[#cite-9|[9,33]]].
997
998
==7 CONCLUDING REMARKS==
999
1000
The FIC governing equations for the convection-diffusion problem written in the principal curvature directions introduce naturally the necessary balancing diffusion terms to accurately solve convection dominated problems with sharp internal gradients and boundary layers. In our computations over four node quadrilaterals and three node triangles very good results have been obtained by assuming that the principal curvature direction <math display="inline">\xi </math> is constant over each  element  and equal to the direction of the gradient vector at the element center.
1001
1002
The dependence of the balancing diffusion with the solution gradient makes the stabilization process non linear. An efficient iterative scheme has been proposed where the standard SUPG formulation is used to obtain an initial solution. Convergence of the iterative scheme has proved to be very fast  in all problems solved.
1003
1004
The balancing diffusion terms can be interpreted as the sum of a non linear SUPG diffusion term and a non linear shock capturing term. If the velocity is parallel to the gradient vector, then the standard (linear) SUPG term is recovered.
1005
1006
The efficiency and accuracy of the method was tested in a number of problems with arbitrary sharp gradients solved with structured and unstructured meshes of linear quadrilaterals and triangles.
1007
1008
Very accurate results were obtained in just two iterations for most of the problems solved (Examples 6.1&#8211;6.3). One iteration  sufficed to provide good quality stabilized results in many cases.
1009
1010
As a general rule, both linear triangles and bilinear quadrilaterals yielded similar good results for structured meshes. The linear triangle shows a slightly superior performance for unstructured meshes.
1011
1012
The examples presented show that the FIC formulation incorporates in a unified theoretical and computational framework the best features of the classical streamline stabilization methods and shock capturing techniques.
1013
1014
==ACKNOWLEDGEMENTS==
1015
1016
The authors thank S. Badia, C. Felippa, R. Löhner, R.L. Taylor and O.C. Zienkiewicz for many useful discussions.
1017
1018
==APPENDIX A==
1019
1020
===Computation of the balancing diffusion matrix <math>\overline{\textbf D}</math> in local and global axes===
1021
1022
The balancing diffusion matrix <math display="inline">\bar {\textbf D}</math> can be computed by transforming the local matrix <math display="inline">\bar{\textbf D}'</math> of Eq.(23) to global axes, or by using directly Eq.(33). We will prove next that both expressions yield the same system of governing differential equations, i.e. we will prove that
1023
1024
{| class="formulaSCP" style="width: 100%; text-align: left;" 
1025
|-
1026
| 
1027
{| style="text-align: left; margin:auto;width: 100%;" 
1028
|-
1029
| style="text-align: center;" | <math>{\boldsymbol \nabla }^T ( {\textbf T}^T \bar{\textbf D}' {\textbf T}) {\boldsymbol \nabla }\phi = {\boldsymbol \nabla }^T \left({1\over 2} {\textbf h} {\textbf u}^T\right){\boldsymbol \nabla }\phi  </math>
1030
|}
1031
| style="width: 5px;text-align: right;white-space: nowrap;" | (A.1)
1032
|}
1033
1034
where
1035
1036
{| class="formulaSCP" style="width: 100%; text-align: left;" 
1037
|-
1038
| 
1039
{| style="text-align: left; margin:auto;width: 100%;" 
1040
|-
1041
| style="text-align: center;" | <math>\bar{\textbf D}' = {1\over 2} \left[\begin{array}{cc}u_\xi h_\xi & 0\\ 0 & u_\eta h_\eta \end{array}\right]\quad ,\quad {\textbf T} =\left[\begin{array}{cc}c_\alpha & s_\alpha \\ - s_\alpha & c_\alpha \end{array}\right] </math>
1042
|}
1043
| style="width: 5px;text-align: right;white-space: nowrap;" | (A.2)
1044
|}
1045
1046
and
1047
1048
{| class="formulaSCP" style="width: 100%; text-align: left;" 
1049
|-
1050
| 
1051
{| style="text-align: left; margin:auto;width: 100%;" 
1052
|-
1053
| style="text-align: center;" | <math>{\textbf h}= \left\{\begin{array}{c}h_x \\h_y\end{array} \right\}= {\textbf T}^T \left\{\begin{array}{c}h_\xi \\h_\eta \end{array} \right\}= {\textbf T}^T{\textbf h}'</math>
1054
| style="width: 5px;text-align: right;white-space: nowrap;" | (A.3)
1055
|-
1056
| style="text-align: center;" | <math> {\textbf u}= \left\{\begin{array}{c}u\\ v \end{array} \right\}= {\textbf T}^T \left\{\begin{array}{c}u_\xi \\u_\eta \end{array} \right\}= {\textbf T}^T{\textbf u}' </math>
1057
| style="width: 5px;text-align: right;white-space: nowrap;" | (A.4)
1058
|}
1059
|}
1060
1061
In above <math display="inline">c_\alpha =\cos \alpha , s_\alpha =\sin \alpha </math> where <math display="inline">\alpha </math> is the angle that the principal curvature axis <math display="inline">\vec{\xi }</math> forms with the global direction <math display="inline">x</math>. The characteristic length distances <math display="inline">h_\xi </math> and <math display="inline">h_\eta </math> are computed as described in Eqs.(25&#8211;27).
1062
1063
In order to prove the identity in Eq.(A.1) we proceed as follows
1064
1065
{| class="formulaSCP" style="width: 100%; text-align: left;" 
1066
|-
1067
| 
1068
{| style="text-align: left; margin:auto;width: 100%;" 
1069
|-
1070
| style="text-align: center;" | <math>\bar{\textbf D} = {\textbf T}^T \bar{\textbf D}'{\textbf T} = {1\over 2}  \left[\begin{array}{ccc}\displaystyle{u_\xi h_\xi c_\alpha ^2 + u_\eta h_\eta s_\alpha ^2  \over \hbox{Sym.}} & \!\!\!\!\Bigg|& \!\!\!\!\displaystyle{(u_\xi h_\xi - u_\eta h_\eta ) s_\alpha c_\alpha \over  u_\xi h_\xi s_\alpha ^2 + u_\eta h_\eta c_\alpha ^2}\end{array}\right] </math>
1071
|}
1072
| style="width: 5px;text-align: right;white-space: nowrap;" | (A.5)
1073
|}
1074
1075
{| class="formulaSCP" style="width: 100%; text-align: left;" 
1076
|-
1077
| 
1078
{| style="text-align: left; margin:auto;width: 100%;" 
1079
|-
1080
| style="text-align: center;" | <math>\begin{array}{ll}{\boldsymbol \nabla }^T ({\textbf T}^T \bar{\textbf D}'{\textbf T}) {\boldsymbol \nabla }\phi = & {1\over 2} \left[(u_\xi h_\xi c_\alpha ^2  + u_\eta h_\eta s_\alpha ^2) \phi _x^{''} + (u_\xi h_\xi s_\alpha ^2 + u_\eta h_\eta c_\alpha ^2) \phi _y^{''} +\right.\\ &\left.+  2 (u_\xi h_\xi - u_\eta h_\eta ) s_\alpha c_\alpha \phi _{xy}^{''}\right] \end{array} </math>
1081
|}
1082
| style="width: 5px;text-align: right;white-space: nowrap;" | (A.6)
1083
|}
1084
1085
On the other hand
1086
1087
{| class="formulaSCP" style="width: 100%; text-align: left;" 
1088
|-
1089
| 
1090
{| style="text-align: left; margin:auto;width: 100%;" 
1091
|-
1092
| style="text-align: center;" | <math>{1\over 2} {\textbf h }{\textbf u}^T = {1\over 2} {\textbf T}^T ({\textbf h}' {\textbf u}^{'T}) {\textbf T} </math>
1093
|}
1094
| style="width: 5px;text-align: right;white-space: nowrap;" | (A.7)
1095
|}
1096
1097
Finally
1098
1099
{| class="formulaSCP" style="width: 100%; text-align: left;" 
1100
|-
1101
| 
1102
{| style="text-align: left; margin:auto;width: 100%;" 
1103
|-
1104
| style="text-align: center;" | <math>\begin{array}{ll}{\boldsymbol \nabla }^T \left({1\over 2}{\textbf h }{\textbf u}^T\right){\boldsymbol \nabla } \phi = & {1\over 2} {\boldsymbol \nabla }^T [{\textbf T}^T ({\textbf h}' {\textbf u}^{'T}){\textbf T}]  {\boldsymbol \nabla } \phi ]= {1\over 2} \left[(u_\xi h_\xi c_\alpha ^2  + \right.\\ &\left.u_\eta h_\eta s_\alpha ^2) \phi _x^{''} + (u_\xi h_\xi s_\alpha ^2 + u_\eta h_\eta c_\alpha ^2) \phi _y^{''} + 2 (u_\xi h_\xi - u_\eta h_\eta ) s_\alpha c_\alpha \phi _{xy}^{''}\right]+ \\ & \left[s_\alpha c_\alpha (\phi _y^{''}-\phi _x^{''}) + (c_\alpha ^2 - s_\alpha ^2 ) \phi _{xy}^{''}\right](u_\xi h_\xi + u_\eta h_\eta ) \end{array} </math>
1105
|}
1106
| style="width: 5px;text-align: right;white-space: nowrap;" | (A.8)
1107
|}
1108
1109
Clearly Eqs.(A.6) and (A.8) coincide if the last term in Eq.(A.8) is zero. This happens when <math display="inline">\vec{\xi }</math> and <math display="inline">\vec{\eta }</math> are the principal curvature directions. In order to prove this we will consider the usual case for which <math display="inline">\phi _{xy}^{''} = \phi _{yx}^{''}</math> and both principal curvature directions are orthogonal. Then it exists a transformation matrix <math display="inline">\textbf T</math> such that
1110
1111
{| class="formulaSCP" style="width: 100%; text-align: left;" 
1112
|-
1113
| 
1114
{| style="text-align: left; margin:auto;width: 100%;" 
1115
|-
1116
| style="text-align: center;" | <math>{\textbf T}\left[\begin{array}{cc}\phi _x^{''} & \phi _{xy}^{''}\\ \phi _{xy}^{''}&  \phi _y^{''}  \end{array}\right]{\textbf T} ^T= \left[\begin{array}{cc}\phi _{\xi }^{''} &0\\ 0 & \phi _{\eta }^{''} \end{array}\right] </math>
1117
|}
1118
| style="width: 5px;text-align: right;white-space: nowrap;" | (A.9)
1119
|}
1120
1121
with <math display="inline">{\textbf T}</math> defined as in Eq.(A.2).
1122
1123
The condition which ensures a diagonal matrix in the r.h.s. of Eq.(A.9) is
1124
1125
{| class="formulaSCP" style="width: 100%; text-align: left;" 
1126
|-
1127
| 
1128
{| style="text-align: left; margin:auto;width: 100%;" 
1129
|-
1130
| style="text-align: center;" | <math>s_\alpha c_\alpha (\phi _y^{''}-\phi _x^{''}) +  ( c_\alpha ^2 - s_\alpha ^2 )\phi _{xy}^{''} =0 </math>
1131
|}
1132
| style="width: 5px;text-align: right;white-space: nowrap;" | (A.10)
1133
|}
1134
1135
which is precisely the condition which cancels out the last term in Eq.(A.8).
1136
1137
Hence the identity of Eq.(A.1) is satisfied.
1138
1139
==REFERENCES==
1140
1141
<div id="cite-1"></div>
1142
'''[[#citeF-1|[1]]]''' Zienkiewicz O.C. and Taylor R.L. ''The finite element method''. 5th Edition, 3 Volumes, Butterworth&#8211;Heinemann, 2000.
1143
1144
<div id="cite-2"></div>
1145
'''[[#citeF-2|[2]]]'''  Hirsch C. ''Numerical computation of internal and external flow'', J. Wiley, Vol. 1 1988, Vol. 2, 1990.
1146
1147
<div id="cite-3"></div>
1148
'''[[#citeF-3|[3]]]''' Heinrich J.C.,  Huyakorn P.S. and  Zienkiewicz O.C. An upwind  finite element scheme for two dimensional convective transport equations,  ''Int. J. Num. Meth. Engng.'', '''11''', 131&#8211;143, 1977.
1149
1150
<div id="cite-4"></div>
1151
'''[[#citeF-4|[4]]]'''  Kelly D.W.,  Nakazawa S.,  Zienkiewicz O.C. and  Heinrich  J.C. A  note on upwind and anisotropic balancing dissipation in finite element  approximation to convective diffusion problems. ''Int. J. Num. Meth.  Engng.'', '''15''', pp. 1705&#8211;1711, 1980.
1152
1153
<div id="cite-5"></div>
1154
'''[[#citeF-5|[5]]]''' Brooks A.N. and Hughes T.J.R. Streamline upwind/Petrov-Galerkin formulation for convection dominated flows with particular emphasis  on the incompressible Navier-Stokes equations. ''Comput. Methods Appl.  Mech. Engrg.'', '''32''', 199&#8211;259, 1982.
1155
1156
<div id="cite-6"></div>
1157
'''[[#citeF-6|[6]]]''' Hughes T.J.R and Tezduyar, T.E. Finite element method for first order hyperbolic systems with particular emphasis on the compressible Euler equations. ''Comput. Meth. Appl. Mech. Engng.'', '''45''', 217&#8211;284, 1984.
1158
1159
<div id="cite-7"></div>
1160
'''[[#citeF-7|[7]]]''' Hughes T.J.R and Mallet M. A new finite element formulations  for computational fluid dynamics: III. The generalized streamline operator  for multidimensional advective-diffusive systems. ''Comput Methods Appl.  Mech. Engrg.'', '''58''', 305&#8211;328, 1986a.
1161
1162
<div id="cite-8"></div>
1163
'''[[#citeF-8|[8]]]'''  Codina R., Oñate E. and Cervera M. The intrinsic time for the streamline-upwind Petrov-Galerkin formulation using quadratic elements. ''Int. J. Num. Meth. Engrg.'', '''94''', 239&#8211;262, 1992.
1164
1165
<div id="cite-9"></div>
1166
'''[[#citeF-9|[9]]]'''  Codina R. ''A finite element formulation for the numerical solution of the convection-diffusion equations''. Monograph no. 14, CIMNE, Barcelona 1993.
1167
1168
<div id="cite-10"></div>
1169
'''[[#citeF-10|[10]]]'''  Donea J. A Taylor-Galerkin method for convective transport  problems. ''Int. J. Num. Meth. Engng.'', '''20''', pp. 101&#8211;119,  1984.
1170
1171
<div id="cite-11"></div>
1172
'''[[#citeF-11|[11]]]'''   Donea J. and Huerta A. ''Finite element methods for flow problems''. J. Wiley, 2003.
1173
1174
<div id="cite-12"></div>
1175
'''[[#citeF-12|[12]]]'''  Donea J., Belytschko T. and Smolinski P. A generalized  Galerkin method for steady state convection-diffusion problems with  applications to quadratic shape functions elements. ''Comp. Meth.  Appl. Mech. Engng.'', '''48''', 25&#8211;43, 1985.
1176
1177
<div id="cite-13"></div>
1178
'''[[#citeF-13|[13]]]'''   Goldschmit M.B. and Dvorkin E.N. On the solution of the  steady-state convection-diffusion equation using quadratic elements. A  generalized Galerkin technique also reliable with distorted meshes. '' Engng. Comput.'', '''11''', 6, 565&#8211;579, 1994.
1179
1180
<div id="cite-14"></div>
1181
'''[[#citeF-14|[14]]]''' Hughes T.J.R, Franca L.P. and Hulbert G.M. A new finite  element formulation for computational fluid dynamics: VIII. The  Galerkin/least-squares method for advective-diffusive equations. '' Comput. Methods Appl. Mech. Engrg.'', '''73''', 173&#8211;189, 1989.
1182
1183
<div id="cite-15"></div>
1184
'''[[#citeF-15|[15]]]'''   Franca L.P.,  Frey S.L. and  Hughes T.J.R. Stabilized finite element methods: I. Application to the  advective-diffusive model. ''Comput. Meth. Appl. Mech. Engn'', Vol. '''95''', pp. 253&#8211;276, 1992.
1185
1186
<div id="cite-16"></div>
1187
'''[[#citeF-16|[16]]]''' Franca  L.P. and Dutra do Carmo E.G. The Galerkin Gradient Least Square method. ''Comput. Methods Appl. Mech. Engrg.'', '''74''', 41&#8211;54, 1989.
1188
1189
<div id="cite-17"></div>
1190
'''[[#citeF-17|[17]]]'''  Douglas J. and  Russell T.F. Numerical methods for convection dominated diffusion problems based on combining the method of characteristics with finite element or finite difference procedures. ''SIAM J. Numer. Anal.'', '''19''', 871, 1982.
1191
1192
<div id="cite-18"></div>
1193
'''[[#citeF-18|[18]]]'''  Löhner R., Morgan K. and  Zienkiewicz O.C. The solution of non-linear hyperbolic equation systems by the finite element method. ''Int. J. Num. Meth. in Fluids'', '''4''', 1043, 1984.
1194
1195
<div id="cite-19"></div>
1196
'''[[#citeF-19|[19]]]''' Zienkiewicz  O.C. and  Codina R. A general algorithm for  compressible and incompressible flow. Part I: The split characteristic  based scheme. ''Int. J. Num. Meth. in Fluids'', '''20''', 869-85, 1995.
1197
1198
<div id="cite-20"></div>
1199
'''[[#citeF-20|[20]]]''' Hughes T.J.R. Multiscale phenomena: Green functions,  subgrid scale models, bubbles and the origins of stabilized methods.  ''Comput. Methods Appl. Mech. Engrg'' 1995, '''127''', 387&#8211;401, 1995.
1200
1201
<div id="cite-21"></div>
1202
'''[[#citeF-21|[21]]]''' Brezzi F., Franca L.P., Hughes T.J.R. and  Russo A. <math>b=\int  g</math>. ''Comput. Methods Appl. Mech. Engrg.'', '''145''', 329&#8211;339, 1997.
1203
1204
<div id="cite-22"></div>
1205
'''[[#citeF-22|[22]]]'''  Codina R. Stabilization of incompressibility and convection through orthogonal sub-scales in finite element method. ''Comput. Methods Appl. Mech. Engrg.'', '''190''', 1579&#8211;1599, 2000.
1206
1207
<div id="cite-23"></div>
1208
'''[[#citeF-23|[23]]]'''  Hauke G. A simple subgrid scale stabilized method for the advection-diffusion-reaction equation. ''Comput. Methods Appl. Mech. Engrg.'', '''191''', 2925&#8211;2948, 2002.
1209
1210
<div id="cite-24"></div>
1211
'''[[#citeF-24|[24]]]'''   Brezzi, F. and Russo A. Choosing bubbles for advection-diffusion problems. ''Math Models Methods Appl. Sci.'', '''4''', 571&#8211;587, 1994.
1212
1213
<div id="cite-25"></div>
1214
'''[[#citeF-25|[25]]]'''  Farhat C., Harari I. and  Franca L.P. The discontinuous enrichment method.  ''Comput. Methods Appl. Mech. Engrg.'', '''190''', 6455&#8211;6479, 2001.
1215
1216
<div id="cite-26"></div>
1217
'''[[#citeF-26|[26]]]'''  Ilinca F., Hétu J.F. and Pelletier D. On stabilized finite element formulation for incompressible advective-diffusive transport and fluid flow problems. ''Comput. Methods  Appl. Mech. Engrg.'', '''188''', 235&#8211;257, 2000.
1218
1219
<div id="cite-27"></div>
1220
'''[[#citeF-27|[27]]]'''  Tezduyar T.E. and Osawa Y. Finite element stabilization parameters computed from element matrices and vectors. ''Comput. Methods Appl. Mech. Engrg.'', '''190''', 411&#8211;430, 2000.
1221
1222
<div id="cite-28"></div>
1223
'''[[#citeF-28|[28]]]'''   Tezduyar T.E. Adaptive determination of the finite element stabilization parameters. In ''Proceedings of the ECCOMAS Computational Fluid Dynamics Conference 2001'' (CD-ROM), Swansea, Wales, United Kingdom 2001.
1224
1225
<div id="cite-29"></div>
1226
'''[[#citeF-29|[29]]]'''  Harari I.,  Franca L.P. and  Oliveira S.P. Streamline design of stability parameters for advection-diffusion problems. ''J. Comput. Physics'', '''171''', 115&#8211;131, 2001.
1227
1228
<div id="cite-30"></div>
1229
'''[[#citeF-30|[30]]]'''  Nesliturk A. and Harari I. The nearly-optimal Petrov-Galerkin method for convection-diffusion problems. ''Comput Methods  Appl. Mech. Engrg.'', '''192''', 2501&#8211;2519, 2003.
1230
1231
<div id="cite-31"></div>
1232
'''[[#citeF-31|[31]]]'''  Tezduyar T.E. Computation of moving boundaries and stabilization parameters. ''Int. J. Num. Meth. Fluids'', '''43''', 555&#8211;575, 2003.
1233
1234
<div id="cite-32"></div>
1235
'''[[#citeF-32|[32]]]'''  Hughes T.J.R. and Mallet M. A new finite element formulations for computational fluid dynamics: IV. A discontinuity capturing operator for multidimensional advective-diffusive system. ''Comput. Methods Appl. Mech. Engrg.'', '''58''', 329&#8211;336, 1986b.
1236
1237
<div id="cite-33"></div>
1238
'''[[#citeF-33|[33]]]'''  Codina R. A discontinuity-capturing crosswind dissipation for the finite element solution of the convection-diffusion equation. ''Comput. Methods Appl. Mech. Engrg.'', '''110''', 325&#8211;342, 1993.
1239
1240
<div id="cite-34"></div>
1241
'''[[#citeF-34|[34]]]'''  Hughes T.J.R.,  Mallet M. and Mizukami A. A new finite element formulation for comptutational fluid dynamics: II Beyond SUPG. ''Comput. Methods Appl. Mech. Engrg.'', '''54''', 341&#8211;355, 1986.
1242
1243
<div id="cite-35"></div>
1244
'''[[#citeF-35|[35]]]'''  Galeo A.C. and  Dutra do Carmo E.G. A consistent approximate upwind Petrov-Galerkin method for convection-dominated problems. ''Comput. Methods Appl. Mech. Engrg.'', '''68''', 83&#8211;95, 1988.
1245
1246
<div id="cite-36"></div>
1247
'''[[#citeF-36|[36]]]'''  Tezduyar T.E. and  Park Y.J. Discontinuity-capturing finite element formulations for nonlinear convection-diffusion-reaction equations. ''Comput. Methods Appl. Mech. Engrg.'', '''59''', 307&#8211;325, 1986
1248
1249
<div id="cite-37"></div>
1250
'''[[#citeF-37|[37]]]''' Oñate E. Derivation of stabilized equations for  advective-diffusive transport and fluid flow problems.  ''Comput. Methods Appl. Mech. Engrg.'', '''151:1-2''', 233&#8211;267, 1998.
1251
1252
<div id="cite-38"></div>
1253
'''[[#citeF-38|[38]]]'''  Oñate E. Possibilities of finite calculus in computational mechanics.  ''Int. J. Num. Meth. Engng.'' 2004; '''60''':255&#8211;281.
1254
1255
<div id="cite-39"></div>
1256
'''[[#citeF-39|[39]]]''' Oñate E. and  Manzan M. Stabilization techniques for finite element analysis of convection diffusion problems. In ''Comput. Anal. of Heat Transfer'',  WIT Press, G. Comini and B. Sunden (Eds.), 2000.
1257
1258
<div id="cite-40"></div>
1259
'''[[#citeF-40|[40]]]''' Oñate E., García J. and Idelsohn S.R. Computation of the stabilization  parameter for the finite element solution of advective-diffusive problems. ''Int. J. Num. Meth. Fluids'', '''25''', 1385&#8211;1407, 1997.
1260
1261
<div id="cite-41"></div>
1262
'''[[#citeF-41|[41]]]''' Oñate E. and Manzan M. A general procedure for deriving stabilized space-time finite element methods for advective-diffusive problems. ''Int. J. Num. Meth. Fluids'', '''31''', 203&#8211;221, 1999.
1263
1264
<div id="cite-42"></div>
1265
'''[[#citeF-42|[42]]]'''  Felippa C.A. and  Oñate E. Nodally exact Ritz discretization of 1D diffusion-absorption and Helmholtz equations by variational FIC and modified equation methods. Research Report No. PI 237, CIMNE, Barcelona 2004. Submitted to ''Computational Mechanics''.
1266
1267
<div id="cite-43"></div>
1268
'''[[#citeF-43|[43]]]'''  Oñate E., Miquel J. and Hauke G. Stabilized formulation for the 1D advection-diffusion-absorption equation using finite calculus and the finite element method. Submitted to ''Comput. Meth. Appl. Mech. Engng.'', Dec. 2004.
1269
1270
<div id="cite-44"></div>
1271
'''[[#citeF-44|[44]]]'''  Oñate E. A stabilized finite element method for incompressible viscous flows using a finite increment calculus formulation. ''Comput. Methods Appl. Mech. Engrg.'' 2000; '''182:1&#8211;2''':355&#8211;370.
1272
1273
<div id="cite-45"></div>
1274
'''[[#citeF-45|[45]]]'''  Oñate E.,  García J. A finite element method for fluid-structure interaction with surface waves using a finite calculus formulation. in ''Comput. Methods Appl. Mech. Engrg.'', '''191:6-7''', 635-660, 2001.
1275
1276
<div id="cite-46"></div>
1277
'''[[#citeF-46|[46]]]'''  García J. and Oñate E. An unstructured finite element solver for ship hydrodynamic problems. ''Journal of Appl. Mechanics'', '''70''', 18&#8211;26, 2003.
1278
1279
<div id="cite-47"></div>
1280
'''[[#citeF-47|[47]]]'''   Oñate E., García J., Idelsohn S.R. Ship Hydrodynamics. ''Encyclopedia of Computational Mechanics'', T. Hughes, R. de Borst and E. Stein (Eds.), J. Wiley, 2004.
1281
1282
<div id="cite-48"></div>
1283
'''[[#citeF-48|[48]]]'''  Oñate E., Taylor R.L., Zienkiewicz O.C. and  Rojek J. A residual correction method based on finite calculus. ''Engineering Computations'', Vol. '''20''', No. '''5/6''', 629&#8211;658, 2003.
1284
1285
<div id="cite-49"></div>
1286
'''[[#citeF-49|[49]]]''' Oñate E., Rojek J., Taylor R.L. and Zienkiewicz O.C. Finite calculus formulation for analysis of incompressible solids using linear triangles and tetrahedra. ''Int. J. Num. Meth. Engng.'', '''59''', (11), 1473&#8211;1500, 2004.
1287
1288
<div id="cite-50"></div>
1289
'''[[#citeF-50|[50]]]'''  Zienkiewicz OC, Zhu JZ. The Superconvergent patch recovery (SPR) and adaptive finite element refinement. ''Comput. Methods Appl. Mech. Engrg.'' 1992; '''101''':207&#8211;224.
1290
1291
<div id="cite-51"></div>
1292
'''[[#citeF-51|[51]]]'''  Wiberg NW, Abdulwahab F,  Li XD. (1997). Error estimation  and adaptive procedures based on superconvergent patch recovery. ''Archives Comput. Meth. Engng.'' 1997; '''4:3''':203&#8211;242.
1293

Return to Onate Zarate et al 2006a.

Back to Top