version 3.11-dev
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages Concepts
forchheimerslaw.hh File Reference

Advective fluxes according to Forchheims's law (extends Darcy's law by an nonlinear drag) More...

Go to the source code of this file.

Description

Darcy’s law is linear in the seepage velocity v. As described in "darcyslaw.hh", this is valid for creeping flow (Re<<1). As v increases further, a nonlinear drag arises. The nonlinear drag arises, because the friction becomes comparable to surface drag due to friction. This additional friction is added as the forchheimer term to the Darcy's law. Resulting in the Forchheimer's law. see e.g. Nield & Bejan: Convection in Porous Media [59]

For multiphase flow, the relative passability ηr is the "Forchheimer-equivalent" to the relative permeability kr. We use the same function for ηr as for kr (Van-Genuchten, Brooks-Corey, linear), other authors use a simple power law e.g.: ηrw=Sw3

This leads to the equation in the form:

vα+cFKραμα|vα|vα+krαμαK(pα+ραgz)=0

This already includes the assumption kr(Sw)=ηr(Sw):

  • ηrw=Swx looks very similar to e.g. Van Genuchten relative permeabilities
  • Fichot et al. (2006) [30] state that several authors claim that kr(Sw),ηr(Sw) can be chosen equal
  • It leads to the equation not degenerating for the case of Sw=1, because I do not need to multiply with two different functions, and therefore there are terms not being zero.
  • If this assumption is not to be made: Some regularization needs to be introduced ensuring that not all terms become zero for Sw=1.

This non-linear equations is solved for vα using Newton's method and an analytical derivative w.r.t. vα.

The gradient of the Forchheimer relations looks as follows (mind that K is a tensor):

f(vα)=(100010001)+cFραμα|vα|K+cFραμα1|vα|K(vx2vxvyvxvzvyvxvy2vyvzvzvxvzvyvz2)

Note
We restrict the use of Forchheimer's law to diagonal permeability tensors so far. This might be changed to general tensors using eigenvalue decomposition to get K
Forchheimer's law specialized for different discretization schemes (e.g. Box, CCTpfa).
Forchheimer's law works with every model that contains Darcy's law.
Include dependency graph for forchheimerslaw.hh: