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.
FoamToVtkConversionDriver.C
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 *******************************************************************************/
30 
31 #include "Mesh/foamMesh.H"
32 #include "Mesh/vtkMesh.H"
33 
34 namespace NEM {
35 namespace DRV {
36 
38  : file_(std::move(file)) {}
39 
42 
44 const {
45  return file_;
46 }
47 
49  this->file_ = std::move(file);
50 }
51 
53  meshBase *fm = new FOAM::foamMesh();
54  fm->read("NULL");
55  // TODO: Fix report and write methods for the foamMesh class
56  // std::cout << "Variable values is = " << srcmsh << std::endl;
57  vtkMesh *vm = new vtkMesh(fm->getDataSet(), this->file_.outputFile);
58  vm->report();
59  vm->write();
60  delete vm;
61  delete fm;
62 }
63 
65  const {
66  static constexpr Opts opts{};
67  return opts;
68 }
69 
70 } // namespace DRV
71 } // namespace NEM
std::string outputFile
Definition: NemDriver.H:78
A brief description of meshBase.
Definition: meshBase.H:64
STL namespace.
foamMesh class contains methods for reading and writing mesh in OpenFOAM polyMesh format...
Definition: foamMesh.H:49
vtkSmartPointer< vtkDataSet > getDataSet() const
get this meshes&#39; dataSet
Definition: meshBase.H:308
void execute() const override
Run the workflow represented by the driver.
virtual void read(const std::string &fname)=0
abstract read method reserved for derived classes
void report() const override
generate a report of the mesh
Definition: vtkMesh.C:780
void write() const override
write the mesh to file named after the private var &#39;filename&#39;.
Definition: vtkMesh.H:152