102 void update(
const ElementContext& elemCtx,
106 ParentType::update(elemCtx, dofIdx, timeIdx);
107 ParentType::checkDefined();
109 typename FluidSystem::template ParameterCache<Evaluation> paramCache;
110 const auto& priVars = elemCtx.primaryVars(dofIdx, timeIdx);
113 Evaluation sumSat = 0;
114 for (
unsigned phaseIdx = 0; phaseIdx < numPhases - 1; ++phaseIdx) {
115 const Evaluation& val = priVars.makeEvaluation(saturation0Idx + phaseIdx, timeIdx);
116 fluidState_.setSaturation(phaseIdx, val);
119 fluidState_.setSaturation(numPhases - 1, 1.0 - sumSat);
120 Opm::Valgrind::CheckDefined(sumSat);
123 EnergyIntensiveQuantities::updateTemperatures_(fluidState_, elemCtx, dofIdx, timeIdx);
126 const auto& problem = elemCtx.problem();
127 const MaterialLawParams& materialParams =
128 problem.materialLawParams(elemCtx, dofIdx, timeIdx);
131 std::array<Evaluation, numPhases> capPress;
132 MaterialLaw::capillaryPressures(capPress, materialParams, fluidState_);
135 const Evaluation& pressure0 = priVars.makeEvaluation(pressure0Idx, timeIdx);
136 for (
unsigned phaseIdx = 0; phaseIdx < numPhases; ++phaseIdx) {
137 fluidState_.setPressure(phaseIdx, pressure0 + (capPress[phaseIdx] - capPress[0]));
142 for (
unsigned compIdx = 0; compIdx < numComponents; ++compIdx) {
143 fug[compIdx] = priVars.makeEvaluation(fugacity0Idx + compIdx, timeIdx);
147 const auto* hint = elemCtx.thermodynamicHint(dofIdx, timeIdx);
148 for (
unsigned phaseIdx = 0; phaseIdx < numPhases; ++phaseIdx) {
151 for (
unsigned compIdx = 0; compIdx < numComponents; ++compIdx) {
153 const Evaluation& moleFracIJ = hint->fluidState().moleFraction(phaseIdx, compIdx);
154 fluidState_.setMoleFraction(phaseIdx, compIdx, moleFracIJ);
158 CompositionFromFugacitiesSolver::guessInitial(fluidState_, phaseIdx, fug);
163 CompositionFromFugacitiesSolver::solve(fluidState_, paramCache, phaseIdx, fug);
167 porosity_ = problem.porosity(elemCtx, dofIdx, timeIdx);
168 Opm::Valgrind::CheckDefined(porosity_);
171 MaterialLaw::relativePermeabilities(relativePermeability_, materialParams, fluidState_);
174 for (
unsigned phaseIdx = 0; phaseIdx < numPhases; ++phaseIdx) {
176 const Evaluation& mu = FluidSystem::viscosity(fluidState_, paramCache, phaseIdx);
177 fluidState_.setViscosity(phaseIdx, mu);
179 mobility_[phaseIdx] = relativePermeability_[phaseIdx]/mu;
183 intrinsicPerm_ = problem.intrinsicPermeability(elemCtx, dofIdx, timeIdx);
186 FluxIntensiveQuantities::update_(elemCtx, dofIdx, timeIdx);
189 EnergyIntensiveQuantities::update_(fluidState_, paramCache, elemCtx, dofIdx, timeIdx);
192 DiffusionIntensiveQuantities::update_(fluidState_, paramCache, elemCtx, dofIdx, timeIdx);