mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-01-16 15:21:56 -06:00
Merge pull request #5215 from vkip/nextstep_without_tuning
Ensure NEXTSTEP is respected also without --enable-tuning=true
This commit is contained in:
commit
4d40197406
@ -473,7 +473,7 @@ beginEpisode_(bool enableExperiments,
|
|||||||
{
|
{
|
||||||
const auto& sched_state = schedule_[episodeIdx];
|
const auto& sched_state = schedule_[episodeIdx];
|
||||||
const auto& tuning = sched_state.tuning();
|
const auto& tuning = sched_state.tuning();
|
||||||
initialTimeStepSize_ = sched_state.max_next_tstep();
|
initialTimeStepSize_ = sched_state.max_next_tstep(enableTuning_);
|
||||||
maxTimeStepAfterWellEvent_ = tuning.TMAXWC;
|
maxTimeStepAfterWellEvent_ = tuning.TMAXWC;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -286,15 +286,15 @@ public:
|
|||||||
bool enableTUNING = EWOMS_GET_PARAM(TypeTag, bool, EnableTuning);
|
bool enableTUNING = EWOMS_GET_PARAM(TypeTag, bool, EnableTuning);
|
||||||
if (enableAdaptive) {
|
if (enableAdaptive) {
|
||||||
const UnitSystem& unitSystem = this->ebosSimulator_.vanguard().eclState().getUnits();
|
const UnitSystem& unitSystem = this->ebosSimulator_.vanguard().eclState().getUnits();
|
||||||
if (enableTUNING) {
|
|
||||||
const auto& sched_state = schedule()[timer.currentStepNum()];
|
const auto& sched_state = schedule()[timer.currentStepNum()];
|
||||||
auto max_next_tstep = sched_state.max_next_tstep();
|
auto max_next_tstep = sched_state.max_next_tstep(enableTUNING);
|
||||||
|
if (enableTUNING) {
|
||||||
adaptiveTimeStepping_ = std::make_unique<TimeStepper>(max_next_tstep,
|
adaptiveTimeStepping_ = std::make_unique<TimeStepper>(max_next_tstep,
|
||||||
sched_state.tuning(),
|
sched_state.tuning(),
|
||||||
unitSystem, terminalOutput_);
|
unitSystem, terminalOutput_);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
adaptiveTimeStepping_ = std::make_unique<TimeStepper>(unitSystem, terminalOutput_);
|
adaptiveTimeStepping_ = std::make_unique<TimeStepper>(unitSystem, max_next_tstep, terminalOutput_);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isRestart()) {
|
if (isRestart()) {
|
||||||
@ -379,18 +379,21 @@ public:
|
|||||||
// \Note: The sub stepping will require a copy of the state variables
|
// \Note: The sub stepping will require a copy of the state variables
|
||||||
if (adaptiveTimeStepping_) {
|
if (adaptiveTimeStepping_) {
|
||||||
const auto& events = schedule()[timer.currentStepNum()].events();
|
const auto& events = schedule()[timer.currentStepNum()].events();
|
||||||
if (enableTUNING) {
|
|
||||||
if (events.hasEvent(ScheduleEvents::TUNING_CHANGE)) {
|
if (events.hasEvent(ScheduleEvents::TUNING_CHANGE)) {
|
||||||
const auto& sched_state = schedule()[timer.currentStepNum()];
|
const auto& sched_state = schedule()[timer.currentStepNum()];
|
||||||
|
const auto& max_next_tstep = sched_state.max_next_tstep(enableTUNING);
|
||||||
|
if (enableTUNING) {
|
||||||
const auto& tuning = sched_state.tuning();
|
const auto& tuning = sched_state.tuning();
|
||||||
const auto& max_next_tstep = sched_state.max_next_tstep();
|
|
||||||
adaptiveTimeStepping_->updateTUNING(max_next_tstep, tuning);
|
adaptiveTimeStepping_->updateTUNING(max_next_tstep, tuning);
|
||||||
// \Note: Assumes TUNING is only used with adaptive time-stepping
|
// \Note: Assumes TUNING is only used with adaptive time-stepping
|
||||||
// \Note: Need to update both solver (model) and simulator since solver is re-created each report step.
|
// \Note: Need to update both solver (model) and simulator since solver is re-created each report step.
|
||||||
solver_->model().updateTUNING(tuning);
|
solver_->model().updateTUNING(tuning);
|
||||||
this->updateTUNING(tuning);
|
this->updateTUNING(tuning);
|
||||||
|
} else {
|
||||||
|
adaptiveTimeStepping_->updateNEXTSTEP(max_next_tstep);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool event = events.hasEvent(ScheduleEvents::NEW_WELL) ||
|
bool event = events.hasEvent(ScheduleEvents::NEW_WELL) ||
|
||||||
events.hasEvent(ScheduleEvents::INJECTION_TYPE_CHANGED) ||
|
events.hasEvent(ScheduleEvents::INJECTION_TYPE_CHANGED) ||
|
||||||
events.hasEvent(ScheduleEvents::WELL_SWITCHED_INJECTOR_PRODUCER) ||
|
events.hasEvent(ScheduleEvents::WELL_SWITCHED_INJECTOR_PRODUCER) ||
|
||||||
|
@ -249,6 +249,7 @@ std::set<std::string> consistentlyFailingWells(const std::vector<StepReport>& sr
|
|||||||
|
|
||||||
//! \brief contructor taking parameter object
|
//! \brief contructor taking parameter object
|
||||||
AdaptiveTimeStepping(const UnitSystem& unitSystem,
|
AdaptiveTimeStepping(const UnitSystem& unitSystem,
|
||||||
|
const double max_next_tstep = -1.0,
|
||||||
const bool terminalOutput = true)
|
const bool terminalOutput = true)
|
||||||
: timeStepControl_()
|
: timeStepControl_()
|
||||||
, restartFactor_(EWOMS_GET_PARAM(TypeTag, double, SolverRestartFactor)) // 0.33
|
, restartFactor_(EWOMS_GET_PARAM(TypeTag, double, SolverRestartFactor)) // 0.33
|
||||||
@ -260,7 +261,7 @@ std::set<std::string> consistentlyFailingWells(const std::vector<StepReport>& sr
|
|||||||
, solverRestartMax_(EWOMS_GET_PARAM(TypeTag, int, SolverMaxRestarts)) // 10
|
, solverRestartMax_(EWOMS_GET_PARAM(TypeTag, int, SolverMaxRestarts)) // 10
|
||||||
, solverVerbose_(EWOMS_GET_PARAM(TypeTag, int, SolverVerbosity) > 0 && terminalOutput) // 2
|
, solverVerbose_(EWOMS_GET_PARAM(TypeTag, int, SolverVerbosity) > 0 && terminalOutput) // 2
|
||||||
, timestepVerbose_(EWOMS_GET_PARAM(TypeTag, int, TimeStepVerbosity) > 0 && terminalOutput) // 2
|
, timestepVerbose_(EWOMS_GET_PARAM(TypeTag, int, TimeStepVerbosity) > 0 && terminalOutput) // 2
|
||||||
, suggestedNextTimestep_(EWOMS_GET_PARAM(TypeTag, double, InitialTimeStepInDays)*24*60*60) // 1.0
|
, suggestedNextTimestep_((max_next_tstep <= 0 ? EWOMS_GET_PARAM(TypeTag, double, InitialTimeStepInDays) : max_next_tstep)*24*60*60) // 1.0
|
||||||
, fullTimestepInitially_(EWOMS_GET_PARAM(TypeTag, bool, FullTimeStepInitially)) // false
|
, fullTimestepInitially_(EWOMS_GET_PARAM(TypeTag, bool, FullTimeStepInitially)) // false
|
||||||
, timestepAfterEvent_(EWOMS_GET_PARAM(TypeTag, double, TimeStepAfterEventInDays)*24*60*60) // 1e30
|
, timestepAfterEvent_(EWOMS_GET_PARAM(TypeTag, double, TimeStepAfterEventInDays)*24*60*60) // 1e30
|
||||||
, useNewtonIteration_(false)
|
, useNewtonIteration_(false)
|
||||||
@ -289,7 +290,7 @@ std::set<std::string> consistentlyFailingWells(const std::vector<StepReport>& sr
|
|||||||
, solverRestartMax_(EWOMS_GET_PARAM(TypeTag, int, SolverMaxRestarts)) // 10
|
, solverRestartMax_(EWOMS_GET_PARAM(TypeTag, int, SolverMaxRestarts)) // 10
|
||||||
, solverVerbose_(EWOMS_GET_PARAM(TypeTag, int, SolverVerbosity) > 0 && terminalOutput) // 2
|
, solverVerbose_(EWOMS_GET_PARAM(TypeTag, int, SolverVerbosity) > 0 && terminalOutput) // 2
|
||||||
, timestepVerbose_(EWOMS_GET_PARAM(TypeTag, int, TimeStepVerbosity) > 0 && terminalOutput) // 2
|
, timestepVerbose_(EWOMS_GET_PARAM(TypeTag, int, TimeStepVerbosity) > 0 && terminalOutput) // 2
|
||||||
, suggestedNextTimestep_(max_next_tstep <= 0 ? EWOMS_GET_PARAM(TypeTag, double, InitialTimeStepInDays)*86400 : max_next_tstep) // 1.0
|
, suggestedNextTimestep_(max_next_tstep <= 0 ? EWOMS_GET_PARAM(TypeTag, double, InitialTimeStepInDays)*24*60*60 : max_next_tstep) // 1.0
|
||||||
, fullTimestepInitially_(EWOMS_GET_PARAM(TypeTag, bool, FullTimeStepInitially)) // false
|
, fullTimestepInitially_(EWOMS_GET_PARAM(TypeTag, bool, FullTimeStepInitially)) // false
|
||||||
, timestepAfterEvent_(tuning.TMAXWC) // 1e30
|
, timestepAfterEvent_(tuning.TMAXWC) // 1e30
|
||||||
, useNewtonIteration_(false)
|
, useNewtonIteration_(false)
|
||||||
@ -625,11 +626,16 @@ std::set<std::string> consistentlyFailingWells(const std::vector<StepReport>& sr
|
|||||||
growthFactor_ = tuning.TFDIFF;
|
growthFactor_ = tuning.TFDIFF;
|
||||||
maxGrowth_ = tuning.TSFMAX;
|
maxGrowth_ = tuning.TSFMAX;
|
||||||
maxTimeStep_ = tuning.TSMAXZ;
|
maxTimeStep_ = tuning.TSMAXZ;
|
||||||
|
updateNEXTSTEP(max_next_tstep);
|
||||||
|
timestepAfterEvent_ = tuning.TMAXWC;
|
||||||
|
}
|
||||||
|
|
||||||
|
void updateNEXTSTEP(double max_next_tstep)
|
||||||
|
{
|
||||||
// \Note Only update next suggested step if TSINIT was explicitly set in TUNING or NEXTSTEP is active.
|
// \Note Only update next suggested step if TSINIT was explicitly set in TUNING or NEXTSTEP is active.
|
||||||
if (max_next_tstep > 0) {
|
if (max_next_tstep > 0) {
|
||||||
suggestedNextTimestep_ = max_next_tstep;
|
suggestedNextTimestep_ = max_next_tstep;
|
||||||
}
|
}
|
||||||
timestepAfterEvent_ = tuning.TMAXWC;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class Serializer>
|
template<class Serializer>
|
||||||
|
Loading…
Reference in New Issue
Block a user