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.
ProteusDriver.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_PROTEUSDRIVER_H_
30 #define NEMOSYS_PROTEUSDRIVER_H_
31 
32 #include "nemosys_export.h"
33 #include "Drivers/NemDriver.H"
34 
35 namespace NEM {
36 namespace DRV {
37 
38 /**
39  * @brief Driver to read Proteus output. Converts Proteus HDF mesh to VTK/Exodus
40  * format
41  */
42 class NEMOSYS_EXPORT ProteusDriver : public NemDriver {
43  public:
44  struct NEMOSYS_EXPORT Files {
45  public:
46  Files(std::string fieldFName, std::string meshFName,
47  std::string exoMeshFName);
48  /**
49  * @brief Proteus format HDF5 field filename
50  */
51  std::string fieldFName{};
52  /**
53  * @brief Output VTK mesh filename
54  */
55  std::string meshFName{};
56  /**
57  * @brief Output Exodus mesh filename
58  */
59  std::string exoMeshFName{};
60  JSONCONS_TYPE_TRAITS_FRIEND
61  private:
62  Files() = default;
63  };
64 
65  struct NEMOSYS_EXPORT Opts {
66  public:
67  explicit Opts(std::string edgeSidesetName);
68  /**
69  * @brief Name of sideset written to output Exodus file
70  */
71  std::string edgeSidesetName{};
72  /**
73  * @brief Boolean converting high order cells to low order
74  */
75  bool lowOrder{false};
76  /**
77  * @brief Boolean to employ boundary constraint during refinement
78  */
79  bool bndryConst{true};
80  JSONCONS_TYPE_TRAITS_FRIEND
81  private:
82  Opts() = default;
83  };
84  ProteusDriver(Files files, Opts opts);
85 
86  const Files &getFiles() const;
87  void setFiles(Files files);
88  const Opts &getOpts() const;
89  void setOpts(Opts opts);
90  void execute() const override;
91 
92  ~ProteusDriver() override;
93 
94  JSONCONS_TYPE_TRAITS_FRIEND
95 
96  private:
97  ProteusDriver();
98 
101 
102  static constexpr const char *programType = "Proteus";
103  jsoncons::string_view getProgramType() const override;
104 };
105 
106 } // namespace DRV
107 } // namespace NEM
108 
109 #endif // NEMOSYS_PROTEUSDRIVER_H_
Driver to read Proteus output.
Definition: ProteusDriver.H:42
base class for drivers
Definition: NemDriver.H:46
static constexpr auto programType