diff --git a/flowexperimental/BlackOilIntensiveQuantitiesGlobalIndex.hpp b/flowexperimental/BlackOilIntensiveQuantitiesGlobalIndex.hpp index 20f5b0d308e..e964b902a8a 100644 --- a/flowexperimental/BlackOilIntensiveQuantitiesGlobalIndex.hpp +++ b/flowexperimental/BlackOilIntensiveQuantitiesGlobalIndex.hpp @@ -49,6 +49,7 @@ #include #include #include +#include #include #include @@ -78,6 +79,7 @@ class BlackOilIntensiveQuantitiesGlobalIndex , public BlackOilBrineIntensiveQuantities , public BlackOilEnergyIntensiveQuantitiesGlobalIndex , public BlackOilMICPIntensiveQuantities + , public BlackOilConvectiveMixingIntensiveQuantities { using ParentType = GetPropType; using Implementation = GetPropType; @@ -103,6 +105,7 @@ class BlackOilIntensiveQuantitiesGlobalIndex enum { enableTemperature = getPropValue() }; enum { enableEnergy = getPropValue() }; enum { enableDiffusion = getPropValue() }; + enum { enableConvectiveMixing = getPropValue() }; enum { enableMICP = getPropValue() }; enum { numPhases = getPropValue() }; enum { numComponents = getPropValue() }; @@ -382,6 +385,10 @@ class BlackOilIntensiveQuantitiesGlobalIndex rockCompTransMultiplier_ = problem.template rockCompTransMultiplier(*this, globalSpaceIdx); + if constexpr (enableConvectiveMixing) { + asImp_().updateSaturatedDissolutionFactor_(); + } + #ifndef NDEBUG // some safety checks in debug mode for (unsigned phaseIdx = 0; phaseIdx < numPhases; ++ phaseIdx) { diff --git a/opm/models/blackoil/blackoilconvectivemixingmodule.hh b/opm/models/blackoil/blackoilconvectivemixingmodule.hh index ac46d3bfd64..1deac71b07e 100644 --- a/opm/models/blackoil/blackoilconvectivemixingmodule.hh +++ b/opm/models/blackoil/blackoilconvectivemixingmodule.hh @@ -289,15 +289,11 @@ public: const auto& liquidPhaseIdx = (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) ? FluidSystem::waterPhaseIdx : FluidSystem::oilPhaseIdx; - const Evaluation SoMax = 0.0; //interiour const auto& t_in = intQuantsIn.fluidState().temperature(liquidPhaseIdx); const auto& p_in = intQuantsIn.fluidState().pressure(liquidPhaseIdx); - const auto& rssat_in = FluidSystem::saturatedDissolutionFactor(intQuantsIn.fluidState(), - liquidPhaseIdx, - intQuantsIn.pvtRegionIndex(), - SoMax); + const auto& rssat_in = intQuantsIn.saturatedDissolutionFactor(); const auto& salt_in = intQuantsIn.fluidState().saltSaturation(); const auto bLiquidSatIn = (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) ? @@ -315,10 +311,7 @@ public: //exteriour const auto t_ex = Opm::getValue(intQuantsEx.fluidState().temperature(liquidPhaseIdx)); const auto p_ex = Opm::getValue(intQuantsEx.fluidState().pressure(liquidPhaseIdx)); - const auto rssat_ex = Opm::getValue(FluidSystem::saturatedDissolutionFactor(intQuantsEx.fluidState(), - liquidPhaseIdx, - intQuantsEx.pvtRegionIndex(), - SoMax)); + const auto rssat_ex = Opm::getValue(intQuantsEx.saturatedDissolutionFactor()); const auto salt_ex = Opm::getValue(intQuantsEx.fluidState().saltSaturation()); const auto bLiquidSatEx = (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) ? FluidSystem::waterPvt().inverseFormationVolumeFactor(intQuantsEx.pvtRegionIndex(), t_ex, p_ex, rssat_ex, salt_ex): @@ -382,6 +375,53 @@ public: } }; +/*! + * \ingroup BlackOil + * \class Opm::BlackOilConvectiveMixingIntensiveQuantities + * + * \brief Provides the volumetric quantities required for the equations needed by the + * convective mixing (DRSDTCON) model. + */ +template ()> +class BlackOilConvectiveMixingIntensiveQuantities +{ + using Implementation = GetPropType; + using Evaluation = GetPropType; + using FluidSystem = GetPropType; + +public: + /*! + * \brief Compute the intensive quantities needed to handle convective dissolution + * + */ + void updateSaturatedDissolutionFactor_() + { + auto& fs = asImp_().fluidState(); + const auto& liquidPhaseIdx = (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) ? + FluidSystem::waterPhaseIdx : + FluidSystem::oilPhaseIdx; + const Evaluation SoMax = 0.0; + saturatedDissolutionFactor_ = FluidSystem::saturatedDissolutionFactor(fs, + liquidPhaseIdx, + asImp_().pvtRegionIndex(), + SoMax); + } + + const Evaluation& saturatedDissolutionFactor() const + { return saturatedDissolutionFactor_; } + +protected: + Implementation& asImp_() + { return *static_cast(this); } + + Evaluation saturatedDissolutionFactor_; +}; + +template +class BlackOilConvectiveMixingIntensiveQuantities +{ +}; + } #endif diff --git a/opm/models/blackoil/blackoilintensivequantities.hh b/opm/models/blackoil/blackoilintensivequantities.hh index 2de7bea2893..2d57b3e2b0f 100644 --- a/opm/models/blackoil/blackoilintensivequantities.hh +++ b/opm/models/blackoil/blackoilintensivequantities.hh @@ -38,6 +38,7 @@ #include "blackoildiffusionmodule.hh" #include "blackoildispersionmodule.hh" #include "blackoilmicpmodules.hh" +#include "blackoilconvectivemixingmodule.hh" #include #include @@ -79,6 +80,7 @@ class BlackOilIntensiveQuantities , public BlackOilBrineIntensiveQuantities , public BlackOilEnergyIntensiveQuantities , public BlackOilMICPIntensiveQuantities + , public BlackOilConvectiveMixingIntensiveQuantities { using ParentType = GetPropType; using Implementation = GetPropType; @@ -106,6 +108,7 @@ class BlackOilIntensiveQuantities enum { enableEnergy = getPropValue() }; enum { enableDiffusion = getPropValue() }; enum { enableDispersion = getPropValue() }; + enum { enableConvectiveMixing = getPropValue() }; enum { enableMICP = getPropValue() }; enum { numPhases = getPropValue() }; enum { numComponents = getPropValue() }; @@ -497,6 +500,10 @@ public: // update the dispersion specific quantities of the intensive quantities DispersionIntensiveQuantities::update_(elemCtx, dofIdx, timeIdx); + if constexpr (enableConvectiveMixing) { + asImp_().updateSaturatedDissolutionFactor_(); + } + #ifndef NDEBUG // some safety checks in debug mode for (unsigned phaseIdx = 0; phaseIdx < numPhases; ++ phaseIdx) {