version 0.4.1
gent.hh
Go to the documentation of this file.
1// SPDX-FileCopyrightText: 2021-2025 The Ikarus Developers mueller@ibb.uni-stuttgart.de
2// SPDX-License-Identifier: LGPL-3.0-or-later
3
10#pragma once
11
16
17namespace Ikarus {
18
21{
22 double mu;
23 double Jm;
24};
25} // namespace Ikarus
26
27namespace Ikarus::Materials {
28
52template <typename ST_>
53struct GentT
54{
55 static constexpr int dim = 3;
56 using ScalarType = ST_;
57
58 template <typename ST = ScalarType>
59 using PrincipalStretches = Eigen::Vector<ST, 3>;
60
61 template <typename ST = ScalarType>
63
64 template <typename ST = ScalarType>
65 using FirstDerivative = Eigen::Vector<ST, dim>;
66 template <typename ST = ScalarType>
67 using SecondDerivative = Eigen::Matrix<ST, dim, dim>;
68
70
72
73 [[nodiscard]] constexpr static std::string name() noexcept { return "Gent"; }
74
81 explicit GentT(const MaterialParameters& matPar)
82 : matPar_{matPar} {}
83
87 MaterialParameters materialParametersImpl() const { return matPar_; }
88
97 template <typename ST = ScalarType>
98 ST storedEnergyImpl(const PrincipalStretches<ST>& lambda) const {
99 const Invariants<ST>& invariants = Impl::invariants(lambda);
100 const auto& devInvariants = DeviatoricInvariants<PrincipalStretches<ST>>(lambda);
101 const auto W1 = devInvariants.value()[0];
102 checkJm(W1);
103 return -(matPar_.mu / 2.0) * matPar_.Jm * log(1.0 - ((W1 - 3.0) / matPar_.Jm));
104 }
105
113 template <typename ST = ScalarType>
115 const Invariants<ST>& invariants = Impl::invariants(lambda);
116 const auto& devInvariants = DeviatoricInvariants<PrincipalStretches<ST>>(lambda);
117 const auto W1 = devInvariants.value()[0];
118 const auto& dW1dLambda = devInvariants.firstDerivative().first;
119 const auto mu = matPar_.mu;
120 const auto Jm = matPar_.Jm;
121 checkJm(W1);
122
123 FirstDerivative<ST> dWdLambda = (mu * dW1dLambda * Jm) / (2.0 * (Jm - W1) + 6.0);
124
125 return dWdLambda;
126 }
127
135 template <typename ST = ScalarType>
137 const Invariants<ST>& invariants = Impl::invariants(lambda);
138 auto dS = SecondDerivative<ST>::Zero().eval();
139
140 const auto& devInvariants = DeviatoricInvariants<PrincipalStretches<ST>>(lambda);
141 const auto W1 = devInvariants.value()[0];
142 const auto& dW1dLambda = devInvariants.firstDerivative().first;
143 const auto& ddW1dLambda = devInvariants.secondDerivative().first;
144 const auto mu = matPar_.mu;
145 const auto Jm = matPar_.Jm;
146 checkJm(W1);
147
148 for (const auto i : dimensionRange())
149 for (const auto j : dimensionRange()) {
150 auto factor1 = 1.0 - ((W1 - 3.0) / Jm);
151 dS(i, j) += (mu / (2.0 * factor1)) * (ddW1dLambda(i, j) + (dW1dLambda[i] * dW1dLambda[j] / (factor1 * Jm)));
152 if (i == j)
153 dS(i, j) -= (mu / (2.0 * lambda[i] * factor1)) * dW1dLambda[i];
154 }
155
156 return dS;
157 }
158
164 template <typename STO>
165 auto rebind() const {
166 return GentT<STO>(matPar_);
167 }
168
169private:
170 MaterialParameters matPar_;
171
172 inline static constexpr auto dimensionRange() { return Dune::range(dim); }
173
174 void checkJm(ScalarType W1) const {
175 if (Dune::FloatCmp::le(matPar_.Jm, static_cast<double>(W1) - 3.0, 1e-14))
176 DUNE_THROW(Dune::InvalidStateException, "The material parameter Jm should be greater than (W1 - 3)");
177 }
178};
179
184
185} // namespace Ikarus::Materials
Helper for the Eigen::Tensor types.
helper functions used by material model implementations.
Definition of several material related enums.
Implementation of the computation of the deviatoric invariants and its derivatives.
Definition: assemblermanipulatorbuildingblocks.hh:22
Definition: arrudaboyce.hh:27
Implementation of the deviatoric invariants and its derivatives.
Definition: deviatoricinvariants.hh:35
auto value() const
Computation of value of the deviatoric invariants.
Definition: deviatoricinvariants.hh:55
< Structure representing material parameters for the Gent material model.
Definition: gent.hh:21
double mu
Denotes the shear modulus.
Definition: gent.hh:22
double Jm
Denotes a dimensionless parameter that controls the extensibility of chains.
Definition: gent.hh:23
Implementation of the Gent material model.
Definition: gent.hh:54
ST_ ScalarType
Definition: gent.hh:56
static constexpr auto stretchTag
Definition: gent.hh:71
Eigen::Vector< ST, dim > FirstDerivative
Definition: gent.hh:65
SecondDerivative< ST > secondDerivativeImpl(const PrincipalStretches< ST > &lambda) const
Computes the second derivatives of the stored energy function w.r.t. the total principal stretches.
Definition: gent.hh:136
GentT(const MaterialParameters &matPar)
Constructor for GentT.
Definition: gent.hh:81
auto rebind() const
Rebinds the material to a different scalar type.
Definition: gent.hh:165
ST storedEnergyImpl(const PrincipalStretches< ST > &lambda) const
Computes the stored energy in the Gent material model.
Definition: gent.hh:98
static constexpr std::string name() noexcept
Definition: gent.hh:73
MaterialParameters materialParametersImpl() const
Returns the material parameters stored in the material.
Definition: gent.hh:87
PrincipalStretches< ST > Invariants
Definition: gent.hh:62
Eigen::Matrix< ST, dim, dim > SecondDerivative
Definition: gent.hh:67
static constexpr int dim
Definition: gent.hh:55
FirstDerivative< ST > firstDerivativeImpl(const PrincipalStretches< ST > &lambda) const
Computes the first derivative of the stored energy function w.r.t. the total principal stretches.
Definition: gent.hh:114
Eigen::Vector< ST, 3 > PrincipalStretches
Definition: gent.hh:59
GentMatParameters MaterialParameters
Definition: gent.hh:69