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
00031
00032
00033
00034
00035
00036 #ifndef __ELAS3DT4_H
00037 #define __ELAS3DT4_H
00038
00039
00040 #include "Equa_Solid.h"
00041 #include "Tetra4.h"
00042 #include "Triang3.h"
00043
00044 namespace OFELI {
00045
00059 class Elas3DT4 : virtual public Equa_Solid<double,4,12,3,9>
00060 {
00061
00062 public :
00063
00065 Elas3DT4()
00066 {
00067 _tetra = NULL; _tr = NULL;
00068 #ifdef _OFELI_DEBUG
00069 std::clog << "An instance of class Elas3DT4 is constructed.\n";
00070 std::clog << "File : " << __FILE__ << ", Line : " << __LINE__ << endl;
00071 #endif
00072 }
00073
00075 Elas3DT4(const Element *el);
00076
00078 Elas3DT4(const Side *sd);
00079
00081 Elas3DT4(const Element *element, const Vect<double> &u, const double &time=0.);
00082
00084 Elas3DT4(const Side *side, const Vect<double> &u, const double &time=0.);
00085
00087 ~Elas3DT4();
00088
00094 void Media(double E, double nu, double rho);
00095
00097 void LMassToLHS(double coef=1);
00098
00100 void LMassToRHS(double coef=1);
00101
00103 void LMass(double coef) { LMassToLHS(coef); LMassToRHS(coef); }
00104
00105 #ifndef DOXYGEN_SHOULD_SKIP_THIS
00107 void Mass(double coef=1.) { coef=1; cout << "Sorry, consistent mass matrix is not implemented !\n"; }
00108 #endif
00109
00111 void Deviator(double coef=1.);
00112
00114 void DeviatorToRHS(double coef=1.);
00115
00117 void Dilatation(double coef=1.);
00118
00120 void DilatationToRHS(double coef=1.);
00121
00124 void BodyRHS(UserData<double> &ud);
00125
00131 void BodyRHS(const NodeVect<double> &f, int opt=LOCAL_ARRAY);
00132
00133 private :
00134 Tetra4 *_tetra;
00135 Triang3 *_tr;
00136
00137 };
00138
00139 }
00140
00141 #endif