00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef Q0_QUADRANGLE3D_FINITE_ELEMENT_HPP
00021 #define Q0_QUADRANGLE3D_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 Q0Quadrangle3DFiniteElement
00033 : public ThreadStaticBase<Q0Quadrangle3DFiniteElement>,
00034 public LagrangianFiniteElement<1, Q0Quadrangle3DFiniteElement,
00035 QuadratureFormulaQ0Quadrangle3D>
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 };
00048
00054 static const TinyVector<3, real_t>& massCenter()
00055 {
00056 return __massCenter;
00057 }
00058
00067 real_t W (const size_t& i, const TinyVector<3>& x) const;
00068
00077 real_t dxW(const size_t& i, const TinyVector<3>& x) const;
00078
00087 real_t dyW(const size_t& i, const TinyVector<3>& x) const;
00088
00097 real_t dzW(const size_t& i, const TinyVector<3>& x) const;
00098
00099 inline const
00100 TinyVector<QuadratureType::numberOfQuadraturePoints,
00101 TinyVector<3> >&
00102 integrationVertices() const
00103 {
00104 return QuadratureType::instance().vertices();
00105 }
00106
00107 Q0Quadrangle3DFiniteElement()
00108 {
00109 ;
00110 }
00111
00112 ~Q0Quadrangle3DFiniteElement()
00113 {
00114 ;
00115 }
00116 };
00117
00118 #endif // Q0_QUADRANGLE3D_FINITE_ELEMENT_HPP