00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef P0_TETRAHEDRON_FINITE_ELEMENT_HPP
00021 #define P0_TETRAHEDRON_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 P0TetrahedronFiniteElement
00033 : public ThreadStaticBase<P0TetrahedronFiniteElement>,
00034 public LagrangianFiniteElement<1, P0TetrahedronFiniteElement,
00035 QuadratureFormulaP0Tetrahedron>
00036 {
00037 private:
00038 static TinyVector<3, real_t> __massCenter;
00040 public:
00041 enum {
00042 numberOfDegreesOfFreedom = 1,
00043 numberOfVertexDegreesOfFreedom = 0,
00044 numberOfEdgeDegreesOfFreedom = 0,
00045 numberOfFaceDegreesOfFreedom = 0,
00046 numberOfVolumeDegreesOfFreedom = 1,
00047 numberOfFaceLivingDegreesOfFreedom = 0
00048 };
00049
00055 static const size_t facesDOF[Tetrahedron::NumberOfFaces][1];
00056
00062 static const TinyVector<3, real_t>& massCenter()
00063 {
00064 return __massCenter;
00065 }
00066
00067
00068 real_t W (const size_t& i, const TinyVector<3>& X) const;
00069 real_t dxW(const size_t& i, const TinyVector<3>& X) const;
00070 real_t dyW(const size_t& i, const TinyVector<3>& X) const;
00071 real_t dzW(const size_t& i, const TinyVector<3>& X) const;
00072
00073 inline const
00074 TinyVector<QuadratureType::numberOfQuadraturePoints,
00075 TinyVector<3> >&
00076 integrationVertices() const
00077 {
00078 return QuadratureType::instance().vertices();
00079 }
00080
00081 P0TetrahedronFiniteElement()
00082 {
00083 ;
00084 }
00085
00086 ~P0TetrahedronFiniteElement()
00087 {
00088 ;
00089 }
00090 };
00091
00092 #endif // P0_TETRAHEDRON_FINITE_ELEMENT_HPP