Nektar++
InputGmsh.h
Go to the documentation of this file.
1 ////////////////////////////////////////////////////////////////////////////////
2 //
3 // File: InputGmsh.h
4 //
5 // For more information, please see: http://www.nektar.info/
6 //
7 // The MIT License
8 //
9 // Copyright (c) 2006 Division of Applied Mathematics, Brown University (USA),
10 // Department of Aeronautics, Imperial College London (UK), and Scientific
11 // Computing and Imaging Institute, University of Utah (USA).
12 //
13 // Permission is hereby granted, free of charge, to any person obtaining a
14 // copy of this software and associated documentation files (the "Software"),
15 // to deal in the Software without restriction, including without limitation
16 // the rights to use, copy, modify, merge, publish, distribute, sublicense,
17 // and/or sell copies of the Software, and to permit persons to whom the
18 // Software is furnished to do so, subject to the following conditions:
19 //
20 // The above copyright notice and this permission notice shall be included
21 // in all copies or substantial portions of the Software.
22 //
23 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
24 // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
26 // THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
28 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
29 // DEALINGS IN THE SOFTWARE.
30 //
31 // Description: GMSH converter.
32 //
33 ////////////////////////////////////////////////////////////////////////////////
34 
35 #ifndef UTILITIES_NEKMESH_INPUTGMSH
36 #define UTILITIES_NEKMESH_INPUTGMSH
37 
39 
40 namespace Nektar
41 {
42 namespace Utilities
43 {
44 
45 /**
46  * Converter for Gmsh files.
47  */
49 {
50 public:
52  virtual ~InputGmsh();
53  virtual void Process();
54 
55  /// Creates an instance of this class
57  {
59  }
60  /// %ModuleKey for class.
62  static std::map<unsigned int, NekMeshUtils::ElmtConfig> GenElmMap();
63 
64  /**
65  * Element map; takes a msh id to an %ElmtConfig object.
66  */
67  static std::map<unsigned int, NekMeshUtils::ElmtConfig> elmMap;
68  static std::vector<int> CreateReordering(unsigned int InputGmshEntity);
69 
70 private:
71  int GetNnodes(unsigned int InputGmshEntity);
72  static std::vector<int> TriReordering (NekMeshUtils::ElmtConfig conf);
73  static std::vector<int> QuadReordering (NekMeshUtils::ElmtConfig conf);
74  static std::vector<int> HexReordering (NekMeshUtils::ElmtConfig conf);
75  static std::vector<int> PrismReordering(NekMeshUtils::ElmtConfig conf);
76  static std::vector<int> TetReordering (NekMeshUtils::ElmtConfig conf);
77  static std::vector<int> LineReordering (NekMeshUtils::ElmtConfig conf);
78 
79  // Gmsh file version
81  // Previous id for contiguousness
82  int m_prevId;
83  // Id map if non-contiguous
84  std::map<int, int> m_idMap;
85  // Highest tag number
87  // This map takes each element ID and maps it to a permutation map
88  // that is required to take Gmsh element node orderings and map them
89  // to Nektar++ orderings.
90  std::unordered_map<int, std::vector<int>> m_orderingMap;
91 
92  void ReadNextNode();
93  void ReadNextNodeBlock(int nVertices = 0);
94  void SaveNode(int id, NekDouble x = 0, NekDouble y = 0, NekDouble z = 0);
95  void ReadNextElement(int tag = 0, int elm_type = 0);
96 };
97 }
98 }
99 
100 #endif
Basic information about an element.
Definition: ElementConfig.h:49
void ReadNextNodeBlock(int nVertices=0)
Definition: InputGmsh.cpp:983
std::shared_ptr< Module > ModuleSharedPtr
static std::vector< int > PrismReordering(NekMeshUtils::ElmtConfig conf)
Create a reordering for prisms.
Definition: InputGmsh.cpp:1523
std::shared_ptr< Mesh > MeshSharedPtr
Shared pointer to a mesh.
Definition: Mesh.h:156
static std::vector< int > TetReordering(NekMeshUtils::ElmtConfig conf)
Create a reordering for tetrahedra.
Definition: InputGmsh.cpp:1371
static NekMeshUtils::ModuleKey className
ModuleKey for class.
Definition: InputGmsh.h:61
std::unordered_map< int, std::vector< int > > m_orderingMap
Definition: InputGmsh.h:90
static NekMeshUtils::ModuleSharedPtr create(NekMeshUtils::MeshSharedPtr m)
Creates an instance of this class.
Definition: InputGmsh.h:56
static std::vector< int > HexReordering(NekMeshUtils::ElmtConfig conf)
Create a reordering for hexahedra.
Definition: InputGmsh.cpp:1742
static std::vector< int > CreateReordering(unsigned int InputGmshEntity)
Create a reordering map for a given element.
Definition: InputGmsh.cpp:1218
void SaveNode(int id, NekDouble x=0, NekDouble y=0, NekDouble z=0)
Definition: InputGmsh.cpp:1024
static std::vector< int > LineReordering(NekMeshUtils::ElmtConfig conf)
Definition: InputGmsh.cpp:1258
void ReadNextElement(int tag=0, int elm_type=0)
Definition: InputGmsh.cpp:1069
InputGmsh(NekMeshUtils::MeshSharedPtr m)
Set up InputGmsh object.
Definition: InputGmsh.cpp:700
static std::shared_ptr< DataType > AllocateSharedPtr(const Args &...args)
Allocate a shared pointer from the memory pool.
double NekDouble
static std::vector< int > QuadReordering(NekMeshUtils::ElmtConfig conf)
Create a reordering for quadrilaterals.
Definition: InputGmsh.cpp:1323
Abstract base class for input modules.
int GetNnodes(unsigned int InputGmshEntity)
Definition: InputGmsh.cpp:1162
static std::vector< int > TriReordering(NekMeshUtils::ElmtConfig conf)
Create a reordering for triangles.
Definition: InputGmsh.cpp:1274
std::pair< ModuleType, std::string > ModuleKey
static std::map< unsigned int, NekMeshUtils::ElmtConfig > GenElmMap()
Definition: InputGmsh.cpp:1890
std::map< int, int > m_idMap
Definition: InputGmsh.h:84
static std::map< unsigned int, NekMeshUtils::ElmtConfig > elmMap
Definition: InputGmsh.h:67