QuadraticMeshHelper.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
00031
00032
00033
00034
00035
00036 #ifndef QUADRATICMESHHELPER_HPP_
00037 #define QUADRATICMESHHELPER_HPP_
00038
00039 #include "AbstractTetrahedralMesh.hpp"
00040 #include "TrianglesMeshReader.hpp"
00041
00046 template<unsigned DIM>
00047 class QuadraticMeshHelper
00048 {
00049 public:
00059 static void AddInternalNodesToElements(AbstractTetrahedralMesh<DIM, DIM>* pMesh,
00060 AbstractMeshReader<DIM,DIM>* pMeshReader);
00061
00073 static void AddInternalNodesToBoundaryElements(AbstractTetrahedralMesh<DIM, DIM>* pMesh,
00074 AbstractMeshReader<DIM,DIM>* pMeshReader);
00075
00076
00087 static void AddNodesToBoundaryElements(AbstractTetrahedralMesh<DIM, DIM>* pMesh,
00088 AbstractMeshReader<DIM,DIM>* pMeshReader);
00089
00095 static void CheckBoundaryElements(AbstractTetrahedralMesh<DIM, DIM>* pMesh);
00096
00097
00108 static void AddNodeToBoundaryElement(AbstractTetrahedralMesh<DIM, DIM>* pMesh,
00109 BoundaryElement<DIM-1,DIM>* pBoundaryElement,
00110 Element<DIM,DIM>* pElement,
00111 unsigned internalNode);
00112
00121 static void AddNodeToBoundaryElement(AbstractTetrahedralMesh<DIM, DIM>* pMesh,
00122 BoundaryElement<DIM-1,DIM>* pBoundaryElement,
00123 Node<DIM>* pNode);
00124
00136 static void AddExtraBoundaryNodes(AbstractTetrahedralMesh<DIM, DIM>* pMesh,
00137 BoundaryElement<DIM-1,DIM>* pBoundaryElement,
00138 Element<DIM,DIM>* pElement,
00139 unsigned nodeIndexOppositeToFace);
00140
00163 static void HelperMethod1(unsigned boundaryElemNode0, unsigned boundaryElemNode1,
00164 Element<DIM,DIM>* pElement,
00165 unsigned node0, unsigned node1, unsigned node2,
00166 unsigned& rOffset,
00167 bool& rReverse);
00168
00188 static void HelperMethod2(AbstractTetrahedralMesh<DIM, DIM>* pMesh,
00189 BoundaryElement<DIM-1,DIM>* pBoundaryElement,
00190 Element<DIM,DIM>* pElement,
00191 unsigned internalNode0, unsigned internalNode1, unsigned internalNode2,
00192 unsigned offset,
00193 bool reverse);
00194
00195 };
00196
00197 #endif // QUADRATICMESHHELPER_HPP_