pub struct ElasticViscoplasticAdditiveElastic<C1, C2, Y1>{ /* private fields */ }Expand description
A hybrid elastic-viscoplastic constitutive model based on the additive decomposition.
Trait Implementations§
Source§impl<C1, C2, Y1> Clone for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> Clone for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
Source§fn clone(&self) -> ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
fn clone(&self) -> ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl<C1, C2, Y1> Debug for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> Debug for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
Source§impl<C1, C2, Y1> Deref for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> Deref for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
Source§impl<C1, C2, Y1> ElasticPlasticOrViscoplastic for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> ElasticPlasticOrViscoplastic for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
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>
Calculates and returns the Cauchy stress.
\boldsymbol{\sigma}(\mathbf{F},\mathbf{F}_\mathrm{p}) = \boldsymbol{\sigma}_1(\mathbf{F},\mathbf{F}_\mathrm{p}) + \boldsymbol{\sigma}_2(\mathbf{F})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>
Calculates and returns the tangent stiffness associated with the Cauchy stress.
\mathcal{T}(\mathbf{F},\mathbf{F}_\mathrm{p}) = \mathcal{T}_1(\mathbf{F},\mathbf{F}_\mathrm{p}) + \mathcal{T}_2(\mathbf{F})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>
Calculates and returns the first Piola-Kirchhoff stress.
\mathbf{P}(\mathbf{F},\mathbf{F}_\mathrm{p}) = \mathbf{P}_1(\mathbf{F},\mathbf{F}_\mathrm{p}) + \mathbf{P}_2(\mathbf{F})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>
Calculates and returns the tangent stiffness associated with the first Piola-Kirchhoff stress.
\mathcal{C}(\mathbf{F},\mathbf{F}_\mathrm{p}) = \mathcal{C}_1(\mathbf{F},\mathbf{F}_\mathrm{p}) + \mathcal{C}_2(\mathbf{F})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>
Calculates and returns the second Piola-Kirchhoff stress.
\mathbf{S}(\mathbf{F},\mathbf{F}_\mathrm{p}) = \mathbf{S}_1(\mathbf{F},\mathbf{F}_\mathrm{p}) + \mathbf{S}_2(\mathbf{F})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>
Calculates and returns the tangent stiffness associated with the second Piola-Kirchhoff stress.
\mathcal{G}(\mathbf{F},\mathbf{F}_\mathrm{p}) = \mathcal{G}_1(\mathbf{F},\mathbf{F}_\mathrm{p}) + \mathcal{G}_2(\mathbf{F})Source§impl<C1, C2, Y1> ElasticViscoplastic<Y1> for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> ElasticViscoplastic<Y1> for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
Source§fn state_variables_evolution(
&self,
deformation_gradient: &DeformationGradient,
state_variables: &ViscoplasticStateVariables<Y1>,
) -> Result<ViscoplasticStateVariables<Y1>, ConstitutiveError>
fn state_variables_evolution( &self, deformation_gradient: &DeformationGradient, state_variables: &ViscoplasticStateVariables<Y1>, ) -> Result<ViscoplasticStateVariables<Y1>, ConstitutiveError>
Calculates and returns the evolution of the state variables.
Source§impl<C1, C2, Y1> From<(C1, C2)> for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> From<(C1, C2)> for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
Source§impl<C1, C2, Y1> HyperelasticViscoplastic<Y1> for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> HyperelasticViscoplastic<Y1> for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
Source§fn helmholtz_free_energy_density(
&self,
deformation_gradient: &DeformationGradient,
deformation_gradient_p: &DeformationGradientPlastic,
) -> Result<Scalar, ConstitutiveError>
fn helmholtz_free_energy_density( &self, deformation_gradient: &DeformationGradient, deformation_gradient_p: &DeformationGradientPlastic, ) -> Result<Scalar, ConstitutiveError>
Calculates and returns the Helmholtz free energy density.
a = a_1(\mathbf{F},\mathbf{F}_\mathrm{p}) + a_2(\mathbf{F})Source§impl<C1, C2, Y1> Plastic for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> Plastic for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
Source§fn initial_yield_stress(&self) -> Scalar
fn initial_yield_stress(&self) -> Scalar
Returns the initial yield stress.
Source§fn hardening_slope(&self) -> Scalar
fn hardening_slope(&self) -> Scalar
Returns the isotropic hardening slope.
Source§fn yield_stress(
&self,
equivalent_plastic_strain: Scalar,
) -> Result<Scalar, ConstitutiveError>
fn yield_stress( &self, equivalent_plastic_strain: Scalar, ) -> Result<Scalar, ConstitutiveError>
Calculates and returns the yield stress. Read more
Source§impl<C1, C2, Y1> Solid for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> Solid for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
Source§fn bulk_modulus(&self) -> Scalar
fn bulk_modulus(&self) -> Scalar
Returns the bulk modulus.
Source§fn shear_modulus(&self) -> Scalar
fn shear_modulus(&self) -> Scalar
Returns the shear modulus.
Source§fn jacobian<const I: usize, const J: usize>(
&self,
deformation_gradient: &DeformationGradientGeneral<I, J>,
) -> Result<Scalar, ConstitutiveError>
fn jacobian<const I: usize, const J: usize>( &self, deformation_gradient: &DeformationGradientGeneral<I, J>, ) -> Result<Scalar, ConstitutiveError>
Calculates and returns the Jacobian.
Source§impl<C1, C2, Y1> Viscoplastic<Y1> for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> Viscoplastic<Y1> for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
Source§fn initial_state(&self) -> ViscoplasticStateVariables<Y1>
fn initial_state(&self) -> ViscoplasticStateVariables<Y1>
Returns the initial state of the variables.
Source§fn plastic_evolution(
&self,
mandel_stress: MandelStressElastic,
state_variables: &ViscoplasticStateVariables<Y1>,
) -> Result<ViscoplasticStateVariables<Y1>, ConstitutiveError>
fn plastic_evolution( &self, mandel_stress: MandelStressElastic, state_variables: &ViscoplasticStateVariables<Y1>, ) -> Result<ViscoplasticStateVariables<Y1>, ConstitutiveError>
Calculates and returns the plastic evolution. Read more
Source§fn rate_sensitivity(&self) -> Scalar
fn rate_sensitivity(&self) -> Scalar
Returns the rate_sensitivity parameter.
Source§fn reference_flow_rate(&self) -> Scalar
fn reference_flow_rate(&self) -> Scalar
Returns the reference flow rate.
Source§fn plastic_stretching_rate(
&self,
deviatoric_mandel_stress: MandelStressElastic,
yield_stress: Scalar,
) -> Result<StretchingRatePlastic, ConstitutiveError>
fn plastic_stretching_rate( &self, deviatoric_mandel_stress: MandelStressElastic, yield_stress: Scalar, ) -> Result<StretchingRatePlastic, ConstitutiveError>
Calculates and returns the rate of plastic stretching. Read more
Auto Trait Implementations§
impl<C1, C2, Y1> Freeze for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> RefUnwindSafe for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> Send for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> Sync for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> Unpin for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
impl<C1, C2, Y1> UnwindSafe for ElasticViscoplasticAdditiveElastic<C1, C2, Y1>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<C, Y> FirstOrderMinimize<Y> for Cwhere
C: HyperelasticViscoplastic<Y>,
Y: Tensor,
impl<C, Y> FirstOrderMinimize<Y> for Cwhere
C: HyperelasticViscoplastic<Y>,
Y: Tensor,
Source§fn minimize(
&self,
applied_load: AppliedLoad<'_>,
integrator: impl ExplicitDaeFirstOrderMinimize<f64, TensorTuple<TensorRank2<3, 2, 0>, Y>, TensorRank2<3, 1, 0>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>, TensorVector<TensorRank2<3, 1, 0>>>,
solver: impl FirstOrderOptimization<f64, TensorRank2<3, 1, 0>>,
) -> Result<(Vector, TensorVector<TensorRank2<3, 1, 0>>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>), ConstitutiveError>
fn minimize( &self, applied_load: AppliedLoad<'_>, integrator: impl ExplicitDaeFirstOrderMinimize<f64, TensorTuple<TensorRank2<3, 2, 0>, Y>, TensorRank2<3, 1, 0>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>, TensorVector<TensorRank2<3, 1, 0>>>, solver: impl FirstOrderOptimization<f64, TensorRank2<3, 1, 0>>, ) -> Result<(Vector, TensorVector<TensorRank2<3, 1, 0>>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>), ConstitutiveError>
Solve for the unknown components of the deformation gradients under an applied load. Read more
Source§impl<C, Y> FirstOrderRoot<Y> for Cwhere
C: ElasticViscoplastic<Y>,
Y: Tensor,
impl<C, Y> FirstOrderRoot<Y> for Cwhere
C: ElasticViscoplastic<Y>,
Y: Tensor,
Source§fn root(
&self,
applied_load: AppliedLoad<'_>,
integrator: impl ExplicitDaeFirstOrderRoot<TensorRank2<3, 1, 0>, TensorRank4<3, 1, 0, 1, 0>, TensorTuple<TensorRank2<3, 2, 0>, Y>, TensorRank2<3, 1, 0>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>, TensorVector<TensorRank2<3, 1, 0>>>,
solver: impl FirstOrderRootFinding<TensorRank2<3, 1, 0>, TensorRank4<3, 1, 0, 1, 0>, TensorRank2<3, 1, 0>>,
) -> Result<(Vector, TensorVector<TensorRank2<3, 1, 0>>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>), ConstitutiveError>
fn root( &self, applied_load: AppliedLoad<'_>, integrator: impl ExplicitDaeFirstOrderRoot<TensorRank2<3, 1, 0>, TensorRank4<3, 1, 0, 1, 0>, TensorTuple<TensorRank2<3, 2, 0>, Y>, TensorRank2<3, 1, 0>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>, TensorVector<TensorRank2<3, 1, 0>>>, solver: impl FirstOrderRootFinding<TensorRank2<3, 1, 0>, TensorRank4<3, 1, 0, 1, 0>, TensorRank2<3, 1, 0>>, ) -> Result<(Vector, TensorVector<TensorRank2<3, 1, 0>>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>), ConstitutiveError>
Solve for the unknown components of the deformation gradients under an applied load. Read more
Source§impl<C, Y> SecondOrderMinimize<Y> for Cwhere
C: HyperelasticViscoplastic<Y>,
Y: Tensor,
impl<C, Y> SecondOrderMinimize<Y> for Cwhere
C: HyperelasticViscoplastic<Y>,
Y: Tensor,
Source§fn minimize(
&self,
applied_load: AppliedLoad<'_>,
integrator: impl ExplicitDaeSecondOrderMinimize<f64, TensorRank2<3, 1, 0>, TensorRank4<3, 1, 0, 1, 0>, TensorTuple<TensorRank2<3, 2, 0>, Y>, TensorRank2<3, 1, 0>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>, TensorVector<TensorRank2<3, 1, 0>>>,
solver: impl SecondOrderOptimization<f64, TensorRank2<3, 1, 0>, TensorRank4<3, 1, 0, 1, 0>, TensorRank2<3, 1, 0>>,
) -> Result<(Vector, TensorVector<TensorRank2<3, 1, 0>>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>), ConstitutiveError>
fn minimize( &self, applied_load: AppliedLoad<'_>, integrator: impl ExplicitDaeSecondOrderMinimize<f64, TensorRank2<3, 1, 0>, TensorRank4<3, 1, 0, 1, 0>, TensorTuple<TensorRank2<3, 2, 0>, Y>, TensorRank2<3, 1, 0>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>, TensorVector<TensorRank2<3, 1, 0>>>, solver: impl SecondOrderOptimization<f64, TensorRank2<3, 1, 0>, TensorRank4<3, 1, 0, 1, 0>, TensorRank2<3, 1, 0>>, ) -> Result<(Vector, TensorVector<TensorRank2<3, 1, 0>>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>), ConstitutiveError>
Solve for the unknown components of the deformation gradients under an applied load. Read more
Source§impl<C, Y> ZerothOrderRoot<Y> for Cwhere
C: ElasticViscoplastic<Y>,
Y: Tensor,
impl<C, Y> ZerothOrderRoot<Y> for Cwhere
C: ElasticViscoplastic<Y>,
Y: Tensor,
Source§fn root(
&self,
applied_load: AppliedLoad<'_>,
integrator: impl ExplicitDaeZerothOrderRoot<TensorTuple<TensorRank2<3, 2, 0>, Y>, TensorRank2<3, 1, 0>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>, TensorVector<TensorRank2<3, 1, 0>>>,
solver: impl ZerothOrderRootFinding<TensorRank2<3, 1, 0>>,
) -> Result<(Vector, TensorVector<TensorRank2<3, 1, 0>>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>), ConstitutiveError>
fn root( &self, applied_load: AppliedLoad<'_>, integrator: impl ExplicitDaeZerothOrderRoot<TensorTuple<TensorRank2<3, 2, 0>, Y>, TensorRank2<3, 1, 0>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>, TensorVector<TensorRank2<3, 1, 0>>>, solver: impl ZerothOrderRootFinding<TensorRank2<3, 1, 0>>, ) -> Result<(Vector, TensorVector<TensorRank2<3, 1, 0>>, TensorVector<TensorTuple<TensorRank2<3, 2, 0>, Y>>), ConstitutiveError>
Solve for the unknown components of the deformation gradients under an applied load. Read more