Initial commit for version 2.0.x patch release
[OpenFOAM-2.0.x.git] / src / meshTools / cellFeatures / cellFeatures.H
blobe861a6abd348dacc525448f436c32625c5d51198
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 2004-2010 OpenCFD Ltd.
6      \\/     M anipulation  |
7 -------------------------------------------------------------------------------
8 License
9     This file is part of OpenFOAM.
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.
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.
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/>.
24 Class
25     Foam::cellFeatures
27 Description
28     Cell analysis class.
30     Constructs feature edges and feature points, which are edges/points with
31     and angle > given specification.
32     Can be asked for 'superFaces' which can be used to see if a cell is a
33     'splitHex'.
35 SourceFiles
36     cellFeatures.C
38 \*---------------------------------------------------------------------------*/
40 #ifndef cellFeatures_H
41 #define cellFeatures_H
43 #include "faceList.H"
44 #include "labelList.H"
45 #include "boolList.H"
46 #include "HashSet.H"
47 #include "Map.H"
48 #include "DynamicList.H"
50 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
52 namespace Foam
55 // Forward declaration of classes
56 class primitiveMesh;
58 /*---------------------------------------------------------------------------*\
59                            Class cellFeatures Declaration
60 \*---------------------------------------------------------------------------*/
62 class cellFeatures
64     // Private data
66         const primitiveMesh& mesh_;
68         //- cos of angle between two connected faces or two connected edges on
69         //  same face before edge/point is 'feature'.
70         scalar minCos_;
72         label cellI_;
74         //- Feature edges
75         labelHashSet featureEdge_;
77         //- (demand driven) Faces after removing internal points&edges
78         mutable faceList* facesPtr_;
80         //- New to old face mapping
81         mutable List<DynamicList<label> > faceMap_;
84     // Private Member Functions
86         bool faceAlignedEdge(const label, const label) const;
88         label nextEdge
89         (
90             const Map<label>& toSuperFace,
91             const label superFaceI,
92             const label thisEdgeI,
93             const label thisVertI
94         ) const;
96         bool isCellFeatureEdge(const scalar, const label) const;
98         void walkSuperFace
99         (
100             const label faceI,
101             const label superFaceI,
102             Map<label>& toSuperFace
103         ) const;
105         void calcSuperFaces() const;
108         //- Disallow default bitwise copy construct
109         cellFeatures(const cellFeatures&);
111         //- Disallow default bitwise assignment
112         void operator=(const cellFeatures&);
114 public:
116     // Constructors
118         //- Construct from cell in mesh
119         cellFeatures
120         (
121             const primitiveMesh&,
122             const scalar minCos,    // angle to use for feature recognition.
123             const label cellI
124         );
127     //- Destructor
128     ~cellFeatures();
131     // Member Functions
133         // Access
135             const labelHashSet& featureEdge() const
136             {
137                 return featureEdge_;
138             }
140             const faceList& faces() const
141             {
142                 if (!facesPtr_)
143                 {
144                     calcSuperFaces();
145                 }
146                 return *facesPtr_;
147             }
149             //- New to old faceMap. Guaranteed to be shrunk.
150             const List<DynamicList<label> >& faceMap() const
151             {
152                 if (!facesPtr_)
153                 {
154                     calcSuperFaces();
155                 }
156                 return faceMap_;
157             }
160         // Check
162             //- Is edge a feature edge (uniquely determined since on cell
163             //  only two faces sharing edge)
164             bool isFeatureEdge(const label edgeI) const
165             {
166                 return featureEdge().found(edgeI);
167             }
169             //- Are two edges connected at feature point?
170             //  Is local to face since point might be seen as feature point
171             //  from one face but not from another.
172             bool isFeaturePoint(const label edge0, const label edge1) const;
174             //- Is vertexI on faceI used by two edges that form feature
175             //  point
176             bool isFeatureVertex(const label faceI, const label vertI) const;
181 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
183 } // End namespace Foam
185 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
187 #endif
189 // ************************************************************************* //