3#ifndef OPM_ADAPTIVE_TIME_STEPPING_HPP
4#define OPM_ADAPTIVE_TIME_STEPPING_HPP
9#include <opm/simulators/timestepping/AdaptiveSimulatorTimer.hpp>
10#include <opm/simulators/timestepping/SimulatorReport.hpp>
11#include <opm/simulators/timestepping/SimulatorTimer.hpp>
12#include <opm/simulators/timestepping/TimeStepControl.hpp>
13#include <opm/simulators/timestepping/TimeStepControlInterface.hpp>
16#define RESERVOIR_COUPLING_ENABLED
18#ifdef RESERVOIR_COUPLING_ENABLED
19#include <opm/simulators/flow/ReservoirCoupling.hpp>
20#include <opm/simulators/flow/ReservoirCouplingMaster.hpp>
21#include <opm/simulators/flow/ReservoirCouplingSlave.hpp>
31namespace Opm::Parameters {
68 consistentlyFailingWells(
const std::vector<StepReport>& sr,
69 bool requireRepeatedFailures);
70 void registerAdaptiveParameters();
72 std::tuple<TimeStepControlType, std::unique_ptr<TimeStepControlInterface>,
bool>
73 createController(
const UnitSystem& unitSystem);
76template<
class TypeTag>
77class AdaptiveTimeStepping
80 using TuningUpdateCallback = std::function<bool(
const double,
const double,
const int)>;
85 template <
class Solver>
89 explicit SolutionTimeErrorSolverWrapper(
const Solver& solver);
93 const Solver& solver_;
97 template <
class Solver>
class SubStepIteration;
99 template <
class Solver>
102 SubStepper(AdaptiveTimeStepping<TypeTag>& adaptive_time_stepping,
106 const TuningUpdateCallback& tuning_updater);
108 AdaptiveTimeStepping<TypeTag>& getAdaptiveTimerStepper();
110 friend class SubStepIteration<Solver>;
113 bool isReservoirCouplingMaster_()
const;
114 bool isReservoirCouplingSlave_()
const;
115 void maybeModifySuggestedTimeStepAtBeginningOfReportStep_(
const double originalTimeStep);
116 bool maybeUpdateTuning_(
double elapsed,
double dt,
int sub_step_number)
const;
117 double maxTimeStep_()
const;
119#ifdef RESERVOIR_COUPLING_ENABLED
125 double suggestedNextTimestep_()
const;
127 AdaptiveTimeStepping<TypeTag>& adaptive_time_stepping_;
130 const bool is_event_;
131 const TuningUpdateCallback& tuning_updater_;
134 template <
class Solver>
135 class SubStepIteration {
137 SubStepIteration(SubStepper<Solver>& substepper,
139 const double original_time_step,
140 const bool final_step);
145 bool checkContinueOnUnconvergedSolution_(
double dt)
const;
146 void checkTimeStepMaxRestartLimit_(
const int restarts)
const;
147 void checkTimeStepMinLimit_(
const double new_time_step)
const;
148 void chopTimeStep_(
const double new_time_step);
149 bool chopTimeStepOrCloseFailingWells_(
const double new_time_step);
150 boost::posix_time::ptime currentDateTime_()
const;
152 double growthFactor_()
const;
153 bool ignoreConvergenceFailure_()
const;
155 double maybeRestrictTimeStepGrowth_(
const double dt,
157 const int restarts)
const;
158 void maybeUpdateTuningAndTimeStep_();
159 double maxGrowth_()
const;
160 double minTimeStepBeforeClosingWells_()
const;
161 double minTimeStep_()
const;
162 double restartFactor_()
const;
164 int solverRestartMax_()
const;
165 double suggestedNextTimestep_()
const;
166 void setSuggestedNextStep_(
double step);
167 void setTimeStep_(
double dt_estimate);
168 Solver& solver_()
const;
169 bool solverVerbose_()
const;
171 boost::posix_time::ptime startDateTime_()
const;
172 double timeStepControlComputeEstimate_(
const double dt,
173 const int iterations,
175 bool timeStepVerbose_()
const;
176 void updateSuggestedNextStep_();
177 bool useNewtonIteration_()
const;
178 double writeOutput_()
const;
180 SubStepper<Solver>& substepper_;
182 const double original_time_step_;
183 const bool final_step_;
184 std::string cause_of_failure_;
185 AdaptiveTimeStepping<TypeTag>& adaptive_time_stepping_;
189 AdaptiveTimeStepping() =
default;
191 AdaptiveTimeStepping(
const UnitSystem& unitSystem,
193 const double max_next_tstep = -1.0,
194 const bool terminalOutput =
true);
196 AdaptiveTimeStepping(
double max_next_tstep,
197 const Tuning& tuning,
198 const UnitSystem& unitSystem,
200 const bool terminalOutput =
true);
202 bool operator==(
const AdaptiveTimeStepping<TypeTag>& rhs);
204 static void registerParameters();
205 void setSuggestedNextStep(
const double x);
206 double suggestedNextStep()
const;
209 template <
class Solver>
213 const TuningUpdateCallback& tuning_updater);
215 void updateTUNING(
double max_next_tstep,
const Tuning& tuning);
216 void updateNEXTSTEP(
double max_next_tstep);
218 template<
class Serializer>
219 void serializeOp(Serializer& serializer);
223 static AdaptiveTimeStepping<TypeTag> serializationTestObjectHardcoded();
224 static AdaptiveTimeStepping<TypeTag> serializationTestObjectPID();
225 static AdaptiveTimeStepping<TypeTag> serializationTestObjectPIDIt();
226 static AdaptiveTimeStepping<TypeTag> serializationTestObjectSimple();
227 static AdaptiveTimeStepping<TypeTag> serializationTestObject3rdOrder();
230 void maybeModifySuggestedTimeStepAtBeginningOfReportStep_(
const double original_time_step,
231 const bool is_event);
233 template<
class Controller>
234 static AdaptiveTimeStepping<TypeTag> serializationTestObject_();
236 template<
class T,
class Serializer>
237 void allocAndSerialize(Serializer& serializer);
240 bool castAndComp(
const AdaptiveTimeStepping<TypeTag>& Rhs)
const;
243 void init_(
const UnitSystem& unitSystem);
245 using TimeStepController = std::unique_ptr<TimeStepControlInterface>;
274#include <opm/simulators/timestepping/AdaptiveTimeStepping_impl.hpp>
Defines a type tags and some fundamental properties all models.
Simulation timer for adaptive time stepping.
Definition AdaptiveSimulatorTimer.hpp:41
double max_growth_
factor that limits the maximum growth of a time step
Definition AdaptiveTimeStepping.hpp:252
double max_time_step_
maximal allowed time step size in days
Definition AdaptiveTimeStepping.hpp:253
bool solver_verbose_
solver verbosity
Definition AdaptiveTimeStepping.hpp:257
int solver_restart_max_
how many restart of solver are allowed
Definition AdaptiveTimeStepping.hpp:256
double timestep_after_event_
suggested size of timestep after an event
Definition AdaptiveTimeStepping.hpp:261
bool ignore_convergence_failure_
continue instead of stop when minimum time step is reached
Definition AdaptiveTimeStepping.hpp:255
double suggested_next_timestep_
suggested size of next timestep
Definition AdaptiveTimeStepping.hpp:259
TimeStepControlType time_step_control_type_
type of time step control object
Definition AdaptiveTimeStepping.hpp:248
bool full_timestep_initially_
beginning with the size of the time step from data file
Definition AdaptiveTimeStepping.hpp:260
SimulatorReport step(const SimulatorTimer &simulator_timer, Solver &solver, const bool is_event, const TuningUpdateCallback &tuning_updater)
step method that acts like the solver::step method in a sub cycle of time steps
Definition AdaptiveTimeStepping_impl.hpp:202
double growth_factor_
factor to multiply time step when solver recovered from failed convergence
Definition AdaptiveTimeStepping.hpp:251
double restart_factor_
factor to multiply time step with when solver fails to converge
Definition AdaptiveTimeStepping.hpp:250
double min_time_step_
minimal allowed time step size before throwing
Definition AdaptiveTimeStepping.hpp:254
TimeStepController time_step_control_
time step control object
Definition AdaptiveTimeStepping.hpp:249
double min_time_step_before_shutting_problematic_wells_
< shut problematic wells when time step size in days are less than this
Definition AdaptiveTimeStepping.hpp:265
bool timestep_verbose_
timestep verbosity
Definition AdaptiveTimeStepping.hpp:258
bool use_newton_iteration_
use newton iteration count for adaptive time step control
Definition AdaptiveTimeStepping.hpp:262
RelativeChangeInterface.
Definition TimeStepControlInterface.hpp:34
virtual double relativeChange() const =0
Definition ReservoirCouplingMaster.hpp:35
Definition ReservoirCouplingSlave.hpp:35
Definition SimulatorTimer.hpp:39
TimeStepControlInterface.
Definition TimeStepControlInterface.hpp:51
This file contains a set of helper functions used by VFPProd / VFPInj.
Definition blackoilbioeffectsmodules.hh:43
typename Properties::Detail::GetPropImpl< TypeTag, Property >::type::type GetPropType
get the type alias defined in the property (equivalent to old macro GET_PROP_TYPE(....
Definition propertysystem.hh:233
The Opm property system, traits with inheritance.
Definition AdaptiveTimeStepping.hpp:38
Definition AdaptiveTimeStepping.hpp:37
Definition AdaptiveTimeStepping.hpp:49
Definition AdaptiveTimeStepping.hpp:48
Definition AdaptiveTimeStepping.hpp:33
Definition AdaptiveTimeStepping.hpp:34
Definition AdaptiveTimeStepping.hpp:35
Definition AdaptiveTimeStepping.hpp:45
Definition AdaptiveTimeStepping.hpp:43
Definition AdaptiveTimeStepping.hpp:47
Definition AdaptiveTimeStepping.hpp:46
Definition AdaptiveTimeStepping.hpp:44
Definition AdaptiveTimeStepping.hpp:53
Definition AdaptiveTimeStepping.hpp:54
Definition AdaptiveTimeStepping.hpp:51
Definition AdaptiveTimeStepping.hpp:50
Definition AdaptiveTimeStepping.hpp:41
Definition AdaptiveTimeStepping.hpp:42
Definition AdaptiveTimeStepping.hpp:52
Definition AdaptiveTimeStepping.hpp:40
Definition AdaptiveTimeStepping.hpp:39
Definition AdaptiveTimeStepping.hpp:36
A struct for returning timing data from a simulator to its caller.
Definition SimulatorReport.hpp:34
Definition SimulatorReport.hpp:122
Definition ConvergenceReport.hpp:460