OpenFOAM
dev
The OpenFOAM Foundation
mergePoints.H
Go to the documentation of this file.
1
/*---------------------------------------------------------------------------*\
2
========= |
3
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4
\\ / O peration | Website: https://openfoam.org
5
\\ / A nd | Copyright (C) 2011-2026 OpenFOAM Foundation
6
\\/ M anipulation |
7
-------------------------------------------------------------------------------
8
License
9
This file is part of OpenFOAM.
10
11
OpenFOAM is free software: you can redistribute it and/or modify it
12
under the terms of the GNU General Public License as published by
13
the Free Software Foundation, either version 3 of the License, or
14
(at your option) any later version.
15
16
OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
19
for more details.
20
21
You should have received a copy of the GNU General Public License
22
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
23
24
Description
25
Merge points. See below.
26
27
SourceFiles
28
mergePoints.C
29
30
\*---------------------------------------------------------------------------*/
31
32
#ifndef mergePoints_H
33
#define mergePoints_H
34
35
#include "
Field.H
"
36
37
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
38
39
namespace
Foam
40
{
41
42
/*---------------------------------------------------------------------------*\
43
Function mergePoints Declaration
44
\*---------------------------------------------------------------------------*/
45
46
//- Sorts and merges points. All points closer than/equal mergeTol get merged.
47
// Returns the number of unique points and a map from old to new.
48
template
<
class
Type>
49
label
mergePoints
50
(
51
const
Field<Type>
&
points
,
52
const
scalar mergeTol,
53
const
bool
verbose,
54
labelList
& pointMap,
55
const
Type& origin = Type::zero
56
);
57
58
//- Sorts and merges points. Determines new points. Returns true if anything
59
// merged (though newPoints still sorted even if not merged).
60
template
<
class
Type>
61
bool
mergePoints
62
(
63
const
Field<Type>
&
points
,
64
const
scalar mergeTol,
65
const
bool
verbose,
66
labelList
& pointMap,
67
List<Type>
& newPoints,
68
const
Type& origin = Type::zero
69
);
70
71
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
72
73
}
// End namespace Foam
74
75
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
76
77
#ifdef NoRepository
78
#include "
mergePoints.C
"
79
#endif
80
81
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
82
83
#endif
84
85
// ************************************************************************* //
Field.H
Foam::Field
Pre-declare SubField and related Field type.
Definition:
Field.H:83
Foam::List< label >
points
const pointField & points
Definition:
gmvOutputHeader.H:1
mergePoints.C
Foam
Namespace for OpenFOAM.
Definition:
atmosphericBoundaryLayer.C:32
Foam::label
intWM_LABEL_SIZE_t label
A label is an int32_t or int64_t as specified by the pre-processor macro WM_LABEL_SIZE.
Definition:
label.H:59
Foam::mergePoints
label mergePoints(const Field< Type > &points, const scalar mergeTol, const bool verbose, labelList &pointMap, const Type &origin=Type::zero)
Sorts and merges points. All points closer than/equal mergeTol get merged.
src
OpenFOAM
meshes
meshTools
mergePoints.H
Generated by
1.9.1