blackoilbioeffectsparams.hpp
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 This file is part of the Open Porous Media project (OPM).
5
6 OPM is free software: you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation, either version 2 of the License, or
9 (at your option) any later version.
10
11 OPM is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with OPM. If not, see <http://www.gnu.org/licenses/>.
18
19 Consult the COPYING file in the top-level source directory of this
20 module for the precise wording of the license and the list of
21 copyright holders.
22*/
28#ifndef OPM_BLACK_OIL_BIOEFFECTS_PARAMS_HPP
29#define OPM_BLACK_OIL_BIOEFFECTS_PARAMS_HPP
30
31#include <opm/material/common/Tabulated1DFunction.hpp>
32
33#include <vector>
34
35namespace Opm {
36
37class EclipseState;
38
40template<class Scalar>
42{
43 template<bool enableBioeffects , bool enableMICP>
44 void initFromState(const EclipseState& eclState);
45
46 using TabulatedFunction = Tabulated1DFunction<Scalar>;
47
48 enum { numDiffCoef = 3 };
49 enum { micrDiffIdx = 0 };
50 enum { oxygDiffIdx = 1 };
51 enum { ureaDiffIdx = 2 };
52
53 std::vector<TabulatedFunction> permfactTable_;
54 std::vector<TabulatedFunction> pcfactTable_;
55
56 std::vector<Scalar> densityBiofilm_{};
57 std::vector<Scalar> densityCalcite_{};
58 std::vector<Scalar> detachmentRate_{};
59 std::vector<Scalar> detachmentExponent_{};
60 std::vector<Scalar> halfVelocityGrowth_{};
61 std::vector<Scalar> halfVelocityUrea_{};
62 std::vector<Scalar> maximumGrowthRate_{};
63 std::vector<Scalar> maximumUreaUtilization_{};
64 std::vector<Scalar> microbialAttachmentRate_{};
65 std::vector<Scalar> microbialDeathRate_{};
66 std::vector<Scalar> oxygenConsumptionFactor_{};
67 std::vector<Scalar> yieldGrowthCoefficient_{};
68 std::vector<Scalar> yieldUreaToCalciteCoefficient_{};
69
70 std::vector<std::vector<Scalar>> bioDiffCoefficient_{};
71};
72
73} // namespace Opm
74
75#endif // OPM_BLACK_OIL_BIOEFFECTS_PARAMS_HPP
Definition: blackoilbioeffectsmodules.hh:45
Struct holding the parameters for the BlackOilBioeffectsModule class.
Definition: blackoilbioeffectsparams.hpp:42
std::vector< Scalar > oxygenConsumptionFactor_
Definition: blackoilbioeffectsparams.hpp:66
std::vector< std::vector< Scalar > > bioDiffCoefficient_
Definition: blackoilbioeffectsparams.hpp:70
std::vector< Scalar > halfVelocityUrea_
Definition: blackoilbioeffectsparams.hpp:61
@ ureaDiffIdx
Definition: blackoilbioeffectsparams.hpp:51
std::vector< Scalar > densityCalcite_
Definition: blackoilbioeffectsparams.hpp:57
std::vector< Scalar > detachmentRate_
Definition: blackoilbioeffectsparams.hpp:58
std::vector< Scalar > halfVelocityGrowth_
Definition: blackoilbioeffectsparams.hpp:60
std::vector< Scalar > microbialDeathRate_
Definition: blackoilbioeffectsparams.hpp:65
std::vector< TabulatedFunction > permfactTable_
Definition: blackoilbioeffectsparams.hpp:53
Tabulated1DFunction< Scalar > TabulatedFunction
Definition: blackoilbioeffectsparams.hpp:46
std::vector< Scalar > maximumUreaUtilization_
Definition: blackoilbioeffectsparams.hpp:63
std::vector< Scalar > yieldGrowthCoefficient_
Definition: blackoilbioeffectsparams.hpp:67
std::vector< Scalar > detachmentExponent_
Definition: blackoilbioeffectsparams.hpp:59
@ micrDiffIdx
Definition: blackoilbioeffectsparams.hpp:49
std::vector< TabulatedFunction > pcfactTable_
Definition: blackoilbioeffectsparams.hpp:54
std::vector< Scalar > maximumGrowthRate_
Definition: blackoilbioeffectsparams.hpp:62
std::vector< Scalar > microbialAttachmentRate_
Definition: blackoilbioeffectsparams.hpp:64
std::vector< Scalar > yieldUreaToCalciteCoefficient_
Definition: blackoilbioeffectsparams.hpp:68
@ numDiffCoef
Definition: blackoilbioeffectsparams.hpp:48
@ oxygDiffIdx
Definition: blackoilbioeffectsparams.hpp:50
std::vector< Scalar > densityBiofilm_
Definition: blackoilbioeffectsparams.hpp:56
void initFromState(const EclipseState &eclState)