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.
HexagonalArray.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_HEXAGONALARRAY_H_
30 #define NEMOSYS_HEXAGONALARRAY_H_
31 
32 #include "nemosys_export.h"
33 #include "NucMesh/ShapesArray.H"
34 
35 #include <array>
36 
37 namespace NEM {
38 namespace NUCMESH {
39 
40 class NEMOSYS_EXPORT HexagonalArray : public ShapesArray {
41  public:
42  HexagonalArray(std::size_t numRadii, double deltaRadius,
43  const std::array<double, 3> &center = {0, 0, 0});
44 
45  const std::size_t &getPatternRowCol(int row, int col) const;
46  const std::size_t &getPatternCoordCenter(int right, int rightUp) const;
47 
48  void setPatternRowCol(int row, int col, std::size_t patternKey);
49  /**
50  * The shape will be translated by <tt> right * [getGridDistance(), 0, 0] +
51  * rightUp * [getGridDistance() * cos(60), getGridDistance() * sin(60), 0] +
52  * getCenter() </tt>.
53  */
54  void setPatternCoordCenter(int right, int rightUp, std::size_t patternKey);
55 
56  std::size_t getNumRadii() const { return numRadii_; }
57  double getGridDistance() const { return delta_; }
58  void setGridDistance(double gridDistance) { delta_ = gridDistance; }
59 
60  protected:
61  NEM::GEO::GeoManager createGeo() const override;
62 
63  private:
64  double delta_;
65  std::size_t numRadii_;
66 };
67 
68 } // namespace NUCMESH
69 } // namespace NEM
70 
71 #endif // NEMOSYS_HEXAGONALARRAY_H_
Class to manage TopoDS_Shapes along with metadata.
Definition: GeoManager.H:61
std::size_t getNumRadii() const
void setGridDistance(double gridDistance)
Abstract base class representing a set of other ShapeBase objects, with a transformation applied to e...
Definition: ShapesArray.H:52