diff --git a/dumux/porousmediumflow/mpnc/implicit/energy/fluxvariables.hh b/dumux/porousmediumflow/mpnc/implicit/energy/fluxvariables.hh index 38ecf3f353b9de8f5ab3e856df61bd891e5ae3c6..265bef607b35081d7e9590dfdc723afcde862665 100644 --- a/dumux/porousmediumflow/mpnc/implicit/energy/fluxvariables.hh +++ b/dumux/porousmediumflow/mpnc/implicit/energy/fluxvariables.hh @@ -141,7 +141,7 @@ public: // index for the element volume variables int volVarsIdx = face.fapIndices[idx]; - tmp *= elemVolVars[volVarsIdx].fluidState().temperature(/*phaseIdx=*/0); + tmp *= elemVolVars[volVarsIdx].temperature(/*phaseIdx=*/0); temperatureGradient += tmp; } diff --git a/dumux/porousmediumflow/mpnc/implicit/energy/localresidual.hh b/dumux/porousmediumflow/mpnc/implicit/energy/localresidual.hh index b8dc111468ef50db6d125748562e753daae44fec..dcc3cbee521b304c845de287b01ec9aa6fe3c6c7 100644 --- a/dumux/porousmediumflow/mpnc/implicit/energy/localresidual.hh +++ b/dumux/porousmediumflow/mpnc/implicit/energy/localresidual.hh @@ -161,7 +161,7 @@ public: // heat stored in the rock matrix storage[energyEqIdx] += - volVars.fluidState().temperature(/*phaseIdx=*/0) + volVars.temperature(/*phaseIdx=*/0) * volVars.solidDensity() * (1.0 - volVars.porosity()) * volVars.solidHeatCapacity(); diff --git a/dumux/porousmediumflow/mpnc/implicit/energy/vtkwriter.hh b/dumux/porousmediumflow/mpnc/implicit/energy/vtkwriter.hh index ac725f024446a31f702838b9043bfa09bac5e07c..51cabb317e1ff8b8eb14e964243fc13b5e364762 100644 --- a/dumux/porousmediumflow/mpnc/implicit/energy/vtkwriter.hh +++ b/dumux/porousmediumflow/mpnc/implicit/energy/vtkwriter.hh @@ -100,7 +100,7 @@ public: const VolumeVariables &volVars = elemVolVars[scvIdx]; if (temperatureOutput_) - temperature_[dofIdxGlobal] = volVars.fluidState().temperature(/*phaseIdx=*/0); + temperature_[dofIdxGlobal] = volVars.temperature(/*phaseIdx=*/0); } } @@ -190,7 +190,7 @@ public: int gobalIdx = this->problem_.model().dofMapper().subIndex(element, scvIdx, dofCodim); const VolumeVariables &volVars = elemVolVars[scvIdx]; - if (temperatureOutput_) temperature_[gobalIdx] = volVars.fluidState().temperature(/*phaseIdx=*/0); + if (temperatureOutput_) temperature_[gobalIdx] = volVars.temperature(/*phaseIdx=*/0); for (int phaseIdx = 0; phaseIdx < numPhases; ++ phaseIdx) { if (enthalpyOutput_) enthalpy_[phaseIdx][gobalIdx] = volVars.enthalpy(phaseIdx); diff --git a/dumux/porousmediumflow/mpnc/implicit/mass/localresidual.hh b/dumux/porousmediumflow/mpnc/implicit/mass/localresidual.hh index a2f6a9347cbfed2c41928514170871ac9cedd638..7ad8af1e1b6c8473887a886a6fd90f96e4f320b1 100644 --- a/dumux/porousmediumflow/mpnc/implicit/mass/localresidual.hh +++ b/dumux/porousmediumflow/mpnc/implicit/mass/localresidual.hh @@ -184,7 +184,7 @@ if (!std::isfinite(volumeFlux)) + ( 1. - massUpwindWeight)*dn.molarity(phaseIdx, compIdx) ); if (!std::isfinite(flux[compIdx])) - DUNE_THROW(NumericalProblem, "Calculated non-finite normal flux in phase " << phaseIdx << " comp " << compIdx << "T: "<< up.fluidState().temperature(phaseIdx) << "S "<<up.saturation(phaseIdx) ) ; + DUNE_THROW(NumericalProblem, "Calculated non-finite normal flux in phase " << phaseIdx << " comp " << compIdx << "T: "<< up.temperature(phaseIdx) << "S "<<up.saturation(phaseIdx) ) ; } } } diff --git a/dumux/porousmediumflow/mpnc/implicit/mass/localresidualkinetic.hh b/dumux/porousmediumflow/mpnc/implicit/mass/localresidualkinetic.hh index 41ec6a67c62a48c9d11845f689640eb6fbcd868e..19cf008fae996420c74d3771ae1aab5bd0b4afe9 100644 --- a/dumux/porousmediumflow/mpnc/implicit/mass/localresidualkinetic.hh +++ b/dumux/porousmediumflow/mpnc/implicit/mass/localresidualkinetic.hh @@ -195,7 +195,7 @@ public: Valgrind::CheckDefined(mu_nPhaseWComp); const Scalar characteristicLength = volVars.characteristicLength() ; - const Scalar temperature = volVars.fluidState().temperature(wPhaseIdx); + const Scalar temperature = volVars.temperature(wPhaseIdx); const Scalar pn = volVars.pressure(nPhaseIdx); const Scalar henry = FluidSystem::henry(temperature) ; const Scalar gradNinWApprox = ( mu_wPhaseNComp - mu_nPhaseNCompEquil) / characteristicLength; // very 2p2c // 1. / henry * diff --git a/dumux/porousmediumflow/mpnc/implicit/volumevariables.hh b/dumux/porousmediumflow/mpnc/implicit/volumevariables.hh index 56a458f0d1812c383961abda9c471bbfab866278..705813c7fb2797f32c6d99bede1f2b3228663933 100644 --- a/dumux/porousmediumflow/mpnc/implicit/volumevariables.hh +++ b/dumux/porousmediumflow/mpnc/implicit/volumevariables.hh @@ -321,6 +321,34 @@ public: Scalar density(const int phaseIdx) const { return fluidState_.density(phaseIdx); } + /*! + * \brief Returns the fluid/solid phase temperature + * in the sub-control volume for the assumption of local thermal + * non-equillibrium where there is more than one energy equation + * and each phase and the matrix can have different temperatures + * + * \param phaseIdx The local index of the phases + */ + template <class T = TypeTag> + typename std::enable_if<(GET_PROP_VALUE(T, NumEnergyEquations) > 1), Scalar>::type temperature(const unsigned int phaseIdx) const + { + return EnergyVolumeVariables::temperature(phaseIdx); + } + + /*! + * \brief Returns the fluid/solid phase temperature + * in the sub-control volume for the assumption of local thermal + * equillibrium where there is only one or no energy equation + * and all phases including the matrix have the same temperature + * + * \param phaseIdx The local index of the phases + */ + template <class T = TypeTag> + typename std::enable_if<(GET_PROP_VALUE(T, NumEnergyEquations) < 2), Scalar>::type temperature(const unsigned int phaseIdx) const + { + return fluidState_.temperature(phaseIdx); + } + /*! * \brief Return enthalpy \f$\mathrm{[kg/m^3]}\f$ the of the fluid phase. */ diff --git a/test/porousmediumflow/mpnc/implicit/combustionproblem1c.hh b/test/porousmediumflow/mpnc/implicit/combustionproblem1c.hh index beed6ad0ccdf208242b0690c54dd14a980ce966d..c102e016524265cc15c5af41364e403adade0e7f 100644 --- a/test/porousmediumflow/mpnc/implicit/combustionproblem1c.hh +++ b/test/porousmediumflow/mpnc/implicit/combustionproblem1c.hh @@ -481,8 +481,8 @@ public: const Scalar pn = elemVolVars[scvIdx].pressure(nPhaseIdx); const Scalar pw = elemVolVars[scvIdx].pressure(wPhaseIdx); - const Scalar Tn = elemVolVars[scvIdx].fluidState().temperature(nPhaseIdx); - const Scalar Tw = elemVolVars[scvIdx].fluidState().temperature(wPhaseIdx); + const Scalar Tn = elemVolVars[scvIdx].temperature(nPhaseIdx); + const Scalar Tw = elemVolVars[scvIdx].temperature(wPhaseIdx); fluidState.setPressure(nPhaseIdx, pn); fluidState.setPressure(wPhaseIdx, pw);