NEMoSys  0.63.0
A modular, extensible resource with robust automated mesh generation, mesh quality analysis, adaptive mesh refinement, and data transfer between arbitrary meshes.
hmxShape.H
Go to the documentation of this file.
1 /*******************************************************************************
2 * Promesh *
3 * Copyright (C) 2022, IllinoisRocstar LLC. All rights reserved. *
4 * *
5 * Promesh is the property of IllinoisRocstar LLC. *
6 * *
7 * IllinoisRocstar LLC *
8 * Champaign, IL *
9 * www.illinoisrocstar.com *
10 * promesh@illinoisrocstar.com *
11 *******************************************************************************/
12 /*******************************************************************************
13 * This file is part of Promesh *
14 * *
15 * This version of Promesh is free software: you can redistribute it and/or *
16 * modify it under the terms of the GNU Lesser General Public License as *
17 * published by the Free Software Foundation, either version 3 of the License, *
18 * or (at your option) any later version. *
19 * *
20 * Promesh is distributed in the hope that it will be useful, but WITHOUT ANY *
21 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS *
22 * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more *
23 * details. *
24 * *
25 * You should have received a copy of the GNU Lesser General Public License *
26 * along with this program. If not, see <https://www.gnu.org/licenses/>. *
27 * *
28 *******************************************************************************/
29 #ifndef NEMOSYS_HMXSHAPE_H_
30 #define NEMOSYS_HMXSHAPE_H_
31 
32 #include "nemosys_export.h"
33 #include "Geometry/rocPackShape.H"
34 #include <string>
35 #include <vector>
36 
37 namespace NEM {
38 
39 namespace GEO {
40 
41 /** @brief This class wraps around abstract class rocPackShape. This particular
42  shape is called "HMX", which is a shape of "Octogen" crystal.
43  Ref -> https://en.wikipedia.org/wiki/HMX
44 **/
45 class NEMOSYS_EXPORT hmxShape : public rocPackShape
46 {
47  // Constructor, Destructor
48  public:
49  /** @brief hmxShape class standard constructor
50  **/
51  hmxShape();
52 
53  /** @brief hmxShape class standard destructor
54  **/
55  ~hmxShape();
56 
57  // Shape Data Methods
58  public:
59  /** @brief Gets vertices of pack shapes
60  **/
61  std::vector<std::vector<double>> getVertices() override;
62 
63  /** @brief Gets faces of pack shapes
64  **/
65  std::vector<std::vector<int>> getFaces() override;
66 
67 };
68 
69 }
70 }
71 #endif // NEMOSYS_HMXSHAPE_H_
This is an abstract class for all shapes supported by RocPack utility.
Definition: rocPackShape.H:53
This class wraps around abstract class rocPackShape.
Definition: hmxShape.H:45