G+Smo  25.01.0
Geometry + Simulation Modules
 
Loading...
Searching...
No Matches
gsMaterialMatrixTFT< dim, T, linear > Class Template Reference

Detailed Description

template<short_t dim, class T, bool linear = false>
class gismo::gsMaterialMatrixTFT< dim, T, linear >

This class defines a linear material.

Template Parameters
dimThe dimension of the problem (2 = planar, 3 = surface)
TReal type
+ Inheritance diagram for gsMaterialMatrixTFT< dim, T, linear >:
+ Collaboration diagram for gsMaterialMatrixTFT< dim, T, linear >:

Public Types

using Base = gsMaterialMatrixBaseDim< dim, T >
 Base class.
 
typedef gsFunctionSet< T >::Ptr function_ptr
 Shared pointer to a gsFunctionSet.
 
typedef gsMaterialMatrixBase< T >::Ptr material_ptr
 Shared pointer to a gsMaterialMatrixBase.
 
typedef memory::shared_ptr< gsMaterialMatrixTFTPtr
 Shared pointer for gsMaterialMatrixTFT.
 
typedef memory::unique_ptr< gsMaterialMatrixTFTuPtr
 Unique pointer for gsMaterialMatrixTFT.
 

Public Member Functions

void _computeMetricDeformed (const index_t patch, const gsMatrix< T > &u) const
 Computes metric quantities on the deformed geometry.
 
void _computeMetricUndeformed (const index_t patch, const gsMatrix< T > &u) const
 Computes metric quantities on the undeformed geometry.
 
void _computePStrain (const gsMatrix< T > &C) const
 Computes the stretch given deformation tensor C, into class members m_stretches and m_stretchDirs.
 
void _computePStress (const gsMatrix< T > &C) const
 Computes the principal stresses of a given stress tensor S, into class members m_pstress and m_pstressvec.
 
void _computeStretch (const gsMatrix< T > &C, const gsMatrix< T > &gcon_ori) const
 Computes the stretch given deformation tensor C, into class members m_stretches and m_stretchDirs.
 
std::pair< gsVector< T >, gsMatrix< T > > _evalPStrain (const gsMatrix< T > &C) const
 Computes the principal strain given deformation tensor C, into a pair.
 
std::pair< gsVector< T >, gsMatrix< T > > _evalPStress (const gsMatrix< T > &S) const
 Computes the principal stress given stress tensor S, into a pair.
 
std::pair< gsVector< T >, gsMatrix< T > > _evalStretch (const gsMatrix< T > &C, const gsMatrix< T > &gcon_ori) const
 Computes the stretch given deformation tensor C, into a pair.
 
gsMatrix< T > _getAcon_def (index_t k, T z) const
 Returns the contravariant a tensor on the deformed geometry.
 
gsMatrix< T > _getacon_def (index_t k, T z) const
 Returns the contravariant basis vector a on the deformed geometry.
 
gsMatrix< T > _getAcon_ori (index_t k, T z) const
 Returns the contravariant a tensor on the original geometry.
 
gsMatrix< T > _getacon_ori (index_t k, T z) const
 Returns the contravariant basis vector a on the original geometry.
 
gsMatrix< T > _getAcov_def (index_t k, T z) const
 Returns the covariant a tensor on the deformed geometry.
 
gsMatrix< T > _getacov_def (index_t k, T z) const
 Returns the covariant basis vector a on the deformed geometry.
 
gsMatrix< T > _getAcov_ori (index_t k, T z) const
 Returns the covariant a tensor on the original geometry.
 
gsMatrix< T > _getacov_ori (index_t k, T z) const
 Returns the covariant basis vector a on the original geometry.
 
gsMatrix< T > _getBcov_def (index_t k, T z) const
 Returns the covariant b tensor on the deformed geometry.
 
gsMatrix< T > _getBcov_ori (index_t k, T z) const
 Returns the covariant b tensor on the original geometry.
 
