20 params.
addParam<UserObjectName>(
"subblock_index_provider",
21 "SubblockIndexProvider user object name");
22 params.
addCoupledVar(
"scalar_out_of_plane_strain",
"Scalar variable for axisymmetric 1D problem");
23 params.
addCoupledVar(
"out_of_plane_strain",
"Nonlinear variable for axisymmetric 1D problem");
31 _subblock_id_provider(isParamValid(
"subblock_index_provider")
34 _has_out_of_plane_strain(isCoupled(
"out_of_plane_strain")),
35 _out_of_plane_strain(_has_out_of_plane_strain ? coupledValue(
"out_of_plane_strain") : _zero),
36 _has_scalar_out_of_plane_strain(isCoupledScalar(
"scalar_out_of_plane_strain"))
39 mooseError(
"Must define only one of out_of_plane_strain or scalar_out_of_plane_strain");
45 for (
unsigned int i = 0; i < nscalar_strains; ++i)
56 mooseError(
"The coordinate system must be set to RZ for Axisymmetric geometries.");
const MooseArray< Point > & _q_point
Real computeStrainZZ() override
Computes the strain_zz for axisymmetric problems, where .
bool absoluteFuzzyEqual(const T &var1, const T2 &var2, const T3 &tol=libMesh::TOLERANCE *libMesh::TOLERANCE)
const bool _has_scalar_out_of_plane_strain
Whether out-of-plane strain scalar variables are coupled.
void initialSetup() override
ComputeAxisymmetric1DSmallStrain(const InputParameters ¶meters)
Moose::CoordinateSystemType getBlockCoordSystem()
const bool _has_out_of_plane_strain
Whether an out-of-plane strain variable is coupled.
Abstract base class for user objects that provide an index for a given element that is independent of...
std::vector< const VariableValue * > _disp
Displacement variables.
const VariableValue & _out_of_plane_strain
The out-of-plane strain variable.
unsigned int getCurrentSubblockIndex() const
gets its subblock index for current element
static InputParameters validParams()
Real computeStrainYY() override
Computes the strain_yy for axisymmetric problems.
std::vector< const VariableValue * > _scalar_out_of_plane_strain
The out-of-plane strain scalar variables.
const VariableValue & coupledScalarValue(const std::string &var_name, unsigned int comp=0) const
registerMooseObject("SolidMechanicsApp", ComputeAxisymmetric1DSmallStrain)
void initialSetup() override
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
unsigned int coupledScalarComponents(const std::string &var_name) const
static InputParameters validParams()
void mooseError(Args &&... args) const
Compute1DSmallStrain defines a strain tensor, assuming small strains, in 1D problems, handling strains in other two directions.
ComputeAxisymmetric1DSmallStrain defines small strains in an Axisymmetric 1D problem.