immiscibleindices.hh
Go to the documentation of this file.
1 // -*- mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 // vi: set et ts=4 sw=4 sts=4:
3 /*
4  Copyright (C) 2010-2013 by Andreas Lauser
5 
6  This file is part of the Open Porous Media project (OPM).
7 
8  OPM is free software: you can redistribute it and/or modify
9  it under the terms of the GNU General Public License as published by
10  the Free Software Foundation, either version 2 of the License, or
11  (at your option) any later version.
12 
13  OPM is distributed in the hope that it will be useful,
14  but WITHOUT ANY WARRANTY; without even the implied warranty of
15  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  GNU General Public License for more details.
17 
18  You should have received a copy of the GNU General Public License
19  along with OPM. If not, see <http://www.gnu.org/licenses/>.
20 */
26 #ifndef EWOMS_IMMISCIBLE_INDICES_HH
27 #define EWOMS_IMMISCIBLE_INDICES_HH
28 
29 #include "immiscibleproperties.hh"
31 
32 namespace Ewoms {
33 
39 template <class TypeTag, int PVOffset>
41  : public EnergyIndices<PVOffset + GET_PROP_VALUE(TypeTag, NumPhases),
42  GET_PROP_VALUE(TypeTag, EnableEnergy)>
43 {
44  enum { numPhases = GET_PROP_VALUE(TypeTag, NumPhases) };
45  enum { enableEnergy = GET_PROP_VALUE(TypeTag, EnableEnergy) };
47 
48 public:
49  // number of equations/primary variables
50  static const int numEq = numPhases + EnergyIndices::numEq_;
51 
52  // Primary variable indices
53 
56  static const int pressure0Idx = PVOffset + 0;
58  static const int saturation0Idx = PVOffset + 1;
59 
60  // indices of the equations
61 
63  static const int conti0EqIdx = PVOffset + 0;
64 };
65 } // namespace Ewoms
66 
67 #endif
static const int pressure0Idx
Definition: immiscibleindices.hh:56
Definition: immiscibleindices.hh:44
Provides the indices required for the energy equation.
Definition: energymodule.hh:495
#define GET_PROP_VALUE(TypeTag, PropTagName)
Access the value attribute of a property for a type tag.
Definition: propertysystem.hh:468
Defines the properties required for the immiscible multi-phase model.
static const int numEq
Definition: immiscibleindices.hh:50
static const int saturation0Idx
Index of the saturation of the non-wetting/wetting phase.
Definition: immiscibleindices.hh:58
Definition: baseauxiliarymodule.hh:35
Definition: immiscibleindices.hh:45
The indices for the isothermal multi-phase model.
Definition: immiscibleindices.hh:40
Ewoms::EnergyIndices< PVOffset+numPhases, enableEnergy > EnergyIndices
Definition: immiscibleindices.hh:46
static const int conti0EqIdx
Index of the continuity equation of the first phase.
Definition: immiscibleindices.hh:63
Contains the classes required to consider energy as a conservation quantity in a multi-phase module...