gsMatrix< T > _getGcon_def (index_t k, T z) const
 Returns the contravariant metric tensor on the deformed geometry.
 
gsMatrix< T > _getgcon_def (index_t k, T z) const
 Returns the contravariant basis vector g on the deformed geometry.
 
gsMatrix< T > _getGcon_ori (index_t k, T z) const
 Returns the contravariant metric tensor on the original geometry.
 
gsMatrix< T > _getgcon_ori (index_t k, T z) const
 Returns the contravariant basis vector g on the original geometry.
 
gsMatrix< T > _getGcov_def (index_t k, T z) const
 Returns the covariant metric tensor on the deformed geometry.
 
gsMatrix< T > _getgcov_def (index_t k, T z) const
 Returns the covariant basis vector g on the deformed geometry.
 
gsMatrix< T > _getGcov_ori (index_t k, T z) const
 Returns the covariant metric tensor on the original geometry.
 
gsMatrix< T > _getgcov_ori (index_t k, T z) const
 Returns the covariant basis vector g on the original geometry.
 
void _getMetric (const index_t k, const T z) const
 Gets metric quantities on the deformed and undeformed geometries.
 
void _getMetric (index_t k, T z, const gsMatrix< T > &C) const
 Gets metric quantities on the deformed and undeformed geometries.
 
void _getMetricDeformed (const index_t k, const T z) const
 Gets metric quantities on the deformed geometry.
 
void _getMetricUndeformed (const index_t k, const T z) const
 Gets metric quantities on the undeformed geometry.
 
gsMatrix< T > _getncov_def (index_t k, T z) const
 Returns the covariant n tensor on the deformed geometry.
 
gsMatrix< T > _getncov_ori (index_t k, T z) const
 Returns the covariant n tensor on the original geometry.
 
gsMatrix< T > _transformation (const gsMatrix< T > &basis1, const gsMatrix< T > &basis2) const
 Computes the stretch given deformation tensor C, into class members m_stretches and m_stretchDirs.
 
virtual void defaultOptions () override
 See gsMaterialMatrixBase for details.
 
void density_into (const index_t patch, const gsMatrix< T > &u, gsMatrix< T > &result) const override
 See gsMaterialMatrixBase for details.
 
gsMatrix< T > eval3D_CauchyPStress (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z, enum MaterialOutput out) const override
 See gsMaterialMatrixBase for details.
 
gsMatrix< T > eval3D_CauchyStress (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z, enum MaterialOutput out) const override
 See gsMaterialMatrixBase for details.
 
virtual gsMatrix< T > eval3D_CauchyVector (const index_t, const gsMatrix< T > &, const gsMatrix< T > &, enum MaterialOutput) const
 Evaluates the Cauchy Stress vector on patch on in-plane points u with height z.
 
virtual gsMatrix< T > eval3D_con2cart (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z) const override
 See gsMaterialMatrixBase for details.
 
virtual gsMatrix< T > eval3D_cov2cart (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z) const override
 See gsMaterialMatrixBase for details.
 
virtual gsMatrix< T > eval3D_deformation (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z) const override
 See gsMaterialMatrixBase for details.
 
virtual gsMatrix< T > eval3D_detF (const index_t, const gsMatrix< T > &, const gsMatrix< T > &, enum MaterialOutput) const
 { function_description }
 
virtual gsMatrix< T > eval3D_dmatrix (const index_t, const gsMatrix< T > &, const gsMatrix< T > &, enum MaterialOutput) const
 Evaluates the derivative of the matrix on patch on in-plane points u with height z.
 
gsMatrix< T > eval3D_gamma (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z, enum MaterialOutput out=MaterialOutput::Generic) const override
 See gsMaterialMatrixBase for details.
 
gsMatrix< T > eval3D_matrix (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z, enum MaterialOutput out=MaterialOutput::Generic) const override
 See gsMaterialMatrixBase for details.
 
