Transferred copyright to the OpenFOAM Foundation
[OpenFOAM-2.0.x.git] / src / finiteVolume / fvMesh / extendedStencil / cellToCell / fullStencils / cellToCellStencil.H
blobe31b6395aae4ae4b0e8b8220bb30560c072cc6b9
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::cellToCellStencil
27 Description
28     baseclass for extended cell centred addressing. Contains per cell a
29     list of neighbouring cells and/or boundaryfaces in global addressing.
31 SourceFiles
32     cellToCellStencil.C
34 \*---------------------------------------------------------------------------*/
36 #ifndef cellToCellStencil_H
37 #define cellToCellStencil_H
39 #include "globalIndex.H"
40 #include "boolList.H"
41 #include "HashSet.H"
42 #include "indirectPrimitivePatch.H"
44 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
46 namespace Foam
49 class polyMesh;
51 /*---------------------------------------------------------------------------*\
52                       Class cellToCellStencil Declaration
53 \*---------------------------------------------------------------------------*/
55 class cellToCellStencil
57     public labelListList
59     // Private data
61         const polyMesh& mesh_;
63         //- Global numbering for cells and boundary faces
64         const globalIndex globalNumbering_;
67 protected:
69         //- Merge two lists.
70         static void merge
71         (
72             const label,
73             const label,
74             const labelList&,
75             labelList&
76         );
78         //- Merge two lists.
79         static void merge(const label, const labelList&, labelList&);
81         //- Valid boundary faces (not empty and not coupled)
82         void validBoundaryFaces(boolList& isValidBFace) const;
84         //- Return patch of all coupled faces.
85         autoPtr<indirectPrimitivePatch> allCoupledFacesPatch() const;
87         //- Combine operator for labelLists
88         class unionEqOp
89         {
90             public:
91             void operator()(labelList& x, const labelList& y) const;
92         };
94         //- Collect cell neighbours of faces in global numbering
95         void insertFaceCells
96         (
97             const label exclude0,
98             const label exclude1,
99             const boolList& nonEmptyFace,
100             const labelList& faceLabels,
101             labelHashSet& globals
102         ) const;
104         //- Collect cell neighbours of faces in global numbering
105         labelList calcFaceCells
106         (
107             const boolList& nonEmptyFace,
108             const labelList& faceLabels,
109             labelHashSet& globals
110         ) const;
113 public:
115     // Constructors
117         //- Construct from mesh
118         explicit cellToCellStencil(const polyMesh&);
121     // Member Functions
123         const polyMesh& mesh() const
124         {
125             return mesh_;
126         }
128         //- Global numbering for cells and boundary faces
129         const globalIndex& globalNumbering() const
130         {
131             return globalNumbering_;
132         }
137 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
139 } // End namespace Foam
141 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
143 #endif
145 // ************************************************************************* //