pvsmodel.hh File Reference

A generic compositional multi-phase model using primary-variable switching. More...

#include <opm/material/localad/Math.hpp>
#include "pvsproperties.hh"
#include "pvslocalresidual.hh"
#include "pvsnewtonmethod.hh"
#include "pvsprimaryvariables.hh"
#include "pvsratevector.hh"
#include "pvsboundaryratevector.hh"
#include "pvsintensivequantities.hh"
#include "pvsextensivequantities.hh"
#include "pvsindices.hh"
#include <ewoms/models/common/multiphasebasemodel.hh>
#include <ewoms/models/common/diffusionmodule.hh>
#include <ewoms/models/common/energymodule.hh>
#include <ewoms/io/vtkcompositionmodule.hh>
#include <ewoms/io/vtkenergymodule.hh>
#include <ewoms/io/vtkdiffusionmodule.hh>
#include <opm/material/fluidmatrixinteractions/NullMaterial.hpp>
#include <opm/material/fluidmatrixinteractions/MaterialTraits.hpp>
#include <iostream>
#include <sstream>
#include <string>
#include <vector>
Include dependency graph for pvsmodel.hh:

Go to the source code of this file.

Classes

class  Ewoms::PvsModel< TypeTag >
 A generic compositional multi-phase model using primary-variable switching. More...
 
class  Ewoms::PvsModel< TypeTag >
 A generic compositional multi-phase model using primary-variable switching. More...
 

Namespaces

 Ewoms
 
 Ewoms::Properties
 

Functions

 Ewoms::Properties::NEW_TYPE_TAG (PvsModel, INHERITS_FROM(MultiPhaseBaseModel, VtkPhasePresence, VtkComposition, VtkEnergy, VtkDiffusion))
 The type tag for the isothermal single phase problems. More...
 
 Ewoms::Properties::SET_TYPE_PROP (PvsModel, LocalResidual, Ewoms::PvsLocalResidual< TypeTag >)
 Use the PVS local jacobian operator for the PVS model. More...
 
 Ewoms::Properties::SET_TYPE_PROP (PvsModel, NewtonMethod, Ewoms::PvsNewtonMethod< TypeTag >)
 Use the PVS specific newton method for the PVS model. More...
 
 Ewoms::Properties::SET_TYPE_PROP (PvsModel, Model, Ewoms::PvsModel< TypeTag >)
 the Model property More...
 
 Ewoms::Properties::SET_TYPE_PROP (PvsModel, PrimaryVariables, Ewoms::PvsPrimaryVariables< TypeTag >)
 the PrimaryVariables property More...
 
 Ewoms::Properties::SET_TYPE_PROP (PvsModel, RateVector, Ewoms::PvsRateVector< TypeTag >)
 the RateVector property More...
 
 Ewoms::Properties::SET_TYPE_PROP (PvsModel, BoundaryRateVector, Ewoms::PvsBoundaryRateVector< TypeTag >)
 the BoundaryRateVector property More...
 
 Ewoms::Properties::SET_TYPE_PROP (PvsModel, IntensiveQuantities, Ewoms::PvsIntensiveQuantities< TypeTag >)
 the IntensiveQuantities property More...
 
 Ewoms::Properties::SET_TYPE_PROP (PvsModel, ExtensiveQuantities, Ewoms::PvsExtensiveQuantities< TypeTag >)
 the ExtensiveQuantities property More...
 
 Ewoms::Properties::SET_TYPE_PROP (PvsModel, Indices, Ewoms::PvsIndices< TypeTag, 0 >)
 The indices required by the isothermal PVS model. More...
 
 Ewoms::Properties::SET_INT_PROP (PvsModel, PvsVerbosity, 1)
 
 Ewoms::Properties::SET_BOOL_PROP (PvsModel, EnableEnergy, false)
 Disable the energy equation by default. More...
 
 Ewoms::Properties::SET_BOOL_PROP (PvsModel, EnableDiffusion, false)
 
 Ewoms::Properties::SET_SCALAR_PROP (PvsModel, PvsPressureBaseWeight, 1.0)
 The basis value for the weight of the pressure primary variable. More...
 
 Ewoms::Properties::SET_SCALAR_PROP (PvsModel, PvsSaturationsBaseWeight, 1.0)
 The basis value for the weight of the saturation primary variables. More...
 
 Ewoms::Properties::SET_SCALAR_PROP (PvsModel, PvsMoleFractionsBaseWeight, 1.0)
 The basis value for the weight of the mole fraction primary variables. More...
 

Detailed Description

A generic compositional multi-phase model using primary-variable switching.

This model assumes a flow of $M \geq 1$ fluid phases $\alpha$, each of which is assumed to be a mixture $N \geq M$ chemical species $\kappa$.

By default, the standard multi-phase Darcy approach is used to determine the velocity, i.e.

\[ \mathbf{v}_\alpha = - \frac{k_{r\alpha}}{\mu_\alpha} \mathbf{K} \left(\mathbf{grad}\, p_\alpha - \varrho_{\alpha} \mathbf{g} \right) \;, \]

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

\[ \sum_\alpha \frac{\partial\;\phi c_\alpha^\kappa S_\alpha }{\partial t} - \sum_\alpha \mathrm{div} \left\{ c_\alpha^\kappa \mathbf{v}_\alpha \right\} - q^\kappa = 0 \;. \]

To close the system mathematically, $M$ model equations are also required. This model uses the primary variable switching assumptions, which are given by:

\[ 0 \stackrel{!}{=} f_\alpha = \left\{ \begin{array}{cl} S_\alpha & \quad \text{if phase }\alpha\text{ is not present} \ \ 1 - \sum_\kappa x_\alpha^\kappa & \quad \text{else} \end{array} \right. \]

To make this approach applicable, a pseudo primary variable phase presence has to be introduced. Its purpose is to specify for each phase whether it is present or not. It is a pseudo primary variable because it is not directly considered when linearizing the system in the Newton method, but after each Newton iteration, it gets updated like the "real" primary variables. The following rules are used for this update procedure:

  • If phase $\alpha$ is present according to the pseudo primary variable, but $S_\alpha < 0$ after the Newton update, consider the phase $\alpha$ disappeared for the next iteration and use the set of primary variables which correspond to the new phase presence.
  • If phase $\alpha$ is not present according to the pseudo primary variable, but the sum of the component mole fractions in the phase is larger than 1, i.e. $\sum_\kappa x_\alpha^\kappa > 1$, consider the phase $\alpha$ present in the the next iteration and update the set of primary variables to make it consistent with the new phase presence.
  • In all other cases don't modify the phase presence for phase $\alpha$.

The model always requires $N$ primary variables, but their interpretation is dependent on the phase presence:

  • The first primary variable is always interpreted as the pressure of the phase with the lowest index $PV_0 = p_0$.

  • Then, $M - 1$ "switching primary variables" follow, which are interpreted depending in the presence of the first $M-1$ phases: If phase $\alpha$ is present, its saturation $S_\alpha = PV_i$ is used as primary variable; if it is not present, the mole fraction $PV_i = x_{\alpha^\star}^\alpha$ of the component with index $\alpha$ in the phase with the lowest index that is present $\alpha^\star$ is used instead.

  • Finally, the mole fractions of the $N-M$ components with the largest index in the phase with the lowest index that is present $x_{\alpha^\star}^\kappa$ are used as primary variables.