mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-02-25 18:55:30 -06:00
move VtkBlackoilMICPModule parameters to TypeTag-free parameter system
This commit is contained in:
@@ -74,9 +74,8 @@ namespace Opm::Properties {
|
|||||||
namespace TTag {
|
namespace TTag {
|
||||||
|
|
||||||
//! The type tag for the black-oil problems
|
//! The type tag for the black-oil problems
|
||||||
struct BlackOilModel { using InheritsFrom = std::tuple<VtkBlackOilPolymer,
|
struct BlackOilModel
|
||||||
MultiPhaseBaseModel,
|
{ using InheritsFrom = std::tuple<VtkBlackOilPolymer, MultiPhaseBaseModel>; };
|
||||||
VtkBlackOilMICP>; };
|
|
||||||
} // namespace TTag
|
} // namespace TTag
|
||||||
|
|
||||||
//! Set the local residual function
|
//! Set the local residual function
|
||||||
|
|||||||
@@ -41,51 +41,14 @@
|
|||||||
#include <opm/models/utils/parametersystem.hh>
|
#include <opm/models/utils/parametersystem.hh>
|
||||||
#include <opm/models/utils/propertysystem.hh>
|
#include <opm/models/utils/propertysystem.hh>
|
||||||
|
|
||||||
namespace Opm::Properties::TTag {
|
|
||||||
|
|
||||||
// create new type tag for the VTK multi-phase output
|
|
||||||
struct VtkBlackOilMICP {};
|
|
||||||
|
|
||||||
} // namespace Opm::Properties::TTag
|
|
||||||
|
|
||||||
namespace Opm::Parameters {
|
namespace Opm::Parameters {
|
||||||
|
|
||||||
// create the property tags needed for the MICP output module
|
|
||||||
template<class TypeTag, class MyTypeTag>
|
|
||||||
struct VtkWriteMicrobialConcentration { using type = Properties::UndefinedProperty; };
|
|
||||||
|
|
||||||
template<class TypeTag, class MyTypeTag>
|
|
||||||
struct VtkWriteOxygenConcentration { using type = Properties::UndefinedProperty; };
|
|
||||||
|
|
||||||
template<class TypeTag, class MyTypeTag>
|
|
||||||
struct VtkWriteUreaConcentration { using type = Properties::UndefinedProperty; };
|
|
||||||
|
|
||||||
template<class TypeTag, class MyTypeTag>
|
|
||||||
struct VtkWriteBiofilmConcentration { using type = Properties::UndefinedProperty; };
|
|
||||||
|
|
||||||
template<class TypeTag, class MyTypeTag>
|
|
||||||
struct VtkWriteCalciteConcentration { using type = Properties::UndefinedProperty; };
|
|
||||||
|
|
||||||
// set default values for what quantities to output
|
// set default values for what quantities to output
|
||||||
template<class TypeTag>
|
struct VtkWriteMicrobialConcentration { static constexpr bool value = true; };
|
||||||
struct VtkWriteMicrobialConcentration<TypeTag, Properties::TTag::VtkBlackOilMICP>
|
struct VtkWriteOxygenConcentration { static constexpr bool value = true; };
|
||||||
{ static constexpr bool value = true; };
|
struct VtkWriteUreaConcentration { static constexpr bool value = true; };
|
||||||
|
struct VtkWriteBiofilmConcentration { static constexpr bool value = true; };
|
||||||
template<class TypeTag>
|
struct VtkWriteCalciteConcentration { static constexpr bool value = true; };
|
||||||
struct VtkWriteOxygenConcentration<TypeTag, Properties::TTag::VtkBlackOilMICP>
|
|
||||||
{ static constexpr bool value = true; };
|
|
||||||
|
|
||||||
template<class TypeTag>
|
|
||||||
struct VtkWriteUreaConcentration<TypeTag, Properties::TTag::VtkBlackOilMICP>
|
|
||||||
{ static constexpr bool value = true; };
|
|
||||||
|
|
||||||
template<class TypeTag>
|
|
||||||
struct VtkWriteBiofilmConcentration<TypeTag, Properties::TTag::VtkBlackOilMICP>
|
|
||||||
{ static constexpr bool value = true; };
|
|
||||||
|
|
||||||
template<class TypeTag>
|
|
||||||
struct VtkWriteCalciteConcentration<TypeTag, Properties::TTag::VtkBlackOilMICP>
|
|
||||||
{ static constexpr bool value = true; };
|
|
||||||
|
|
||||||
} // namespace Opm::Parameters
|
} // namespace Opm::Parameters
|
||||||
|
|
||||||
@@ -127,18 +90,18 @@ public:
|
|||||||
if (!enableMICP)
|
if (!enableMICP)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
Parameters::registerParam<TypeTag, Parameters::VtkWriteMicrobialConcentration>
|
Parameters::Register<Parameters::VtkWriteMicrobialConcentration>
|
||||||
("Include the concentration of the microbial component in the water phase "
|
("Include the concentration of the microbial component in the water phase "
|
||||||
"in the VTK output files");
|
"in the VTK output files");
|
||||||
Parameters::registerParam<TypeTag, Parameters::VtkWriteOxygenConcentration>
|
Parameters::Register<Parameters::VtkWriteOxygenConcentration>
|
||||||
("Include the concentration of the oxygen component in the water phase "
|
("Include the concentration of the oxygen component in the water phase "
|
||||||
"in the VTK output files");
|
"in the VTK output files");
|
||||||
Parameters::registerParam<TypeTag, Parameters::VtkWriteUreaConcentration>
|
Parameters::Register<Parameters::VtkWriteUreaConcentration>
|
||||||
("Include the concentration of the urea component in the water phase "
|
("Include the concentration of the urea component in the water phase "
|
||||||
"in the VTK output files");
|
"in the VTK output files");
|
||||||
Parameters::registerParam<TypeTag, Parameters::VtkWriteBiofilmConcentration>
|
Parameters::Register<Parameters::VtkWriteBiofilmConcentration>
|
||||||
("Include the biofilm volume fraction in the VTK output files");
|
("Include the biofilm volume fraction in the VTK output files");
|
||||||
Parameters::registerParam<TypeTag, Parameters::VtkWriteCalciteConcentration>
|
Parameters::Register<Parameters::VtkWriteCalciteConcentration>
|
||||||
("Include the calcite volume fraction in the VTK output files");
|
("Include the calcite volume fraction in the VTK output files");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -239,31 +202,31 @@ public:
|
|||||||
private:
|
private:
|
||||||
static bool microbialConcentrationOutput_()
|
static bool microbialConcentrationOutput_()
|
||||||
{
|
{
|
||||||
static bool val = Parameters::get<TypeTag, Parameters::VtkWriteMicrobialConcentration>();
|
static bool val = Parameters::Get<Parameters::VtkWriteMicrobialConcentration>();
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool oxygenConcentrationOutput_()
|
static bool oxygenConcentrationOutput_()
|
||||||
{
|
{
|
||||||
static bool val = Parameters::get<TypeTag, Parameters::VtkWriteOxygenConcentration>();
|
static bool val = Parameters::Get<Parameters::VtkWriteOxygenConcentration>();
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool ureaConcentrationOutput_()
|
static bool ureaConcentrationOutput_()
|
||||||
{
|
{
|
||||||
static bool val = Parameters::get<TypeTag, Parameters::VtkWriteUreaConcentration>();
|
static bool val = Parameters::Get<Parameters::VtkWriteUreaConcentration>();
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool biofilmConcentrationOutput_()
|
static bool biofilmConcentrationOutput_()
|
||||||
{
|
{
|
||||||
static bool val = Parameters::get<TypeTag, Parameters::VtkWriteBiofilmConcentration>();
|
static bool val = Parameters::Get<Parameters::VtkWriteBiofilmConcentration>();
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool calciteConcentrationOutput_()
|
static bool calciteConcentrationOutput_()
|
||||||
{
|
{
|
||||||
static bool val = Parameters::get<TypeTag, Parameters::VtkWriteCalciteConcentration>();
|
static bool val = Parameters::Get<Parameters::VtkWriteCalciteConcentration>();
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user