Fluid flow is one of the most common physical phenomena in nature and technological devices. Examples include atmospheric flows (“weather”), global ocean currents, air flow around a car, breathing, and circulation of blood, to mention a few. The focus in the forthcoming text is on a subset of flows without turbulence, where the flow can be considered as incompressible, and where the fluid’s viscosity is constant. (Actually, the model to be discussed can be used for turbulence, in principle, but the computations are very heavy.)
The derivation of the Navier-Stokes equations contains some equations that are useful for alternative formulations of numerical methods, so we shall briefly recover the steps to arrive at (1) and (2). We start with the general momentum balance equation for a continuum (arising from Newton’s second law of motion),
where \(\pmb{\sigma}\) is the stress tensor and the operator \(D/dt\) is the material derivative,
here denoting acceleration. Therefore, \(\varrho D\pmb{u}/dt\) is density (“mass”) times acceleration, while the terms on the right-hand side are the forces that induce the motion \(\pmb{u}\): the internal stresses \(\pmb{\sigma}\) and the external body forces \(\pmb{f}\).
The other fundamental equation for a fluid is that of mass conservation, called the continuity equation. It has the general form
which can be rewritten as
An incompressible flow is defined as a flow where each fluid particle maintains its density. Since \(\frac{D \varrho}{dt}\) is the rate of change of \(\varrho\) of a fluid particle, incompressible flow means \(\frac{D \varrho}{dt}=0\) and hence \(\nabla\cdot\pmb{u} = 0\). The latter is the most useful equation in a PDE system for incompressible flow since it involves the unknown velocity \(\pmb{u}\).
Different types of fluids will have different relations between the motion \(\pmb{u}\) and the internal stresses \(\pmb{\sigma}\). A Newtonian fluid has an isotropic, linear relation between \(\pmb{u}\) and \(\pmb{\sigma}\):
where \(\pmb{I}\) is the identity tensor, and \(\mu\) is the dynamic viscosity (\(\mu = \varrho\nu\)). The relation (4) assumes incompressible flow. Inserting (4) in (3) gives (1) after dividing by \(\varrho\), using \(\nabla\cdot (p\pmb{I}) = \nabla p\), and calculating \(\nabla\cdot (\nabla\pmb{u} + (\nabla\pmb{u})^T)\) as \(\nabla^2\pmb{u} + \nabla (\nabla\cdot\pmb{u}) = \nabla^2\pmb{u}\). The vector operations involving the nabla operator are easiest performed by using index or dyadic notation, but the derivation of the particular terms is not important for the forthcoming text.
Some numerical methods apply the \(\nabla\cdot\pmb{\sigma} = -\nabla p + \nabla\cdot (\nabla\pmb{u} + (\nabla\pmb{u})^T)\) form in (1):
or
Other formulations add a \(\varrho_t\) term to the continuity equation, usually by assuming slight compressibility. Then \(\varrho = \varrho (p)\) and we have
It is common to evaluate \(\partial\varrho/\partial p\) for some fixed reference value \(\varrho_0\) so that \(1/c^2 = \partial\varrho/\partial p\) can be treated as a constant. The parameter \(c\) is the speed of sound in the fluid. The equation of continuity is in such cases often written as
where we have used the simplification \(\nabla(\varrho\pmb{u}) = \varrho_0\nabla\pmb{u}\) for a slightly incompressible fluid and divided the original equation by \(\varrho_0\).
The incompressible Navier-Stokes equations need three scalar conditions on the velocity components or the stress vector at each point on the boundary. The boundary conditions can be classified as follows.
Dirichlet conditions: components of \(\pmb{u}\) are known.
Neumann conditions:
- Stress condition: components of \(\pmb{\sigma}\cdot\pmb{n}\) are prescribed.
- Outflow or symmetry condition: \(\partial\pmb{u}/\partial n=0\) (or components of this vector are zero).
We have here introduce the notion of Dirichlet and Neumann conditions using similarities with Laplace and Poisson problems (i.e., whether the condition regards the unknown itself or its derivative).
A combination of velocity and stress boundary conditions at a point is possible. For example, at a symmetry boundary we set the normal velocity to be zero.
The earliest and still the most widely applied numerical method for the incompressible Navier-Stokes equations is based on splitting the PDE system into simpler components for which we can apply standard discretization methods. Such a strategy is known as operator splitting.
The equation (1) looks similar to a convection-diffusion equation. The simplest possible numerical method for such equations applies an explicit Forward Euler scheme in time. It is therefore tempting to advance (1) in time using a standard Forward Euler discretization:
which yields an explicit formula for \(\pmb{u}^{n+1}\):
There are two fundamental problems with this method:
- the new \(\pmb{u}^{n+1}\) will in general not satisfy (2), i.e., \(\nabla\cdot\pmb{u}^{n+1}\neq 0\),
- there is no strategy for computing \(p^{n+1}\).
We may say that the incompressible Navier-Stokes equations are difficult to solve numerically because of the incompressibility constraint \(\nabla\cdot\pmb{u} = 0\) and the pressure term \(\nabla p\).
Intuitively speaking, the fulfillment \(\nabla\cdot\pmb{u}^{n+1}\) requires us to have “more unknowns to play with” when advancing (1). The idea is to basically use the Forward Euler scheme, but evaluate the pressure term at the new time level \(n+1\):
We must also require
The equations (9)-(10) constitute 3+1 coupled PDEs for the 3+1 unknowns \(\pmb{u}^{n+1}\) and \(p^{n+1}\).
The method for solving (9)-(10) is based on a splitting idea where we first propagate the velocity from old values to some intermediate velocity \(\pmb{u}^*\), using (9). Then we enforce the incompressibility constraint (10) to compute a correction to \(\pmb{u}^*\) and also the new pressure \(p^{n+1}\).
A plain Forward Euler discretization of (1), but with a weight \(\beta\) on the \(\nabla p^n\) term, reads
The intermediate velocity \(\pmb{u}^*\) does not fulfill the incompressibility constraint (10), but we seek a correction \(\delta\pmb{u}\),
such that \(\nabla\cdot \pmb{u}^{n+1} = 0\). Since \(\delta\pmb{u} = \pmb{u}^{n+1} - \pmb{u}^*\), we can subtract (11) from (9) to find \(\delta\pmb{u}\).
The quantity \(\Phi\) is introduced as a kind of pressure change:
Inserting \(\delta\pmb{u}\) in the incompressibility constraint,
or equivalently,
results in
since \(\nabla\cdot\nabla\Phi = \nabla^2\Phi\).
As soon as \(\Phi\) is computed from the Poisson equation (15), we can calculate
and
The solution algorithm at a time level then consists of the following steps:
Remarks. The literature is full of papers and books with methods equivalent or almost equivalent to the scheme above. Many schemes apply \(\beta =0\) and replace \(\Phi\) by \(p^{n+1}\).
What boundary conditions should we assign to \(\pmb{u}^*\) when solving (11)? A standard choice is to apply the same boundary conditions as those specified for \(\pmb{u}\). It follows that \(\delta\pmb{u} =0\) on the boundary where \(\pmb{u}\) is subject to Dirichlet conditions. We let \(\partial\Omega_{D,u}\) denote the part of the boundary \(\partial\Omega\) with Dirichlet conditions, while \(\partial\Omega_{N,u}\) denotes the boundary where Neumann conditions involving \(\partial\pmb{u}/\partial n\) apply.
The boundary condition on the pressure in the original incompressible Navier-Stokes equations is simply to prescribe \(p\) at a single point, potentially as a function of time. However, when solving the Poisson equation (15) we need Dirichlet or Neumann boundary conditions for \(\Phi\) (the pressure change) on the whole boundary. Sometimes the pressure is prescribed at an inlet or outlet boundary, which then yields a Dirichlet condition for \(\Phi = p^{n+1}-\beta p^n\). At the boundaries where \(\pmb{u}\) is subject to Dirichlet conditions, \(\pmb{u}^*\) has the same conditions, and \(\delta\pmb{u} = 0\), which implies \(\nabla\Phi =0\). In particular, \(\partial\Phi/\partial n=0\), and homogeneous Neumann conditions are therefore used on such boundaries when solving the Poisson equation for \(\Phi\). Also, at symmetry boundaries, \(\partial\Phi/\partial n=0\). At an inlet boundary, a pressure gradient in the flow direction is often known, say as \(f(t)\), implying that we can compute \(\partial\Phi/\partial n= -(f(t^{n+1}) - \beta f(t^n))\).
We let \(\partial\Omega_{D,\Phi}\) be the part of the boundary where \(\Phi\) is subject to Dirichlet conditions, while \(\partial\Omega_{N,p}\) is the remaining part where Neumann conditions involving \(\partial\Phi/\partial n\) are assigned.
The equations to be solved, (11), (15), (16), and (17), are of two types: explicit updates (approximations a la \(u=f\)) and the Poisson equation. We introduce a vector test function \(\pmb{v}^{(u)}\in V^{(u)}\) for the vector equations (11) and (16), and a scalar test function \(v^{(\Phi)}\in V^{(\Phi)}\) for the Poisson equation and the update (17). Modulo nonzero Dirichlet conditions, we seek \(\pmb{u}^*,\pmb{u}^{n+1}\in V^{(u)}\) and \(p^{n+1}\in V^{(\Phi)}\).
The variational form of a vector equation like (11) is derived by taking the inner product of the equation and \(\pmb{v}^{(u)}\). The Laplace term is integrated by parts, as usual, but this time vectors are involved. The relevant rule takes the form
where \(\nabla\pmb{u} :\nabla\pmb{v}\) means the inner tensor product: \(\pmb{A}:\pmb{B} = \sum_j\sum_j A_{ij}B_{ij}\) (when \(\pmb{A}\) has elements \(A_{i,j}\) and \(\pmb{B}\) has elements \(B_{i,j}\). Alternatively, we may say that \(\pmb{A}:\pmb{B}\) is simply the scalar product of the tensors \(\pmb{A}\) and \(\pmb{B}\) when these are viewed as vectors (of length 9 instead of tensors of dimension \(3\times 3\) in 3D problems). The normal derivative has the usual definition: \(\partial\pmb{u}/\partial n = \pmb{n}\cdot \nabla\pmb{u}\).
The \(\int_\Omega \nabla p^n\cdot\pmb{v}^{(u)}{\, \mathrm{d}x}\) integral can also be a candidate for integrated by parts, if desired. The relevant rule reads
We use such an integration by parts below. The advantage is that we get a boundary integral involving \(p\pmb{n}\), which is advantageous if we want to set a condition on \(p\), especially at an outflow boundary, but also on an inflow boundary.
For notational simplicity and close correspondence to computer code, we introduce the subscript 1 on quantities from the previous time level \(n\) and drop any superscript \(n+1\) for quantities to be computed at the new time level. The resulting variational form can be written as
\(\forall\pmb{v}^{(u)}\in V^{(u)}\). The variational form corresponding to the Poisson equation becomes
The variational form for the velocity update (16) is based on taking the inner product of \(\pmb{v}^{(u)}\) and (16):
Note that this is the same form as in a vector approximation problem: approximate a given vector field \(\pmb{f}\) by a \(\pmb{u}\), where the components of \(\pmb{u}\) are scalar finite element functions. Also note that \(\pmb{u}\) in (20) is actually \(\pmb{u}^{n+1}\), but that the superscript is dropped since we do not use that in an implementation.
The pressure update has the variational form
(Also here, \(p\) denotes \(p^{n+1}\) and \(p_1\) is \(p^n\).)
The splitting method presented above allows flexible choices of elements for \(\pmb{u}\) and \(p\). In the early days of the finite element method for incompressible flow, fully implicit formulations were used and these require the \(\pmb{u}\) element to be of one polynomial degree higher than the \(p\) element. This restriction does not apply to the splitting scheme, so one may, e.g., choose P1 elements for the velocity components and the pressure.
The boundary integral in (18) comes into play at element faces on the boundary if the nodes on a face are not subject to Dirichlet conditions. As for scalar PDEs, Dirichlet conditions either mean that \(\pmb{v}=0\) on that part of the boundary, or the element matrix and vector (or the global coefficient matrix and right-hand side) are manipulated to enforce known values of the unknown such that any boundary integral is erased and replaced by the boundary value.
The boundary integral most often applies to inflow and outflow boundaries \(x=\hbox{const}\) where we assume unidirectional flow, \(\pmb{u} = u\pmb{i}\). Because of \(\nabla\cdot\pmb{u} = 0\) we have \(\partial\pmb{u}/\partial x = \partial\pmb{u}/\partial n=0\) and \(p=\hbox{const}\). Very often, the boundary integral in (18) is zero, because we apply it to an outflow boundary where we have \(\partial\pmb{u}/\partial n=0\) and then we fix the pressure at \(p=0\). Note that in the original Navier-Stokes equations, \(p\) enters just through \(\nabla p\) so a boundary condition at one point is necessary to uniquely determine \(p\) (otherwise \(p\) is known up to a free additive constant). At inflow boundaries, \(\pmb{u}\) is either known, which implies that the boundary integral does not apply, or we have \(\partial\pmb{u}/\partial n=0\) and \(p=p_0\). In this latter case, the boundary integral involves an integration of \(p\pmb{n}\cdot\pmb{v}\).
The boundary integral involving \(\partial\Phi/\partial n\) is usually omitted since we apply the condition \(\partial\Phi/\partial n =0\), see the section Boundary conditions (2).
As mentioned in the section Derivation, we may exchange the \(\nu\nabla^2\pmb{u}\) term in (1) with a stress term \(\varrho^{-1}\nabla\cdot\pmb{\sigma}\), where \(\pmb{\sigma}\) is given by (4). Occasionally, the \(\nabla\cdot\pmb{\sigma}\) term is advantageous, because integration by parts of \(\int_\Omega\nabla\cdot\pmb{\sigma}\cdot\pmb{v}^{(u)}{\, \mathrm{d}x}\) gives a boundary integral with the stress vector \(\pmb{\sigma}\cdot\pmb{n}\). This is convenient when boundary conditions are formulated in terms of stresses.
The explicit scheme (11) resembles the same stability problems as when a Forward Euler scheme is applied to the diffusion equation. However, there is also a convection term \(\pmb{u}\cdot\nabla\pmb{u}\) that reduces the time step restrictions. The stability criterion reads
where \(h\) is the minimum element size and \(U\) is a characteristic size of the velocity. The term \(2\nu\) stems from the viscous (Laplace) term while \(Uh\) arises from the convection term in the Navier-Stokes equations. Which of the term that dominates in the denominator therefore depends on whether viscous forces or convection is important in the equation.
Treating the viscosity term \(\nu\nabla^2\pmb{u}\) implicitly helps greatly on the stability properties of the scheme for \(\pmb{u}^*\). We may, for example, apply a Backward Euler scheme. Instead of (9) we then have
An intermediate velocity can be computed from the first equation if we replace \(p^{n+1}\) by \(\beta p^n\) as done earlier:
To simplify the nonlinearity in \((\pmb{u}^{*}\cdot\nabla)\pmb{u}^{*}\) we may use an old value in the convective velocity:
This approximation is essentially one Picard iteration using \(u^n\) as initial guess.
The intermediate velocity \(\pmb{u}^*\) is now governed by a linear problem
The correction \(\delta\pmb{u} = \pmb{u}^{n+1} - \pmb{u}^*\) becomes
Under the assumption that \(\pmb{u}^*\) is close to \(\pmb{u}^{n+1}\), we may drop the terms involving \(\pmb{u}^{n+1}-\pmb{u}^*\) and just keep the \(\nabla\Phi\) term. Then
as before, and the incompressibility constraint \(\nabla\cdot\delta\pmb{u} = - \nabla\cdot\pmb{u}^*\) gives \(\nabla^2 \Phi = \frac{\varrho}{\Delta t}\nabla\cdot\pmb{u}^*\).
The algorithm becomes the same as for a Forward Euler discretization, except that (11) is replaced by (24).
By allowing a slight compressibility we can replace the problematic constraint \(\nabla\cdot\pmb{u}\) by an evolution equation (7) for \(p\). Essentially, we then have two evolution equations for \(\pmb{u}\) and \(p\):
The simplest method is a Forward Euler scheme:
The major problem with this scheme is the stability constraint, which is dictated by the \(c\) parameter (velocity of sound): \(\Delta t \sim 1/c\). Usually, \(c\) is taken as a tuning parameter and values much less than the speed of sound may give solutions with acceptable compressibility.
Any other explicit scheme, say a 2nd- or 4th-order Runge-Kutta method, is easily applied. Implicit schemes are of course also possible, but then one has to solve linear systems, and the original formulation with a true incompressibility constraint \(\nabla\cdot\pmb{u} = 0\) is not more complicated and usually preferred. In general, the method based on slight compressibility and explicit time integration becomes computationally very heavy and is not competitive unless one can use a \(c\) value much lower than the speed of sound.
Early attempts to use the finite element method to solve the Navier-Stokes equations were based on fully implicit formulations. This is easily derived by applying a Backward Euler scheme to the system (1)-(2):
We introduce the test functions \(\pmb{v}^{(u)}\in V^{(u)}\) for the momentum balance equation and seek \(\pmb{u}^{n+1}\in V^{(u)}\) (or more precisely, the part of \(\pmb{u}^{n+1}\) without nonzero Dirichlet conditions). We seek \(p\in V^{(p)}\) and use \(v^{(p}\in V^{(p}\) as test function for the continuity equation. We may write the system of PDEs as
A variational formulation can be based on treating the two equations separately,
or we may use an inner product of the two equations \(({\cal L}_u, \nabla\cdot\pmb{u})\) and the test vector \((\pmb{v}^{(u)}, v^{(p)})\):
To minimize the distance between code and mathematics, we introduce new symbols: \(\pmb{u}\) for \(\pmb{u}^n\), \(\pmb{u}_1\) for \(\pmb{u}^{n-1}\), and \(p\) for \(p^n\). Integrating the pressure and viscous terms by parts yields
This is nothing but a coupled, nonlinear equation system for \(\pmb{u}\) and \(p\). Inserting finite element expansions for \(\pmb{u}\) and \(p\) yields discrete equations that can be written in matrix form as
where \(M\) is the usual mass matrix, but here for a vector function, \(u\) collects all coefficients for the \(\pmb{u}\) field, \(C(u)\) is a matrix arising from the convection term \((\pmb{u}\cdot\nabla)\pmb{u}\), \(L\) is a matrix arising from the \(p\nabla\cdot\pmb{v}^{(u)}\) term, \(K\) is the matrix corresponding to the Laplace operator (acting on a vector), and \(f\) is a vector of the source terms arising from \(\pmb{f}\). The nonlinearity is typically handled by a Newton method.
The simplified system arising from dropping the time derivative and the convection term \((\pmb{u}\cdot\nabla)\pmb{u}\) can be analyzed. It turns out that only certain combinations of \(V^{(u)}\) and \(V^{(p)}\) can guarantee a stable solution. The polynomials in \(V^{(u)}\) must be (at least) one degree higher than those in \(V^{(p)}\). For example, one may use P2 elements for \(\pmb{u}\) and P1 elements for \(p\). This combination is known as the famous Taylor-Hood element. Numerical experimentation indicates that the same stability restriction on the combination of spaces is also important for the fully nonlinear Navier-Stokes equations when solved by a fully implicit method. The splitting into simpler systems, as shown in the section A working scheme, introduces further approximations that stabilize the problem such that the same type of element can be used for velocity components and pressure.
The splitting method is much more widely used than the fully implicit formulation. Although the latter is more robust and much better suited for stationary flow, it is also involves much heavier computations. In each Newton iteration, a linear system involving all the coefficients in \(\pmb{u}\) and \(p\) must be solved, and it is non-trivial to construct efficient iterative solution methods (especially preconditioners).
Figure Flow in a channel exemplifies the boundary conditions for flow in a channel between two infinite plates. This flow configuration is assumed to be stationary, \(\pmb{u}_t=0\), and a simple analytical solution can be found in this particular case.
Note that the numerical solution method described above requires a time-dependent problem. Stationary problems must be simulated by starting with some initial condition and letting the flow develop toward the stationary solution as \(t\rightarrow\infty\).
The velocity field in channel flow is symmetric with respect to the center line. It is therefore sufficient to calculate the flow in half the channel. Figure Flow in a half a channel with a symmetry line displays the computational domain and the relevant boundary conditions.
Figure Flow over a backward facing step depicts a more complex flow geometry, leading to a more complex velocity field. The boundary conditions are, however, similar to those for channel flow.
The boundary conditions in Figure Flow around a cylinder are not listed in the figure because there are multiple options. The inflow boundary must have a prescribed velocity \(\pmb{u}\), and on the cylinder we must have \(\pmb{u} = 0\). On the remaining three boundaries we have some freedom in what to assign. At the outflow one typically sets \(\partial\pmb{u}/\partial n=0\) and fix the pressure at one value. Alternatively, one may apply a stress-free condition \(\pmb{\sigma}\cdot\pmb{n} = 0\), which implicitly also sets the pressure. On the boundaries AB and DC there is more freedom. The weakest condition is \(\partial\pmb{u}/\partial n=0\), assuming that the boundary is far enough away from the cylinder such that the flow field changes very little. Some prefer to set \(\pmb{\sigma}\cdot\pmb{n} = 0\) here instead. A stronger condition is to require \(u_y=0\) and \(\partial u_x/\partial n=0\). However, \(u_y=0\) requires the boundary to be far away from the cylinder.