SOFA API  651e7a3a
Open source framework for multi-physics simuation
sofa::component::solidmechanics::fem::hyperelastic::material::Ogden< DataTypes > Class Template Reference

#include <Ogden.h>

Inheritance diagram for sofa::component::solidmechanics::fem::hyperelastic::material::Ogden< DataTypes >:

Detailed Description

template<class DataTypes>
class sofa::component::solidmechanics::fem::hyperelastic::material::Ogden< DataTypes >

a Class that describe a generic hyperelastic material : exemple of Boyce and Arruda The material is described based on continuum mechanics and the description is independent to any discretization method like the finite element method. A material is generically described by a strain energy function and its first and second derivatives. In practice the energy is the sum of several energy terms which depends on 2 quantities : the determinant of the deformation gradient J and the right Cauchy Green deformation tensor

Static Public Attributes

static constexpr std::string_view Name = "Ogden"
 

Public Member Functions

Real getStrainEnergy (StrainInformation< DataTypes > *sinfo, const MaterialParameters< DataTypes > &param) override
 
void deriveSPKTensor (StrainInformation< DataTypes > *sinfo, const MaterialParameters< DataTypes > &param, MatrixSym &SPKTensorGeneral) override
 
void applyElasticityTensor (StrainInformation< DataTypes > *sinfo, const MaterialParameters< DataTypes > &param, const MatrixSym &inputTensor, MatrixSym &outputTensor) override
 
void ElasticityTensor (StrainInformation< DataTypes > *sinfo, const MaterialParameters< DataTypes > &param, Matrix6 &outputTensor) override
 
- Public Member Functions inherited from sofa::component::solidmechanics::fem::hyperelastic::material::HyperelasticMaterial< DataTypes >
virtual ~HyperelasticMaterial ()
 

Attribute details

◆ Name

template<class DataTypes >
constexpr std::string_view sofa::component::solidmechanics::fem::hyperelastic::material::Ogden< DataTypes >::Name = "Ogden"
staticconstexpr

Function details

◆ applyElasticityTensor()

template<class DataTypes >
void sofa::component::solidmechanics::fem::hyperelastic::material::Ogden< DataTypes >::applyElasticityTensor ( StrainInformation< DataTypes > *  ,
const MaterialParameters< DataTypes > &  ,
const MatrixSym ,
MatrixSym  
)
inlineoverridevirtual

computes the Elasticity Tensor of the current configuration

Reimplemented from sofa::component::solidmechanics::fem::hyperelastic::material::HyperelasticMaterial< DataTypes >.

◆ deriveSPKTensor()

template<class DataTypes >
void sofa::component::solidmechanics::fem::hyperelastic::material::Ogden< DataTypes >::deriveSPKTensor ( StrainInformation< DataTypes > *  ,
const MaterialParameters< DataTypes > &  ,
MatrixSym  
)
inlineoverridevirtual

computes the second Piola Kirchhoff stress tensor of the current configuration

Reimplemented from sofa::component::solidmechanics::fem::hyperelastic::material::HyperelasticMaterial< DataTypes >.

◆ ElasticityTensor()

template<class DataTypes >
void sofa::component::solidmechanics::fem::hyperelastic::material::Ogden< DataTypes >::ElasticityTensor ( StrainInformation< DataTypes > *  sinfo,
const MaterialParameters< DataTypes > &  param,
Matrix6 outputTensor 
)
inlineoverridevirtual

◆ getStrainEnergy()

template<class DataTypes >
Real sofa::component::solidmechanics::fem::hyperelastic::material::Ogden< DataTypes >::getStrainEnergy ( StrainInformation< DataTypes > *  ,
const MaterialParameters< DataTypes > &   
)
inlineoverridevirtual

returns the strain energy of the current configuration

Reimplemented from sofa::component::solidmechanics::fem::hyperelastic::material::HyperelasticMaterial< DataTypes >.