gsMatrix< T > eval3D_pstrain (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z) const override
 See gsMaterialMatrixBase for details.
 
gsMatrix< T > eval3D_pstress (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z, enum MaterialOutput out=MaterialOutput::Generic) const override
 
virtual gsMatrix< T > eval3D_pstressDir (const index_t, const gsMatrix< T > &, const gsMatrix< T > &, enum MaterialOutput) const
 Evaluates the principal stress directions on patch on in-plane points u with height z.
 
virtual gsMatrix< T > eval3D_pstressTransform (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z) const
 Provides the transformation of the principle stresses.
 
gsMatrix< T > eval3D_pstretch (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z) const override
 See gsMaterialMatrixBase for details.
 
gsMatrix< T > eval3D_pstretchDir (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z) const override
 See gsMaterialMatrixBase for details.
 
virtual gsMatrix< T > eval3D_pstretchTransform (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z) const
 Provides the transformation of the principle stretches.
 
virtual gsMatrix< T > eval3D_spec2con (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z) const override
 See gsMaterialMatrixBase for details.
 
virtual gsMatrix< T > eval3D_spec2cov (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z) const override
 See gsMaterialMatrixBase for details.
 
gsMatrix< T > eval3D_strain (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z) const override
 See gsMaterialMatrixBase for details.
 
virtual gsMatrix< T > eval3D_strain (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z) const override
 See gsMaterialMatrixBase for details.
 
virtual gsMatrix< T > eval3D_strain (const index_t, const gsMatrix< T > &, const gsMatrix< T > &) const
 { function_description }
 
gsMatrix< T > eval3D_stress (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z, enum MaterialOutput out) const override
 See gsMaterialMatrixBase for details.
 
virtual gsMatrix< T > eval3D_tensionfield (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z, enum MaterialOutput out) const override
 See gsMaterialMatrixBase for details.
 
gsMatrix< T > eval3D_tensionfield (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z, enum MaterialOutput out=MaterialOutput::Generic) const override
 See gsMaterialMatrixBase for details.
 
virtual gsMatrix< T > eval3D_tensionfield (const index_t, const gsMatrix< T > &, const gsMatrix< T > &, enum MaterialOutput) const
 to do
 
gsMatrix< T > eval3D_theta (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z, enum MaterialOutput out=MaterialOutput::Generic) const override
 See gsMaterialMatrixBase for details.
 
gsMatrix< T > eval3D_vector (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z, enum MaterialOutput out=MaterialOutput::Generic) const override
 See gsMaterialMatrixBase for details.
 
gsMatrix< T > eval_theta (const gsMatrix< T > &Cs, const gsMatrix< T > &Ns, const gsMatrix< T > &Es) const
 Computes theta.
 
virtual const function_ptr getDensity () const
 Gets the Density.
 
virtual const function_ptr getParameter (const index_t i) const
 Gets parameter i.
 
virtual const function_ptr getThickness () const
 Gets the Density.
 
 gsMaterialMatrixTFT (const material_ptr &materialMatrix)
 Constructs a TFT material matrix using a reference to another material matrix.
 
 gsMaterialMatrixTFT (gsMaterialMatrixBase< T > &materialMatrix)
 Constructs a TFT material matrix using a reference to another material matrix.
 
 gsMaterialMatrixTFT (gsMaterialMatrixBase< T > *materialMatrix)
 Constructs a TFT material matrix using a reference to another material matrix.
 
virtual bool hasDensity () const
 Returns true if a density is assigned.
 
virtual bool hasThickness () const
 Returns true if a thickness is assigned.
 
void info () const override
 See gsMaterialMatrixBase for details.
 
enum MatIntegration isMatIntegrated () const override
 
enum MatIntegration isVecIntegrated () const override
 
const gsMaterialMatrixBase< T > * material () const override
 See gsMaterialMatrixBase for details.
 
