pub trait SecondOrderMinimize<V, T1, T2, T3>{
type Variables;
// Required method
fn minimize(
&self,
applied_load: AppliedLoad,
solver: impl SecondOrderOptimization<Scalar, Self::Variables, TensorTuple<FirstPiolaKirchhoffTangentStiffness, TensorTuple<T1, TensorTuple<T2, T3>>>, Self::Variables>,
) -> Result<(DeformationGradient, V), ConstitutiveError>;
}Expand description
Second-order minimization methods for hyperelastic solid constitutive models with internal variables.
Required Associated Types§
Required Methods§
Sourcefn minimize(
&self,
applied_load: AppliedLoad,
solver: impl SecondOrderOptimization<Scalar, Self::Variables, TensorTuple<FirstPiolaKirchhoffTangentStiffness, TensorTuple<T1, TensorTuple<T2, T3>>>, Self::Variables>,
) -> Result<(DeformationGradient, V), ConstitutiveError>
fn minimize( &self, applied_load: AppliedLoad, solver: impl SecondOrderOptimization<Scalar, Self::Variables, TensorTuple<FirstPiolaKirchhoffTangentStiffness, TensorTuple<T1, TensorTuple<T2, T3>>>, Self::Variables>, ) -> Result<(DeformationGradient, V), ConstitutiveError>
Solve for the unknown components of the deformation gradient under an applied load.
\Pi(\mathbf{F},\boldsymbol{\lambda}) = a(\mathbf{F}) - \boldsymbol{\lambda}:(\mathbf{F} - \mathbf{F}_0) - \mathbf{P}_0:\mathbf{F}Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.