Home
Downloads
Documentation
Installation
User Guide
man-pages
API Documentation
README
Release Notes
Changes
License
Support
SourceForge Project
Main Page
Related Pages
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Pages
src
dynamicMesh
polyTopoChange
polyTopoChange
duplicatePoints.H
Go to the documentation of this file.
1
/*---------------------------------------------------------------------------*\
2
========= |
3
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4
\\ / O peration |
5
\\ / A nd | Copyright (C) 1991-2010 OpenCFD Ltd.
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
Class
25
Foam::duplicatePoints
26
27
Description
28
Duplicate points
29
30
SourceFiles
31
duplicatePoints.C
32
33
\*---------------------------------------------------------------------------*/
34
35
#ifndef duplicatePoints_H
36
#define duplicatePoints_H
37
38
#include <
OpenFOAM/labelList.H
>
39
#include <
OpenFOAM/typeInfo.H
>
40
41
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
42
43
namespace
Foam
44
{
45
46
// Forward declaration of classes
47
class
polyMesh;
48
class
polyTopoChange;
49
class
edge;
50
class
face;
51
class
mapPolyMesh;
52
class
localPointRegion;
53
54
/*---------------------------------------------------------------------------*\
55
Class duplicatePoints Declaration
56
\*---------------------------------------------------------------------------*/
57
58
class
duplicatePoints
59
{
60
// Private data
61
62
//- Reference to mesh
63
const
polyMesh
& mesh_;
64
65
//- Per regionSide.pointRegion() the points created.
66
// element 0 is the original point.
67
// Can have empty entries if a point only has one region.
68
labelListList
duplicates_;
69
70
71
// Private Member Functions
72
73
//- Disallow default bitwise copy construct
74
duplicatePoints
(
const
duplicatePoints
&);
75
76
//- Disallow default bitwise assignment
77
void
operator=(
const
duplicatePoints
&);
78
79
public
:
80
81
//- Runtime type information
82
ClassName
(
"duplicatePoints"
);
83
84
85
// Constructors
86
87
//- Construct from mesh
88
duplicatePoints
(
const
polyMesh
&
mesh
);
89
90
91
// Member Functions
92
93
// Access
94
95
//- Per point in regionSide.pointRegions() the points created.
96
const
labelListList
&
duplicates
()
const
97
{
98
return
duplicates_;
99
}
100
101
102
// Topology changes
103
104
//- Play commands into polyTopoChange to duplicate points. Gets
105
// localPointRegion structure which is per non-manifold point
106
// the regions per point.
107
void
setRefinement
108
(
109
const
localPointRegion
&
regionSide
,
110
polyTopoChange
&
111
);
112
113
//- Force recalculation of locally stored data on topological change
114
void
updateMesh
(
const
mapPolyMesh
&);
115
};
116
117
118
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
119
120
}
// End namespace Foam
121
122
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
123
124
#endif
125
126
// ************************ vim: set sw=4 sts=4 et: ************************ //