surfaceMeshImport.C
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration |
5  \\ / A nd | www.openfoam.com
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8  Copyright (C) 2011-2016 OpenFOAM Foundation
9  Copyright (C) 2018-2023 OpenCFD Ltd.
10 -------------------------------------------------------------------------------
11 License
12  This file is part of OpenFOAM.
13 
14  OpenFOAM is free software: you can redistribute it and/or modify it
15  under the terms of the GNU General Public License as published by
16  the Free Software Foundation, either version 3 of the License, or
17  (at your option) any later version.
18 
19  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
20  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
22  for more details.
23 
24  You should have received a copy of the GNU General Public License
25  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
26 
27 Application
28  surfaceMeshImport
29 
30 Group
31  grpSurfaceUtilities
32 
33 Description
34  Import from various third-party surface formats into surfMesh
35  with optional scaling or transformations (rotate/translate)
36  on a coordinateSystem.
37 
38 Usage
39  \b surfaceMeshImport inputFile [OPTION]
40 
41  Options:
42  - \par -clean
43  Perform some surface checking/cleanup on the input surface.
44 
45  - \par -name <name>
46  Specify an alternative surface name when writing.
47 
48  - \par -read-format <type>
49  Specify input file format
50 
51  - \par -read-scale <scale>
52  Scale factor when reading files.
53 
54  - \par -write-scale <scale>
55  Scale factor when writing files.
56 
57  - \par -dict <dictionary>
58  Alternative dictionary for constant/coordinateSystems.
59 
60  - \par -from <coordinateSystem>
61  Specify a coordinate system when reading files.
62 
63  - \par -to <coordinateSystem>
64  Specify a coordinate system when writing files.
65 
66 Note
67  The filename extensions are used to determine the file format type.
68 
69 \*---------------------------------------------------------------------------*/
70 
71 #include "argList.H"
72 #include "Time.H"
73 
74 #include "MeshedSurfaces.H"
75 #include "coordinateSystems.H"
76 #include "cartesianCS.H"
77 
78 using namespace Foam;
79 
80 static word getExtension(const fileName& name)
81 {
82  return
83  (
84  name.has_ext("gz")
85  ? name.stem().ext()
86  : name.ext()
87  );
88 }
89 
90 
91 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
92 
93 int main(int argc, char *argv[])
94 {
96  (
97  "Import from various third-party surface formats into surfMesh"
98  );
99 
101  argList::addArgument("surface", "The input surface file");
102 
104  (
105  "clean",
106  "Perform some surface checking/cleanup on the input surface"
107  );
110  (
111  "name",
112  "name",
113  "The surface name when writing (default is 'default')"
114  );
116  (
117  "read-format",
118  "type",
119  "Input format (default: use file extension)"
120  );
122  (
123  "read-scale",
124  "factor",
125  "Input geometry scaling factor"
126  );
128  (
129  "write-scale",
130  "factor",
131  "Output geometry scaling factor"
132  );
133 
134  argList::addOptionCompat("read-scale", {"scaleIn", 1912});
135  argList::addOptionCompat("write-scale", {"scaleOut", 1912});
136 
137  argList::addOption("dict", "file", "Alternative coordinateSystems");
138 
140  (
141  "from",
142  "system",
143  "The source coordinate system, applied after '-read-scale'",
144  true // advanced
145  );
147  (
148  "to",
149  "system",
150  "The target coordinate system, applied before '-write-scale'",
151  true // advanced
152  );
153 
154  #include "setRootCase.H"
155  #include "createTime.H"
156 
157  // try for the latestTime, but create "constant" as needed
158  instantList Times = runTime.times();
159  if (Times.size())
160  {
161  label startTime = Times.size()-1;
163  }
164  else
165  {
167  }
168 
169 
170  const auto importName = args.get<fileName>(1);
171  const auto exportName = args.getOrDefault<word>("name", "default");
172 
173  const int optVerbose = args.verbose();
174 
175  const word readFileType
176  (
177  args.getOrDefault<word>("read-format", getExtension(importName))
178  );
179 
180  // Check that reading is supported
181  if (!meshedSurface::canRead(readFileType, true))
182  {
183  FatalError
184  << "Unsupported file format(s)" << nl
185  << exit(FatalError);
186  }
187 
188 
189  scalar scaleFactor(0);
190 
191  // The coordinate transformations (must be cartesian)
194 
195  if (args.found("from") || args.found("to"))
196  {
198  (
199  IOobject
200  (
201  coordinateSystems::typeName,
202  runTime.constant(),
203  runTime,
207  ),
208  args.getOrDefault<fileName>("dict", "")
209  );
210 
211  if (!ioCsys.typeHeaderOk<coordinateSystems>(false))
212  {
213  FatalError
214  << ioCsys.objectPath() << nl
215  << exit(FatalError);
216  }
217 
218  coordinateSystems globalCoords(ioCsys);
219 
220  if (args.found("from"))
221  {
222  const word csName(args["from"]);
223  const auto* csPtr = globalCoords.cfind(csName);
224 
225  if (!csPtr)
226  {
227  FatalError
228  << "Cannot find -from " << csName << nl
229  << "available coordinateSystems: "
230  << flatOutput(globalCoords.names()) << nl
231  << exit(FatalError);
232  }
233 
234  fromCsys = autoPtr<coordSystem::cartesian>::New(*csPtr);
235  }
236 
237  if (args.found("to"))
238  {
239  const word csName(args["to"]);
240  const auto* csPtr = globalCoords.cfind(csName);
241 
242  if (!csPtr)
243  {
244  FatalError
245  << "Cannot find -to " << csName << nl
246  << "available coordinateSystems: "
247  << flatOutput(globalCoords.names()) << nl
248  << exit(FatalError);
249  }
250 
251  toCsys = autoPtr<coordSystem::cartesian>::New(*csPtr);
252  }
253 
254  // Maybe fix this later
255  if (fromCsys && toCsys)
256  {
257  FatalError
258  << "Only allowed '-from' or '-to' option at the moment."
259  << exit(FatalError);
260  }
261  }
262 
263 
264  meshedSurface surf(importName, readFileType);
265 
266  if (args.readIfPresent("read-scale", scaleFactor) && scaleFactor > 0)
267  {
268  Info<< "scale input " << scaleFactor << nl;
269  surf.scalePoints(scaleFactor);
270  }
271 
272  if (args.found("clean"))
273  {
274  surf.cleanup(optVerbose);
275  }
276 
277  if (fromCsys)
278  {
279  Info<< "move points from coordinate system: "
280  << fromCsys->name() << endl;
281  tmp<pointField> tpf = fromCsys->localPosition(surf.points());
282  surf.movePoints(tpf());
283  }
284 
285  if (toCsys)
286  {
287  Info<< "move points to coordinate system: "
288  << toCsys->name() << endl;
289  tmp<pointField> tpf = toCsys->globalPosition(surf.points());
290  surf.movePoints(tpf());
291  }
292 
293  if (args.readIfPresent("write-scale", scaleFactor) && scaleFactor > 0)
294  {
295  Info<< "scale output " << scaleFactor << nl;
296  surf.scalePoints(scaleFactor);
297  }
298 
299  surfMesh smesh
300  (
301  IOobject
302  (
303  exportName,
304  runTime.constant(),
305  runTime
306  ),
307  std::move(surf)
308  );
309 
310 
311  Info<< "writing surfMesh:\n " << smesh.objectPath() << endl;
312  smesh.write();
313 
314  Info<< "\nEnd\n" << endl;
315 
316  return 0;
317 }
318 
319 // ************************************************************************* //
point globalPosition(const point &local) const
From local coordinate position to global (cartesian) position.
static void addNote(const string &note)
Add extra notes for the usage information.
Definition: argList.C:462
void size(const label n)
Older name for setAddressableSize.
Definition: UList.H:116
A class for handling file names.
Definition: fileName.H:72
errorManipArg< error, int > exit(error &err, const int errNo=1)
Definition: errorManip.H:125
error FatalError
Error stream (stdout output on all processes), with additional &#39;FOAM FATAL ERROR&#39; header text and sta...
static bool canRead(const fileName &name, bool verbose=false)
Can we read this file format?
Definition: MeshedSurface.C:87
constexpr char nl
The newline &#39;\n&#39; character (0x0a)
Definition: Ostream.H:50
A centralized collection of named coordinate systems.
engineTime & runTime
Ostream & endl(Ostream &os)
Add newline and flush stream.
Definition: Ostream.H:531
static void addBoolOption(const word &optName, const string &usage="", bool advanced=false)
Add a bool option to validOptions with usage information.
Definition: argList.C:374
static void noParallel()
Remove the parallel options.
Definition: argList.C:584
static void addOptionCompat(const word &optName, std::pair< const char *, int > compat)
Specify an alias for the option name.
Definition: argList.C:418
Ignore writing from objectRegistry::writeObject()
T getOrDefault(const word &optName, const T &deflt) const
Get a value from the named option if present, or return default.
Definition: argListI.H:300
fileName objectPath() const
The complete path + object name.
Definition: IOobjectI.H:284
point localPosition(const point &global) const
From global (cartesian) position to local coordinate position.
word ext() const
Return file name extension (part after last .)
Definition: wordI.H:171
word name(const expressions::valueTypeCode typeCode)
A word representation of a valueTypeCode. Empty for expressions::valueTypeCode::INVALID.
Definition: exprTraits.C:127
bool has_ext() const
Various checks for extensions.
Definition: stringI.H:43
A class for handling words, derived from Foam::string.
Definition: word.H:63
static void addOption(const word &optName, const string &param="", const string &usage="", bool advanced=false)
Add an option to validOptions with usage information.
Definition: argList.C:385
virtual bool write(const token &tok)=0
Write token to stream or otherwise handle it.
virtual void setTime(const Time &t)
Reset the time and time-index to those of the given time.
Definition: Time.C:935
bool typeHeaderOk(const bool checkType=true, const bool search=true, const bool verbose=true)
Read header (respects is_globalIOobject trait) and check its info.
A surface mesh consisting of general polygon faces that has IO capabilities and a registry for storin...
Definition: surfMesh.H:59
static void addVerboseOption(const string &usage="", bool advanced=false)
Enable a &#39;verbose&#39; bool option, with usage information.
Definition: argList.C:520
const word & constant() const noexcept
Return constant name.
Definition: TimePathsI.H:112
An instant of time. Contains the time value and name. Uses Foam::Time when formatting the name...
Definition: instant.H:53
instantList times() const
Search the case for valid time directories.
Definition: TimePaths.C:118
T get(const label index) const
Get a value from the argument at index.
Definition: argListI.H:271
virtual const word & name() const
Return the name.
static void addArgument(const string &argName, const string &usage="")
Append a (mandatory) argument to validArgs.
Definition: argList.C:351
messageStream Info
Information stream (stdout output on master, null elsewhere)
Pointer management similar to std::unique_ptr, with some additional methods and type checking...
Definition: HashPtrTable.H:48
bool readIfPresent(const word &optName, T &val) const
Read a value from the named option if present.
Definition: argListI.H:316
A class for managing temporary objects.
Definition: HashPtrTable.H:50
static autoPtr< T > New(Args &&... args)
Construct autoPtr with forwarding arguments.
Definition: autoPtr.H:178
Foam::argList args(argc, argv)
Defines the attributes of an object for which implicit objectRegistry management is supported...
Definition: IOobject.H:172
Foam::label startTime
int verbose() const noexcept
Return the verbose flag.
Definition: argListI.H:121
Do not request registration (bool: false)
bool found(const word &optName) const
Return true if the named option is found.
Definition: argListI.H:171
Namespace for OpenFOAM.
static IOobject selectIO(const IOobject &io, const fileName &altFile, const word &ioName="")
Return the IOobject, but also consider an alternative file name.
Definition: IOobject.C:256
FlatOutput::OutputAdaptor< Container, Delimiters > flatOutput(const Container &obj, Delimiters delim)
Global flatOutput() function with specified output delimiters.
Definition: FlatOutput.H:225