blackoilmicpparams.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_MICP_PARAMS_HPP
29#define OPM_BLACK_OIL_MICP_PARAMS_HPP
30
31#include <opm/material/common/Tabulated1DFunction.hpp>
32
33#include <vector>
34
35namespace Opm {
36
37#if HAVE_ECL_INPUT
38class EclipseState;
39#endif
40
42template<class Scalar>
44{
45#if HAVE_ECL_INPUT
46 template<bool enableMICP>
47 void initFromState(const EclipseState& eclState);
48#endif
49
50 using TabulatedFunction = Tabulated1DFunction<Scalar>;
51
52 std::vector<TabulatedFunction> permfactTable_;
53
54 std::vector<Scalar> densityBiofilm_;
55 std::vector<Scalar> densityCalcite_;
56 std::vector<Scalar> detachmentRate_;
57 std::vector<Scalar> detachmentExponent_;
58 std::vector<Scalar> halfVelocityOxygen_;
59 std::vector<Scalar> halfVelocityUrea_;
60 std::vector<Scalar> maximumGrowthRate_;
61 std::vector<Scalar> maximumUreaUtilization_;
62 std::vector<Scalar> microbialAttachmentRate_;
63 std::vector<Scalar> microbialDeathRate_;
64 std::vector<Scalar> oxygenConsumptionFactor_;
65 std::vector<Scalar> yieldGrowthCoefficient_;
66 std::vector<Scalar> yieldUreaToCalciteCoefficient_;
67 std::vector<Scalar> microbialDiffusion_;
68 std::vector<Scalar> oxygenDiffusion_;
69 std::vector<Scalar> ureaDiffusion_;
70};
71
72} // namespace Opm
73
74#endif // OPM_BLACK_OIL_MICP_PARAMS_HPP
Definition: blackoilboundaryratevector.hh:39
Struct holding the parameters for the BlackOilMICPModule class.
Definition: blackoilmicpparams.hpp:44
Tabulated1DFunction< Scalar > TabulatedFunction
Definition: blackoilmicpparams.hpp:50
std::vector< Scalar > detachmentRate_
Definition: blackoilmicpparams.hpp:56
std::vector< Scalar > oxygenDiffusion_
Definition: blackoilmicpparams.hpp:68
std::vector< Scalar > microbialDiffusion_
Definition: blackoilmicpparams.hpp:67
std::vector< Scalar > halfVelocityUrea_
Definition: blackoilmicpparams.hpp:59
std::vector< Scalar > detachmentExponent_
Definition: blackoilmicpparams.hpp:57
std::vector< Scalar > halfVelocityOxygen_
Definition: blackoilmicpparams.hpp:58
std::vector< Scalar > microbialDeathRate_
Definition: blackoilmicpparams.hpp:63
std::vector< Scalar > oxygenConsumptionFactor_
Definition: blackoilmicpparams.hpp:64
std::vector< Scalar > maximumGrowthRate_
Definition: blackoilmicpparams.hpp:60
std::vector< Scalar > yieldGrowthCoefficient_
Definition: blackoilmicpparams.hpp:65
std::vector< TabulatedFunction > permfactTable_
Definition: blackoilmicpparams.hpp:52
std::vector< Scalar > yieldUreaToCalciteCoefficient_
Definition: blackoilmicpparams.hpp:66
std::vector< Scalar > densityBiofilm_
Definition: blackoilmicpparams.hpp:54
std::vector< Scalar > densityCalcite_
Definition: blackoilmicpparams.hpp:55
std::vector< Scalar > maximumUreaUtilization_
Definition: blackoilmicpparams.hpp:61
std::vector< Scalar > ureaDiffusion_
Definition: blackoilmicpparams.hpp:69
std::vector< Scalar > microbialAttachmentRate_
Definition: blackoilmicpparams.hpp:62