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.
SizeFieldRefineDriver.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/meshBase.H"
32 
33 namespace NEM {
34 namespace DRV {
35 
36 SizeFieldRefineDriver::Opts::Opts(Method method, std::string arrayName,
37  double stdDevMult, bool maxIsMin,
38  bool transferData)
39  : method(method),
40  arrayName(std::move(arrayName)),
41  stdDevMult(stdDevMult),
42  maxIsMin(maxIsMin),
43  transferData(transferData) {}
44 
46  switch (this->method) {
47  case Method::VALUE: return valStr;
48  case Method::GRADIENT: return gradStr;
49  }
50  return "";
51 }
52 
54  : RefineDriver(std::move(files)), opts_(std::move(opts)) {}
55 
57  : SizeFieldRefineDriver({{}, {}}, {{}, {}, {}, {}, {}}) {}
58 
60  return opts_;
61 }
62 
64  this->opts_ = std::move(opts);
65 }
66 
68  std::cout << "Size Factor = " << this->opts_.sizeFactor << std::endl;
69  std::shared_ptr<meshBase> mesh =
71  std::cout << "\n";
72  mesh->report();
73  std::cout << "\n";
74  // Edge scale is unused
75  mesh->refineMesh(this->opts_.getMethodStr(), this->opts_.arrayName,
76  this->opts_.stdDevMult, this->opts_.maxIsMin, {},
78  this->opts_.sizeFactor);
79 }
80 
81 } // namespace DRV
82 } // namespace NEM
void execute() const override
Run the workflow represented by the driver.
std::string outputMeshFile
Definition: NemDriver.H:91
STL namespace.
static constexpr const char * valStr
std::string inputMeshFile
Definition: NemDriver.H:90
std::shared_ptr< meshBase > mesh
static std::shared_ptr< meshBase > CreateShared(const std::string &fname)
Create shared ptr from fname.
Definition: meshBase.C:171
static constexpr const char * gradStr