MooneyRivlinMaterialLaw.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 MOONEYRIVLINMATERIALLAW_HPP_
00031 #define MOONEYRIVLINMATERIALLAW_HPP_
00032
00033 #include "AbstractIsotropicIncompressibleMaterialLaw.hpp"
00034 #include "Exception.hpp"
00035
00036 #define MINUS_LARGE -1e6
00037
00038
00056 template<unsigned DIM>
00057 class MooneyRivlinMaterialLaw : public AbstractIsotropicIncompressibleMaterialLaw<DIM>
00058 {
00059 private:
00060
00062 double mC1;
00063
00065 double mC2;
00066
00067 public:
00068
00077 double Get_dW_dI1(double I1, double I2);
00078
00087 double Get_dW_dI2(double I1, double I2);
00088
00097 double Get_d2W_dI1(double I1, double I2);
00098
00107 double Get_d2W_dI2(double I1, double I2);
00108
00117 double Get_d2W_dI1I2(double I1, double I2);
00118
00120 double GetC1();
00121
00123 double GetC2();
00124
00132 MooneyRivlinMaterialLaw(double c1, double c2 = MINUS_LARGE);
00133
00139 void ScaleMaterialParameters(double scaleFactor);
00140 };
00141
00142
00143 #endif