BUG: UListIO: byteSize overflowing on really big faceLists
[OpenFOAM-2.0.x.git] / src / OpenFOAM / meshes / primitiveMesh / PrimitivePatch / PrimitivePatch.H
blobc3d359016ab84be8031f3b42c192a487777515d4
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 2011 OpenFOAM Foundation
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::PrimitivePatch
27 Description
28     A list of faces which address into the list of points.
30     The class is templated on the face type (e.g. triangle, polygon etc.)
31     and on the list type of faces and points so that it can refer to
32     existing lists using UList and const pointField& or hold the storage
33     using List and pointField.
35 SourceFiles
36     PrimitivePatchAddressing.C
37     PrimitivePatchBdryPoints.C
38     PrimitivePatch.C
39     PrimitivePatchCheck.C
40     PrimitivePatchClear.C
41     PrimitivePatchEdgeLoops.C
42     PrimitivePatchLocalPointOrder.C
43     PrimitivePatchMeshData.C
44     PrimitivePatchMeshEdges.C
45     PrimitivePatchName.C
46     PrimitivePatchPointAddressing.C
47     PrimitivePatchProjectPoints.C
49 \*---------------------------------------------------------------------------*/
51 #ifndef PrimitivePatch_H
52 #define PrimitivePatch_H
54 #include "boolList.H"
55 #include "labelList.H"
56 #include "edgeList.H"
57 #include "point.H"
58 #include "intersection.H"
59 #include "HashSet.H"
60 #include "objectHit.H"
62 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
64 namespace Foam
67 class face;
68 template<class T> class Map;
70 /*---------------------------------------------------------------------------*\
71                         Class PrimitivePatchName Declaration
72 \*---------------------------------------------------------------------------*/
74 TemplateName(PrimitivePatch);
77 /*---------------------------------------------------------------------------*\
78                            Class PrimitivePatch Declaration
79 \*---------------------------------------------------------------------------*/
81 template
83     class Face,
84     template<class> class FaceList,
85     class PointField,
86     class PointType=point
88 class PrimitivePatch
90     public PrimitivePatchName,
91     public FaceList<Face>
94 public:
96     // Public typedefs
98         typedef Face FaceType;
99         typedef FaceList<Face> FaceListType;
100         typedef PointField PointFieldType;
103     // Public data types
105         //- Enumeration defining the surface type. Used in check routines.
106         enum surfaceTopo
107         {
108             MANIFOLD,
109             OPEN,
110             ILLEGAL
111         };
113 private:
115     // Private data
117         //- Reference to global list of points
118         PointField points_;
121     // Demand driven private data
123         //- Edges of the patch; address into local point list;
124         //  sorted with internal edges first in upper-triangular order
125         //  and external edges last.
126         mutable edgeList* edgesPtr_;
128         //- Which part of edgesPtr_ is internal edges.
129         mutable label nInternalEdges_;
131         //- Boundary point labels, addressing into local point list
132         mutable labelList* boundaryPointsPtr_;
134         //- Face-face addressing
135         mutable labelListList* faceFacesPtr_;
137         //- Edge-face addressing
138         mutable labelListList* edgeFacesPtr_;
140         //- Face-edge addressing
141         mutable labelListList* faceEdgesPtr_;
143         //- Point-edge addressing
144         mutable labelListList* pointEdgesPtr_;
146         //- Point-face addressing
147         mutable labelListList* pointFacesPtr_;
149         //- Faces addressing into local point list
150         mutable List<Face>* localFacesPtr_;
152         //- Labels of mesh points
153         mutable labelList* meshPointsPtr_;
155         //- Mesh point map.  Given the global point index find its
156         //location in the patch
157         mutable Map<label>* meshPointMapPtr_;
159         //- Outside edge loops
160         mutable labelListList* edgeLoopsPtr_;
162         //- Points local to patch
163         mutable Field<PointType>* localPointsPtr_;
165         //- Local point order for most efficient search
166         mutable labelList* localPointOrderPtr_;
168         //- Face centres
169         mutable Field<PointType>* faceCentresPtr_;
171         //- Face unit normals
172         mutable Field<PointType>* faceNormalsPtr_;
174         //- Point unit normals
175         mutable Field<PointType>* pointNormalsPtr_;
178     // Private Member Functions
180         //- Calculate edges of the patch
181         void calcIntBdryEdges() const;
183         //- Calculated boundary points on a patch
184         void calcBdryPoints() const;
186         //- Calculate addressing
187         void calcAddressing() const;
189         //- Calculate point-edge addressing
190         void calcPointEdges() const;
192         //- Calculate point-face addressing
193         void calcPointFaces() const;
195         //- Calculate mesh addressing
196         void calcMeshData() const;
198         //- Calculate mesh point map
199         void calcMeshPointMap() const;
201         //- Calculate outside edge loops
202         void calcEdgeLoops() const;
204         //- Calculate local points
205         void calcLocalPoints() const;
207         //- Calculate local point order
208         void calcLocalPointOrder() const;
210         //- Calculate face centres
211         void calcFaceCentres() const;
213         //- Calculate unit face normals
214         void calcFaceNormals() const;
216         //- Calculate unit point normals
217         void calcPointNormals() const;
219         //- Calculate edge owner
220         void calcEdgeOwner() const;
223         //- Face-edge-face walk while remaining on a patch point.
224         //  Used to determine if surface multiply connected through point.
225         void visitPointRegion
226         (
227             const label pointI,
228             const labelList& pFaces,
229             const label startFaceI,
230             const label startEdgeI,
231             boolList& pFacesHad
232         ) const;
235 public:
237     // Constructors
239         //- Construct from components
240         PrimitivePatch
241         (
242             const FaceList<Face>& faces,
243             const Field<PointType>& points
244         );
246         //- Construct from components, reuse storage
247         PrimitivePatch
248         (
249             FaceList<Face>& faces,
250             Field<PointType>& points,
251             const bool reUse
252         );
254         //- Construct as copy
255         PrimitivePatch
256         (
257             const PrimitivePatch<Face, FaceList, PointField, PointType>&
258         );
261     //- Destructor
262     virtual ~PrimitivePatch();
264         void clearOut();
266         void clearGeom();
268         void clearTopology();
270         void clearPatchMeshAddr();
273     // Member Functions
275     // Access
277         //- Return reference to global points
278         const Field<PointType>& points() const
279         {
280             return points_;
281         }
284     // Access functions for demand driven data
286         // Topological data; no mesh required.
288             //- Return number of points supporting patch faces
289             label nPoints() const
290             {
291                 return meshPoints().size();
292             }
294             //- Return number of edges in patch
295             label nEdges() const
296             {
297                 return edges().size();
298             }
300             //- Return list of edges, address into LOCAL point list
301             const edgeList& edges() const;
303             //- Number of internal edges
304             label nInternalEdges() const;
306             //- Is internal edge?
307             bool isInternalEdge(const label edgeI) const
308             {
309                 return edgeI < nInternalEdges();
310             }
312             //- Return list of boundary points,
313             //  address into LOCAL point list
314             const labelList& boundaryPoints() const;
316             //- Return face-face addressing
317             const labelListList& faceFaces() const;
319             //- Return edge-face addressing
320             const labelListList& edgeFaces() const;
322             //- Return face-edge addressing
323             const labelListList& faceEdges() const;
325             //- Return point-edge addressing
326             const labelListList& pointEdges() const;
328             //- Return point-face addressing
329             const labelListList& pointFaces() const;
331             //- Return patch faces addressing into local point list
332             const List<Face>& localFaces() const;
335         // Addressing into mesh
337             //- Return labelList of mesh points in patch. They are constructed
338             //  walking through the faces in incremental order and not sorted
339             //  anymore.
340             const labelList& meshPoints() const;
342             //- Mesh point map.  Given the global point index find its
343             //  location in the patch
344             const Map<label>& meshPointMap() const;
346             //- Return pointField of points in patch
347             const Field<PointType>& localPoints() const;
349             //- Return orders the local points for most efficient search
350             const labelList& localPointOrder() const;
352             //- Given a global point index, return the local point index.
353             //  If the point is not found, return -1
354             label whichPoint(const label gp) const;
356             //- Given an edge in local point labels, return its
357             //  index in the edge list.  If the edge is not found, return -1
358             label whichEdge(const edge&) const;
360             //- Return labels of patch edges in the global edge list using
361             //  cell addressing
362             labelList meshEdges
363             (
364                 const edgeList& allEdges,
365                 const labelListList& cellEdges,
366                 const labelList& faceCells
367             ) const;
369             //- Return labels of patch edges in the global edge list using
370             //  basic edge addressing.
371             labelList meshEdges
372             (
373                 const edgeList& allEdges,
374                 const labelListList& pointEdges
375             ) const;
377             //- Return face centres for patch
378             const Field<PointType>& faceCentres() const;
380             //- Return face normals for patch
381             const Field<PointType>& faceNormals() const;
383             //- Return point normals for patch
384             const Field<PointType>& pointNormals() const;
387         // Other patch operations
389             //- Project vertices of patch onto another patch
390             template <class ToPatch>
391             List<objectHit> projectPoints
392             (
393                 const ToPatch& targetPatch,
394                 const Field<PointType>& projectionDirection,
395                 const intersection::algorithm = intersection::FULL_RAY,
396                 const intersection::direction = intersection::VECTOR
397             ) const;
399             //- Project vertices of patch onto another patch
400             template <class ToPatch>
401             List<objectHit> projectFaceCentres
402             (
403                 const ToPatch& targetPatch,
404                 const Field<PointType>& projectionDirection,
405                 const intersection::algorithm = intersection::FULL_RAY,
406                 const intersection::direction = intersection::VECTOR
407             ) const;
409             //- Return list of closed loops of boundary vertices.
410             //  Edge loops are given as ordered lists of vertices
411             //  in local addressing
412             const labelListList& edgeLoops() const;
415     // Check
417         //- Calculate surface type formed by patch.
418         //  Types:
419         //  - all edges have two neighbours (manifold)
420         //  - some edges have more than two neighbours (illegal)
421         //  - other (open)
422         surfaceTopo surfaceType() const;
424         //- Check surface formed by patch for manifoldness (see above).
425         //  Return true if any incorrect edges are found.
426         //  Insert vertices of incorrect edges into set.
427         bool checkTopology
428         (
429             const bool report = false,
430             labelHashSet* setPtr = NULL
431         ) const;
433         //- Checks primitivePatch for faces sharing point but not edge.
434         //  This denotes a surface that is pinched at a single point
435         //  (test for pinched at single edge is already in PrimitivePatch)
436         //  Returns true if this situation found and puts conflicting
437         //  (mesh)point in set. Based on all the checking routines in
438         //  primitiveMesh.
439         bool checkPointManifold
440         (
441             const bool report = false,
442             labelHashSet* setPtr = NULL
443         ) const;
446     // Edit
448         //- Correct patch after moving points
449         virtual void movePoints(const Field<PointType>&);
452     // Member operators
454         //- Assignment
455         void operator=
456         (
457             const PrimitivePatch<Face, FaceList, PointField, PointType>&
458         );
462 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
464 } // End namespace Foam
466 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
468 #ifdef NoRepository
469 #   include "PrimitivePatch.C"
470 #endif
472 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
474 #endif
476 // ************************************************************************* //