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.
RectangularArray.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_RECTANGULARARRAY_H_
30 #define NEMOSYS_RECTANGULARARRAY_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 RectangularArray : public ShapesArray {
41  public:
42  RectangularArray(const std::array<std::size_t, 2> &gridDims,
43  const std::array<double, 2> &deltaGrid,
44  const std::array<double, 3> &center = {0, 0, 0});
45 
46  const std::size_t &getPattern(std::size_t x, std::size_t y) const;
47  /**
48  * The shape at <tt> [x, y] </tt> will be translated by <tt> [(x -
49  * (getGridDims()[0] - 1) / 2) * getGridDistance()[0], (y - (getGridDims()[1]
50  * - 1) / 2) * getGridDistance()[1], 0] + getCenter() </tt>.
51  */
52  void setPattern(std::size_t x, std::size_t y, std::size_t patternKey);
53 
54  const std::array<std::size_t, 2> &getGridDims() const { return dims_; }
55  const std::array<double, 2> &getGridDistance() const { return delta_; }
56  void setGridDistance(const std::array<double, 2> &gridDistance) {
57  delta_ = gridDistance;
58  }
59 
60  protected:
61  NEM::GEO::GeoManager createGeo() const override;
62 
63  private:
64  std::array<std::size_t, 2> dims_;
65  std::array<double, 2> delta_;
66 };
67 
68 } // namespace NUCMESH
69 } // namespace NEM
70 
71 #endif // NEMOSYS_RECTANGULARARRAY_H_
Class to manage TopoDS_Shapes along with metadata.
Definition: GeoManager.H:61
std::array< double, 2 > delta_
const std::array< std::size_t, 2 > & getGridDims() const
void setGridDistance(const std::array< double, 2 > &gridDistance)
const std::array< double, 2 > & getGridDistance() const
std::array< std::size_t, 2 > dims_
Abstract base class representing a set of other ShapeBase objects, with a transformation applied to e...
Definition: ShapesArray.H:52