gsMaterialMatrixBase< T > * material () override
 See gsMaterialMatrixBase for details.
 
virtual index_t numParameters () const
 Gets the number of parameters.
 
virtual gsOptionListoptions ()
 Returns the options.
 
virtual void parameters_into (const index_t patch, const gsMatrix< T > &u, gsMatrix< T > &result) const override
 See gsMaterialMatrixBase for details.
 
std::ostream & print (std::ostream &os) const override
 See gsMaterialMatrixBase for details.
 
virtual void pstress_into (const index_t, const gsMatrix< T > &, gsMatrix< T > &) const
 Evaluates the priciple stresses in the shell (3x1 vector)
 
virtual void pstressDir_into (const index_t, const gsMatrix< T > &, gsMatrix< T > &) const
 Evaluates the directions of the priciple stresses in the shell (3x1 vector per direction)
 
virtual void pstretch_into (const index_t, const gsMatrix< T > &, gsMatrix< T > &) const
 Evaluates the stretches in the shell (3x1 vector)
 
virtual void pstretchDir_into (const index_t, const gsMatrix< T > &, gsMatrix< T > &) const
 Evaluates the directions of the stretches in the shell (3x1 vector per direction)
 
virtual void resetParameters ()
 See gsMaterialMatrixBase for details.
 
void setDeformed (const gsFunctionSet< T > *deformed) override
 See gsMaterialMatrixBase for details.
 
void setDeformed (function_ptr deformed) override
 See gsMaterialMatrixBase for details.
 
virtual void setDensity (const gsFunctionSet< T > &Density)
 Sets the density.
 
virtual void setDensity (function_ptr Density)
 Sets the density.
 
virtual void setOptions (gsOptionList opt)
 Sets the options.
 
virtual void setParameter (const index_t i, const function_ptr &par)
 Sets the material parameters.
 
virtual void setParameter (const index_t i, const gsFunctionSet< T > &par)
 Sets the material parameters.
 
virtual void setParameters (const std::vector< function_ptr > &pars)
 Sets the material parameters.
 
void setParameters (const std::vector< gsFunctionSet< T > * > &pars) override
 See gsMaterialMatrixBase for details.
 
virtual void setThickness (const function_ptr &thickness)
 Sets the thickness.
 
virtual void setThickness (const gsFunctionSet< T > &thickness)
 Sets the thickness.
 
void setUndeformed (const gsFunctionSet< T > *undeformed) override
 See gsMaterialMatrixBase for details.
 
void setUndeformed (function_ptr undeformed) override
 See gsMaterialMatrixBase for details.
 
void thickness_into (const index_t patch, const gsMatrix< T > &u, gsMatrix< T > &result) const override
 See gsMaterialMatrixBase for details.
 
virtual void transform_into (const index_t, const gsMatrix< T > &, gsMatrix< T > &) const
 Constructs a transformation matrix that transforms a quantity (IN VOIGHT NOTATION) in the spectral basis to the (undeformed) convariant basis.
 
void updateDeformed (const function_ptr &deformed)
 Updates the reference to the deformed patches used for TFT (explicit only)
 
void updateDeformed (const gsFunctionSet< T > *deformed)
 Updates the reference to the deformed patches used for TFT (explicit only)
 

Protected Member Functions

template<bool _linear>
std::enable_if< _linear, gsMatrix< T > >::type _eval3D_matrix_impl (const index_t patch, const gsMatrix< T > &u, const gsMatrix< T > &z, enum MaterialOutput out=MaterialOutput::Generic) const
 Provides an implementation of eval3D_matrix for gsMaterialMatrixLinear.
 

Private Member Functions

