|
opm-simulators
|
A compositional multi-phase model based on non-linear complementarity functions.
More...
#include <dune/common/fvector.hh>#include <opm/common/Exceptions.hpp>#include <opm/material/common/Valgrind.hpp>#include <opm/material/densead/Math.hpp>#include <opm/models/ncp/ncpproperties.hh>#include <opm/models/ncp/ncplocalresidual.hh>#include <opm/models/ncp/ncpextensivequantities.hh>#include <opm/models/ncp/ncpprimaryvariables.hh>#include <opm/models/ncp/ncpboundaryratevector.hh>#include <opm/models/ncp/ncpratevector.hh>#include <opm/models/ncp/ncpintensivequantities.hh>#include <opm/models/ncp/ncpnewtonmethod.hh>#include <opm/models/ncp/ncpindices.hh>#include <opm/models/common/diffusionmodule.hh>#include <opm/models/common/energymodule.hh>#include <opm/models/common/multiphasebasemodel.hh>#include <opm/models/io/vtkcompositionmodule.hpp>#include <opm/models/io/vtkdiffusionmodule.hpp>#include <opm/models/io/vtkenergymodule.hpp>#include <algorithm>#include <cassert>#include <cmath>#include <memory>#include <sstream>#include <string>#include <tuple>#include <vector>Go to the source code of this file.
Namespaces | |
| Opm | |
| This file contains a set of helper functions used by VFPProd / VFPInj. | |
| Opm::Properties::TTag | |
| The generic type tag for problems using the immiscible multi-phase model. | |
A compositional multi-phase model based on non-linear complementarity functions.
This model implements a
-phase flow of a fluid mixture composed of
chemical species. The phases are denoted by lower index
. All fluid phases are mixtures of
chemical species which are denoted by the upper index
.
By default, the standard multi-phase Darcy approach is used to determine the velocity, i.e.
although the actual approach which is used can be specified via the FluxModule property. For example, the velocity model can by changed to the Forchheimer approach by
The core of the model is the conservation mass of each component by means of the equation
For the missing
model assumptions, the model uses non-linear complementarity functions. These are based on the observation that if a fluid phase is not present, the sum of the mole fractions of this fluid phase is smaller than
, i.e.
Also, if a fluid phase may be present at a given spatial location its saturation must be non-negative:
Since at any given spatial location, a phase is always either present or not present, one of the strict equalities on the right hand side is always true, i.e.
always holds.
These three equations constitute a non-linear complementarity problem, which can be solved using so-called non-linear complementarity functions
. Such functions have the property
Several non-linear complementarity functions have been suggested, e.g. the Fischer-Burmeister function
This model uses
because of its piecewise linearity.
The model assumes local thermodynamic equilibrium and uses the following primary variables:


phases 
if the energy equation is enabled