AbstractIsotropicIncompressibleMaterialLaw.hpp
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030 #ifndef ABSTRACTISOTROPICINCOMPRESSIBLEMATERIALLAW_HPP_
00031 #define ABSTRACTISOTROPICINCOMPRESSIBLEMATERIALLAW_HPP_
00032
00033 #include "AbstractIncompressibleMaterialLaw.hpp"
00034
00047 template<unsigned DIM>
00048 class AbstractIsotropicIncompressibleMaterialLaw : public AbstractIncompressibleMaterialLaw<DIM>
00049 {
00050 protected:
00051
00060 virtual double Get_dW_dI1(double I1, double I2)=0;
00061
00070 virtual double Get_dW_dI2(double I1, double I2)=0;
00071
00080 virtual double Get_d2W_dI1(double I1, double I2)=0;
00081
00090 virtual double Get_d2W_dI2(double I1, double I2)=0;
00091
00100 virtual double Get_d2W_dI1I2(double I1, double I2)=0;
00101
00102 public:
00103
00125 void ComputeStressAndStressDerivative(c_matrix<double,DIM,DIM>& rC,
00126 c_matrix<double,DIM,DIM>& rInvC,
00127 double pressure,
00128 c_matrix<double,DIM,DIM>& rT,
00129 FourthOrderTensor<DIM,DIM,DIM,DIM>& rDTdE,
00130 bool computeDTdE);
00131
00135 virtual ~AbstractIsotropicIncompressibleMaterialLaw();
00136
00143 double GetZeroStrainPressure();
00144 };
00145
00146 #endif