12 #include "libmesh/utility.h" 16 TensorMechanicsPlasticOrthotropic,
24 params.
addRequiredParam<std::vector<Real>>(
"c1",
"The six coefficients of L prime");
25 params.
addRequiredParam<std::vector<Real>>(
"c2",
"The six coefficients of L prime prime");
26 params.
addClassDescription(
"Orthotropic plasticity for pressure sensitive materials and also " 27 "models the strength differential effect");
34 _c1(getParam<
std::vector<
Real>>(
"c1")),
35 _c2(getParam<
std::vector<
Real>>(
"c2"))
38 _l1(0, 0, 0, 0) = (
_c1[1] +
_c1[2]) / 3.0;
39 _l1(0, 0, 1, 1) = -
_c1[2] / 3.0;
40 _l1(0, 0, 2, 2) = -
_c1[1] / 3.0;
41 _l1(1, 1, 0, 0) = -
_c1[2] / 3.0;
42 _l1(1, 1, 1, 1) = (
_c1[0] +
_c1[2]) / 3.0;
43 _l1(1, 1, 2, 2) = -
_c1[0] / 3.0;
44 _l1(2, 2, 0, 0) = -
_c1[1] / 3.0;
45 _l1(2, 2, 1, 1) = -
_c1[0] / 3.0;
46 _l1(2, 2, 2, 2) = (
_c1[0] +
_c1[1]) / 3.0;
47 _l1(0, 1, 1, 0) =
_c1[5] / 2.0;
48 _l1(0, 1, 0, 1) =
_c1[5] / 2.0;
49 _l1(1, 0, 1, 0) =
_c1[5] / 2.0;
50 _l1(1, 0, 0, 1) =
_c1[5] / 2.0;
51 _l1(0, 2, 0, 2) =
_c1[4] / 2.0;
52 _l1(0, 2, 2, 0) =
_c1[4] / 2.0;
53 _l1(2, 0, 2, 0) =
_c1[4] / 2.0;
54 _l1(2, 0, 0, 2) =
_c1[4] / 2.0;
55 _l1(1, 2, 2, 1) =
_c1[3] / 2.0;
56 _l1(1, 2, 1, 2) =
_c1[3] / 2.0;
57 _l1(2, 1, 1, 2) =
_c1[3] / 2.0;
58 _l1(2, 1, 2, 1) =
_c1[3] / 2.0;
60 _l2(0, 0, 0, 0) = (
_c2[1] +
_c2[2]) / 3.0;
61 _l2(0, 0, 1, 1) = -
_c2[2] / 3.0;
62 _l2(0, 0, 2, 2) = -
_c2[1] / 3.0;
63 _l2(1, 1, 0, 0) = -
_c2[2] / 3.0;
64 _l2(1, 1, 1, 1) = (
_c2[0] +
_c2[2]) / 3.0;
65 _l2(1, 1, 2, 2) = -
_c2[0] / 3.0;
66 _l2(2, 2, 0, 0) = -
_c2[1] / 3.0;
67 _l2(2, 2, 1, 1) = -
_c2[0] / 3.0;
68 _l2(2, 2, 2, 2) = (
_c2[0] +
_c2[1]) / 3.0;
69 _l2(0, 1, 1, 0) =
_c2[5] / 2.0;
70 _l2(0, 1, 0, 1) =
_c2[5] / 2.0;
71 _l2(1, 0, 1, 0) =
_c2[5] / 2.0;
72 _l2(1, 0, 0, 1) =
_c2[5] / 2.0;
73 _l2(0, 2, 0, 2) =
_c2[4] / 2.0;
74 _l2(0, 2, 2, 0) =
_c2[4] / 2.0;
75 _l2(2, 0, 2, 0) =
_c2[4] / 2.0;
76 _l2(2, 0, 0, 2) =
_c2[4] / 2.0;
77 _l2(1, 2, 2, 1) =
_c2[3] / 2.0;
78 _l2(1, 2, 1, 2) =
_c2[3] / 2.0;
79 _l2(2, 1, 1, 2) =
_c2[3] / 2.0;
80 _l2(2, 1, 2, 1) =
_c2[3] / 2.0;
88 return _b * stress.trace() +
143 return a /
a.L2norm();
RankFourTensorTempl< Real > outerProduct(const RankTwoTensorTempl< Real > &b) const
Real dfj3_dj2(const Real j2, const Real j3) const
derivative of dphi_dJ3 with respect to J2
Real dfj2_dj3(const Real j2, const Real j3) const
derivative of dphi_dJ2 with respect to J3
Real generalSecondInvariant() const
RankFourTensor _l1
Transformation tensor from the stress tensor to the deviatoric stress tensor for J2.
Real dfj3_dj3(const Real j2, const Real j3) const
derivative of dphi_dJ3 with respect to J3
RankTwoTensorTempl< T > innerProductTranspose(const RankTwoTensorTempl< T > &) const
const bool _associative
Flag for flow-rule, true if not specified.
const Real _b
A constant to model the influence of pressure.
RankTwoTensor dyieldFunction_dstress(const RankTwoTensor &stress, Real intnl) const override
Tensor derivative of the yield_function with respect to the stress tensor.
SolidMechanicsPlasticOrthotropic(const InputParameters ¶meters)
RankTwoTensor dI_sigma() const
derivative of the trace with respect to sigma rank two tensor
static InputParameters validParams()
RankTwoTensor dj2_dSkl(const RankTwoTensor &stress) const
derivative of the second invariant with respect to the stress deviatoric tensor
Real dphi_dj2(const Real j2, const Real j3) const
derivative of phi with respect to J2, phi is b*I1 + (J2^{3/2} - c*J3)^{1/3}
virtual RankFourTensor dflowPotential_dstress(const RankTwoTensor &stress, Real intnl) const override
The derivative of the flow potential with respect to stress.
Real dphi_dj3(const Real j2, const Real j3) const
derivative of phi with respect to J3
Orthotropic plasticity model from Yoon (2013) the name of the paper is "Asymmetric yield function bas...
RankTwoTensor flowPotential(const RankTwoTensor &stress, Real intnl) const override
Receives the flag for associative or non-associative and calculates the flow potential accordingly...
RankFourTensor dflowPotential_dstress(const RankTwoTensor &stress, Real intnl) const override
Tensor derivative of the tensor derivative of the yield_function with respect to the stress tensor...
Real _c
A constant to model the influence of strength differential effect.
RankFourTensor _l2
Transformation tensor from the stress tensor to the deviatoric stress tensor for J3.
virtual Real yieldStrength(Real intnl) const
YieldStrength.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
virtual RankTwoTensor dyieldFunction_dstress(const RankTwoTensor &stress, Real intnl) const override
The derivative of yield function with respect to stress.
RankTwoTensorTempl< Real > ddet() const
IsotropicSD plasticity model from Yoon (2013) the name of the paper is "Asymmetric yield function bas...
registerMooseObject("SolidMechanicsApp", SolidMechanicsPlasticOrthotropic)
registerMooseObjectRenamed("SolidMechanicsApp", TensorMechanicsPlasticOrthotropic, "01/01/2025 00:00", SolidMechanicsPlasticOrthotropic)
Real dfj2_dj2(const Real j2, const Real j3) const
derivative of dphi_dJ2 with respect to J2
MooseUnits pow(const MooseUnits &, int)
const std::vector< Real > _c1
The six coefficients of L prime.
const std::vector< Real > _c2
The six coefficients of L prime prime.
Real yieldFunction(const RankTwoTensor &stress, Real intnl) const override
Yield_function = a[b*I1 + (J2^{3/2} - c*J3)^{1/3}] - yield_strength.
static InputParameters validParams()