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
<!-- metadata commented in wiki content
2
==FINITE ELEMENT FORMULATION FOR CONVECTIVE-DIFFUSIVE PROBLEMS WITH SHARP GRADIENTS USING FINITE CALCULUS==
3
4
'''Eugenio Oñate, Francisco Zárate and Sergio R. Idelsohn'''
5
6
{|
7
|-
8
|International Center for Numerical Methods in Engineering (CIMNE)
9
|-
10
| Universidad Politécnica de Cataluña
11
|-
12
| Edificio C1, Gran Capitán s/n, 08034, Barcelona, Spain
13
|-
14
| e-mail: [mailto:onate@cimne.upc.edu onate@cimne.upc.edu]
15
|}
16
-->
17
18
==Abstract==
19
20
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.
21
22
<br/><br/>
23
24
==1 INTRODUCTION==
25
26
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]]. 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]], the Streamline Upwind Petrov-Galerkin (SUPG) method <span id='citeF-5'></span>[[#cite-5|5]], the Taylor-Galerkin method <span id='citeF-12'></span>[[#cite-12|12]], the generalized Galerkin method <span id='citeF-17'></span>[[#cite-17|17]], the Galerkin Least Square method and related approaches <span id='citeF-19'></span>[[#cite-19|19]], the Characteristic Galerkin method <span id='citeF-22'></span>[[#cite-22|22]], the Characteristic Based Split method <span id='citeF-24'></span>[[#cite-24|24]], the  Subgrid Scale method <span id='citeF-25'></span>[[#cite-25|25]], the Residual Free Bubbles method <span id='citeF-37'></span>[[#cite-37|37]], the Discontinuous Enrichment Method <span id='citeF-39'></span>[[#cite-39|39]] and the Streamline Upwind with Boundary Terms method <span id='citeF-40'></span>[[#cite-40|40]].  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|41]]. 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|49]]. 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.
27
28
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.
29
30
The formulation proposed is based in the so called Finite Calculus (FIC) approach <span id='citeF-50'></span>[[#cite-50|50]]. 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.
31
32
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|50]], convection-diffusion-absorption [42,43], incompressible fluid flow <span id='citeF-47'></span>[[#cite-47|47]] and incompressible solid mechanics [48,49].
33
34
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|50]].
35
36
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|50]]. In <span id='citeF-51'></span>[[#cite-51|51]] 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.
37
38
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.
39
40
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.
41
42
==2 FIC GOVERNING EQUATIONS FOR STEADY-STATE CONVECTION-DIFFUSIVE PROBLEMS==
43
44
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
45
46
{| class="formulaSCP" style="width: 100%; text-align: left;" 
47
|-
48
| 
49
{| style="text-align: left; margin:auto;width: 100%;" 
50
|-
51
| 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>
52
|}
53
| style="width: 5px;text-align: right;white-space: nowrap;" | (1)
54
|}
55
56
with the boundary conditions
57
58
{| class="formulaSCP" style="width: 100%; text-align: left;" 
59
|-
60
| 
61
{| style="text-align: left; margin:auto;width: 100%;" 
62
|-
63
| style="text-align: center;" | <math>\phi - \phi ^p = 0\qquad \hbox{on}~~\Gamma _\phi </math>
64
|}
65
| style="width: 5px;text-align: right;white-space: nowrap;" |  (2a)
66
|}
67
68
{| class="formulaSCP" style="width: 100%; text-align: left;" 
69
|-
70
| 
71
{| style="text-align: left; margin:auto;width: 100%;" 
72
|-
73
| style="text-align: center;" | <math>{n}^T {D} {\boldsymbol \nabla }\phi +q_n^p - \underline{{1\over 2}{h}^T {n}  r}{1\over 2}{h}^T {n}  r= 0\qquad \hbox{on}~~\Gamma _q </math>
74
|}
75
| style="width: 5px;text-align: right;white-space: nowrap;" |  (2b)
76
|}
77
78
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-50|50]]. In above equations
79
80
{| class="formulaSCP" style="width: 100%; text-align: left;" 
81
|-
82
| 
83
{| style="text-align: left; margin:auto;width: 100%;" 
84
|-
85
| style="text-align: center;" | <math>r := -{u}^T {\boldsymbol \nabla } \phi + {\boldsymbol \nabla }^T {D} {\boldsymbol \nabla }\phi + Q </math>
86
|}
87
| style="width: 5px;text-align: right;white-space: nowrap;" | (3)
88
|}
89
90
where <math display="inline">u</math> is the divergence-free velocity vector, <math display="inline">{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">{n}</math> is the normal vector. Vector <math display="inline">{h}</math>  is the ''characteristic length'' vector. For 2D problems <math display="inline">{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-50|50]].
91
92
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-50|50]]. The finite element formulation will be presented next.
93
94
===2.1 Finite element discretization===
95
96
A finite element interpolation of the unknown <math display="inline">\phi </math> can be written as
97
98
{| class="formulaSCP" style="width: 100%; text-align: left;" 
99
|-
100
| 
101
{| style="text-align: left; margin:auto;width: 100%;" 
102
|-
103
| style="text-align: center;" | <math>\phi \simeq \hat \phi =\sum N_i \phi _i </math>
104
|}
105
| style="width: 5px;text-align: right;white-space: nowrap;" | (4)
106
|}
107
108
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]].
109
110
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>
111
112
{| class="formulaSCP" style="width: 100%; text-align: left;" 
113
|-
114
| 
115
{| style="text-align: left; margin:auto;width: 100%;" 
116
|-
117
| style="text-align: center;" | <math>\int _\Omega N_i \hat r d\Omega - \int _{\Gamma _q} N_i ({n}^T {D} {\boldsymbol \nabla }\hat \phi +q_n^p)d\Gamma + \sum \limits _e {1\over 2}  \int _{\Omega ^e} ({h}^T{\boldsymbol \nabla } N_i + N_i {\boldsymbol \nabla }^T {h})\hat r d\Omega =0 </math>
118
|}
119
| style="width: 5px;text-align: right;white-space: nowrap;" | (5)
120
|}
121
122
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.
123
124
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).
125
126
Integrating by parts the diffusive terms in the first integral of Eq.(5) leads to
127
128
{| class="formulaSCP" style="width: 100%; text-align: left;" 
129
|-
130
| 
131
{| style="text-align: left; margin:auto;width: 100%;" 
132
|-
133
| style="text-align: center;" | <math>\int _\Omega N_i [{u}^T \nabla \hat \phi + {\boldsymbol \nabla }^T N_i {D}{\boldsymbol \nabla }\hat \phi ] d\Omega - \sum \limits _e {1\over 2} \int _{\Omega ^e} ({h}^T{\boldsymbol \nabla } N_i + N_i {\boldsymbol \nabla }^T {h})\hat r  d\Omega - \int _\Omega N_i Q d\Omega +\int _{\Gamma _q} N_i q_n^p d\Gamma =0 </math>
134
|}
135
| style="width: 5px;text-align: right;white-space: nowrap;" | (6)
136
|}
137
138
In matrix form
139
140
{| class="formulaSCP" style="width: 100%; text-align: left;" 
141
|-
142
| 
143
{| style="text-align: left; margin:auto;width: 100%;" 
144
|-
145
| style="text-align: center;" | <math>{K}{a}={f} </math>
146
|}
147
| style="width: 5px;text-align: right;white-space: nowrap;" | (7)
148
|}
149
150
Matrix '''K''' and vector '''f''' are assembled from the element contributions given by
151
152
{| class="formulaSCP" style="width: 100%; text-align: left;" 
153
|-
154
| 
155
{| style="text-align: left; margin:auto;width: 100%;" 
156
|-
157
| style="text-align: center;" | <math>K_{ij}^e = \int _{\Omega ^e} [N_i{u}^T {\boldsymbol \nabla }N_j + {\boldsymbol \nabla }^T N_i ({D} + {1\over 2}{h}{u}^T){\boldsymbol \nabla } N_j + N_i ({\boldsymbol \nabla }^T {h}) {u}^T {\boldsymbol \nabla } N_j ]d\Omega -</math>
158
|-
159
| style="text-align: center;" | <math> - {1\over 2} \int _{\Omega ^e} ({h}^T {\boldsymbol \nabla } N_i + N_i {\boldsymbol \nabla }^T {h}) {\boldsymbol \nabla }^T ({D} {\boldsymbol \nabla } N_j)d\Omega </math>
160
| style="width: 5px;text-align: right;white-space: nowrap;" | (8.a)
161
|-
162
| style="text-align: center;" | <math> f_i^e = \int _{\Omega ^e} [N_i + {1\over 2} ({h}^T{\boldsymbol \nabla } N_i +N_i {\boldsymbol \nabla }^T {h}) ] Qd\Omega - \int _{\Gamma _q^e}N_i q_n^p d\Gamma  </math>
163
| style="width: 5px;text-align: right;white-space: nowrap;" | (8.b)
164
|}
165
|}
166
167
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
168
169
{| class="formulaSCP" style="width: 100%; text-align: left;" 
170
|-
171
| 
172
{| style="text-align: left; margin:auto;width: 100%;" 
173
|-
174
| style="text-align: center;" | <math>{D}_G = {D} +\bar {D} \quad \hbox{and}\quad \bar {D} = {1\over 2} {h}{u}^T </math>
175
|}
176
| style="width: 5px;text-align: right;white-space: nowrap;" | (9)
177
|}
178
179
In Eq.(9) <math display="inline">\bar {D}</math> is the ''balancing diffusion matrix'' introduced by the FIC method.
180
181
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.
182
183
Note  that when linear elements are used the second integral of Equation (8a) vanishes. The same happens with the term <math display="inline">{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">h</math> vanish if <math display="inline">h</math> is constant over the element. The evaluation of these integrals is mandatory in any other case.
184
185
===2.2 Equivalence with the SUPG method===
186
187
Let us now assume that the direction of vector <math display="inline">h</math> is ''parallel'' to that of the velocity <math display="inline">u</math>, i.e. <math display="inline">{h}= h{{u}\over \vert {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{h}=0</math>)
188
189
{| class="formulaSCP" style="width: 100%; text-align: left;" 
190
|-
191
| 
192
{| style="text-align: left; margin:auto;width: 100%;" 
193
|-
194
| style="text-align: center;" | <math>\int _\Omega N_i \hat r d\Omega - \int _{\Gamma _q} N_i ({n}^T {D} {\boldsymbol \nabla }\hat \phi +q_n^p)d\Omega{+} \sum \limits _e \int _{\Omega ^e} {h\over 2\vert {u}\vert  }   {u}^T{\boldsymbol \nabla } N_i \hat rd\Omega =0 </math>
195
|}
196
| style="width: 5px;text-align: right;white-space: nowrap;" | (10)
197
|}
198
199
Equation (10) coincides precisely with the SUPG method. The ratio <math display="inline">\displaystyle{h\over 2\vert {u}\vert  }</math> has dimensions of time and it is usually termed element ''intrinsic time'' parameter <math display="inline">\tau </math>.
200
201
The balancing diffusion matrix <math display="inline">\bar {D}</math> of Eq.(9) is now given by
202
203
{| class="formulaSCP" style="width: 100%; text-align: left;" 
204
|-
205
| 
206
{| style="text-align: left; margin:auto;width: 100%;" 
207
|-
208
| style="text-align: center;" | <math>\bar {D} ={h\over 2\vert {u}\vert }{u}{u}^T=\tau {u}{u}^T </math>
209
|}
210
| style="width: 5px;text-align: right;white-space: nowrap;" | (11)
211
|}
212
213
It can be shown that the definition of <math display="inline">\bar {D}</math> of Eq.(11) is equivalent to introducing an artificial diffusion of value <math display="inline">{h\vert {u}\vert \over 2}</math> along the streamlines <span id='citeF-1'></span>[[#cite-1|1]] 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]].
214
215
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 {D}</math> given by Eq.(11).
216
217
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">{h}</math> is arbitrary and not necessarily coincident with that of <math display="inline">{u}</math>. The components of <math display="inline">{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-49|49]].
218
219
==3 COMPUTATION OF THE CHARACTERISTIC LENGTH FOR THE 1D CONVECTION-DIFFUSION EQUATION==
220
221
The computation of the characteristic length is a crucial step as its value affect to the stability and accuracy of the numerical solution.
222
223
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.
224
225
The FIC equation for the 1D steady-state convection-diffusion problem is written as
226
227
{| class="formulaSCP" style="width: 100%; text-align: left;" 
228
|-
229
| 
230
{| style="text-align: left; margin:auto;width: 100%;" 
231
|-
232
| style="text-align: center;" | <math>r - {h\over 2}\frac{d r}{dx}=0 </math>
233
|}
234
| style="width: 5px;text-align: right;white-space: nowrap;" | (12)
235
|}
236
237
with
238
239
{| class="formulaSCP" style="width: 100%; text-align: left;" 
240
|-
241
| 
242
{| style="text-align: left; margin:auto;width: 100%;" 
243
|-
244
| style="text-align: center;" | <math>r:=-u \phi'  +k \phi''{+}Q </math>
245
|}
246
| style="width: 5px;text-align: right;white-space: nowrap;" | (13)
247
|}
248
249
where primes denote differentiation with respect to the independent space variable <math display="inline">x</math>.
250
251
The element matrices of Eqs.(8) are now written for ''two node linear elements'' as
252
253
{| class="formulaSCP" style="width: 100%; text-align: left;" 
254
|-
255
| 
256
{| style="text-align: left; margin:auto;width: 100%;" 
257
|-
258
| 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>
259
| style="width: 5px;text-align: right;white-space: nowrap;" | (14.a)
260
|-
261
| 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>
262
| style="width: 5px;text-align: right;white-space: nowrap;" | (14.b)
263
|}
264
|}
265
266
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.
267
268
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]].
269
270
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
271
272
{| class="formulaSCP" style="width: 100%; text-align: left;" 
273
|-
274
| 
275
{| style="text-align: left; margin:auto;width: 100%;" 
276
|-
277
| 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>
278
|}
279
| style="width: 5px;text-align: right;white-space: nowrap;" | (15)
280
|}
281
282
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
283
284
{| class="formulaSCP" style="width: 100%; text-align: left;" 
285
|-
286
| 
287
{| style="text-align: left; margin:auto;width: 100%;" 
288
|-
289
| style="text-align: center;" | <math>\alpha _{opt} =\coth \gamma - {1\over \gamma } </math>
290
|}
291
| style="width: 5px;text-align: right;white-space: nowrap;" | (16)
292
|}
293
294
where <math display="inline">\gamma = {ul\over 2k}</math> is the element Peclet number.
295
296
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
297
298
{| class="formulaSCP" style="width: 100%; text-align: left;" 
299
|-
300
| 
301
{| style="text-align: left; margin:auto;width: 100%;" 
302
|-
303
| 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>
304
|}
305
| style="width: 5px;text-align: right;white-space: nowrap;" | (17)
306
|}
307
308
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
309
310
{| class="formulaSCP" style="width: 100%; text-align: left;" 
311
|-
312
| 
313
{| style="text-align: left; margin:auto;width: 100%;" 
314
|-
315
| 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>
316
|}
317
| style="width: 5px;text-align: right;white-space: nowrap;" | (18)
318
|}
319
320
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.
321
322
Above well know results from the finite element and finite difference literature will be useful for the general multidimensional case described next.
323
324
===Remark 1===
325
326
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.
327
328
==4 COMPUTATION OF THE CHARACTERISTIC LENGTH VECTOR==
329
330
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.
331
332
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
333
334
{| class="formulaSCP" style="width: 100%; text-align: left;" 
335
|-
336
| 
337
{| style="text-align: left; margin:auto;width: 100%;" 
338
|-
339
| 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>
340
|-
341
| 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>
342
|}
343
| style="width: 5px;text-align: right;white-space: nowrap;" | (19)
344
|}
345
346
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.
347
348
As <math display="inline">\xi </math> and <math display="inline">\eta </math> are the principal curvature axes of the solution then
349
350
{| class="formulaSCP" style="width: 100%; text-align: left;" 
351
|-
352
| 
353
{| style="text-align: left; margin:auto;width: 100%;" 
354
|-
355
| style="text-align: center;" | <math>{\partial ^2\phi \over \partial \xi \partial \eta }= {\partial ^2\phi \over \partial \eta \partial \xi }=0 </math>
356
|}
357
| style="width: 5px;text-align: right;white-space: nowrap;" | (20)
358
|}
359
360
Introducing this simplification into Eq.(19) we can rewrite this equation as
361
362
{| class="formulaSCP" style="width: 100%; text-align: left;" 
363
|-
364
| 
365
{| style="text-align: left; margin:auto;width: 100%;" 
366
|-
367
| 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 {h_\xi \over 2}{\partial ^3 \phi \over \partial \xi ^3}+  h_\eta {h_\eta \over 2} {\partial ^3 \phi \over \partial \eta ^3}\right)=0 }</math>
368
|}
369
| style="width: 5px;text-align: right;white-space: nowrap;" | (21)
370
|}
371
372
}
373
374
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.
375
376
Eq.(21) can be rewritten in matrix form (neglecting the last term) as
377
378
{| class="formulaSCP" style="width: 100%; text-align: left;" 
379
|-
380
| 
381
{| style="text-align: left; margin:auto;width: 100%;" 
382
|-
383
| style="text-align: center;" | <math>- {u}^{\prime T} {\boldsymbol \nabla }^\prime \phi + {\boldsymbol \nabla }^{\prime T} ({D}+\bar {D}^\prime ) {\boldsymbol \nabla }^{\prime }\phi =0 </math>
384
|}
385
| style="width: 5px;text-align: right;white-space: nowrap;" | (22)
386
|}
387
388
where <math display="inline">{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">D</math> is the “physical” isotropic diffusion matrix and <math display="inline">\bar {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
389
390
{| class="formulaSCP" style="width: 100%; text-align: left;" 
391
|-
392
| 
393
{| style="text-align: left; margin:auto;width: 100%;" 
394
|-
395
| style="text-align: center;" | <math>{D}= \left[\begin{array}{cc}k &0\\0&k\end{array}\right]\qquad \hbox{and} \qquad \bar {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>
396
|}
397
| style="width: 5px;text-align: right;white-space: nowrap;" | (23)
398
|}
399
400
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
401
402
{| class="formulaSCP" style="width: 100%; text-align: left;" 
403
|-
404
| 
405
{| style="text-align: left; margin:auto;width: 100%;" 
406
|-
407
| style="text-align: center;" | <math>{u}'=\left\{\begin{array}{c}u_\xi \\ u_\eta \end{array}\right\}= {T} {u}  \quad \hbox{with}\quad {T}= \left[\begin{array}{cc}c_\alpha & s_\alpha \\ - s_\alpha & c_\alpha \end{array}\right]\quad ,\quad {u}=\left\{\begin{array}{c}u\\v\end{array}\right\} </math>
408
|}
409
| style="width: 5px;text-align: right;white-space: nowrap;" | (24)
410
|}
411
412
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.
413
414
The characteristic length distances <math display="inline">h_\xi </math> and <math display="inline">h_\eta </math> are defined as
415
416
{| class="formulaSCP" style="width: 100%; text-align: left;" 
417
|-
418
| 
419
{| style="text-align: left; margin:auto;width: 100%;" 
420
|-
421
| style="text-align: center;" | <math>h_\xi =\alpha _\xi l_\xi \quad \hbox{and}\quad h_\eta =\alpha _\eta l_\eta  </math>
422
|}
423
| style="width: 5px;text-align: right;white-space: nowrap;" | (25)
424
|}
425
426
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.
427
428
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)
429
430
{| class="formulaSCP" style="width: 100%; text-align: left;" 
431
|-
432
| 
433
{| style="text-align: left; margin:auto;width: 100%;" 
434
|-
435
| 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>
436
| style="width: 5px;text-align: right;white-space: nowrap;" | (26.a)
437
|-
438
| 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>
439
| style="width: 5px;text-align: right;white-space: nowrap;" | (26.b)
440
|}
441
|}
442
443
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.
444
445
{| class="formulaSCP" style="width: 100%; text-align: left;" 
446
|-
447
| 
448
{| style="text-align: left; margin:auto;width: 100%;" 
449
|-
450
| style="text-align: center;" | <math>l_i =\max ({d}_j^T {u}_i)\quad ,\quad i=\xi ,\eta  </math>
451
|}
452
| style="width: 5px;text-align: right;white-space: nowrap;" | (27.a)
453
|}
454
455
with
456
457
{| class="formulaSCP" style="width: 100%; text-align: left;" 
458
|-
459
| 
460
{| style="text-align: left; margin:auto;width: 100%;" 
461
|-
462
| 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>
463
|}
464
| style="width: 5px;text-align: right;white-space: nowrap;" | (27.b)
465
|}
466
467
In Eq.(27a) <math display="inline">{u}_\xi </math> and <math display="inline">{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">{d}_j</math> are the element sides vectors, whereas for quadrilaterals <math display="inline">{d}_j</math> are the element diagonals vectors.
468
469
The next step is to transform Eq.(22) to global axes <math display="inline">x,y</math>. The resulting equation is written as
470
471
{| class="formulaSCP" style="width: 100%; text-align: left;" 
472
|-
473
| 
474
{| style="text-align: left; margin:auto;width: 100%;" 
475
|-
476
| style="text-align: center;" | <math>-{u}^T {\boldsymbol \nabla }\phi +{\boldsymbol \nabla }^T {D}_G {\boldsymbol \nabla }\phi=0 </math>
477
|}
478
| style="width: 5px;text-align: right;white-space: nowrap;" | (28)
479
|}
480
481
where the global diffusion matrix <math display="inline">{D}_G</math> is
482
483
{| class="formulaSCP" style="width: 100%; text-align: left;" 
484
|-
485
| 
486
{| style="text-align: left; margin:auto;width: 100%;" 
487
|-
488
| style="text-align: center;" | <math>{D}_G={D}+\bar{D}</math>
489
|}
490
| style="width: 5px;text-align: right;white-space: nowrap;" | (29a)
491
|}
492
493
The isotropic diffusion matrix <math display="inline">D</math> is given by Eq.(23) and  the global balancing diffusion matrix <math display="inline">\bar{D}</math> is
494
495
{| class="formulaSCP" style="width: 100%; text-align: left;" 
496
|-
497
| 
498
{| style="text-align: left; margin:auto;width: 100%;" 
499
|-
500
| style="text-align: center;" | <math>\bar {D} = {T}^T \bar {D}^\prime {T}</math>
501
|}
502
| style="width: 5px;text-align: right;white-space: nowrap;" | (29b)
503
|}
504
505
where the transformation matrix '''T''' is given in Eq.(24).
506
507
===Remark 2===
508
509
We can write the local balancing diffusion matrix <math display="inline">\bar{D}'</math> of Eq.(23) for <math display="inline">k_\xi{-}k_\eta >0</math>  as
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>\bar{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{D}_\xi + \bar{D}_{iso}</math>
517
|}
518
| style="width: 5px;text-align: right;white-space: nowrap;" | (30a)
519
|}
520
521
where
522
523
{| class="formulaSCP" style="width: 100%; text-align: left;" 
524
|-
525
| 
526
{| style="text-align: left; margin:auto;width: 100%;" 
527
|-
528
| style="text-align: center;" | <math>k_\xi ={u_\xi h_\xi \over 2}\quad ,\quad k_\eta ={u_\eta h_\eta \over 2}</math>
529
|}
530
| style="width: 5px;text-align: right;white-space: nowrap;" | (30b)
531
|}
532
533
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{D}_\xi </math> and <math display="inline">k_\eta </math> is replaced by <math display="inline">k_\xi </math>  in <math display="inline">\bar{D}_{iso}</math>.
534
535
Eq.(30a) shows that the diffusivity matrix <math display="inline">\bar{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{D}_{iso}</math>
536
537
The global balancing diffusion matrix of Eq.(29a) can therefore be written as
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 {D} = \bar{D}_{iso} + {T}^T\bar{D}_\xi {T} </math>
545
|}
546
| style="width: 5px;text-align: right;white-space: nowrap;" | (31)
547
|}
548
549
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{D}_{iso}={0}</math> and
550
551
{| class="formulaSCP" style="width: 100%; text-align: left;" 
552
|-
553
| 
554
{| style="text-align: left; margin:auto;width: 100%;" 
555
|-
556
| style="text-align: center;" | <math>\bar{D}= \bar{D}_\xi =\left[\begin{array}{cc}{u_\xi h_\xi \over 2} &0\\0&0\end{array}\right] </math>
557
|}
558
| style="width: 5px;text-align: right;white-space: nowrap;" | (32)
559
|}
560
561
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.
562
563
===Remark 3===
564
565
The global balance diffusion matrix <math display="inline">\bar  {D}</math> can be also computed from the expression of vector <math display="inline">h</math> in global axes as
566
567
{| class="formulaSCP" style="width: 100%; text-align: left;" 
568
|-
569
| 
570
{| style="text-align: left; margin:auto;width: 100%;" 
571
|-
572
| style="text-align: center;" | <math>\bar  {D} ={1\over 2} {h}^T {u}\quad \hbox{with }{h}=\left\{\begin{array}{c}h_x\\h_y \end{array}\right\}  = {T}^T {h}' </math>
573
|}
574
| style="width: 5px;text-align: right;white-space: nowrap;" | (33)
575
|}
576
577
where <math display="inline">{h}'=[h_\xi , h_\eta ]^T</math> and <math display="inline">{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  {D}</math> via Eqs.(23)&#8211;(29).
578
579
===4.1 Computation of the principal curvature axes for linear elements===
580
581
The principal curvature axes <math display="inline">\xi ,\eta </math> can be estimated as the eigenvectors of the curvature matrix
582
583
{| class="formulaSCP" style="width: 100%; text-align: left;" 
584
|-
585
| 
586
{| style="text-align: left; margin:auto;width: 100%;" 
587
|-
588
| style="text-align: center;" | <math>{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>
589
|}
590
| style="width: 5px;text-align: right;white-space: nowrap;" | (34)
591
|}
592
593
In general matrix '''C''' varies within each element.
594
595
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].
596
597
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>.
598
599
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.
600
601
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.
602
603
The dependence of the balancing diffusion matrix <math display="inline">\bar{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.
604
605
===4.2 General iterative scheme===
606
607
A stabilized numerical solution can be found by the following algorithm.
608
609
'''Step 0'''  (SUPG step). At each integration point choose <math display="inline">{}^0{\boldsymbol \xi } ={u}</math>, i.e. the gradient direction is taken coincident with the velocity direction. Compute <math display="inline">{}^0{\boldsymbol \eta }, {}^1\bar  {D}'</math>, <math display="inline">{}^0\bar  {D}</math> and <math display="inline">{}^0{D}_G</math> from Eqs.(23&#8211;29). ''The  expression of the balancing diffusion matrix coincides  now precisely with the standard (linear) SUPG form''.
610
611
Solve for <math display="inline">{}^0\bar{\boldsymbol \phi }</math>.
612
613
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.
614
615
For each iteration: '''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  {D}'</math>, <math display="inline">{}^1\bar  {D}</math> and <math display="inline">{}^1{D}_G</math>.
616
617
Solve for <math display="inline">{}^1\bar{\boldsymbol \phi }</math>.
618
619
'''Step 2'''  Estimate the convergence of the process. We have chosen the following convergence norm
620
621
{| class="formulaSCP" style="width: 100%; text-align: left;" 
622
|-
623
| 
624
{| style="text-align: left; margin:auto;width: 100%;" 
625
|-
626
| 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>
627
|}
628
| style="width: 5px;text-align: right;white-space: nowrap;" | (35)
629
|}
630
631
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.
632
633
In the examples shown in the next section <math display="inline">\varepsilon =10^{-3}</math> has been taken in Eq.(35).
634
635
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.
636
637
===Remark 4===
638
639
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
640
641
{| class="formulaSCP" style="width: 100%; text-align: left;" 
642
|-
643
| 
644
{| style="text-align: left; margin:auto;width: 100%;" 
645
|-
646
| style="text-align: center;" | <math>{D}_G = \beta ^i \bar{D}_G + (1-\beta ) {}^{i-1}\bar{D}_G  </math>
647
|}
648
| style="width: 5px;text-align: right;white-space: nowrap;" | (36)
649
|}
650
651
where <math display="inline">\beta </math> is a relaxation factor such that <math display="inline">0\le \beta \le 1</math>.
652
653
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.
654
655
===Remark 5===
656
657
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.
658
659
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-11|11]] for solving a similar class of convection-diffusion problems.
660
661
==5 EQUIVALENCE WITH SUPG AND SHOCK-CAPTURING TECHNIQUES==
662
663
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).
664
665
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.
666
667
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.
668
669
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-49|49]]. 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.
670
671
A similar shock capturing method of this kind was proposed by Oñate <span id='citeF-51'></span>[[#cite-51|51]] 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-51|51]]. The formulation we present here is more general as it encompasses the SUPG method and the shock capturing strategy in a unified approach.
672
673
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.
674
675
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
676
677
{| class="formulaSCP" style="width: 100%; text-align: left;" 
678
|-
679
| 
680
{| style="text-align: left; margin:auto;width: 100%;" 
681
|-
682
| style="text-align: center;" | <math>{h}= h_s {{u}\over \vert {u}\vert } +h_t {{\boldsymbol \nabla }\hat \phi \over \vert {\boldsymbol \nabla } \hat \phi \vert } </math>
683
|}
684
| style="width: 5px;text-align: right;white-space: nowrap;" | (37)
685
|}
686
687
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.
688
689
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
690
691
{| class="formulaSCP" style="width: 100%; text-align: left;" 
692
|-
693
| 
694
{| style="text-align: left; margin:auto;width: 100%;" 
695
|-
696
| 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 {u}\vert </math>
697
|}
698
| style="width: 5px;text-align: right;white-space: nowrap;" | (38.a)
699
|}
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>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>
707
|}
708
| style="width: 5px;text-align: right;white-space: nowrap;" | (38.b)
709
|}
710
711
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).
712
713
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.
714
715
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
716
717
{| class="formulaSCP" style="width: 100%; text-align: left;" 
718
|-
719
| 
720
{| style="text-align: left; margin:auto;width: 100%;" 
721
|-
722
| style="text-align: center;" | <math>c_\alpha = {u\over \vert {u}\vert }, \quad s_\alpha ={v\over \vert {v}\vert }, \quad h_x = {uh_\xi  \over \vert {u}\vert }, \quad h_y ={vh_\xi  \over \vert {u}\vert }</math>
723
|}
724
| style="width: 5px;text-align: right;white-space: nowrap;" |  (39a)
725
|}
726
727
Hence
728
729
{| class="formulaSCP" style="width: 100%; text-align: left;" 
730
|-
731
| 
732
{| style="text-align: left; margin:auto;width: 100%;" 
733
|-
734
| style="text-align: center;" | <math>h_s =h_\xi \quad \hbox{and } h_t=0</math>
735
|}
736
| style="width: 5px;text-align: right;white-space: nowrap;" |  (39b)
737
|}
738
739
and the method coincides in this case with the standard linear SUPG approach, as expected.
740
741
A case of practical interest is when the directions of <math display="inline">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
742
743
{| class="formulaSCP" style="width: 100%; text-align: left;" 
744
|-
745
| 
746
{| style="text-align: left; margin:auto;width: 100%;" 
747
|-
748
| 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 {u}\vert }\quad \hbox{and} \quad s_\alpha ={u\over \vert {u}\vert } </math>
749
|}
750
| style="width: 5px;text-align: right;white-space: nowrap;" | (40)
751
|}
752
753
Hence from Eq.(33)
754
755
{| class="formulaSCP" style="width: 100%; text-align: left;" 
756
|-
757
| 
758
{| style="text-align: left; margin:auto;width: 100%;" 
759
|-
760
| style="text-align: center;" | <math>h_x = - h_\eta   {u\over \vert {u}\vert } \quad ,\quad  h_y = - h_\eta  {v\over \vert {u}\vert } </math>
761
|}
762
| style="width: 5px;text-align: right;white-space: nowrap;" | (41.a)
763
|}
764
765
and from Eqs.(38)
766
767
{| class="formulaSCP" style="width: 100%; text-align: left;" 
768
|-
769
| 
770
{| style="text-align: left; margin:auto;width: 100%;" 
771
|-
772
| style="text-align: center;" | <math>h_s = h_\eta \quad \hbox{ and }h_t =0 </math>
773
|}
774
| style="width: 5px;text-align: right;white-space: nowrap;" | (41.b)
775
|}
776
777
Once again, the linear SUPG method is  recovered and the stabilized formulation does not introduce any additional transverse dissipation, as should be expected.
778
779
===Remark 6===
780
781
From above arguments we conclude that the simplified expression <math display="inline">{h}=h_s {{u} \over \vert {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]]. 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.
782
783
==6 EXAMPLES==
784
785
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.
786
787
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.
788
789
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.
790
791
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).
792
793
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-49|49]]. 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.
794
795
===6.1 Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source===
796
797
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>.
798
799
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.
800
801
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.
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
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.
806
807
===6.2 Square domain with non uniform Dirichlet conditions, downwards diagonal velocity and zero source===
808
809
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.
810
811
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.
812
813
The convergence of the process for both elements is shown in Figure 9.
814
815
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.
816
817
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.
818
819
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.
820
821
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-11|11]] 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-11|11]].
822
823
===6.3 Rectangular domain with Neumann and non uniform Dirichlet conditions, rotational  velocity field and zero source===
824
825
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.
826
827
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).
828
829
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.
830
831
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.
832
833
===6.4 Square domain with homogeneous Dirichlet condition and constant source===
834
835
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.
836
837
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.
838
839
This problem was also studied by Codina <span id='citeF-11'></span>[[#cite-11|11]] 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-11|11]].
840
841
==7 CONCLUDING REMARKS==
842
843
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.
844
845
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.
846
847
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.
848
849
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.
850
851
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.
852
853
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.
854
855
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.
856
857
==ACKNOWLEDGEMENTS==
858
859
The authors thank S. Badia, C. Felippa, R. Löhner, R.L. Taylor and O.C. Zienkiewicz for many useful discussions.
860
861
==APPENDIX==
862
863
===Computation of the balancing diffusion matrix ̄D in local and global axes===
864
865
The balancing diffusion matrix <math display="inline">\bar {D}</math> can be computed by transforming the local matrix <math display="inline">\bar{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
866
867
{| class="formulaSCP" style="width: 100%; text-align: left;" 
868
|-
869
| 
870
{| style="text-align: left; margin:auto;width: 100%;" 
871
|-
872
| style="text-align: center;" | <math>{\boldsymbol \nabla }^T ( {T}^T \bar{D}' {T}) {\boldsymbol \nabla }\phi = {\boldsymbol \nabla }^T \left({1\over 2} {h} {u}^T\right){\boldsymbol \nabla }\phi  </math>
873
|}
874
| style="width: 5px;text-align: right;white-space: nowrap;" | (42)
875
|}
876
877
where
878
879
{| class="formulaSCP" style="width: 100%; text-align: left;" 
880
|-
881
| 
882
{| style="text-align: left; margin:auto;width: 100%;" 
883
|-
884
| style="text-align: center;" | <math>\bar{D}' = {1\over 2} \left[\begin{array}{cc}u_\xi h_\xi & 0\\ 0 & u_\eta h_\eta \end{array}\right]\quad ,\quad {T} =\left[\begin{array}{cc}c_\alpha & s_\alpha \\ - s_\alpha & c_\alpha \end{array}\right] </math>
885
|}
886
| style="width: 5px;text-align: right;white-space: nowrap;" | (43)
887
|}
888
889
and
890
891
{| class="formulaSCP" style="width: 100%; text-align: left;" 
892
|-
893
| 
894
{| style="text-align: left; margin:auto;width: 100%;" 
895
|-
896
| style="text-align: center;" | <math>{h}= \left\{\begin{array}{c}h_x \\h_y\end{array} \right\}= {T}^T \left\{\begin{array}{c}h_\xi \\h_\eta \end{array} \right\}= {T}^T{h}'</math>
897
| style="width: 5px;text-align: right;white-space: nowrap;" | (46)
898
|-
899
| style="text-align: center;" | <math> {u}= \left\{\begin{array}{c}u\\ v \end{array} \right\}= {T}^T \left\{\begin{array}{c}u_\xi \\u_\eta \end{array} \right\}= {T}^T{u}' </math>
900
| style="width: 5px;text-align: right;white-space: nowrap;" | (49)
901
|}
902
|}
903
904
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).
905
906
In order to prove the identity in Eq.(A.1) we proceed as follows
907
908
{| class="formulaSCP" style="width: 100%; text-align: left;" 
909
|-
910
| 
911
{| style="text-align: left; margin:auto;width: 100%;" 
912
|-
913
| style="text-align: center;" | <math>\bar{D} = {T}^T \bar{D}'{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>
914
|}
915
| style="width: 5px;text-align: right;white-space: nowrap;" | (50)
916
|}
917
918
{| class="formulaSCP" style="width: 100%; text-align: left;" 
919
|-
920
| 
921
{| style="text-align: left; margin:auto;width: 100%;" 
922
|-
923
| style="text-align: center;" | <math>\begin{array}{ll}{\boldsymbol \nabla }^T ({T}^T \bar{D}'{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>
924
|}
925
| style="width: 5px;text-align: right;white-space: nowrap;" | (51)
926
|}
927
928
On the other hand
929
930
{| class="formulaSCP" style="width: 100%; text-align: left;" 
931
|-
932
| 
933
{| style="text-align: left; margin:auto;width: 100%;" 
934
|-
935
| style="text-align: center;" | <math>{1\over 2} {h }{u}^T = {1\over 2} {T}^T ({h}' {u}^{'T}) {T} </math>
936
|}
937
| style="width: 5px;text-align: right;white-space: nowrap;" | (52)
938
|}
939
940
Finally
941
942
{| class="formulaSCP" style="width: 100%; text-align: left;" 
943
|-
944
| 
945
{| style="text-align: left; margin:auto;width: 100%;" 
946
|-
947
| style="text-align: center;" | <math>\begin{array}{ll}{\boldsymbol \nabla }^T \left({1\over 2}{h }{u}^T\right){\boldsymbol \nabla } \phi = & {1\over 2} {\boldsymbol \nabla }^T [{T}^T ({h}' {u}^{'T}){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>
948
|}
949
| style="width: 5px;text-align: right;white-space: nowrap;" | (53)
950
|}
951
952
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">T</math> such that
953
954
{| class="formulaSCP" style="width: 100%; text-align: left;" 
955
|-
956
| 
957
{| style="text-align: left; margin:auto;width: 100%;" 
958
|-
959
| style="text-align: center;" | <math>{T}\left[\begin{array}{cc}\phi _x^{''} & \phi _{xy}^{''}\\ \phi _{xy}^{''}&  \phi _y^{''}  \end{array}\right]{T} ^T= \left[\begin{array}{cc}\phi _{\xi }^{''} &0\\ 0 & \phi _{\eta }^{''} \end{array}\right] </math>
960
|}
961
| style="width: 5px;text-align: right;white-space: nowrap;" | (54)
962
|}
963
964
with <math display="inline">{T}</math> defined as in Eq.(A.2).
965
966
The condition which ensures a diagonal matrix in the r.h.s. of Eq.(A.9) is
967
968
{| class="formulaSCP" style="width: 100%; text-align: left;" 
969
|-
970
| 
971
{| style="text-align: left; margin:auto;width: 100%;" 
972
|-
973
| style="text-align: center;" | <math>s_\alpha c_\alpha (\phi _y^{''}-\phi _x^{''}) +  ( c_\alpha ^2 - s_\alpha ^2 )\phi _{xy}^{''} =0 </math>
974
|}
975
| style="width: 5px;text-align: right;white-space: nowrap;" | (55)
976
|}
977
978
which is precisely the condition which cancels out the last term in Eq.(A.8).
979
980
Hence the identity of Eq.(A.1) is satisfied.
981
982
===BIBLIOGRAPHY===
983
984
<div id="cite-1"></div>
985
'''[[#citeF-1|[1]]]''' Zienkiewicz O.C. and Taylor R.L. ''The finite element method''. 5th Edition, 3 Volumes, Butterworth&#8211;Heinemann, 2000.
986
987
<div id="cite-2"></div>
988
'''[[#citeF-2|[2]]]'''  Hirsch C. ''Numerical computation of internal and external flow'', J. Wiley, Vol. 1 1988, Vol. 2, 1990.
989
990
<div id="cite-3"></div>
991
'''[[#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.
992
993
<div id="cite-4"></div>
994
'''[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.
995
996
<div id="cite-5"></div>
997
'''[[#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.
998
999
<div id="cite-6"></div>
1000
'''[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.
1001
1002
<div id="cite-7"></div>
1003
'''[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.
1004
1005
<div id="cite-8"></div>
1006
'''[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.
1007
1008
<div id="cite-9"></div>
1009
'''[9]'''  Codina R. ''A finite element formulation for the numerical solution of the convection-diffusion equations''. Monograph no. 14, CIMNE, Barcelona 1993.
1010
1011
<div id="cite-10"></div>
1012
'''[10]'''  Donea J. A Taylor-Galerkin method for convective transport  problems. ''Int. J. Num. Meth. Engng.'', '''20''', pp. 101&#8211;119,  1984.
1013
1014
<div id="cite-11"></div>
1015
'''[[#citeF-11|[11]]]'''   Donea J. and Huerta A. ''Finite element methods for flow problems''. J. Wiley, 2003.
1016
1017
<div id="cite-12"></div>
1018
'''[[#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.
1019
1020
<div id="cite-13"></div>
1021
'''[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.
1022
1023
<div id="cite-14"></div>
1024
'''[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.
1025
1026
<div id="cite-15"></div>
1027
'''[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.
1028
1029
<div id="cite-16"></div>
1030
'''[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.
1031
1032
<div id="cite-17"></div>
1033
'''[[#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.
1034
1035
<div id="cite-18"></div>
1036
'''[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.
1037
1038
<div id="cite-19"></div>
1039
'''[[#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.
1040
1041
<div id="cite-20"></div>
1042
'''[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.
1043
1044
<div id="cite-21"></div>
1045
'''[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.
1046
1047
<div id="cite-22"></div>
1048
'''[[#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.
1049
1050
<div id="cite-23"></div>
1051
'''[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.
1052
1053
<div id="cite-24"></div>
1054
'''[[#citeF-24|[24]]]'''   Brezzi, F. and Russo A. Choosing bubbles for advection-diffusion problems. ''Math Models Methods Appl. Sci.'', '''4''', 571&#8211;587, 1994.
1055
1056
<div id="cite-25"></div>
1057
'''[[#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.
1058
1059
<div id="cite-26"></div>
1060
'''[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.
1061
1062
<div id="cite-27"></div>
1063
'''[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.
1064
1065
<div id="cite-28"></div>
1066
'''[[#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.
1067
1068
<div id="cite-29"></div>
1069
'''[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.
1070
1071
<div id="cite-30"></div>
1072
'''[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.
1073
1074
<div id="cite-31"></div>
1075
'''[31]'''  Tezduyar T.E. Computation of moving boundaries and stabilization parameters. ''Int. J. Num. Meth. Fluids'', '''43''', 555&#8211;575, 2003.
1076
1077
<div id="cite-32"></div>
1078
'''[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.
1079
1080
<div id="cite-33"></div>
1081
'''[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.
1082
1083
<div id="cite-34"></div>
1084
'''[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.
1085
1086
<div id="cite-35"></div>
1087
'''[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.
1088
1089
<div id="cite-36"></div>
1090
'''[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
1091
1092
<div id="cite-37"></div>
1093
'''[[#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.
1094
1095
<div id="cite-38"></div>
1096
'''[38]'''  Oñate E. Possibilities of finite calculus in computational mechanics.  ''Int. J. Num. Meth. Engng.'' 2004; '''60''':255&#8211;281.
1097
1098
<div id="cite-39"></div>
1099
'''[[#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.
1100
1101
<div id="cite-40"></div>
1102
'''[[#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.
1103
1104
<div id="cite-41"></div>
1105
'''[[#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.
1106
1107
<div id="cite-42"></div>
1108
'''[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''.
1109
1110
<div id="cite-43"></div>
1111
'''[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.
1112
1113
<div id="cite-44"></div>
1114
'''[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.
1115
1116
<div id="cite-45"></div>
1117
'''[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.
1118
1119
<div id="cite-46"></div>
1120
'''[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.
1121
1122
<div id="cite-47"></div>
1123
'''[[#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.
1124
1125
<div id="cite-48"></div>
1126
'''[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.
1127
1128
<div id="cite-49"></div>
1129
'''[[#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.
1130
1131
<div id="cite-50"></div>
1132
'''[[#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.
1133
1134
<div id="cite-51"></div>
1135
'''[[#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.
1136
1137
<div id='img-1'></div>
1138
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1139
|-
1140
|[[Image:Draft_Samper_426828278-Figure1.png|351px|Global axes (x,y) and principal curvature axes (ξ,η)]]
1141
|- style="text-align: center; font-size: 75%;"
1142
| colspan="1" | '''Figure 1:''' Global axes (<math>x,y</math>) and principal curvature axes (<math>\xi ,\eta </math>)
1143
|}
1144
1145
<div id='img-2'></div>
1146
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1147
|-
1148
|[[Image:Draft_Samper_426828278-Figure2.png|351px|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]]
1149
|- style="text-align: center; font-size: 75%;"
1150
| 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
1151
|}
1152
1153
<div id='img-3'></div>
1154
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1155
|-
1156
|[[Image:Draft_Samper_426828278-Figure3.png|351px|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]]
1157
|- style="text-align: center; font-size: 75%;"
1158
| 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
1159
|}
1160
1161
<div id='img-4'></div>
1162
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1163
|-
1164
|[[Image:Draft_Samper_426828278-Figure4.png|351px|Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. Convergence of the FIC solution for square and triangular elements]]
1165
|- style="text-align: center; font-size: 75%;"
1166
| 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
1167
|}
1168
1169
<div id='img-5'></div>
1170
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1171
|-
1172
|[[Image:Draft_Samper_426828278-Figure5.png|351px|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]]
1173
|- style="text-align: center; font-size: 75%;"
1174
| 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
1175
|}
1176
1177
<div id='img-6'></div>
1178
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1179
|-
1180
|[[Image:Draft_Samper_426828278-Figure6.png|351px|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]]
1181
|- style="text-align: center; font-size: 75%;"
1182
| 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
1183
|}
1184
1185
<div id='img-7'></div>
1186
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1187
|-
1188
|[[Image:Draft_Samper_426828278-Figure7.png|351px|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]]
1189
|- style="text-align: center; font-size: 75%;"
1190
| 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
1191
|}
1192
1193
<div id='img-8'></div>
1194
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1195
|-
1196
|[[Image:Draft_Samper_426828278-Figure8.png|351px|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]]
1197
|- style="text-align: center; font-size: 75%;"
1198
| 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
1199
|}
1200
1201
<div id='img-9'></div>
1202
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1203
|-
1204
|[[Image:Draft_Samper_426828278-Figure9.png|351px|Square domain with uniform Dirichlet conditions, upward diagonal velocity and zero source. Convergence of the FIC solution for square and triangular elements]]
1205
|- style="text-align: center; font-size: 75%;"
1206
| 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
1207
|}
1208
1209
<div id='img-10'></div>
1210
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1211
|-
1212
|[[Image:Draft_Samper_426828278-Figure10.png|351px|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]]
1213
|- style="text-align: center; font-size: 75%;"
1214
| 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
1215
|}
1216
1217
<div id='img-11'></div>
1218
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1219
|-
1220
|[[Image:Draft_Samper_426828278-Figure11.png|351px|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]]
1221
|- style="text-align: center; font-size: 75%;"
1222
| 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
1223
|}
1224
1225
<div id='img-12'></div>
1226
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1227
|-
1228
|[[Image:Draft_Samper_426828278-Figure12.png|351px|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]]
1229
|- style="text-align: center; font-size: 75%;"
1230
| 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
1231
|}
1232
1233
<div id='img-13'></div>
1234
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1235
|-
1236
|[[Image:Draft_Samper_426828278-Figure13.png|351px|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]]
1237
|- style="text-align: center; font-size: 75%;"
1238
| 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
1239
|}
1240
1241
<div id='img-14'></div>
1242
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1243
|-
1244
|[[Image:Draft_Samper_426828278-Figure14.png|351px|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]]
1245
|- style="text-align: center; font-size: 75%;"
1246
| 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
1247
|}
1248
1249
<div id='img-15'></div>
1250
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1251
|-
1252
|[[Image:Draft_Samper_426828278-Figure15.png|351px|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]]
1253
|- style="text-align: center; font-size: 75%;"
1254
| 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
1255
|}
1256
1257
<div id='img-16'></div>
1258
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1259
|-
1260
|[[Image:Draft_Samper_426828278-Figure16.png|351px|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]]
1261
|- style="text-align: center; font-size: 75%;"
1262
| 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
1263
|}
1264
1265
<div id='img-17'></div>
1266
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1267
|-
1268
|[[Image:Draft_Samper_426828278-Figure17.png|351px|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]]
1269
|- style="text-align: center; font-size: 75%;"
1270
| 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
1271
|}
1272
1273
<div id='img-18'></div>
1274
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1275
|-
1276
|[[Image:Draft_Samper_426828278-Figure18.png|351px|]]
1277
|[[Image:Draft_Samper_426828278-Figure18b.png|351px|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]]
1278
|- style="text-align: center; font-size: 75%;"
1279
| 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
1280
|}
1281
1282
<div id='img-19'></div>
1283
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1284
|-
1285
|[[Image:Draft_Samper_426828278-Figure19.png|351px|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]]
1286
|- style="text-align: center; font-size: 75%;"
1287
| 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
1288
|}
1289
1290
<div id='img-20'></div>
1291
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1292
|-
1293
|[[Image:Draft_Samper_426828278-Figura20.png|351px|Square domain with homogeneous Dirichlet conditions and constant source. Solution for a structural mesh of 20×20 four node quadrilaterals]]
1294
|- style="text-align: center; font-size: 75%;"
1295
| 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
1296
|}
1297
1298
<div id='img-21'></div>
1299
{| class="floating_imageSCP" style="text-align: center; border: 1px solid #BBB; margin: 1em auto; width: 100%;max-width: 100%;"
1300
|-
1301
|[[Image:Draft_Samper_426828278-Figura21.png|351px|Square domain with homogeneous Dirichlet conditions and constant source. Solution for an unstructured mesh of 2 ×20×20 three node triangles]]
1302
|- style="text-align: center; font-size: 75%;"
1303
| 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
1304
|}
1305

Return to Onate Zarate et al 2006a.

Back to Top