mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-02-25 18:55:30 -06:00
Merge pull request #5735 from totto82/dontshutGRUPwells
dont shut well with GRUP control that struggles to converge
This commit is contained in:
@@ -426,24 +426,34 @@ void registerAdaptiveParameters();
|
||||
// Found no wells to close, chop the timestep as above.
|
||||
chopTimestep();
|
||||
} else {
|
||||
// Close all consistently failing wells.
|
||||
int num_shut_wells = 0;
|
||||
// Close all consistently failing wells that are not under group control
|
||||
std::vector<std::string> shut_wells;
|
||||
for (const auto& well : failing_wells) {
|
||||
bool was_shut = solver.model().wellModel().forceShutWellByName(well, substepTimer.simulationTimeElapsed());
|
||||
bool was_shut = solver.model().wellModel().forceShutWellByName(
|
||||
well, substepTimer.simulationTimeElapsed(), /*dont_shut_grup_wells =*/ true);
|
||||
if (was_shut) {
|
||||
++num_shut_wells;
|
||||
shut_wells.push_back(well);
|
||||
}
|
||||
}
|
||||
if (num_shut_wells == 0) {
|
||||
// None of the problematic wells were shut.
|
||||
// We must fall back to chopping again.
|
||||
// If no wells are closed we also try to shut wells under group control
|
||||
if (shut_wells.empty()) {
|
||||
for (const auto& well : failing_wells) {
|
||||
bool was_shut = solver.model().wellModel().forceShutWellByName(
|
||||
well, substepTimer.simulationTimeElapsed(), /*dont_shut_grup_wells =*/ false);
|
||||
if (was_shut) {
|
||||
shut_wells.push_back(well);
|
||||
}
|
||||
}
|
||||
}
|
||||
// If still no wells are closed we must fall back to chopping again
|
||||
if (shut_wells.empty()) {
|
||||
chopTimestep();
|
||||
} else {
|
||||
substepTimer.provideTimeStepEstimate(dt);
|
||||
if (solverVerbose_) {
|
||||
std::string msg;
|
||||
msg = "\nProblematic well(s) were shut: ";
|
||||
for (const auto& well : failing_wells) {
|
||||
for (const auto& well : shut_wells) {
|
||||
msg += well;
|
||||
msg += " ";
|
||||
}
|
||||
|
@@ -1318,13 +1318,27 @@ needPreStepNetworkRebalance(const int report_step) const
|
||||
template<class Scalar>
|
||||
bool BlackoilWellModelGeneric<Scalar>::
|
||||
forceShutWellByName(const std::string& wellname,
|
||||
const double simulation_time)
|
||||
const double simulation_time,
|
||||
const bool dont_shut_grup_wells)
|
||||
{
|
||||
// Only add the well to the closed list on the
|
||||
// process that owns it.
|
||||
int well_was_shut = 0;
|
||||
for (const auto& well : well_container_generic_) {
|
||||
if (well->name() == wellname) {
|
||||
// if one well on individuel control (typical thp/bhp) in a group strugles to converge
|
||||
// it may lead to problems for the other wells in the group
|
||||
// we dont want to shut all the wells in a group only the one creating the problems.
|
||||
const auto& ws = this->wellState().well(well->indexOfWell());
|
||||
if (dont_shut_grup_wells) {
|
||||
if (well->isInjector()) {
|
||||
if (ws.injection_cmode == Well::InjectorCMode::GRUP)
|
||||
continue;
|
||||
} else {
|
||||
if (ws.production_cmode == Well::ProducerCMode::GRUP)
|
||||
continue;
|
||||
}
|
||||
}
|
||||
wellTestState().close_well(wellname, WellTestConfig::Reason::PHYSICAL, simulation_time);
|
||||
well_was_shut = 1;
|
||||
break;
|
||||
|
@@ -191,7 +191,8 @@ public:
|
||||
/// Shut down any single well
|
||||
/// Returns true if the well was actually found and shut.
|
||||
bool forceShutWellByName(const std::string& wellname,
|
||||
const double simulation_time);
|
||||
const double simulation_time,
|
||||
const bool dont_shut_grup_wells);
|
||||
|
||||
const std::vector<PerforationData<Scalar>>& perfData(const int well_idx) const
|
||||
{ return well_perf_data_[well_idx]; }
|
||||
|
Reference in New Issue
Block a user