00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef Q1_HEXAHEDRON_FINITE_ELEMENT_HPP
00021 #define Q1_HEXAHEDRON_FINITE_ELEMENT_HPP
00022
00023 #include <TinyVector.hpp>
00024 #include <TinyMatrix.hpp>
00025
00026 #include <QuadratureFormula.hpp>
00027 #include <ConformTransformation.hpp>
00028
00029 #include <LagrangianFiniteElement.hpp>
00030 #include <ThreadStaticBase.hpp>
00031
00032 class Q1HexahedronFiniteElement
00033 : public ThreadStaticBase<Q1HexahedronFiniteElement>,
00034 public LagrangianFiniteElement<8, Q1HexahedronFiniteElement,
00035 QuadratureFormulaQ1Hexahedron>
00036 {
00037 private:
00038 static TinyVector<3, real_t> __massCenter;
00040 public:
00041 enum {
00042 numberOfDegreesOfFreedom = 8,
00043 numberOfVertexDegreesOfFreedom = 1,
00044 numberOfEdgeDegreesOfFreedom = 0,
00045 numberOfFaceDegreesOfFreedom = 0,
00046 numberOfVolumeDegreesOfFreedom = 0,
00047 numberOfFaceLivingDegreesOfFreedom = 4
00048 };
00049
00053 static const size_t facesDOF[Hexahedron::NumberOfFaces][numberOfFaceLivingDegreesOfFreedom];
00054
00060 static const TinyVector<3, real_t>& massCenter()
00061 {
00062 return __massCenter;
00063 }
00064
00073 real_t W (const size_t& i, const TinyVector<3>& x) const;
00074
00083 real_t dxW(const size_t& i, const TinyVector<3>& x) const;
00084
00093 real_t dyW(const size_t& i, const TinyVector<3>& x) const;
00094
00103 real_t dzW(const size_t& i, const TinyVector<3>& x) const;
00104
00105 inline const
00106 TinyVector<QuadratureType::numberOfQuadraturePoints,
00107 TinyVector<3> >&
00108 integrationVertices() const
00109 {
00110 return QuadratureType::instance().vertices();
00111 }
00112
00113 Q1HexahedronFiniteElement()
00114 {
00115 ;
00116 }
00117
00118 ~Q1HexahedronFiniteElement()
00119 {
00120 ;
00121 }
00122 };
00123
00124 #endif // Q1_HEXAHEDRON_FINITE_ELEMENT_HPP