mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-01-20 01:32:57 -06:00
Merge pull request #2782 from totto82/fixOilWater
Fix oil water for MSW
This commit is contained in:
commit
79f2908277
@ -725,6 +725,13 @@ add_test_compareECLFiles(CASENAME model4_udq_group
|
||||
REL_TOL ${rel_tol}
|
||||
DIR model4)
|
||||
|
||||
add_test_compareECLFiles(CASENAME model6_msw
|
||||
FILENAME 1_MSW_MODEL6
|
||||
SIMULATOR flow
|
||||
ABS_TOL ${abs_tol}
|
||||
REL_TOL ${rel_tol}
|
||||
DIR model6)
|
||||
|
||||
add_test_compareECLFiles(CASENAME wsegsicd
|
||||
FILENAME TEST_WSEGSICD
|
||||
SIMULATOR flow
|
||||
|
@ -336,9 +336,14 @@ public:
|
||||
const size_t k = size_t(connection.getK());
|
||||
const size_t index = simulator_.vanguard().eclState().gridDims().getGlobalIndex(i, j, k);
|
||||
|
||||
oilConnectionPressures_.emplace(std::make_pair(index, 0.0));
|
||||
waterConnectionSaturations_.emplace(std::make_pair(index, 0.0));
|
||||
gasConnectionSaturations_.emplace(std::make_pair(index, 0.0));
|
||||
if (FluidSystem::phaseIsActive(oilPhaseIdx))
|
||||
oilConnectionPressures_.emplace(std::make_pair(index, 0.0));
|
||||
|
||||
if (FluidSystem::phaseIsActive(waterPhaseIdx))
|
||||
waterConnectionSaturations_.emplace(std::make_pair(index, 0.0));
|
||||
|
||||
if (FluidSystem::phaseIsActive(gasPhaseIdx))
|
||||
gasConnectionSaturations_.emplace(std::make_pair(index, 0.0));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -59,16 +59,15 @@ namespace Opm
|
||||
// TODO: we need to have order for the primary variables and also the order for the well equations.
|
||||
// sometimes, they are similar, while sometimes, they can have very different forms.
|
||||
|
||||
// TODO: the following system looks not rather flexible. Looking into all kinds of possibilities
|
||||
// TODO: gas is always there? how about oil water case?
|
||||
// Is it gas oil two phase case?
|
||||
static const bool gasoil = numEq == 2 && (Indices::compositionSwitchIdx >= 0);
|
||||
static const int GTotal = 0;
|
||||
static const int WFrac = gasoil? -1000: 1;
|
||||
static const int GFrac = gasoil? 1 : 2;
|
||||
static const int SPres = gasoil? 2 : 3;
|
||||
static const bool has_gas = (Indices::compositionSwitchIdx >= 0);
|
||||
static const bool has_water = (Indices::waterSaturationIdx >= 0);
|
||||
|
||||
/// the number of well equations // TODO: it should have a more general strategy for it
|
||||
static const int GTotal = 0;
|
||||
static const int WFrac = has_water? 1: -1000;
|
||||
static const int GFrac = has_gas? has_water + 1 : -1000;
|
||||
static const int SPres = has_gas + has_water + 1;
|
||||
|
||||
// the number of well equations TODO: it should have a more general strategy for it
|
||||
static const int numWellEq = getPropValue<TypeTag, Properties::EnablePolymer>() ? numEq : numEq + 1;
|
||||
|
||||
using typename Base::Scalar;
|
||||
|
@ -2069,8 +2069,12 @@ namespace Opm
|
||||
const int seg_upwind = upwinding_segments_[seg];
|
||||
duneD_[seg][seg][SPres][SPres] += pressure_equation.derivative(SPres + numEq);
|
||||
duneD_[seg][seg][SPres][GTotal] += pressure_equation.derivative(GTotal + numEq);
|
||||
duneD_[seg][seg_upwind][SPres][WFrac] += pressure_equation.derivative(WFrac + numEq);
|
||||
duneD_[seg][seg_upwind][SPres][GFrac] += pressure_equation.derivative(GFrac + numEq);
|
||||
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
||||
duneD_[seg][seg_upwind][SPres][WFrac] += pressure_equation.derivative(WFrac + numEq);
|
||||
}
|
||||
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
||||
duneD_[seg][seg_upwind][SPres][GFrac] += pressure_equation.derivative(GFrac + numEq);
|
||||
}
|
||||
|
||||
// contribution from the outlet segment
|
||||
const int outlet_segment_index = segmentNumberToIndex(segmentSet()[seg].outletSegment());
|
||||
@ -2176,8 +2180,12 @@ namespace Opm
|
||||
resWell_[seg][SPres] -= accelerationPressureLoss.value();
|
||||
duneD_[seg][seg][SPres][SPres] -= accelerationPressureLoss.derivative(SPres + numEq);
|
||||
duneD_[seg][seg][SPres][GTotal] -= accelerationPressureLoss.derivative(GTotal + numEq);
|
||||
duneD_[seg][seg_upwind][SPres][WFrac] -= accelerationPressureLoss.derivative(WFrac + numEq);
|
||||
duneD_[seg][seg_upwind][SPres][GFrac] -= accelerationPressureLoss.derivative(GFrac + numEq);
|
||||
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
||||
duneD_[seg][seg_upwind][SPres][WFrac] -= accelerationPressureLoss.derivative(WFrac + numEq);
|
||||
}
|
||||
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
||||
duneD_[seg][seg_upwind][SPres][GFrac] -= accelerationPressureLoss.derivative(GFrac + numEq);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -2555,8 +2563,12 @@ namespace Opm
|
||||
// and WFrac and GFrac in seg_upwind
|
||||
resWell_[seg][comp_idx] -= segment_rate.value();
|
||||
duneD_[seg][seg][comp_idx][GTotal] -= segment_rate.derivative(GTotal + numEq);
|
||||
duneD_[seg][seg_upwind][comp_idx][WFrac] -= segment_rate.derivative(WFrac + numEq);
|
||||
duneD_[seg][seg_upwind][comp_idx][GFrac] -= segment_rate.derivative(GFrac + numEq);
|
||||
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
||||
duneD_[seg][seg_upwind][comp_idx][WFrac] -= segment_rate.derivative(WFrac + numEq);
|
||||
}
|
||||
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
||||
duneD_[seg][seg_upwind][comp_idx][GFrac] -= segment_rate.derivative(GFrac + numEq);
|
||||
}
|
||||
// pressure derivative should be zero
|
||||
}
|
||||
}
|
||||
@ -2572,8 +2584,12 @@ namespace Opm
|
||||
// and WFrac and GFrac in inlet_upwind
|
||||
resWell_[seg][comp_idx] += inlet_rate.value();
|
||||
duneD_[seg][inlet][comp_idx][GTotal] += inlet_rate.derivative(GTotal + numEq);
|
||||
duneD_[seg][inlet_upwind][comp_idx][WFrac] += inlet_rate.derivative(WFrac + numEq);
|
||||
duneD_[seg][inlet_upwind][comp_idx][GFrac] += inlet_rate.derivative(GFrac + numEq);
|
||||
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
||||
duneD_[seg][inlet_upwind][comp_idx][WFrac] += inlet_rate.derivative(WFrac + numEq);
|
||||
}
|
||||
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
||||
duneD_[seg][inlet_upwind][comp_idx][GFrac] += inlet_rate.derivative(GFrac + numEq);
|
||||
}
|
||||
// pressure derivative should be zero
|
||||
}
|
||||
}
|
||||
@ -3194,8 +3210,12 @@ namespace Opm
|
||||
resWell_[seg][SPres] = pressure_equation.value();
|
||||
duneD_[seg][seg][SPres][SPres] += pressure_equation.derivative(SPres + numEq);
|
||||
duneD_[seg][seg][SPres][GTotal] += pressure_equation.derivative(GTotal + numEq);
|
||||
duneD_[seg][seg_upwind][SPres][WFrac] += pressure_equation.derivative(WFrac + numEq);
|
||||
duneD_[seg][seg_upwind][SPres][GFrac] += pressure_equation.derivative(GFrac + numEq);
|
||||
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
||||
duneD_[seg][seg_upwind][SPres][WFrac] += pressure_equation.derivative(WFrac + numEq);
|
||||
}
|
||||
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
||||
duneD_[seg][seg_upwind][SPres][GFrac] += pressure_equation.derivative(GFrac + numEq);
|
||||
}
|
||||
|
||||
// contribution from the outlet segment
|
||||
const int outlet_segment_index = segmentNumberToIndex(segmentSet()[seg].outletSegment());
|
||||
@ -3236,8 +3256,12 @@ namespace Opm
|
||||
resWell_[seg][SPres] = pressure_equation.value();
|
||||
duneD_[seg][seg][SPres][SPres] += pressure_equation.derivative(SPres + numEq);
|
||||
duneD_[seg][seg][SPres][GTotal] += pressure_equation.derivative(GTotal + numEq);
|
||||
duneD_[seg][seg_upwind][SPres][WFrac] += pressure_equation.derivative(WFrac + numEq);
|
||||
duneD_[seg][seg_upwind][SPres][GFrac] += pressure_equation.derivative(GFrac + numEq);
|
||||
if (FluidSystem::phaseIsActive(FluidSystem::waterPhaseIdx)) {
|
||||
duneD_[seg][seg_upwind][SPres][WFrac] += pressure_equation.derivative(WFrac + numEq);
|
||||
}
|
||||
if (FluidSystem::phaseIsActive(FluidSystem::gasPhaseIdx)) {
|
||||
duneD_[seg][seg_upwind][SPres][GFrac] += pressure_equation.derivative(GFrac + numEq);
|
||||
}
|
||||
|
||||
// contribution from the outlet segment
|
||||
const int outlet_segment_index = segmentNumberToIndex(segmentSet()[seg].outletSegment());
|
||||
|
@ -132,6 +132,7 @@ tests[wsegsicd]="flow wsegsicd TEST_WSEGSICD"
|
||||
tests[bc_lab]="flow bc_lab BC_LAB"
|
||||
tests[pinch_multz_all]="flow pinch PINCH_MULTZ_ALL pinch_multz_all"
|
||||
tests[pinch_multz_all_barrier]="flow pinch PINCH_MULTZ_ALL_BARRIER pinch_multz_all_barrier"
|
||||
tests[model6_msw]="flow model6 1_MSW_MODEL6 model6_msw"
|
||||
|
||||
changed_tests=""
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user