template<short_t _dim>
std::enable_if< _dim==2, void >::type _computeMetricDeformed_impl (const index_t patch, const gsMatrix< T > &u) const
 Implementation of _computeMetricUndeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, void >::type _computeMetricDeformed_impl (const index_t patch, const gsMatrix< T > &u) const
 Implementation of _computeMetricUndeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, void >::type _computeMetricUndeformed_impl (const index_t patch, const gsMatrix< T > &u) const
 Implementation of _getMetric for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, void >::type _computeMetricUndeformed_impl (const index_t patch, const gsMatrix< T > &u) const
 Implementation of _getMetric for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, gsMatrix< T > >::type _getBcov_def_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, gsMatrix< T > >::type _getBcov_def_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, gsMatrix< T > >::type _getBcov_ori_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, gsMatrix< T > >::type _getBcov_ori_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, gsMatrix< T > >::type _getGcon_def_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, gsMatrix< T > >::type _getGcon_def_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, gsMatrix< T > >::type _getGcon_ori_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, gsMatrix< T > >::type _getGcon_ori_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, gsMatrix< T > >::type _getGcov_def_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, gsMatrix< T > >::type _getGcov_def_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, gsMatrix< T > >::type _getgcov_def_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, gsMatrix< T > >::type _getgcov_def_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, gsMatrix< T > >::type _getGcov_ori_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, gsMatrix< T > >::type _getGcov_ori_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, gsMatrix< T > >::type _getgcov_ori_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, gsMatrix< T > >::type _getgcov_ori_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, void >::type _getMetric_impl (const index_t k, const T z) const
 Implementation of _getMetricDeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, void >::type _getMetricDeformed_impl (const index_t k, const T z) const
 Implementation of _getMetricDeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, void >::type _getMetricDeformed_impl (const index_t k, const T z) const
 Implementation of _getMetricDeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, void >::type _getMetricUndeformed_impl (const index_t k, const T z) const
 Implementation of _getMetricUndeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, void >::type _getMetricUndeformed_impl (const index_t k, const T z) const
 Implementation of _getMetricUndeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, gsMatrix< T > >::type _getncov_def_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, gsMatrix< T > >::type _getncov_def_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for surface geometries.
 
template<short_t _dim>
std::enable_if< _dim==2, gsMatrix< T > >::type _getncov_ori_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for planar geometries.
 
template<short_t _dim>
std::enable_if< _dim==3, gsMatrix< T > >::type _getncov_ori_impl (index_t k, T z) const
 Implementation of _getMetricUndeformed for surface geometries.
 

Constructor & Destructor Documentation

◆ gsMaterialMatrixTFT() [1/3]

template<short_t dim, class T , bool linear = false>
gsMaterialMatrixTFT ( gsMaterialMatrixBase< T > *  materialMatrix)
inline

Constructs a TFT material matrix using a reference to another material matrix.

Parameters
materialMatrixThe original material matrix

◆ gsMaterialMatrixTFT() [2/3]

template<short_t dim, class T , bool linear = false>
gsMaterialMatrixTFT ( gsMaterialMatrixBase< T > &  materialMatrix)
inline

Constructs a TFT material matrix using a reference to another material matrix.

Parameters
materialMatrixThe original material matrix

◆ gsMaterialMatrixTFT() [3/3]

template<short_t dim, class T , bool linear = false>
gsMaterialMatrixTFT ( const material_ptr materialMatrix)
inline

Constructs a TFT material matrix using a reference to another material matrix.

Parameters
materialMatrixThe original material matrix

Member Function Documentation

◆ _computeMetricDeformed_impl()

template<short_t dim, class T >
template<short_t _dim>
std::enable_if< _dim==2, void >::type _computeMetricDeformed_impl ( const index_t  patch,
const gsMatrix< T > &  u 
) const
privateinherited

Implementation of _computeMetricUndeformed for planar geometries.

SetZero does not work with gsThreaded?

◆ eval3D_CauchyVector()

template<class T >
virtual gsMatrix< T > eval3D_CauchyVector ( const index_t  ,
const gsMatrix< T > &  ,
const gsMatrix< T > &  ,
enum MaterialOutput   
) const
inlinevirtualinherited

