12 #include "libmesh/quadrature.h" 19 "Compute a strain increment and rotation increment for finite strains in 2D geometries.");
21 MooseEnum outOfPlaneDirection(
"x y z",
"z");
23 "out_of_plane_direction", outOfPlaneDirection,
"The direction of the out-of-plane strain.");
29 _out_of_plane_direction(getParam<
MooseEnum>(
"out_of_plane_direction"))
36 for (
unsigned int i = 0; i < 3; ++i)
60 Real ave_dfgrd_det = 0.0;
85 (*_def_grad_mid)[
_qp].setToIdentity();
86 (*_def_grad_mid)[
_qp] += 0.5 * (
A + Fbar);
135 mooseError(
"For 2D simulations where the out-of-plane direction is x or y the number of " 136 "supplied displacements must be three.");
138 mooseError(
"For 2D simulations where the out-of-plane direction is z the number of supplied " 139 "displacements must be two.");
virtual void displacementIntegrityCheck() override
static InputParameters validParams()
const VariableValue & _zero
FEProblemBase & _fe_problem
static InputParameters validParams()
const QBase *const & _qrule
const Real & _current_elem_volume
Compute2DFiniteStrain(const InputParameters ¶meters)
MaterialProperty< RankTwoTensor > & _deformation_gradient
const VariableGradient & _grad_zero
const MooseArray< Real > & _JxW
std::vector< const VariableValue * > _disp
Displacement variables.
virtual const VariableGradient & coupledGradient(const std::string &var_name, unsigned int comp=0) const
virtual void computeQpStrain()
static RankTwoTensorTempl initializeFromRows(const libMesh::TypeVector< Real > &row0, const libMesh::TypeVector< Real > &row1, const libMesh::TypeVector< Real > &row2)
virtual const VariableValue & coupledValue(const std::string &var_name, unsigned int comp=0) const
const bool _use_hw
Flag if using HughesWinget method.
virtual const VariableGradient & coupledGradientOld(const std::string &var_name, unsigned int comp=0) const
unsigned int _ndisp
Coupled displacement variables.
virtual Real computeOutOfPlaneGradDisp()=0
Computes the current out-of-plane component of the displacement gradient; as a virtual function...
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
ComputeFiniteStrain defines a strain increment and rotation increment, for finite strains...
std::vector< const VariableGradient * > _grad_disp_old
virtual Real computeOutOfPlaneGradDispOld()=0
Computes the old out-of-plane component of the displacement gradient; as a virtual function...
void mooseError(Args &&... args) const
void initialSetup() override
const bool _volumetric_locking_correction
virtual bool isTransient() const override
const unsigned int _out_of_plane_direction
const MooseArray< Real > & _coord
std::vector< RankTwoTensor > _Fhat
Incremental deformation gradient.
virtual void computeProperties() override
std::vector< const VariableGradient * > _grad_disp
Gradient of displacements.