mirror of
				https://github.com/OPM/opm-simulators.git
				synced 2025-02-25 18:55:30 -06:00 
			
		
		
		
	changed: pass fipnum array into adaptive time stepping loop
needed as substep summary reports requires FIP data to be available. add calculation of this data if output is requested and summary config holds relevant keywords.
This commit is contained in:
		| @@ -72,6 +72,7 @@ namespace Opm { | |||||||
|                     in a sub cycle of time steps |                     in a sub cycle of time steps | ||||||
|  |  | ||||||
|             \param  timer        simulator timer providing time and timestep |             \param  timer        simulator timer providing time and timestep | ||||||
|  |             \param  fipnum       Fluid-in-place numbering array | ||||||
|             \param  solver       solver object that must implement a method step( dt, state, well_state ) |             \param  solver       solver object that must implement a method step( dt, state, well_state ) | ||||||
|             \param  state        current state of the solution variables |             \param  state        current state of the solution variables | ||||||
|             \param  well_state   additional well state object |             \param  well_state   additional well state object | ||||||
| @@ -80,13 +81,15 @@ namespace Opm { | |||||||
|         template <class Solver, class State, class WellState, class Output> |         template <class Solver, class State, class WellState, class Output> | ||||||
|         SimulatorReport step( const SimulatorTimer& timer, |         SimulatorReport step( const SimulatorTimer& timer, | ||||||
|                               Solver& solver, State& state, WellState& well_state, |                               Solver& solver, State& state, WellState& well_state, | ||||||
|                               Output& outputWriter ); |                               Output& outputWriter, | ||||||
|  |                               const std::vector<int>* fipnum = nullptr); | ||||||
|  |  | ||||||
|     protected: |     protected: | ||||||
|         template <class Solver, class State, class WellState, class Output> |         template <class Solver, class State, class WellState, class Output> | ||||||
|         SimulatorReport stepImpl( const SimulatorTimer& timer, |         SimulatorReport stepImpl( const SimulatorTimer& timer, | ||||||
|                                   Solver& solver, State& state, WellState& well_state, |                                   Solver& solver, State& state, WellState& well_state, | ||||||
|                                   Output* outputWriter); |                                   Output* outputWriter, | ||||||
|  |                                   const std::vector<int>* fipnum); | ||||||
|  |  | ||||||
|         void init(const parameter::ParameterGroup& param); |         void init(const parameter::ParameterGroup& param); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -152,15 +152,17 @@ namespace Opm { | |||||||
|     SimulatorReport AdaptiveTimeStepping:: |     SimulatorReport AdaptiveTimeStepping:: | ||||||
|     step( const SimulatorTimer& simulatorTimer, Solver& solver, State& state, WellState& well_state ) |     step( const SimulatorTimer& simulatorTimer, Solver& solver, State& state, WellState& well_state ) | ||||||
|     { |     { | ||||||
|         return stepImpl( simulatorTimer, solver, state, well_state ); |         return stepImpl( simulatorTimer, solver, state, well_state,  nullptr, nullptr ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     template <class Solver, class State, class WellState, class Output> |     template <class Solver, class State, class WellState, class Output> | ||||||
|     SimulatorReport AdaptiveTimeStepping:: |     SimulatorReport AdaptiveTimeStepping:: | ||||||
|     step( const SimulatorTimer& simulatorTimer, Solver& solver, State& state, WellState& well_state, |     step( const SimulatorTimer& simulatorTimer, | ||||||
|           Output& outputWriter ) |           Solver& solver, State& state, WellState& well_state, | ||||||
|  |           Output& outputWriter, | ||||||
|  |           const std::vector<int>* fipnum) | ||||||
|     { |     { | ||||||
|         return stepImpl( simulatorTimer, solver, state, well_state, &outputWriter ); |         return stepImpl( simulatorTimer, solver, state, well_state, &outputWriter, fipnum ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -169,7 +171,8 @@ namespace Opm { | |||||||
|     SimulatorReport AdaptiveTimeStepping:: |     SimulatorReport AdaptiveTimeStepping:: | ||||||
|     stepImpl( const SimulatorTimer& simulatorTimer, |     stepImpl( const SimulatorTimer& simulatorTimer, | ||||||
|               Solver& solver, State& state, WState& well_state, |               Solver& solver, State& state, WState& well_state, | ||||||
|               Output* outputWriter ) |               Output* outputWriter, | ||||||
|  |               const std::vector<int>* fipnum) | ||||||
|     { |     { | ||||||
|         SimulatorReport report; |         SimulatorReport report; | ||||||
|         const double timestep = simulatorTimer.currentStepLength(); |         const double timestep = simulatorTimer.currentStepLength(); | ||||||
| @@ -279,6 +282,9 @@ namespace Opm { | |||||||
|                 // to write it as this will be done by the simulator |                 // to write it as this will be done by the simulator | ||||||
|                 // anyway. |                 // anyway. | ||||||
|                 if( outputWriter && !substepTimer.done() ) { |                 if( outputWriter && !substepTimer.done() ) { | ||||||
|  |                     if (fipnum) { | ||||||
|  |                         solver.computeFluidInPlace(state, *fipnum); | ||||||
|  |                     } | ||||||
|                     Opm::time::StopWatch perfTimer; |                     Opm::time::StopWatch perfTimer; | ||||||
|                     perfTimer.start(); |                     perfTimer.start(); | ||||||
|                     bool substep = true; |                     bool substep = true; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user