mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-01-19 16:22:57 -06:00
Merge pull request #2849 from goncalvesmachadoc/aquifer
Prepare Well Implemantion For Water and Water-Gas System
This commit is contained in:
commit
990ce70287
@ -256,30 +256,47 @@ namespace Opm
|
|||||||
return EvalWell(numWellEq_ + numEq, 1.0);
|
return EvalWell(numWellEq_ + numEq, 1.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx) && compIdx == Indices::canonicalToActiveComponentIndex(FluidSystem::waterCompIdx)) {
|
if (FluidSystem::phaseIsActive(FluidSystem::oilPhaseIdx)) {
|
||||||
|
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx) && compIdx == Indices::canonicalToActiveComponentIndex(FluidSystem::waterCompIdx)) {
|
||||||
|
return primary_variables_evaluation_[WFrac];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx) && compIdx == Indices::canonicalToActiveComponentIndex(FluidSystem::gasCompIdx)) {
|
||||||
|
return primary_variables_evaluation_[GFrac];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (has_solvent && compIdx == (unsigned)contiSolventEqIdx) {
|
||||||
|
return primary_variables_evaluation_[SFrac];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx) && compIdx == Indices::canonicalToActiveComponentIndex(FluidSystem::waterCompIdx)) {
|
||||||
|
|
||||||
|
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx) && compIdx == Indices::canonicalToActiveComponentIndex(FluidSystem::gasCompIdx)) {
|
||||||
|
return primary_variables_evaluation_[GFrac];
|
||||||
|
}
|
||||||
return primary_variables_evaluation_[WFrac];
|
return primary_variables_evaluation_[WFrac];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx) && compIdx == Indices::canonicalToActiveComponentIndex(FluidSystem::gasCompIdx)) {
|
// Oil or WATER fraction
|
||||||
return primary_variables_evaluation_[GFrac];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (has_solvent && compIdx == (unsigned)contiSolventEqIdx) {
|
|
||||||
return primary_variables_evaluation_[SFrac];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Oil fraction
|
|
||||||
EvalWell well_fraction(numWellEq_ + numEq, 1.0);
|
EvalWell well_fraction(numWellEq_ + numEq, 1.0);
|
||||||
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
if (FluidSystem::phaseIsActive(FluidSystem::oilPhaseIdx)) {
|
||||||
well_fraction -= primary_variables_evaluation_[WFrac];
|
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
||||||
}
|
well_fraction -= primary_variables_evaluation_[WFrac];
|
||||||
|
}
|
||||||
|
|
||||||
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
||||||
well_fraction -= primary_variables_evaluation_[GFrac];
|
well_fraction -= primary_variables_evaluation_[GFrac];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (has_solvent) {
|
||||||
|
well_fraction -= primary_variables_evaluation_[SFrac];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (has_solvent) {
|
else if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx) && (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx))) {
|
||||||
well_fraction -= primary_variables_evaluation_[SFrac];
|
|
||||||
|
well_fraction -= primary_variables_evaluation_[GFrac];
|
||||||
}
|
}
|
||||||
|
|
||||||
return well_fraction;
|
return well_fraction;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1038,19 +1055,32 @@ namespace Opm
|
|||||||
StandardWell<TypeTag>::
|
StandardWell<TypeTag>::
|
||||||
processFractions() const
|
processFractions() const
|
||||||
{
|
{
|
||||||
assert(FluidSystem::phaseIsActive(FluidSystem::oilPhaseIdx));
|
|
||||||
const auto pu = phaseUsage();
|
const auto pu = phaseUsage();
|
||||||
std::vector<double> F(number_of_phases_, 0.0);
|
std::vector<double> F(number_of_phases_, 0.0);
|
||||||
F[pu.phase_pos[Oil]] = 1.0;
|
|
||||||
|
|
||||||
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
if (FluidSystem::phaseIsActive(FluidSystem::oilPhaseIdx)) {
|
||||||
F[pu.phase_pos[Water]] = primary_variables_[WFrac];
|
F[pu.phase_pos[Oil]] = 1.0;
|
||||||
F[pu.phase_pos[Oil]] -= F[pu.phase_pos[Water]];
|
|
||||||
|
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
||||||
|
F[pu.phase_pos[Water]] = primary_variables_[WFrac];
|
||||||
|
F[pu.phase_pos[Oil]] -= F[pu.phase_pos[Water]];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
||||||
|
F[pu.phase_pos[Gas]] = primary_variables_[GFrac];
|
||||||
|
F[pu.phase_pos[Oil]] -= F[pu.phase_pos[Gas]];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
else if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
||||||
|
F[pu.phase_pos[Water]] = 1.0;
|
||||||
|
|
||||||
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
||||||
F[pu.phase_pos[Gas]] = primary_variables_[GFrac];
|
F[pu.phase_pos[Gas]] = primary_variables_[GFrac];
|
||||||
F[pu.phase_pos[Oil]] -= F[pu.phase_pos[Gas]];
|
F[pu.phase_pos[Water]] -= F[pu.phase_pos[Gas]];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
||||||
|
F[pu.phase_pos[Gas]] = 1.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
double F_solvent = 0.0;
|
double F_solvent = 0.0;
|
||||||
@ -1067,7 +1097,9 @@ namespace Opm
|
|||||||
if (has_solvent) {
|
if (has_solvent) {
|
||||||
F_solvent /= (1.0 - F[pu.phase_pos[Water]]);
|
F_solvent /= (1.0 - F[pu.phase_pos[Water]]);
|
||||||
}
|
}
|
||||||
F[pu.phase_pos[Oil]] /= (1.0 - F[pu.phase_pos[Water]]);
|
if (FluidSystem::phaseIsActive(FluidSystem::oilPhaseIdx)) {
|
||||||
|
F[pu.phase_pos[Oil]] /= (1.0 - F[pu.phase_pos[Water]]);
|
||||||
|
}
|
||||||
F[pu.phase_pos[Water]] = 0.0;
|
F[pu.phase_pos[Water]] = 0.0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1080,22 +1112,26 @@ namespace Opm
|
|||||||
if (has_solvent) {
|
if (has_solvent) {
|
||||||
F_solvent /= (1.0 - F[pu.phase_pos[Gas]]);
|
F_solvent /= (1.0 - F[pu.phase_pos[Gas]]);
|
||||||
}
|
}
|
||||||
F[pu.phase_pos[Oil]] /= (1.0 - F[pu.phase_pos[Gas]]);
|
if (FluidSystem::phaseIsActive(FluidSystem::oilPhaseIdx)) {
|
||||||
|
F[pu.phase_pos[Oil]] /= (1.0 - F[pu.phase_pos[Gas]]);
|
||||||
|
}
|
||||||
F[pu.phase_pos[Gas]] = 0.0;
|
F[pu.phase_pos[Gas]] = 0.0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (F[pu.phase_pos[Oil]] < 0.0) {
|
if (FluidSystem::phaseIsActive(FluidSystem::oilPhaseIdx)) {
|
||||||
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
if (F[pu.phase_pos[Oil]] < 0.0) {
|
||||||
F[pu.phase_pos[Water]] /= (1.0 - F[pu.phase_pos[Oil]]);
|
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
||||||
|
F[pu.phase_pos[Water]] /= (1.0 - F[pu.phase_pos[Oil]]);
|
||||||
|
}
|
||||||
|
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
||||||
|
F[pu.phase_pos[Gas]] /= (1.0 - F[pu.phase_pos[Oil]]);
|
||||||
|
}
|
||||||
|
if (has_solvent) {
|
||||||
|
F_solvent /= (1.0 - F[pu.phase_pos[Oil]]);
|
||||||
|
}
|
||||||
|
F[pu.phase_pos[Oil]] = 0.0;
|
||||||
}
|
}
|
||||||
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
|
||||||
F[pu.phase_pos[Gas]] /= (1.0 - F[pu.phase_pos[Oil]]);
|
|
||||||
}
|
|
||||||
if (has_solvent) {
|
|
||||||
F_solvent /= (1.0 - F[pu.phase_pos[Oil]]);
|
|
||||||
}
|
|
||||||
F[pu.phase_pos[Oil]] = 0.0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
||||||
@ -1119,29 +1155,44 @@ namespace Opm
|
|||||||
updateWellStateFromPrimaryVariables(WellState& well_state, Opm::DeferredLogger& deferred_logger) const
|
updateWellStateFromPrimaryVariables(WellState& well_state, Opm::DeferredLogger& deferred_logger) const
|
||||||
{
|
{
|
||||||
const PhaseUsage& pu = phaseUsage();
|
const PhaseUsage& pu = phaseUsage();
|
||||||
assert( FluidSystem::phaseIsActive(FluidSystem::oilPhaseIdx) );
|
|
||||||
const int oil_pos = pu.phase_pos[Oil];
|
|
||||||
|
|
||||||
std::vector<double> F(number_of_phases_, 0.0);
|
std::vector<double> F(number_of_phases_, 0.0);
|
||||||
F[oil_pos] = 1.0;
|
|
||||||
|
|
||||||
if ( FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx) ) {
|
|
||||||
const int water_pos = pu.phase_pos[Water];
|
|
||||||
F[water_pos] = primary_variables_[WFrac];
|
|
||||||
F[oil_pos] -= F[water_pos];
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx) ) {
|
|
||||||
const int gas_pos = pu.phase_pos[Gas];
|
|
||||||
F[gas_pos] = primary_variables_[GFrac];
|
|
||||||
F[oil_pos] -= F[gas_pos];
|
|
||||||
}
|
|
||||||
|
|
||||||
double F_solvent = 0.0;
|
double F_solvent = 0.0;
|
||||||
if (has_solvent) {
|
if ( FluidSystem::phaseIsActive(FluidSystem::oilPhaseIdx) ) {
|
||||||
F_solvent = primary_variables_[SFrac];
|
const int oil_pos = pu.phase_pos[Oil];
|
||||||
F[oil_pos] -= F_solvent;
|
F[oil_pos] = 1.0;
|
||||||
|
|
||||||
|
if ( FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx) ) {
|
||||||
|
const int water_pos = pu.phase_pos[Water];
|
||||||
|
F[water_pos] = primary_variables_[WFrac];
|
||||||
|
F[oil_pos] -= F[water_pos];
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx) ) {
|
||||||
|
const int gas_pos = pu.phase_pos[Gas];
|
||||||
|
F[gas_pos] = primary_variables_[GFrac];
|
||||||
|
F[oil_pos] -= F[gas_pos];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (has_solvent) {
|
||||||
|
F_solvent = primary_variables_[SFrac];
|
||||||
|
F[oil_pos] -= F_solvent;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
else if ( FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx) ) {
|
||||||
|
const int water_pos = pu.phase_pos[Water];
|
||||||
|
F[water_pos] = 1.0;
|
||||||
|
|
||||||
|
if ( FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx) ) {
|
||||||
|
const int gas_pos = pu.phase_pos[Gas];
|
||||||
|
F[gas_pos] = primary_variables_[GFrac];
|
||||||
|
F[water_pos] -= F[gas_pos];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if ( FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx) ) {
|
||||||
|
const int gas_pos = pu.phase_pos[Gas];
|
||||||
|
F[gas_pos] = 1.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// convert the fractions to be Q_p / G_total to calculate the phase rates
|
// convert the fractions to be Q_p / G_total to calculate the phase rates
|
||||||
for (int p = 0; p < number_of_phases_; ++p) {
|
for (int p = 0; p < number_of_phases_; ++p) {
|
||||||
|
Loading…
Reference in New Issue
Block a user