Evaluates the Cauchy Stress vector on patch on in-plane points u with height z.

note: the Cauchy stress vector is returned in the actual basis

Parameters
[in]patchThe patch
[in]uThe in-plane shell coordinates to be eveluated on
[in]zThe point through-thickness coorinate
[in]out(for classes with MatIntegration==Integrated, more details about MaterialOutput can be found in gsMaterialMatrixUtils)
Returns
Matrix with the result (vector) ordered per z coordinate per point [(u1,z1) (u2,z1) .. (un,z1), (u1,z2) .. (un,z2), .., (u1,zm) .. (un,zm)]

Reimplemented in gsMaterialMatrixLinear< dim, T >, and gsMaterialMatrixNonlinear< dim, T, matId, comp, mat, imp >.

◆ eval3D_detF()

template<class T >
virtual gsMatrix< T > eval3D_detF ( const index_t  ,
const gsMatrix< T > &  ,
const gsMatrix< T > &  ,
enum MaterialOutput   
) const
inlinevirtualinherited

{ function_description }

Parameters
[in]patchThe patch
[in]u{ parameter_description }
[in]z{ parameter_description }
[in]outThe out
Returns
{ description_of_the_return_value }

Reimplemented in gsMaterialMatrixNonlinear< dim, T, matId, comp, mat, imp >, and gsMaterialMatrixLinear< dim, T >.

◆ eval3D_dmatrix()

template<class T >
virtual gsMatrix< T > eval3D_dmatrix ( const index_t  ,
const gsMatrix< T > &  ,
const gsMatrix< T > &  ,
enum MaterialOutput   
) const
inlinevirtualinherited

Evaluates the derivative of the matrix on patch on in-plane points u with height z.

Parameters
[in]patchThe patch
[in]uThe in-plane shell coordinates to be eveluated on
[in]zThe point through-thickness coorinate
[in]out(for classes with MatIntegration==Integrated, more details about MaterialOutput can be found in gsMaterialMatrixUtils)
Returns
Matrix with the result (matrix) ordered per z coordinate per point [(u1,z1) (u2,z1) .. (un,z1), (u1,z2) .. (un,z2), .., (u1,zm) .. (un,zm)] every column has 9*3=27 entries. To obtain the derivatives of C, one can do the following

dC = eval.reshapeCol(k,9,3); dCd11 = dC.reshapeCol(0,3,3); dCd22 = dC.reshapeCol(1,3,3); dCd11 = dC.reshapeCol(2,3,3);

Reimplemented in gsMaterialMatrixLinear< dim, T >, and gsMaterialMatrixNonlinear< dim, T, matId, comp, mat, imp >.

◆ eval3D_pstress()

template<short_t dim, class T , bool linear>
gsMatrix< T > eval3D_pstress ( const index_t  patch,
const gsMatrix< T > &  u,
const gsMatrix< T > &  z,
enum MaterialOutput  out = MaterialOutput::Generic 
) const
overridevirtual

Returns the principal stresses stored in the underlying material model where the tension-field is non-slack

Parameters
[in]patchThe patch
[in]uEvaluation points
[in]zEvaluation thickness
[in]out(not used)
Returns
{ description_of_the_return_value }

Reimplemented from gsMaterialMatrixBase< T >.

◆ eval3D_pstressDir()

template<class T >
virtual gsMatrix< T > eval3D_pstressDir ( const index_t  ,
const gsMatrix< T > &  ,
const gsMatrix< T > &  ,
enum MaterialOutput   
) const
inlinevirtualinherited

Evaluates the principal stress directions on patch on in-plane points u with height z.

