9#ifndef Tempus_StepperSubcycling_impl_hpp
10#define Tempus_StepperSubcycling_impl_hpp
12#include "Thyra_VectorStdOps.hpp"
14#include "Tempus_StepperForwardEuler.hpp"
18#include "Tempus_IntegratorObserverSubcycling.hpp"
19#include "Tempus_IntegratorObserverNoOp.hpp"
29 using Teuchos::ParameterList;
43 RCP<ParameterList> tempusPL =
44 Teuchos::rcp_const_cast<Teuchos::ParameterList> (
48 tempusPL->sublist(
"Default Integrator")
49 .set(
"Stepper Name",
"Default Subcycling Stepper");
50 RCP<ParameterList> stepperPL = Teuchos::parameterList();
51 stepperPL->set(
"Stepper Type",
"Forward Euler");
52 tempusPL->set(
"Default Subcycling Stepper", *stepperPL);
71 tempusPL->sublist(
"Default Integrator")
72 .sublist(
"Time Step Control")
73 .set(
"Initial Time Step", std::numeric_limits<Scalar>::max());
87 std::string ICConsistency,
88 bool ICConsistencyCheck,
100 if (appModel != Teuchos::null) {
106template<
class Scalar>
115template<
class Scalar>
118 scIntegrator_->getNonConstTimeStepControl()->setMinTimeStep(MinTimeStep);
123template<
class Scalar>
126 scIntegrator_->getNonConstTimeStepControl()->setInitTimeStep(InitTimeStep);
131template<
class Scalar>
134 scIntegrator_->getNonConstTimeStepControl()->setMaxTimeStep(MaxTimeStep);
139template<
class Scalar>
142 scIntegrator_->getNonConstTimeStepControl()->setMaxFailures(MaxFailures);
147template<
class Scalar>
151 scIntegrator_->getNonConstTimeStepControl()->setMaxConsecFailures(MaxConsecFailures);
156template<
class Scalar>
165template<
class Scalar>
174template<
class Scalar>
179 scIntegrator_->getNonConstTimeStepControl()->setTimeStepControlStrategy(tscs);
184template<
class Scalar>
193template<
class Scalar>
197 scIntegrator_->getNonConstTimeStepControl()->setPrintDtChanges(printDtChanges);
202template<
class Scalar>
203Teuchos::RCP<const Stepper<Scalar> >
208template<
class Scalar>
210{
return scIntegrator_->getTimeStepControl()->getMinTimeStep(); }
213template<
class Scalar>
215{
return scIntegrator_->getTimeStepControl()->getInitTimeStep(); }
218template<
class Scalar>
220{
return scIntegrator_->getTimeStepControl()->getMaxTimeStep(); }
223template<
class Scalar>
225{
return scIntegrator_->getTimeStepControl()->getStepType(); }
228template<
class Scalar>
230{
return scIntegrator_->getTimeStepControl()->getMaxFailures(); }
233template<
class Scalar>
235{
return scIntegrator_->getTimeStepControl()->getMaxConsecFailures(); }
238template<
class Scalar>
243template<
class Scalar>
248template<
class Scalar>
249Teuchos::RCP<TimeStepControlStrategy<Scalar> >
251{
return scIntegrator_->getTimeStepControl()->getTimeStepControlStrategy(); }
253template<
class Scalar>
254Teuchos::RCP<IntegratorObserver<Scalar> >
258template<
class Scalar>
260{
return scIntegrator_->getTimeStepControl()->getPrintDtChanges(); }
263template<
class Scalar>
272template<
class Scalar>
281template<
class Scalar>
285 if (appAction == Teuchos::null) {
295template<
class Scalar>
298 Teuchos::RCP<Teuchos::FancyOStream> out = this->getOStream();
306 *out <<
"The IC consistency does not have a valid value!\n"
307 <<
"('None', 'Zero', 'App' or 'Consistent')\n"
314 *out <<
"The Subcycling AppAction is not set!\n";
320 this->
describe(*out, Teuchos::VERB_MEDIUM);
324template<
class Scalar>
329template<
class Scalar>
334template<
class Scalar>
339template<
class Scalar>
344template<
class Scalar>
349template<
class Scalar>
354template<
class Scalar>
359template<
class Scalar>
364template<
class Scalar>
369template<
class Scalar>
372{
return scIntegrator_->getStepper()->getInitTimeStep(solutionHistory); }
375template<
class Scalar>
384template<
class Scalar>
388 scIntegrator_->getStepper()->setInitialConditions(solutionHistory);
393template<
class Scalar>
395 Teuchos::RCP<Thyra::NonlinearSolverBase<Scalar> > solver)
402template<
class Scalar>
403Teuchos::RCP<Thyra::NonlinearSolverBase<Scalar> >
408template<
class Scalar>
414 TEMPUS_FUNC_TIME_MONITOR(
"Tempus::StepperSubcycling::takeStep()");
416 TEUCHOS_TEST_FOR_EXCEPTION(solutionHistory->getNumStates() < 2,
418 "Error - StepperSubcycling<Scalar>::takeStep(...)\n"
419 "Need at least two SolutionStates for Subcycling.\n"
420 " Number of States = " << solutionHistory->getNumStates() <<
"\n"
421 "Try setting in \"Solution History\" \"Storage Type\" = \"Undo\"\n"
422 " or \"Storage Type\" = \"Static\" and \"Storage Limit\" = \"2\"\n");
424 RCP<StepperSubcycling<Scalar> > thisStepper = Teuchos::rcpFromRef(*
this);
427 RCP<SolutionState<Scalar> > currentState=solutionHistory->getCurrentState();
428 RCP<SolutionState<Scalar> > workingState=solutionHistory->getWorkingState();
431 scTSC->setInitTime (currentState->getTime());
432 scTSC->setInitIndex (0);
433 scTSC->setFinalTime (workingState->getTime());
435 auto subcyclingState = currentState->clone();
436 subcyclingState->setTimeStep(scTSC->getInitTimeStep());
437 subcyclingState->setOrder(
scIntegrator_->getStepper()->getOrder());
438 subcyclingState->setIndex(0);
439 subcyclingState->setNFailures(0);
440 subcyclingState->setNRunningFailures(0);
441 subcyclingState->setNConsecutiveFailures(0);
442 subcyclingState->setOutput(
false);
443 subcyclingState->setOutputScreen(
false);
445 TEUCHOS_TEST_FOR_EXCEPTION(!subcyclingState->getIsSynced(),std::logic_error,
446 "Error - StepperSubcycling<Scalar>::takeStep(...)\n"
447 " Subcycling requires the the solution is synced!\n"
448 " (i.e., x, xDot, and xDotDot at the same time level.\n");
451 scSH->setName(
"Subcycling States");
453 scSH->setStorageLimit(3);
454 scSH->addState(subcyclingState);
460 RCP<SolutionState<Scalar> > scCS = scSH->getCurrentState();
462 RCP<Thyra::VectorBase<Scalar> > x = workingState->getX();
463 RCP<Thyra::VectorBase<Scalar> > scX = scCS->getX();
464 Thyra::V_V(x.ptr(), *(scX));
466 RCP<Thyra::VectorBase<Scalar> > xDot = workingState->getXDot();
467 if (xDot != Teuchos::null) {
468 RCP<Thyra::VectorBase<Scalar> > scXDot = scCS->getXDot();
469 Thyra::V_V(xDot.ptr(), *(scXDot));
472 RCP<Thyra::VectorBase<Scalar> > xDotDot = workingState->getXDotDot();
473 if (xDotDot != Teuchos::null) {
474 RCP<Thyra::VectorBase<Scalar> > scXDotDot = scCS->getXDotDot();
475 Thyra::V_V(xDotDot.ptr(), *(scXDotDot));
478 if (pass ==
true) workingState->setSolutionStatus(
Status::PASSED);
480 workingState->setOrder(scCS->getOrder());
481 workingState->computeNorms(currentState);
496template<
class Scalar>
500 Teuchos::RCP<Tempus::StepperState<Scalar> > stepperState =
506template<
class Scalar>
508 Teuchos::FancyOStream &out,
509 const Teuchos::EVerbosityLevel verbLevel)
const
511 out.setOutputToRootOnly(0);
515 out <<
"--- StepperSubcycling ---\n";
518 out <<
"-------------------------" << std::endl;
523template<
class Scalar>
524Teuchos::RCP<const Teuchos::ParameterList>
527 TEUCHOS_TEST_FOR_EXCEPTION(
true, std::logic_error,
528 "Error - StepperSubcycling<Scalar>::getValidParameters()\n"
529 " is not implemented yet.\n");
537template<
class Scalar>
538Teuchos::RCP<StepperSubcycling<Scalar> >
541 Teuchos::RCP<Teuchos::ParameterList> pl)
545 TEUCHOS_TEST_FOR_EXCEPTION(pl != Teuchos::null, std::logic_error,
546 "Error - Construction of StepperSubcycling with a ParameterList\n"
547 "is not implemented yet!\n");
549 if (pl != Teuchos::null) {
550 stepper->setStepperValues(pl);
553 if (model != Teuchos::null) {
554 stepper->setModel(model);
555 stepper->initialize();
IntegratorObserverNoOp class for time integrators. This basic class has simple no-op functions,...
IntegratorObserver class for time integrators.
SolutionHistory is basically a container of SolutionStates. SolutionHistory maintains a collection of...
Forward Euler time stepper.
StepperState is a simple class to hold state information about the stepper.
Application Action for StepperSubcycling.
@ BEGIN_STEP
At the beginning of the step.
@ END_STEP
At the end of the step.
Default modifier for StepperSubcycling.
virtual void setSubcyclingStepper(Teuchos::RCP< Stepper< Scalar > > stepper)
virtual Teuchos::RCP< IntegratorObserver< Scalar > > getSubcyclingIntegratorObserver() const
virtual Scalar getInitTimeStep(const Teuchos::RCP< SolutionHistory< Scalar > > &solutionHistory) const
virtual void setSubcyclingPrintDtChanges(bool printDtChanges)
virtual bool isExplicit() const
virtual OrderODE getOrderODE() const
virtual bool isImplicit() const
virtual Scalar getSubcyclingMaxTimeStep() const
virtual bool isExplicitImplicit() const
Teuchos::RCP< StepperSubcyclingAppAction< Scalar > > stepperSCAppAction_
virtual Scalar getOrder() const
virtual void initialize()
Initialize during construction and after changing input parameters.
virtual Teuchos::RCP< const Stepper< Scalar > > getSubcyclingStepper() const
virtual int getSubcyclingMaxConsecFailures() const
virtual int getSubcyclingScreenOutputIndexInterval() const
virtual void describe(Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel) const
virtual bool getSubcyclingPrintDtChanges() const
virtual void setAppAction(Teuchos::RCP< StepperSubcyclingAppAction< Scalar > > appAction=Teuchos::null)
StepperSubcycling()
Default constructor.
virtual void setSolver(Teuchos::RCP< Thyra::NonlinearSolverBase< Scalar > > solver=Teuchos::null)
Set solver.
virtual void setSubcyclingMaxTimeStep(Scalar MaxTimeStep)
virtual void setModel(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &appModel)
virtual void setNonConstModel(const Teuchos::RCP< Thyra::ModelEvaluator< Scalar > > &appModel)
virtual void setSubcyclingIntegratorObserver(Teuchos::RCP< IntegratorObserver< Scalar > > obs)
virtual void setSubcyclingInitTimeStep(Scalar InitTimeStep)
Teuchos::RCP< IntegratorBasic< Scalar > > scIntegrator_
virtual Scalar getSubcyclingInitTimeStep() const
virtual bool isOneStepMethod() const
virtual Scalar getSubcyclingMinTimeStep() const
virtual int getSubcyclingMaxFailures() const
virtual std::string getSubcyclingStepType() const
virtual void setInitialGuess(Teuchos::RCP< const Thyra::VectorBase< Scalar > > initial_guess)
Pass initial guess to Newton solver (only relevant for implicit solvers)
virtual void setSubcyclingMinTimeStep(Scalar MinTimeStep)
virtual Teuchos::RCP< Thyra::NonlinearSolverBase< Scalar > > getSolver() const
Get solver.
virtual void takeStep(const Teuchos::RCP< SolutionHistory< Scalar > > &solutionHistory)
Take the specified timestep, dt, and return true if successful.
virtual void setSubcyclingScreenOutputIndexInterval(int i)
Teuchos::RCP< const Teuchos::ParameterList > getValidParameters() const
virtual Teuchos::RCP< TimeStepControlStrategy< Scalar > > getSubcyclingTimeStepControlStrategy() const
virtual std::string getSubcyclingScreenOutputIndexList() const
virtual Scalar getOrderMax() const
virtual void setSubcyclingMaxFailures(int MaxFailures)
virtual Scalar getOrderMin() const
virtual void setInitialConditions(const Teuchos::RCP< SolutionHistory< Scalar > > &solutionHistory)
Set the initial conditions, make them consistent, and set needed memory.
virtual Teuchos::RCP< Tempus::StepperState< Scalar > > getDefaultStepperState()
Get a default (initial) StepperState.
virtual void setSubcyclingMaxConsecFailures(int MaxConsecFailures)
virtual void setSubcyclingScreenOutputIndexList(std::string s)
virtual void setSubcyclingTimeStepControlStrategy(Teuchos::RCP< TimeStepControlStrategy< Scalar > > tscs)
virtual bool isMultiStepMethod() const
Thyra Base interface for time steppers.
bool isInitialized_
True if stepper's member data is initialized.
void setICConsistencyCheck(bool c)
void setStepperName(std::string s)
Set the stepper name.
std::string getICConsistency() const
std::string getStepperType() const
Get the stepper type. The stepper type is used as an identifier for the stepper, and can only be set ...
Teuchos::RCP< Teuchos::ParameterList > getValidParametersBasic() const
Add basic parameters to Steppers ParameterList.
virtual void setUseFSAL(bool a)
virtual bool isValidSetup(Teuchos::FancyOStream &out) const
void setStepperType(std::string s)
Set the stepper type.
void setICConsistency(std::string s)
virtual void describe(Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel) const
TimeStepControlStrategy class for TimeStepControl.
@ STORAGE_TYPE_STATIC
Keep a fix number of states.
Teuchos::RCP< StepperSubcycling< Scalar > > createStepperSubcycling(const Teuchos::RCP< const Thyra::ModelEvaluator< Scalar > > &model, Teuchos::RCP< Teuchos::ParameterList > pl)
Nonmember constructor - ModelEvaluator and ParameterList.