48 virtual int order()
override {
return 2; }
53 ADReal & ad_u_dotdot)
const override;
54 virtual void solve()
override;
62 template <
typename T,
typename T2>
71 template <
typename T,
typename T2>
void computeADTimeDerivatives(ADReal &ad_u_dot, const dof_id_type &dof, ADReal &ad_u_dotdot) const override
method for computing local automatic differentiation time derivatives
Second-order Runge-Kutta (implicit midpoint) time integration.
static InputParameters validParams()
virtual int order() override
ImplicitMidpoint(const InputParameters ¶meters)
DualNumber< Real, DNDerivativeType, true > ADReal
Real & _dt
The current time step size.
void computeTimeDerivativeHelper(T &u_dot, const T2 &u_old) const
Helper function that actually does the math for computing the time derivative.
virtual void computeTimeDerivatives() override
Computes the time derivative and the Jacobian of the time derivative.
virtual bool overridesSolve() const override
NumericVector< Number > * _residual_stage1
Buffer to store non-time residual from the first stage.
virtual void solve() override
Solves the time step and sets the number of nonlinear and linear iterations.
Base class for time integrators.
virtual void postResidual(NumericVector< Number > &residual) override
Callback to the NonLinearTimeIntegratorInterface called immediately after the residuals are computed ...
const InputParameters & parameters() const
Get the parameters of the object.