Parameters
[in]patchThe patch
[in]uThe in-plane shell coordinates to be eveluated on
[in]zThe point through-thickness coorinate
[in]out(for classes with MatIntegration==Integrated, more details about MaterialOutput can be found in gsMaterialMatrixUtils)
Returns
Matrix with the result (principal stress directions) ordered per z coordinate per point [(u1,z1) (u2,z1) .. (un,z1), (u1,z2) .. (un,z2), .., (u1,zm) .. (un,zm)]

Reimplemented in gsMaterialMatrixLinear< dim, T >, and gsMaterialMatrixNonlinear< dim, T, matId, comp, mat, imp >.

◆ eval3D_pstressTransform()

template<class T >
virtual gsMatrix< T > eval3D_pstressTransform ( const index_t  patch,
const gsMatrix< T > &  u,
const gsMatrix< T > &  z 
) const
inlinevirtualinherited

Provides the transformation of the principle stresses.

Parameters
[in]patchThe patch to be evaluated on
[in]uThe in-plane shell coordinates to be eveluated on
[in]zThe point through-thickness coorinate
Returns
Matrix with the result (deformation tensor) ordered per z coordinate per point [(u1,z1) (u2,z1) .. (un,z1), (u1,z2) .. (un,z2), .., (u1,zm) .. (un,zm)]

◆ eval3D_pstretchTransform()

template<class T >
virtual gsMatrix< T > eval3D_pstretchTransform ( const index_t  patch,
const gsMatrix< T > &  u,
const gsMatrix< T > &  z 
) const
inlinevirtualinherited

Provides the transformation of the principle stretches.

Parameters
[in]patchThe patch to be evaluated on
[in]uThe in-plane shell coordinates to be eveluated on
[in]zThe point through-thickness coorinate
Returns
Matrix with the result (deformation tensor) ordered per z coordinate per point [(u1,z1) (u2,z1) .. (un,z1), (u1,z2) .. (un,z2), .., (u1,zm) .. (un,zm)]

◆ eval3D_strain()

template<short_t dim, class T , bool linear = false>
virtual gsMatrix< T > eval3D_strain ( const index_t  ,
const gsMatrix< T > &  ,
const gsMatrix< T > &   
) const
inlinevirtual

{ function_description }

Parameters
[in]patchThe patch
[in]u{ parameter_description }
[in]z{ parameter_description }
[in]outThe out
Returns
{ description_of_the_return_value }

Reimplemented from gsMaterialMatrixBaseDim< dim, T >.

◆ eval3D_tensionfield()

template<short_t dim, class T , bool linear = false>
virtual gsMatrix< T > eval3D_tensionfield ( const index_t  ,
const gsMatrix< T > &  ,
const gsMatrix< T > &  ,
enum MaterialOutput   
) const
inlinevirtual

to do

Parameters
[in]patchThe patch
[in]uThe in-plane shell coordinates to be eveluated on
[in]zThe point through-thickness coorinate
[in]out(for classes with MatIntegration==Integrated, more details about MaterialOutput can be found in gsMaterialMatrixUtils)
Returns
Matrix with the result (principal strain) ordered per z coordinate per point [(u1,z1) (u2,z1) .. (un,z1), (u1,z2) .. (un,z2), .., (u1,zm) .. (un,zm)]

Reimplemented from gsMaterialMatrixBaseDim< dim, T >.

◆ getParameter()

template<class T >
virtual const function_ptr getParameter ( const index_t  i) const
inlinevirtualinherited

Gets parameter i.

Parameters
[in]iThe parameter index
Returns
The parameter.

◆ isMatIntegrated()

template<short_t dim, class T , bool linear = false>
enum MatIntegration isMatIntegrated ( ) const
inlineoverridevirtual

See gsMaterialMatrixBase for details Here, we use the integrated matrix and vector to make our computations!

Reimplemented from gsMaterialMatrixBase< T >.

◆ isVecIntegrated()

template<short_t dim, class T , bool linear = false>
enum MatIntegration isVecIntegrated ( ) const
inlineoverridevirtual

