34 template <
class T,
bool _NL>
60 const Damping_t & Damping,
61 const Stiffness_t & Stiffness,
65 Base(Mass,Damping,Stiffness,Force)
73 const Damping_t & Damping,
74 const Stiffness_t & Stiffness,
75 const TForce_t & TForce
78 Base(Mass,Damping,Stiffness,TForce)
86 const Damping_t & Damping,
87 const Jacobian_t & Jacobian,
88 const Residual_t & Residual
91 Base(Mass,Damping,Jacobian,Residual)
99 const Damping_t & Damping,
100 const Jacobian_t & Jacobian,
101 const TResidual_t & TResidual
104 Base(Mass,Damping,Jacobian,TResidual)
112 const Damping_t & Damping,
113 const TJacobian_t & TJacobian,
114 const TResidual_t & TResidual
117 Base(Mass,Damping,TJacobian,TResidual)
124 const TMass_t & TMass,
125 const TDamping_t & TDamping,
126 const TJacobian_t & TJacobian,
127 const TResidual_t & TResidual
130 Base(TMass,TDamping,TJacobian,TResidual)
143 void _initOutput()
const;
144 void _stageOutput(
index_t stage)
const;
145 void _stepOutput(
const index_t it,
const T resnorm,
const T updatenorm)
const;
158 using Base::m_solver;
162 using Base::m_options;
166 template <
bool _nonlinear>
167 typename std::enable_if<(_nonlinear==false), gsStatus>::type
170 template <
bool _nonlinear>
171 typename std::enable_if<(_nonlinear==true), gsStatus>::type
177 #ifndef GISMO_BUILD_LIB
178 #include GISMO_HPP_HEADER(gsDynamicBathe.hpp)
std::function< bool(gsVector< T > const &, const T, gsSparseMatrix< T > &) > TJacobian_t
Jacobian.
Definition: gsStructuralAnalysisTypes.h:85
virtual void _computeForce(const T time, gsVector< T > &F) const
Compute the residual.
Definition: gsDynamicBase.h:261
virtual void _computeMassInverse(const gsSparseMatrix< T > &M, gsSparseMatrix< T > &Minv) const
Compute the mass matrix.
Definition: gsDynamicBase.h:282
Class to perform time integration of second-order structural dynamics systems using the Explicit Eule...
std::function< bool(gsVector< T > const &, const T, gsVector< T > &)> TResidual_t
Time-dependent Residual Fint(t)-Fext(t)
Definition: gsStructuralAnalysisTypes.h:69
Base class to perform time integration of second-order structural dynamics systems.
gsStatus _step(const T t, const T dt, gsVector< T > &U, gsVector< T > &V, gsVector< T > &A) const override
Initialize the ALM.
Definition: gsDynamicBathe.hpp:178
virtual void _computeMass(const T time, gsSparseMatrix< T > &M) const
Compute the mass matrix.
Definition: gsDynamicBase.h:275
gsDynamicBathe(const Mass_t &Mass, const Damping_t &Damping, const Stiffness_t &Stiffness, const TForce_t &TForce)
Constructor.
Definition: gsDynamicBathe.h:71
virtual void defaultOptions() override
Set default options.
Definition: gsDynamicBathe.hpp:20
#define index_t
Definition: gsConfig.h:32
gsStatus
Definition: gsStructuralAnalysisTypes.h:20
gsDynamicBathe(const TMass_t &TMass, const TDamping_t &TDamping, const TJacobian_t &TJacobian, const TResidual_t &TResidual)
Constructor.
Definition: gsDynamicBathe.h:123
std::function< bool(gsVector< T > const &, gsVector< T > &)> Residual_t
Residual, Fint-Fext.
Definition: gsStructuralAnalysisTypes.h:65
std::function< bool(gsSparseMatrix< T > &) > Mass_t
Mass matrix.
Definition: gsStructuralAnalysisTypes.h:72
std::function< bool(gsVector< T > const &, gsSparseMatrix< T > &) > Jacobian_t
Jacobian.
Definition: gsStructuralAnalysisTypes.h:83
std::function< bool(gsVector< T > const &, gsSparseMatrix< T > &) > Damping_t
Damping matrix.
Definition: gsStructuralAnalysisTypes.h:76
Provides a list of labeled parameters/options that can be set and accessed easily.
virtual void _computeDamping(const gsVector< T > &U, const T time, gsSparseMatrix< T > &C) const
Compute the damping matrix.
Definition: gsDynamicBase.h:297
Performs the arc length method to solve a nonlinear system of equations.
Definition: gsDynamicBathe.h:35
std::function< bool(gsVector< T > &)> Force_t
Force.
Definition: gsStructuralAnalysisTypes.h:60
std::function< bool(const T, gsSparseMatrix< T > &) > TMass_t
Time-dependent mass matrix.
Definition: gsStructuralAnalysisTypes.h:74
gsDynamicBathe(const Mass_t &Mass, const Damping_t &Damping, const Stiffness_t &Stiffness, const Force_t &Force)
Constructor.
Definition: gsDynamicBathe.h:58
std::function< bool(gsSparseMatrix< T > &) > Stiffness_t
Stiffness matrix.
Definition: gsStructuralAnalysisTypes.h:81
std::function< bool(const T, gsVector< T > &)> TForce_t
Time-dependent force.
Definition: gsStructuralAnalysisTypes.h:62
virtual void _computeJacobian(const gsVector< T > &U, const T time, gsSparseMatrix< T > &K) const
Compute the Jacobian matrix.
Definition: gsDynamicBase.h:304
index_t m_numIterations
Number of iterations performed.
Definition: gsDynamicBase.h:348
gsDynamicBathe(const Mass_t &Mass, const Damping_t &Damping, const Jacobian_t &Jacobian, const Residual_t &Residual)
Constructor.
Definition: gsDynamicBathe.h:84
This is the main header file that collects wrappers of Eigen for linear algebra.
gsDynamicBathe(const Mass_t &Mass, const Damping_t &Damping, const TJacobian_t &TJacobian, const TResidual_t &TResidual)
Constructor.
Definition: gsDynamicBathe.h:110
Performs the arc length method to solve a nonlinear system of equations.
Definition: gsDynamicNewmark.h:34
std::function< bool(gsVector< T > const &, const T, gsSparseMatrix< T > &) > TDamping_t
Time-dependent Damping matrix.
Definition: gsStructuralAnalysisTypes.h:78
gsDynamicBathe(const Mass_t &Mass, const Damping_t &Damping, const Jacobian_t &Jacobian, const TResidual_t &TResidual)
Constructor.
Definition: gsDynamicBathe.h:97
std::enable_if<(_nonlinear==false), gsStatus >::type _step_impl(const T t, const T dt, gsVector< T > &U, gsVector< T > &V, gsVector< T > &A) const
Definition: gsDynamicBathe.hpp:32
virtual void _computeResidual(const gsVector< T > &U, const T time, gsVector< T > &R) const
Compute the residual.
Definition: gsDynamicBase.h:268