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.
diffMesh.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_DIFFMESH_H_
30 #define NEMOSYS_DIFFMESH_H_
31 
32 #include "nemosys_export.h"
33 #include "Mesh/geoMeshBase.H"
34 
35 namespace NEM {
36 namespace MSH {
37 
38 /**
39  * Compare two @c geoMeshBase objects.
40  * @param gmb1 Reference @c geoMeshBase
41  * @param gmb2 Other @c geoMeshBase
42  * @param floor If a floating point value is less than or equal to @p floor, it
43  * is treated as 0. Should be non-negative
44  * @param relTol Relative tolerance for comparing floating point values
45  * @param numCellsTol Tolerance for number of cells, if positive. If non-positive,
46  * exact match required for number of cells and cell data compared at each cell.
47  * @param numPointsTol Tolerance for number of points, if positive. If
48  * non-positive, exact match required for number of points and point data
49  * compared at each cell.
50  * @return 0 if @p gmb1 and @p gmb2 are similar; 1 otherwise
51  */
52 NEMOSYS_EXPORT int diffMesh(geoMeshBase *gmb1, geoMeshBase *gmb2,
53  double floor = 1e-9, double relTol = 1e-6,
54  double numCellsTol = -1.,
55  double numPointsTol = -1.);
56 
57 } // namespace MSH
58 } // namespace NEM
59 
60 #endif // NEMOSYS_DIFFMESH_H_
int diffMesh(geoMeshBase *gmb1, geoMeshBase *gmb2, double floor, double relTol, double numCellsTol, double numPointsTol)
Compare two geoMeshBase objects.
Definition: diffMesh.C:51