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>& rDTdE,
00130 bool computeDTdE);
00131
00135 virtual ~AbstractIsotropicIncompressibleMaterialLaw();
00136
00143 double GetZeroStrainPressure();
00144 };
00145
00146 #endif