Tempus  Version of the Day
Time Integration
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
Tempus_IntegratorObserverSubcycling_impl.hpp
Go to the documentation of this file.
1 // @HEADER
2 // ****************************************************************************
3 // Tempus: Copyright (2017) Sandia Corporation
4 //
5 // Distributed under BSD 3-clause license (See accompanying file Copyright.txt)
6 // ****************************************************************************
7 // @HEADER
8 
9 #ifndef Tempus_IntegratorObserverSubcycling_impl_hpp
10 #define Tempus_IntegratorObserverSubcycling_impl_hpp
11 
12 #include "Tempus_Stepper.hpp"
13 
14 namespace Tempus {
15 
16 template<class Scalar>
18 
19 template<class Scalar>
21 
22 template<class Scalar>
25 
26  const Teuchos::RCP<Teuchos::FancyOStream> out = integrator.getOStream();
27  Teuchos::OSTab ostab(out,0,"ScreenOutput");
28  *out << "\n Begin Subcycling -------------------------------------------------------\n";
29  // << " Step Time dt Abs Error Rel Error Order nFail dCompTime"
30  // << std::endl;
31 }
32 
33 template<class Scalar>
35 observeStartTimeStep(const Integrator<Scalar>& /* integrator */){}
36 
37 template<class Scalar>
39 observeNextTimeStep(const Integrator<Scalar>& /* integrator */){}
40 
41 template<class Scalar>
43 observeBeforeTakeStep(const Integrator<Scalar>& /* integrator */){}
44 
45 template<class Scalar>
47 observeAfterTakeStep(const Integrator<Scalar>& /* integrator */){}
48 
49 template<class Scalar>
52 
53 template<class Scalar>
56 
57  using Teuchos::RCP;
58  auto cs = integrator.getSolutionHistory()->getCurrentState();
59 
60  if ((cs->getOutputScreen() == true) or
61  (cs->getOutput() == true) or
62  (cs->getTime() == integrator.getTimeStepControl()->getFinalTime())) {
63 
64  const Scalar steppertime = integrator.getStepperTimer()->totalElapsedTime();
65  // reset the stepper timer
66  integrator.getStepperTimer()->reset();
67 
68  const Teuchos::RCP<Teuchos::FancyOStream> out = integrator.getOStream();
69  Teuchos::OSTab ostab(out,0,"ScreenOutput");
70  *out<<std::scientific
71  <<std::setw( 6)<<std::setprecision(3)<<cs->getIndex()
72  <<std::setw(11)<<std::setprecision(3)<<cs->getTime()
73  <<std::setw(11)<<std::setprecision(3)<<cs->getTimeStep()
74  <<std::setw(11)<<std::setprecision(3)<<cs->getErrorAbs()
75  <<std::setw(11)<<std::setprecision(3)<<cs->getErrorRel()
76  <<std::fixed <<std::setw( 7)<<std::setprecision(1)<<cs->getOrder()
77  <<std::scientific<<std::setw( 7)<<std::setprecision(3)<<cs->getNFailures()
78  <<std::setw(11)<<std::setprecision(3)<<steppertime
79  <<std::endl;
80  }
81 
82 }
83 
84 template<class Scalar>
87 
88  const Teuchos::RCP<Teuchos::FancyOStream> out = integrator.getOStream();
89  Teuchos::OSTab ostab(out,0,"ScreenOutput");
90  *out << " End Subcycling ---------------------------------------------------------\n\n";
91 }
92 
93 } // namespace Tempus
94 #endif // Tempus_IntegratorObserverSubcycling_impl_hpp
virtual void observeEndIntegrator(const Integrator< Scalar > &integrator) override
Observe the end of the time integrator.
virtual Teuchos::RCP< Teuchos::Time > getStepperTimer() const =0
virtual void observeBeforeTakeStep(const Integrator< Scalar > &integrator) override
Observe before Stepper takes step.
virtual void observeAfterTakeStep(const Integrator< Scalar > &integrator) override
Observe after Stepper takes step.
virtual Teuchos::RCP< const TimeStepControl< Scalar > > getTimeStepControl() const =0
Returns the TimeStepControl for this Integrator.
virtual void observeAfterCheckTimeStep(const Integrator< Scalar > &integrator) override
Observe after checking time step. Observer can still fail the time step here.
virtual void observeStartTimeStep(const Integrator< Scalar > &integrator) override
Observe the beginning of the time step loop.
virtual void observeStartIntegrator(const Integrator< Scalar > &integrator) override
Observe the beginning of the time integrator.
virtual void observeNextTimeStep(const Integrator< Scalar > &integrator) override
Observe after the next time step size is selected.
Thyra Base interface for time integrators. Time integrators are designed to advance the solution from...
virtual void observeEndTimeStep(const Integrator< Scalar > &integrator) override
Observe the end of the time step loop.
virtual Teuchos::RCP< const SolutionHistory< Scalar > > getSolutionHistory() const =0
Returns the SolutionHistory for this Integrator.