pub struct Multiplicative<C1, C2>(/* private fields */);Expand description
A hybrid constitutive model based on the multiplicative decomposition.
Trait Implementations§
Source§impl<C1: Clone, C2: Clone> Clone for Multiplicative<C1, C2>
impl<C1: Clone, C2: Clone> Clone for Multiplicative<C1, C2>
Source§fn clone(&self) -> Multiplicative<C1, C2>
fn clone(&self) -> Multiplicative<C1, C2>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<C1, C2> Debug for Multiplicative<C1, C2>
impl<C1, C2> Debug for Multiplicative<C1, C2>
Source§impl<C1, C2> Elastic for Multiplicative<C1, C2>
impl<C1, C2> Elastic for Multiplicative<C1, C2>
Source§fn cauchy_stress(
&self,
deformation_gradient: &DeformationGradient,
) -> Result<CauchyStress, ConstitutiveError>
fn cauchy_stress( &self, deformation_gradient: &DeformationGradient, ) -> Result<CauchyStress, ConstitutiveError>
Calculates and returns the Cauchy stress.
\boldsymbol{\sigma}(\mathbf{F}) = \frac{1}{J_2}\,\boldsymbol{\sigma}_1(\mathbf{F}_1)Source§fn cauchy_tangent_stiffness(
&self,
_: &DeformationGradient,
) -> Result<CauchyTangentStiffness, ConstitutiveError>
fn cauchy_tangent_stiffness( &self, _: &DeformationGradient, ) -> Result<CauchyTangentStiffness, ConstitutiveError>
Dummy method that will panic.
Source§fn first_piola_kirchhoff_stress(
&self,
deformation_gradient: &DeformationGradient,
) -> Result<FirstPiolaKirchhoffStress, ConstitutiveError>
fn first_piola_kirchhoff_stress( &self, deformation_gradient: &DeformationGradient, ) -> Result<FirstPiolaKirchhoffStress, ConstitutiveError>
Calculates and returns the first Piola-Kirchhoff stress.
\mathbf{P}(\mathbf{F}) = \mathbf{P}_1(\mathbf{F}_1)\cdot\mathbf{F}_2^{-T}Source§fn first_piola_kirchhoff_tangent_stiffness(
&self,
_: &DeformationGradient,
) -> Result<FirstPiolaKirchhoffTangentStiffness, ConstitutiveError>
fn first_piola_kirchhoff_tangent_stiffness( &self, _: &DeformationGradient, ) -> Result<FirstPiolaKirchhoffTangentStiffness, ConstitutiveError>
Dummy method that will panic.
Source§fn second_piola_kirchhoff_stress(
&self,
deformation_gradient: &DeformationGradient,
) -> Result<SecondPiolaKirchhoffStress, ConstitutiveError>
fn second_piola_kirchhoff_stress( &self, deformation_gradient: &DeformationGradient, ) -> Result<SecondPiolaKirchhoffStress, ConstitutiveError>
Calculates and returns the second Piola-Kirchhoff stress.
\mathbf{S}(\mathbf{F}) = \mathbf{F}_2^{-1}\cdot\mathbf{S}_1(\mathbf{F}_1)\cdot\mathbf{F}_2^{-T}Source§fn second_piola_kirchhoff_tangent_stiffness(
&self,
_: &DeformationGradient,
) -> Result<SecondPiolaKirchhoffTangentStiffness, ConstitutiveError>
fn second_piola_kirchhoff_tangent_stiffness( &self, _: &DeformationGradient, ) -> Result<SecondPiolaKirchhoffTangentStiffness, ConstitutiveError>
Dummy method that will panic.
Source§impl<C1, C2> ElasticIV<TensorRank2<3, 2, 0>, TensorRank4<3, 2, 0, 1, 0>, TensorRank4<3, 1, 0, 2, 0>, TensorRank4<3, 2, 0, 2, 0>> for Multiplicative<C1, C2>
impl<C1, C2> ElasticIV<TensorRank2<3, 2, 0>, TensorRank4<3, 2, 0, 1, 0>, TensorRank4<3, 1, 0, 2, 0>, TensorRank4<3, 2, 0, 2, 0>> for Multiplicative<C1, C2>
Source§fn cauchy_stress_foo(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_2: &DeformationGradient2,
) -> Result<CauchyStress, ConstitutiveError>
fn cauchy_stress_foo( &self, deformation_gradient: &DeformationGradient, deformation_gradient_2: &DeformationGradient2, ) -> Result<CauchyStress, ConstitutiveError>
Calculates and returns the Cauchy stress.
\boldsymbol{\sigma} = \frac{1}{J_2}\,\boldsymbol{\sigma}_1Source§fn cauchy_tangent_stiffness_foo(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_2: &DeformationGradient2,
) -> Result<CauchyTangentStiffness, ConstitutiveError>
fn cauchy_tangent_stiffness_foo( &self, deformation_gradient: &DeformationGradient, deformation_gradient_2: &DeformationGradient2, ) -> Result<CauchyTangentStiffness, ConstitutiveError>
Calculates and returns the tangent stiffness associated with the Cauchy stress.
\boldsymbol{\mathcal{T}} = \frac{1}{J_2}\,\boldsymbol{\mathcal{T}}_1\cdot\mathbf{F}_2^{-T}Source§fn first_piola_kirchhoff_stress_foo(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_2: &DeformationGradient2,
) -> Result<FirstPiolaKirchhoffStress, ConstitutiveError>
fn first_piola_kirchhoff_stress_foo( &self, deformation_gradient: &DeformationGradient, deformation_gradient_2: &DeformationGradient2, ) -> Result<FirstPiolaKirchhoffStress, ConstitutiveError>
Calculates and returns the first Piola-Kirchhoff stress.
\mathbf{P} = \mathbf{P}_1\cdot\mathbf{F}_2^{-T}Source§fn second_piola_kirchhoff_stress_foo(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_2: &DeformationGradient2,
) -> Result<SecondPiolaKirchhoffStress, ConstitutiveError>
fn second_piola_kirchhoff_stress_foo( &self, deformation_gradient: &DeformationGradient, deformation_gradient_2: &DeformationGradient2, ) -> Result<SecondPiolaKirchhoffStress, ConstitutiveError>
Calculates and returns the second Piola-Kirchhoff stress.
\mathbf{S} = \mathbf{F}_2^{-1}\cdot\mathbf{S}_1\cdot\mathbf{F}_2^{-T}Source§fn internal_variables_residual(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_2: &DeformationGradient2,
) -> Result<DeformationGradient2, ConstitutiveError>
fn internal_variables_residual( &self, deformation_gradient: &DeformationGradient, deformation_gradient_2: &DeformationGradient2, ) -> Result<DeformationGradient2, ConstitutiveError>
Calculates and returns the residual associated with the second deformation gradient.
\mathbf{R} = \mathbf{P}_2 - \mathbf{M}_1\cdot\mathbf{F}_2^{-T}Source§fn internal_variables_tangents(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_2: &DeformationGradient2,
) -> Result<(TensorRank4<3, 2, 0, 1, 0>, TensorRank4<3, 1, 0, 2, 0>, FirstPiolaKirchhoffTangentStiffness2), ConstitutiveError>
fn internal_variables_tangents( &self, deformation_gradient: &DeformationGradient, deformation_gradient_2: &DeformationGradient2, ) -> Result<(TensorRank4<3, 2, 0, 1, 0>, TensorRank4<3, 1, 0, 2, 0>, FirstPiolaKirchhoffTangentStiffness2), ConstitutiveError>
Calculates and returns the tangents associated with the internal variables.
\frac{\partial P_{iJ}}{\partial F_{KL}^2} = -P_{iL}F_{KJ}^{2-T} - \mathcal{C}_{iJmL}F_{mK}^1\frac{\partial R_{IJ}}{\partial F_{kL}} = -F_{IL}^{2-T}P_{kJ} - F_{mI}^1\mathcal{C}_{mJkL}\frac{\partial R_{IJ}}{\partial F_{KL}^2} = \mathcal{C}_{IJKL}^2 + F_{IM}^1P_{ML}{F_{KJ}^{2-T}} - \frac{\partial R_{IJ}}{\partial F_{mL}}\,F_{mK}^1Source§fn internal_variables_initial(&self) -> DeformationGradient2
fn internal_variables_initial(&self) -> DeformationGradient2
Source§fn internal_variables_constraints(&self) -> (&[usize], usize)
fn internal_variables_constraints(&self) -> (&[usize], usize)
Source§fn first_piola_kirchhoff_tangent_stiffness_foo(
&self,
deformation_gradient: &DeformationGradient,
internal_variables: &V,
) -> Result<FirstPiolaKirchhoffTangentStiffness, ConstitutiveError>
fn first_piola_kirchhoff_tangent_stiffness_foo( &self, deformation_gradient: &DeformationGradient, internal_variables: &V, ) -> Result<FirstPiolaKirchhoffTangentStiffness, ConstitutiveError>
Source§fn second_piola_kirchhoff_tangent_stiffness_foo(
&self,
deformation_gradient: &DeformationGradient,
internal_variables: &V,
) -> Result<SecondPiolaKirchhoffTangentStiffness, ConstitutiveError>
fn second_piola_kirchhoff_tangent_stiffness_foo( &self, deformation_gradient: &DeformationGradient, internal_variables: &V, ) -> Result<SecondPiolaKirchhoffTangentStiffness, ConstitutiveError>
Source§impl<C1, C2> ElasticViscoplastic for Multiplicative<C1, C2>where
C1: Elastic,
C2: Viscoplastic,
impl<C1, C2> ElasticViscoplastic for Multiplicative<C1, C2>where
C1: Elastic,
C2: Viscoplastic,
Source§fn cauchy_stress(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_p: &DeformationGradientPlastic,
) -> Result<CauchyStress, ConstitutiveError>
fn cauchy_stress( &self, deformation_gradient: &DeformationGradient, deformation_gradient_p: &DeformationGradientPlastic, ) -> Result<CauchyStress, ConstitutiveError>
Source§fn cauchy_tangent_stiffness(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_p: &DeformationGradientPlastic,
) -> Result<CauchyTangentStiffness, ConstitutiveError>
fn cauchy_tangent_stiffness( &self, deformation_gradient: &DeformationGradient, deformation_gradient_p: &DeformationGradientPlastic, ) -> Result<CauchyTangentStiffness, ConstitutiveError>
Source§fn first_piola_kirchhoff_stress(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_p: &DeformationGradientPlastic,
) -> Result<FirstPiolaKirchhoffStress, ConstitutiveError>
fn first_piola_kirchhoff_stress( &self, deformation_gradient: &DeformationGradient, deformation_gradient_p: &DeformationGradientPlastic, ) -> Result<FirstPiolaKirchhoffStress, ConstitutiveError>
Source§fn first_piola_kirchhoff_tangent_stiffness(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_p: &DeformationGradientPlastic,
) -> Result<FirstPiolaKirchhoffTangentStiffness, ConstitutiveError>
fn first_piola_kirchhoff_tangent_stiffness( &self, deformation_gradient: &DeformationGradient, deformation_gradient_p: &DeformationGradientPlastic, ) -> Result<FirstPiolaKirchhoffTangentStiffness, ConstitutiveError>
Source§fn second_piola_kirchhoff_stress(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_p: &DeformationGradientPlastic,
) -> Result<SecondPiolaKirchhoffStress, ConstitutiveError>
fn second_piola_kirchhoff_stress( &self, deformation_gradient: &DeformationGradient, deformation_gradient_p: &DeformationGradientPlastic, ) -> Result<SecondPiolaKirchhoffStress, ConstitutiveError>
Source§fn second_piola_kirchhoff_tangent_stiffness(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_p: &DeformationGradientPlastic,
) -> Result<SecondPiolaKirchhoffTangentStiffness, ConstitutiveError>
fn second_piola_kirchhoff_tangent_stiffness( &self, deformation_gradient: &DeformationGradient, deformation_gradient_p: &DeformationGradientPlastic, ) -> Result<SecondPiolaKirchhoffTangentStiffness, ConstitutiveError>
Source§fn state_variables_evolution(
&self,
deformation_gradient: &DeformationGradient,
state_variables: &StateVariables,
) -> Result<StateVariables, ConstitutiveError>
fn state_variables_evolution( &self, deformation_gradient: &DeformationGradient, state_variables: &StateVariables, ) -> Result<StateVariables, ConstitutiveError>
Source§impl<C1, C2> From<(C1, C2)> for Multiplicative<C1, C2>
impl<C1, C2> From<(C1, C2)> for Multiplicative<C1, C2>
Source§impl<C1, C2> Hyperelastic for Multiplicative<C1, C2>where
C1: Hyperelastic,
C2: Hyperelastic,
impl<C1, C2> Hyperelastic for Multiplicative<C1, C2>where
C1: Hyperelastic,
C2: Hyperelastic,
Source§fn helmholtz_free_energy_density(
&self,
deformation_gradient: &DeformationGradient,
) -> Result<Scalar, ConstitutiveError>
fn helmholtz_free_energy_density( &self, deformation_gradient: &DeformationGradient, ) -> Result<Scalar, ConstitutiveError>
Calculates and returns the Helmholtz free energy density.
a(\mathbf{F}) = a_1(\mathbf{F}_1) + a_2(\mathbf{F}_2)