mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-01-16 16:21:55 -06:00
Merge pull request #3855 from GitPaean/improving_logic_has_energy
reconstructing the if structure for has_energy in function StandardWell<TypeTag>::calculateSinglePerf()
This commit is contained in:
commit
21fd7e8e8b
@ -568,14 +568,13 @@ namespace Opm
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
const unsigned activeCompIdx = Indices::canonicalToActiveComponentIndex(FluidSystem::solventComponentIndex(phaseIdx));
|
// convert to reservoir conditions
|
||||||
// convert to reservoar conditions
|
|
||||||
EvalWell cq_r_thermal(this->numWellEq_ + Indices::numEq, 0.);
|
EvalWell cq_r_thermal(this->numWellEq_ + Indices::numEq, 0.);
|
||||||
if (FluidSystem::phaseIsActive(FluidSystem::oilPhaseIdx) && FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
const unsigned activeCompIdx = Indices::canonicalToActiveComponentIndex(FluidSystem::solventComponentIndex(phaseIdx));
|
||||||
|
const bool both_oil_gas = FluidSystem::phaseIsActive(FluidSystem::oilPhaseIdx) && FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx);
|
||||||
if(FluidSystem::waterPhaseIdx == phaseIdx)
|
if ( !both_oil_gas || FluidSystem::waterPhaseIdx == phaseIdx ) {
|
||||||
cq_r_thermal = cq_s[activeCompIdx] / this->extendEval(fs.invB(phaseIdx));
|
cq_r_thermal = cq_s[activeCompIdx] / this->extendEval(fs.invB(phaseIdx));
|
||||||
|
} else {
|
||||||
// remove dissolved gas and vapporized oil
|
// remove dissolved gas and vapporized oil
|
||||||
const unsigned oilCompIdx = Indices::canonicalToActiveComponentIndex(FluidSystem::oilCompIdx);
|
const unsigned oilCompIdx = Indices::canonicalToActiveComponentIndex(FluidSystem::oilCompIdx);
|
||||||
const unsigned gasCompIdx = Indices::canonicalToActiveComponentIndex(FluidSystem::gasCompIdx);
|
const unsigned gasCompIdx = Indices::canonicalToActiveComponentIndex(FluidSystem::gasCompIdx);
|
||||||
@ -589,9 +588,6 @@ namespace Opm
|
|||||||
// q_or = 1 / (b_o * d) * (q_os - rv * q_gs)
|
// q_or = 1 / (b_o * d) * (q_os - rv * q_gs)
|
||||||
if(FluidSystem::oilPhaseIdx == phaseIdx)
|
if(FluidSystem::oilPhaseIdx == phaseIdx)
|
||||||
cq_r_thermal = (cq_s[oilCompIdx] - this->extendEval(fs.Rv()) * cq_s[gasCompIdx]) / (d * this->extendEval(fs.invB(phaseIdx)) );
|
cq_r_thermal = (cq_s[oilCompIdx] - this->extendEval(fs.Rv()) * cq_s[gasCompIdx]) / (d * this->extendEval(fs.invB(phaseIdx)) );
|
||||||
|
|
||||||
} else {
|
|
||||||
cq_r_thermal = cq_s[activeCompIdx] / this->extendEval(fs.invB(phaseIdx));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// change temperature for injecting fluids
|
// change temperature for injecting fluids
|
||||||
|
Loading…
Reference in New Issue
Block a user