Go to the documentation of this file.
11 #include "libmesh/utility.h"
21 params.addRequiredParam<Real>(
22 "value_0",
"The value of the parameter for all internal_parameter <= internal_0");
23 params.addParam<Real>(
"value_residual",
24 "The value of the parameter for internal_parameter >= "
25 "internal_limit. Default = value_0, ie perfect "
27 params.addParam<Real>(
28 "internal_0", 0.0,
"The value of the internal_parameter when hardening begins");
29 params.addParam<Real>(
"internal_limit",
31 "The value of the internal_parameter when hardening "
32 "ends. This hardening forms a cubic between "
33 "(internal_0, value_0) and (internal_limit, "
34 "value_residual) that is smooth at internal_0 and "
36 params.addClassDescription(
"Hardening is Cubic");
42 _val_0(getParam<Real>(
"value_0")),
43 _val_res(parameters.isParamValid(
"value_residual") ? getParam<Real>(
"value_residual") : _val_0),
44 _intnl_0(getParam<Real>(
"internal_0")),
45 _intnl_limit(getParam<Real>(
"internal_limit")),
46 _half_intnl_limit(0.5 * (_intnl_limit - _intnl_0)),
47 _alpha((_val_0 - _val_res) / (4.0 * Utility::
pow<3>(_half_intnl_limit))),
48 _beta(-3.0 * _alpha * Utility::
pow<2>(_half_intnl_limit))
51 mooseError(
"internal_limit must be greater than internal_0 in Cubic Hardening");
Real _val_0
value is cubic between _val_0 at internal_parameter=_intnl_0, at _val_res at internal_parameter=_intn...
ExpressionBuilder::EBTerm pow(const ExpressionBuilder::EBTerm &left, T exponent)
registerMooseObject("TensorMechanicsApp", TensorMechanicsHardeningCubic)
Real _alpha
convenience parameter for cubic
virtual Real derivative(Real intnl) const override
Real _val_res
value is cubic between _val_0 at internal_parameter=_intnl_0, at _val_res at internal_parameter=_intn...
Real _intnl_limit
value is cubic between _val_0 at internal_parameter=_intnl_0, at _val_res at internal_parameter=_intn...
virtual std::string modelName() const override
virtual Real value(Real intnl) const override
static InputParameters validParams()
defineLegacyParams(TensorMechanicsHardeningCubic)
TensorMechanicsHardeningCubic(const InputParameters ¶meters)
static InputParameters validParams()
Cubic hardening value = _val_0 for p <= _intnl_0 value = _val_res for p >= _intnl_limit value = cubic...
Real _beta
convenience parameter for cubic
Real _intnl_0
value is cubic between _val_0 at internal_parameter=_intnl_0, at _val_res at internal_parameter=_intn...
Real _half_intnl_limit
convenience parameter for cubic
Hardening Model base class.