See gsMaterialMatrixBase for details Here, we use the integrated matrix and vector to make our computations!

Reimplemented from gsMaterialMatrixBase< T >.

◆ options()

template<class T >
virtual gsOptionList & options ( )
inlinevirtualinherited

Returns the options.

Returns
gsOptionList

Reimplemented in gsMaterialMatrixComposite< dim, T >.

◆ pstress_into()

template<class T >
virtual void pstress_into ( const index_t  ,
const gsMatrix< T > &  ,
gsMatrix< T > &   
) const
inlinevirtualinherited

Evaluates the priciple stresses in the shell (3x1 vector)

Parameters
[in]patchThe patch to be evaluated on
[in]uThe in-plane shell coordinates to be eveluated on
resultThe result

Reimplemented in gsMaterialMatrixComposite< dim, T >.

◆ pstressDir_into()

template<class T >
virtual void pstressDir_into ( const index_t  ,
const gsMatrix< T > &  ,
gsMatrix< T > &   
) const
inlinevirtualinherited

Evaluates the directions of the priciple stresses in the shell (3x1 vector per direction)

Parameters
[in]patchThe patch to be evaluated on
[in]uThe in-plane shell coordinates to be eveluated on
resultThe result

Reimplemented in gsMaterialMatrixComposite< dim, T >.

◆ pstretch_into()

template<class T >
virtual void pstretch_into ( const index_t  ,
const gsMatrix< T > &  ,
gsMatrix< T > &   
) const
inlinevirtualinherited

Evaluates the stretches in the shell (3x1 vector)

Parameters
[in]patchThe patch to be evaluated on
[in]uThe in-plane shell coordinates to be eveluated on
resultThe result

Reimplemented in gsMaterialMatrixNonlinear< dim, T, matId, comp, mat, imp >, and gsMaterialMatrixComposite< dim, T >.

◆ pstretchDir_into()

template<class T >
virtual void pstretchDir_into ( const index_t  ,
const gsMatrix< T > &  ,
gsMatrix< T > &   
) const
inlinevirtualinherited

Evaluates the directions of the stretches in the shell (3x1 vector per direction)

Parameters
[in]patchThe patch to be evaluated on
[in]uThe in-plane shell coordinates to be eveluated on
resultThe result

Reimplemented in gsMaterialMatrixNonlinear< dim, T, matId, comp, mat, imp >, and gsMaterialMatrixComposite< dim, T >.

◆ setOptions()

template<class T >
virtual void setOptions ( gsOptionList  opt)
inlinevirtualinherited

Sets the options.

Parameters
[in]optgsOptionList

Reimplemented in gsMaterialMatrixComposite< dim, T >.

◆ setParameter() [1/2]

template<class T >
virtual void setParameter ( const index_t  i,
const function_ptr &  par 
)
inlinevirtualinherited

Sets the material parameters.

Parameters
[in]parsFunction pointers for the parameters in a container

◆ setParameter() [2/2]

template<class T >
virtual void setParameter ( const index_t  i,
const gsFunctionSet< T > &  par 
)
inlinevirtualinherited

Sets the material parameters.

Parameters
[in]parsFunction pointers for the parameters in a container

◆ setParameters()

template<class T >
virtual void setParameters ( const std::vector< function_ptr > &  pars)
inlinevirtualinherited

Sets the material parameters.

Parameters
[in]parsFunction pointers for the parameters in a container

◆ transform_into()

template<class T >
virtual void transform_into ( const index_t  ,
const gsMatrix< T > &  ,
gsMatrix< T > &   
) const
inlinevirtualinherited

Constructs a transformation matrix that transforms a quantity (IN VOIGHT NOTATION) in the spectral basis to the (undeformed) convariant basis.

Parameters
[in]patchThe patch to be evaluated on
[in]uThe in-plane shell coordinates to be eveluated on
resultThe result

Reimplemented in gsMaterialMatrixComposite< dim, T >.