Merge branch 'master' of ssh://git.code.sf.net/p/foam-extend/foam-extend-3.2
[foam-extend-3.2.git] / src / mesh / cfMesh / utilities / meshes / polyMeshGen2DEngine / polyMeshGen2DEngine.H
bloba4a71af2f77fb9776a5a05c218107e6b4d87c267
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | cfMesh: A library for mesh generation
4    \\    /   O peration     |
5     \\  /    A nd           | Author: Franjo Juretic (franjo.juretic@c-fields.com)
6      \\/     M anipulation  | Copyright (C) Creative Fields, Ltd.
7 -------------------------------------------------------------------------------
8 License
9     This file is part of cfMesh.
11     cfMesh is free software; you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by the
13     Free Software Foundation; either version 3 of the License, or (at your
14     option) any later version.
16     cfMesh 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.
21     You should have received a copy of the GNU General Public License
22     along with cfMesh.  If not, see <http://www.gnu.org/licenses/>.
24 Class
25     polyMeshGen2DEngine
27 Description
28     A simple engine which provides topological information of a 2D mesh
29     and allows for maintaining consistency
31 SourceFiles
32     polyMeshGen2DEngine.C
34 \*---------------------------------------------------------------------------*/
36 #ifndef polyMeshGen2DEngine_H
37 #define polyMeshGen2DEngine_H
39 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
41 #include "polyMeshGen.H"
42 #include "boolList.H"
43 #include "labelList.H"
44 #include "boundBox.H"
45 #include "demandDrivenData.H"
47 namespace Foam
50 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
52 class polyMeshGen2DEngine
54     // Private data
55         //- const reference to the mesh
56         const polyMeshGen& mesh_;
58         //- bounding box
59         boundBox bb_;
61         //- which faces are not in the x-y plane
62         mutable boolList* activeFacePtr_;
64         //- labels of active faces
65         mutable labelList* activeFaceLabelsPtr_;
67         //- which points are in the x-y plane and at smallest z
68         mutable boolList* zMinPointPtr_;
70         //- labels of points at minimum z
71         mutable labelList* zMinPointLabelsPtr_;
73         //- labels of offset points of zMin points
74         mutable labelList* zMinToZMaxPtr_;
76         //- which points are in the x-y plane and at largest z
77         mutable boolList* zMaxPointPtr_;
79         //- labels of points at maximum z
80         mutable labelList* zMaxPointLabelsPtr_;
82         //- labels of zMin points of zMax points
83         mutable labelList* zMaxToZMinPtr_;
85     // Private member functions
86         //- find active faces
87         void findActiveFaces() const;
89         //- find active face labels
90         void findActiveFaceLabels() const;
92         //- find points at minimum z
93         void findZMinPoints() const;
95         //- find labels of points at minimum z
96         void findZMinPointLabels() const;
98         //- find offset point to each zMin point
99         void findZMinOffsetPoints() const;
101         //- find points at maximum z
102         void findZMaxPoints() const;
104         //- find labels of points at minimum z
105         void findZMaxPointLabels() const;
107         //- find offset point to each zMin point
108         void findZMaxOffsetPoints() const;
110         //- disallow bitwise assignment
111         void operator=(const polyMeshGen2DEngine&);
113         //- disallow copy construct
114         polyMeshGen2DEngine(const polyMeshGen2DEngine&);
116 public:
118     // Constructors
119         //- Construct from the const reference to the mesh
120         polyMeshGen2DEngine(const polyMeshGen& mesh);
122     // Destructor
123         ~polyMeshGen2DEngine();
125     // Member functions
126         //- const access to active faces
127         inline const boolList& activeFace() const;
129         //- labels of active faces
130         inline const labelList& activeFaceLabels() const;
132         //- const access to an array of booleans which is true for points
133         //- in the x-y plane with the smallest z coordinate
134         inline const boolList& zMinPoints() const;
136         //- labels of points in the x-y with the smallest z coordinate
137         inline const labelList& zMinPointLabels() const;
139         //- offset points of points at minimum z
140         inline const labelList& zMinToZMax() const;
142         //- const access to an array of booleans which is true for points
143         //- in the x-y plane with the largest z coordinate
144         inline const boolList& zMaxPoints() const;
146         //- labels of points in the x-y with the largest z coordinate
147         inline const labelList& zMaxPointLabels() const;
149         //- offset points of points at maximum z
150         inline const labelList& zMaxToZMin() const;
152         //- correct x and y coordinates of offset points
153         //- and unify the z coordinate
154         void correctPoints();
156         //- delete all dynamically allocated data
157         void clearOut();
160 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
162 } // End namespace Foam
164 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
166 #include "polyMeshGen2DEngineI.H"
168 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
170 #endif
172 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //