39 static constexpr int dim = 3;
42 using MaterialTensor = Eigen::TensorFixedSize<ScalarType, Eigen::Sizes<dim, dim, dim, dim>>;
56 [[nodiscard]]
constexpr static std::string
nameImpl() {
return "StVenantKirchhoff"; }
63 : materialParameter_{mpt} {}
76 template <
typename Derived>
78 static_assert(Concepts::EigenMatrixOrVoigtNotation3<Derived>);
80 const ScalarType traceE = E.template segment<3>(0).sum();
82 E.template segment<3>(0).squaredNorm() + E.template segment<3>(3).squaredNorm() /
ScalarType(2.0);
83 return materialParameter_.
lambda /
ScalarType(2.0) * traceE * traceE + materialParameter_.
mu * squaredNorm;
85 const auto traceE = E.trace();
86 return materialParameter_.
lambda /
ScalarType(2.0) * traceE * traceE + materialParameter_.
mu * E.squaredNorm();
97 template <
bool voigt,
typename Derived>
99 static_assert(Concepts::EigenMatrixOrVoigtNotation3<
decltype(E.eval())>);
100 const auto& Ed = E.derived();
101 if constexpr (!voigt) {
103 static_assert(Concepts::EigenVector6<Derived>);
105 const ScalarType traceE = Ed.template segment<3>(0).sum();
106 S.diagonal().array() =
107 materialParameter_.
lambda * traceE + 2 * materialParameter_.
mu * Ed.template segment<3>(0).array();
108 S(1, 2) = S(2, 1) = materialParameter_.
mu * Ed(3);
109 S(0, 2) = S(2, 0) = materialParameter_.
mu * Ed(4);
110 S(0, 1) = S(1, 0) = materialParameter_.
mu * Ed(5);
113 static_assert(Concepts::EigenMatrix33<Derived>);
114 return (materialParameter_.
lambda * Ed.trace() * StrainMatrix::Identity() + 2 * materialParameter_.
mu * Ed)
119 static_assert(Concepts::EigenVector6<Derived>);
120 Eigen::Matrix<ScalarType, 6, 1> S;
121 const ScalarType traceE = Ed.template segment<3>(0).sum();
122 S.template segment<3>(0).array() = traceE * materialParameter_.
lambda;
123 S.template segment<3>(0) += materialParameter_.
mu * 2 * Ed.template segment<3>(0);
124 S.template segment<3>(3) =
125 materialParameter_.
mu * Ed.template segment<3>(3);
128 Eigen::Matrix<ScalarType, 6, 1> S;
129 S.template segment<3>(0).array() = Ed.trace() * materialParameter_.
lambda;
130 S.template segment<3>(0) += 2 * materialParameter_.
mu * Ed.diagonal();
131 S(3) = 2 * materialParameter_.
mu * Ed(1, 2);
132 S(4) = 2 * materialParameter_.
mu * Ed(0, 2);
133 S(5) = 2 * materialParameter_.
mu * Ed(0, 1);
147 template <
bool voigt,
typename Derived>
149 static_assert(Concepts::EigenMatrixOrVoigtNotation3<Derived>);
150 if constexpr (!voigt) {
156 Eigen::Matrix<ScalarType, 6, 6> moduli;
158 moduli.template block<3, 3>(0, 0).array() = materialParameter_.
lambda;
159 moduli.template block<3, 3>(0, 0).diagonal().array() += 2 * materialParameter_.
mu;
160 moduli.template block<3, 3>(3, 3).diagonal().array() = materialParameter_.
mu;
170 template <
typename ScalarTypeOther>
Helper for the Eigen::Tensor types.
auto symmetricIdentityFourthOrder()
Generates a symmetric identity fourth-order tensor.
Definition: tensorutils.hh:73
auto identityFourthOrder()
Generates an identity fourth-order tensor.
Definition: tensorutils.hh:114
Definition: arrudaboyce.hh:27
Interface classf or materials.
Definition: finiteelements/mechanics/materials/interface.hh:80
Implementation of the Saint Venant-Kirchhoff material model.The energy is computed as.
Definition: svk.hh:37
ST ScalarType
Definition: svk.hh:38
auto stressesImpl(const Eigen::MatrixBase< Derived > &E) const
Computes the stresses in the Saint Venant-Kirchhoff material model.
Definition: svk.hh:98
static constexpr std::string nameImpl()
Definition: svk.hh:56
static constexpr bool moduliToVoigt
Definition: svk.hh:52
LamesFirstParameterAndShearModulus MaterialParameters
Definition: svk.hh:44
static constexpr auto strainTag
Definition: svk.hh:46
static constexpr int dim
Definition: svk.hh:39
auto rebind() const
Rebinds the material to a different scalar type.
Definition: svk.hh:171
Eigen::Matrix< ScalarType, dim, dim > StrainMatrix
Definition: svk.hh:40
StrainMatrix StressMatrix
Definition: svk.hh:41
ScalarType storedEnergyImpl(const Eigen::MatrixBase< Derived > &E) const
Computes the stored energy in the Saint Venant-Kirchhoff material model.
Definition: svk.hh:77
static constexpr double derivativeFactorImpl
Definition: svk.hh:54
StVenantKirchhoffT(const MaterialParameters &mpt)
Constructor for StVenantKirchhoffT.
Definition: svk.hh:62
static constexpr bool stressAcceptsVoigt
Definition: svk.hh:51
static constexpr auto stressTag
Definition: svk.hh:47
auto tangentModuliImpl(const Eigen::MatrixBase< Derived > &) const
Computes the tangent moduli in the Saint Venant-Kirchhoff material model.
Definition: svk.hh:148
Eigen::TensorFixedSize< ScalarType, Eigen::Sizes< dim, dim, dim, dim > > MaterialTensor
Definition: svk.hh:42
static constexpr bool moduliAcceptsVoigt
Definition: svk.hh:53
static constexpr bool stressToVoigt
Definition: svk.hh:50
static constexpr bool energyAcceptsVoigt
Definition: svk.hh:49
MaterialParameters materialParametersImpl() const
Returns the material parameters stored in the material.
Definition: svk.hh:68
static constexpr auto tangentModuliTag
Definition: svk.hh:48
Definition: physicshelper.hh:54
double lambda
Definition: physicshelper.hh:55
double mu
Definition: physicshelper.hh:56
Concept defining the requirements for Eigen vectors.
Definition: utils/concepts.hh:362
Contains the Material interface class and related template functions for material properties.