pub struct Element<const G: usize, const N: usize> { /* private fields */ }Trait Implementations§
Source§impl<C, const G: usize, const N: usize> ElasticFiniteElement<C, G, N> for Element<G, N>where
C: Elastic,
impl<C, const G: usize, const N: usize> ElasticFiniteElement<C, G, N> for Element<G, N>where
C: Elastic,
fn nodal_forces( &self, constitutive_model: &C, nodal_coordinates: &ElementNodalCoordinates<N>, ) -> Result<ElementNodalForcesSolid<N>, FiniteElementError>
fn nodal_stiffnesses( &self, constitutive_model: &C, nodal_coordinates: &ElementNodalCoordinates<N>, ) -> Result<ElementNodalStiffnessesSolid<N>, FiniteElementError>
Source§impl<C, const G: usize, const N: usize> ElasticHyperviscousFiniteElement<C, G, N> for Element<G, N>where
C: ElasticHyperviscous,
impl<C, const G: usize, const N: usize> ElasticHyperviscousFiniteElement<C, G, N> for Element<G, N>where
C: ElasticHyperviscous,
fn viscous_dissipation( &self, constitutive_model: &C, nodal_coordinates: &ElementNodalCoordinates<N>, nodal_velocities: &ElementNodalVelocities<N>, ) -> Result<Scalar, FiniteElementError>
fn dissipation_potential( &self, constitutive_model: &C, nodal_coordinates: &ElementNodalCoordinates<N>, nodal_velocities: &ElementNodalVelocities<N>, ) -> Result<Scalar, FiniteElementError>
Source§impl<C, const G: usize, const N: usize> ElasticViscoplasticFiniteElement<C, G, N> for Element<G, N>where
C: ElasticViscoplastic,
impl<C, const G: usize, const N: usize> ElasticViscoplasticFiniteElement<C, G, N> for Element<G, N>where
C: ElasticViscoplastic,
fn nodal_forces( &self, constitutive_model: &C, nodal_coordinates: &ElementNodalCoordinates<N>, state_variables: &ViscoplasticStateVariables<G>, ) -> Result<ElementNodalForcesSolid<N>, FiniteElementError>
fn nodal_stiffnesses( &self, constitutive_model: &C, nodal_coordinates: &ElementNodalCoordinates<N>, state_variables: &ViscoplasticStateVariables<G>, ) -> Result<ElementNodalStiffnessesSolid<N>, FiniteElementError>
fn state_variables_evolution( &self, constitutive_model: &C, nodal_coordinates: &ElementNodalCoordinates<N>, state_variables: &ViscoplasticStateVariables<G>, ) -> Result<ViscoplasticStateVariables<G>, FiniteElementError>
Source§impl<const G: usize, const N: usize> From<TensorList<TensorRank1<3, 0>, N>> for Element<G, N>where
Self: FiniteElement<G, N>,
impl<const G: usize, const N: usize> From<TensorList<TensorRank1<3, 0>, N>> for Element<G, N>where
Self: FiniteElement<G, N>,
Source§fn from(
reference_nodal_coordinates: ElementNodalReferenceCoordinates<N>,
) -> Self
fn from( reference_nodal_coordinates: ElementNodalReferenceCoordinates<N>, ) -> Self
Converts to this type from the input type.
Source§impl<C, const G: usize, const N: usize> HyperelasticFiniteElement<C, G, N> for Element<G, N>where
C: Hyperelastic,
impl<C, const G: usize, const N: usize> HyperelasticFiniteElement<C, G, N> for Element<G, N>where
C: Hyperelastic,
fn helmholtz_free_energy( &self, constitutive_model: &C, nodal_coordinates: &ElementNodalCoordinates<N>, ) -> Result<Scalar, FiniteElementError>
Source§impl<C, const G: usize, const N: usize> HyperviscoelasticFiniteElement<C, G, N> for Element<G, N>where
C: Hyperviscoelastic,
impl<C, const G: usize, const N: usize> HyperviscoelasticFiniteElement<C, G, N> for Element<G, N>where
C: Hyperviscoelastic,
fn helmholtz_free_energy( &self, constitutive_model: &C, nodal_coordinates: &ElementNodalCoordinates<N>, ) -> Result<Scalar, FiniteElementError>
Source§impl<const G: usize, const N: usize> SolidFiniteElement<G, N> for Element<G, N>
impl<const G: usize, const N: usize> SolidFiniteElement<G, N> for Element<G, N>
fn deformation_gradients( &self, nodal_coordinates: &ElementNodalCoordinates<N>, ) -> DeformationGradientList<G>
fn deformation_gradient_rates( &self, _: &ElementNodalCoordinates<N>, nodal_velocities: &ElementNodalVelocities<N>, ) -> DeformationGradientRateList<G>
fn gradient_vectors(&self) -> &GradientVectors<G, N>
fn integration_weights(&self) -> &Scalars<G>
Source§impl<C, const G: usize, const N: usize> ThermalConductionFiniteElement<C, G, N> for Element<G, N>where
C: ThermalConduction,
Self: ThermalFiniteElement<G, N>,
impl<C, const G: usize, const N: usize> ThermalConductionFiniteElement<C, G, N> for Element<G, N>where
C: ThermalConduction,
Self: ThermalFiniteElement<G, N>,
fn potential( &self, constitutive_model: &C, nodal_temperatures: &ElementNodalTemperatures<N>, ) -> Result<Scalar, FiniteElementError>
fn nodal_forces( &self, constitutive_model: &C, nodal_temperatures: &ElementNodalTemperatures<N>, ) -> Result<ElementNodalForcesThermal<N>, FiniteElementError>
fn nodal_stiffnesses( &self, constitutive_model: &C, nodal_temperatures: &ElementNodalTemperatures<N>, ) -> Result<ElementNodalStiffnessesThermal<N>, FiniteElementError>
Source§impl<const G: usize, const N: usize> ThermalFiniteElement<G, N> for Element<G, N>where
Self: Debug,
impl<const G: usize, const N: usize> ThermalFiniteElement<G, N> for Element<G, N>where
Self: Debug,
fn temperature_gradients( &self, nodal_temperatures: &ElementNodalTemperatures<N>, ) -> TemperatureGradients<G>
Source§impl<C, const G: usize, const N: usize> ViscoelasticFiniteElement<C, G, N> for Element<G, N>where
C: Viscoelastic,
impl<C, const G: usize, const N: usize> ViscoelasticFiniteElement<C, G, N> for Element<G, N>where
C: Viscoelastic,
fn nodal_forces( &self, constitutive_model: &C, nodal_coordinates: &ElementNodalCoordinates<N>, nodal_velocities: &ElementNodalVelocities<N>, ) -> Result<ElementNodalForcesSolid<N>, FiniteElementError>
fn nodal_stiffnesses( &self, constitutive_model: &C, nodal_coordinates: &ElementNodalCoordinates<N>, nodal_velocities: &ElementNodalVelocities<N>, ) -> Result<ElementNodalStiffnessesSolid<N>, FiniteElementError>
Auto Trait Implementations§
impl<const G: usize, const N: usize> Freeze for Element<G, N>
impl<const G: usize, const N: usize> RefUnwindSafe for Element<G, N>
impl<const G: usize, const N: usize> Send for Element<G, N>
impl<const G: usize, const N: usize> Sync for Element<G, N>
impl<const G: usize, const N: usize> Unpin for Element<G, N>
impl<const G: usize, const N: usize> UnwindSafe for Element<G, N>
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