9 #ifndef Tempus_StepperSubcycling_impl_hpp
10 #define Tempus_StepperSubcycling_impl_hpp
15 #include "Tempus_IntegratorObserverSubcycling.hpp"
17 #include "Teuchos_VerboseObjectParameterListHelpers.hpp"
18 #include "Thyra_VectorStdOps.hpp"
24 template<
class Scalar>
28 using Teuchos::ParameterList;
30 this->setStepperType(
"Subcycling");
31 this->setUseFSAL( this->getUseFSALDefault());
32 this->setICConsistency( this->getICConsistencyDefault());
33 this->setICConsistencyCheck( this->getICConsistencyCheckDefault());
37 scIntegrator_->setTimeStepControl();
38 scIntegrator_->setObserver(
41 RCP<ParameterList> tempusPL = scIntegrator_->getTempusParameterList();
44 tempusPL->sublist(
"Default Integrator")
45 .set(
"Stepper Name",
"Default Subcycling Stepper");
46 RCP<ParameterList> stepperPL = Teuchos::parameterList();
47 stepperPL->set(
"Stepper Type",
"Forward Euler");
48 tempusPL->set(
"Default Subcycling Stepper", *stepperPL);
51 auto stepperFE = sf->createStepperForwardEuler(Teuchos::null,Teuchos::null);
52 setSubcyclingStepper(stepperFE);
68 tempusPL->sublist(
"Default Integrator")
69 .sublist(
"Time Step Control")
70 .set(
"Initial Time Step", std::numeric_limits<Scalar>::max());
75 template<
class Scalar>
77 const Teuchos::RCP<
const Thyra::ModelEvaluator<Scalar> >& appModel,
81 std::string ICConsistency,
82 bool ICConsistencyCheck)
84 this->setStepperType(
"Subcycling");
85 this->setUseFSAL( useFSAL);
86 this->setICConsistency( ICConsistency);
87 this->setICConsistencyCheck( ICConsistencyCheck);
89 this->setObserver(obs);
90 scIntegrator_ = scIntegrator;
92 if (appModel != Teuchos::null) {
93 this->setModel(appModel);
99 template<
class Scalar>
103 scIntegrator_->setStepperWStepper(stepper);
104 this->isInitialized_ =
false;
108 template<
class Scalar>
111 scIntegrator_->getNonConstTimeStepControl()->setMinTimeStep(MinTimeStep);
112 this->isInitialized_ =
false;
116 template<
class Scalar>
119 scIntegrator_->getNonConstTimeStepControl()->setInitTimeStep(InitTimeStep);
120 this->isInitialized_ =
false;
124 template<
class Scalar>
127 scIntegrator_->getNonConstTimeStepControl()->setMaxTimeStep(MaxTimeStep);
128 this->isInitialized_ =
false;
132 template<
class Scalar>
135 scIntegrator_->getNonConstTimeStepControl()->setStepType(stepType);
137 auto tsc = scIntegrator_->getNonConstTimeStepControl();
138 auto tscStrategy = tsc->getTimeStepControlStrategy();
139 tscStrategy->clearObservers();
141 Teuchos::RCP<TimeStepControlStrategy<Scalar> > strategy =
143 if (stepType ==
"Variable")
146 tscStrategy->addStrategy(strategy);
148 this->isInitialized_ =
false;
152 template<
class Scalar>
155 scIntegrator_->getNonConstTimeStepControl()->setMaxFailures(MaxFailures);
156 this->isInitialized_ =
false;
160 template<
class Scalar>
164 scIntegrator_->getNonConstTimeStepControl()->setMaxConsecFailures(MaxConsecFailures);
165 this->isInitialized_ =
false;
169 template<
class Scalar>
173 scIntegrator_->setScreenOutputIndexInterval(i);
174 this->isInitialized_ =
false;
178 template<
class Scalar>
183 scIntegrator_->getNonConstTimeStepControl()->getTimeStepControlStrategy()->clearObservers();
184 scIntegrator_->getNonConstTimeStepControl()->setTimeStepControlStrategy(tscs);
185 this->isInitialized_ =
false;
189 template<
class Scalar>
191 const Teuchos::RCP<
const Thyra::ModelEvaluator<Scalar> >& appModel)
193 scIntegrator_->setStepper(appModel);
194 this->isInitialized_ =
false;
198 template<
class Scalar>
200 const Teuchos::RCP<Thyra::ModelEvaluator<Scalar> >& appModel)
203 this->isInitialized_ =
false;
207 template<
class Scalar>
211 if (obs != Teuchos::null) stepperSCObserver_ =
214 if (stepperSCObserver_ == Teuchos::null)
217 this->isInitialized_ =
false;
221 template<
class Scalar>
222 Teuchos::RCP<StepperObserver<Scalar> >
224 {
return stepperSCObserver_; }
227 template<
class Scalar>
230 Teuchos::RCP<Teuchos::FancyOStream> out = this->getOStream();
231 bool isValidSetup =
true;
233 if ( !(this->getICConsistency() ==
"None" ||
234 this->getICConsistency() ==
"Zero" ||
235 this->getICConsistency() ==
"App" ||
236 this->getICConsistency() ==
"Consistent") ) {
237 isValidSetup =
false;
238 Teuchos::RCP<Teuchos::FancyOStream> out = this->getOStream();
239 *out <<
"The IC consistency does not have a valid value!\n"
240 <<
"('None', 'Zero', 'App' or 'Consistent')\n"
241 <<
" ICConsistency = " << this->getICConsistency() <<
"\n";
243 scIntegrator_->initialize();
246 if (stepperSCObserver_ == Teuchos::null) {
247 isValidSetup =
false;
248 *out <<
"The Subcycling observer is not set!\n";
252 this->isInitialized_ =
true;
254 this->describe(*out, Teuchos::VERB_MEDIUM);
258 template<
class Scalar>
260 {
return scIntegrator_->getStepper()->isExplicit(); }
263 template<
class Scalar>
265 {
return scIntegrator_->getStepper()->isImplicit(); }
268 template<
class Scalar>
270 {
return scIntegrator_->getStepper()->isExplicitImplicit(); }
273 template<
class Scalar>
275 {
return scIntegrator_->getStepper()->isOneStepMethod(); }
278 template<
class Scalar>
280 {
return scIntegrator_->getStepper()->isMultiStepMethod(); }
283 template<
class Scalar>
285 {
return scIntegrator_->getStepper()->getOrder(); }
288 template<
class Scalar>
290 {
return scIntegrator_->getStepper()->getOrderMin(); }
293 template<
class Scalar>
295 {
return scIntegrator_->getStepper()->getOrderMax(); }
298 template<
class Scalar>
300 {
return scIntegrator_->getStepper()->getOrderODE(); }
303 template<
class Scalar>
306 {
return scIntegrator_->getStepper()->getInitTimeStep(
solutionHistory); }
309 template<
class Scalar>
311 Teuchos::RCP<
const Thyra::VectorBase<Scalar> > initialGuess)
313 scIntegrator_->getStepper()->setInitialGuess(initialGuess);
314 this->isInitialized_ =
false;
318 template<
class Scalar>
321 { scIntegrator_->getStepper()->setInitialConditions(
solutionHistory); }
324 template<
class Scalar>
326 Teuchos::RCP<Thyra::NonlinearSolverBase<Scalar> > solver)
328 scIntegrator_->getStepper()->setSolver(solver);
329 this->isInitialized_ =
false;
333 template<
class Scalar>
334 Teuchos::RCP<Thyra::NonlinearSolverBase<Scalar> >
336 {
return scIntegrator_->getStepper()->getSolver(); }
339 template<
class Scalar>
345 TEMPUS_FUNC_TIME_MONITOR(
"Tempus::StepperSubcycling::takeStep()");
349 "Error - StepperSubcycling<Scalar>::takeStep(...)\n"
350 "Need at least two SolutionStates for Subcycling.\n"
352 "Try setting in \"Solution History\" \"Storage Type\" = \"Undo\"\n"
353 " or \"Storage Type\" = \"Static\" and \"Storage Limit\" = \"2\"\n");
356 RCP<SolutionState<Scalar> > currentState=
solutionHistory->getCurrentState();
357 RCP<SolutionState<Scalar> > workingState=
solutionHistory->getWorkingState();
359 auto scTSC = scIntegrator_->getNonConstTimeStepControl();
360 scTSC->setInitTime (currentState->getTime());
361 scTSC->setInitIndex (0);
362 scTSC->setFinalTime (workingState->getTime());
363 scTSC->setMaxTimeStep(workingState->getTimeStep());
366 Teuchos::RCP<SolutionStateMetaData<Scalar> > scMD =
368 scMD->copy(currentState->getMetaData());
369 scMD->setDt(scTSC->getInitTimeStep());
370 scMD->setOrder(scIntegrator_->getStepper()->getOrder());
372 scMD->setNFailures(0);
373 scMD->setNRunningFailures(0);
374 scMD->setNConsecutiveFailures(0);
375 scMD->setOutput(
false);
376 scMD->setOutputScreen(
false);
378 TEUCHOS_TEST_FOR_EXCEPTION(!scMD->getIsSynced(), std::logic_error,
379 "Error - StepperSubcycling<Scalar>::takeStep(...)\n"
380 " Subcycling requires the the solution is synced!\n"
381 " (i.e., x, xDot, and xDotDot at the same time level.\n");
384 currentState->getX(),
385 currentState->getXDot(),
386 currentState->getXDotDot(),
387 currentState->getStepperState(),
388 currentState->getPhysicsState()));
391 scSH->setName(
"Subcycling States");
393 scSH->setStorageLimit(3);
394 scSH->addState(subcyclingState);
396 scIntegrator_->setSolutionHistory(scSH);
398 bool pass = scIntegrator_->advanceTime();
400 RCP<SolutionState<Scalar> > scCS = scSH->getCurrentState();
402 RCP<Thyra::VectorBase<Scalar> > x = workingState->getX();
403 RCP<Thyra::VectorBase<Scalar> > scX = scCS->getX();
404 Thyra::V_V(x.ptr(), *(scX));
406 RCP<Thyra::VectorBase<Scalar> > xDot = workingState->getXDot();
407 if (xDot != Teuchos::null) {
408 RCP<Thyra::VectorBase<Scalar> > scXDot = scCS->getXDot();
409 Thyra::V_V(xDot.ptr(), *(scXDot));
412 RCP<Thyra::VectorBase<Scalar> > xDotDot = workingState->getXDotDot();
413 if (xDotDot != Teuchos::null) {
414 RCP<Thyra::VectorBase<Scalar> > scXDotDot = scCS->getXDotDot();
415 Thyra::V_V(xDotDot.ptr(), *(scXDotDot));
418 if (pass ==
true) workingState->setSolutionStatus(
Status::PASSED);
420 workingState->setOrder(scCS->getOrder());
434 template<
class Scalar>
438 Teuchos::RCP<Tempus::StepperState<Scalar> > stepperState =
444 template<
class Scalar>
446 Teuchos::FancyOStream &out,
447 const Teuchos::EVerbosityLevel verbLevel)
const
452 out <<
"--- StepperSubcycling ---\n";
453 out <<
" stepperSCObserver = " << stepperSCObserver_ << std::endl;
454 out <<
" scIntegrator = " << scIntegrator_ << std::endl;
455 out <<
"-------------------------" << std::endl;
456 scIntegrator_->getStepper()->describe(out, verbLevel);
460 template<
class Scalar>
461 Teuchos::RCP<const Teuchos::ParameterList>
464 TEUCHOS_TEST_FOR_EXCEPTION(
true, std::logic_error,
465 "Error - StepperSubcycling<Scalar>::getValidParameters()\n"
466 " is not implemented yet.\n");
468 Teuchos::RCP<Teuchos::ParameterList> pl = Teuchos::parameterList();
470 pl->set<
bool>(
"Use FSAL",
true);
471 pl->set<std::string>(
"Initial Condition Consistency",
"Consistent");
477 #endif // Tempus_StepperSubcycling_impl_hpp
Teuchos::RCP< const Teuchos::ParameterList > getValidParameters() const
virtual bool isExplicitImplicit() const
virtual void setSubcyclingStepper(Teuchos::RCP< Stepper< Scalar > > stepper)
virtual void initialize()
Initialize during construction and after changing input parameters.
virtual void setSubcyclingMinTimeStep(Scalar MinTimeStep)
virtual void describe(Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel) const
virtual void setSubcyclingScreenOutputIndexInterval(int i)
virtual void setSubcyclingMaxTimeStep(Scalar MaxTimeStep)
StepControlStrategy class for TimeStepControl.
virtual Teuchos::RCP< Tempus::StepperState< Scalar > > getDefaultStepperState()
Get a default (initial) StepperState.
virtual void takeStep(const Teuchos::RCP< SolutionHistory< Scalar > > &solutionHistory)
Take the specified timestep, dt, and return true if successful.
virtual bool isOneStepMethod() const
virtual void setSolver(Teuchos::RCP< Thyra::NonlinearSolverBase< Scalar > > solver=Teuchos::null)
Set solver.
virtual void setSubcyclingMaxConsecFailures(int MaxConsecFailures)
virtual void setSubcyclingTimeStepControlStrategy(Teuchos::RCP< TimeStepControlStrategy< Scalar > > tscs)
Thyra Base interface for time steppers.
StepperState is a simple class to hold state information about the stepper.
virtual bool isImplicit() const
virtual Scalar getOrderMax() const
virtual void setObserver(Teuchos::RCP< StepperObserver< Scalar > > obs=Teuchos::null)
Set Observer.
virtual Teuchos::RCP< Thyra::NonlinearSolverBase< Scalar > > getSolver() const
Get solver.
virtual void setSubcyclingStepType(std::string StepType)
virtual bool isExplicit() const
StepperObserver class for Stepper class.
virtual bool isMultiStepMethod() const
Teuchos::RCP< SolutionHistory< Scalar > > solutionHistory(Teuchos::RCP< Teuchos::ParameterList > pList=Teuchos::null)
Nonmember constructor.
SolutionHistory is basically a container of SolutionStates. SolutionHistory maintains a collection of...
virtual Scalar getInitTimeStep(const Teuchos::RCP< SolutionHistory< Scalar > > &solutionHistory) const
Keep a fix number of states.
StepControlStrategy class for TimeStepControl.
virtual void setSubcyclingInitTimeStep(Scalar InitTimeStep)
virtual void setInitialGuess(Teuchos::RCP< const Thyra::VectorBase< Scalar > > initial_guess)
Pass initial guess to Newton solver (only relevant for implicit solvers)
virtual Scalar getOrderMin() const
virtual OrderODE getOrderODE() const
virtual Scalar getOrder() const
virtual void setModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &appModel)
StepperSubcycling()
Default constructor.
IntegratorObserverSubcycling class for time integrators. This basic class has simple no-op functions...
StepperSubcyclingObserver class for StepperSubcycling.
StepControlStrategy class for TimeStepControl.
void getValidParametersBasic(Teuchos::RCP< Teuchos::ParameterList > pl, std::string stepperType)
Provide basic parameters to Steppers.
Solution state for integrators and steppers. SolutionState contains the metadata for solutions and th...
virtual void setInitialConditions(const Teuchos::RCP< SolutionHistory< Scalar > > &solutionHistory)
Set the initial conditions, make them consistent, and set needed memory.
virtual void setNonConstModel(const Teuchos::RCP< Thyra::ModelEvaluator< Scalar > > &appModel)
virtual Teuchos::RCP< StepperObserver< Scalar > > getObserver() const
Get Observer.
virtual void setSubcyclingMaxFailures(int MaxFailures)