Loading...
Searching...
No Matches
cellInfo.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 | www.openfoam.com
6 \\/ M anipulation |
7-------------------------------------------------------------------------------
8 Copyright (C) 2011-2016 OpenFOAM Foundation
9 Copyright (C) 2019-2020 OpenCFD Ltd.
10-------------------------------------------------------------------------------
11License
12 This file is part of OpenFOAM.
13
14 OpenFOAM is free software: you can redistribute it and/or modify it
15 under the terms of the GNU General Public License as published by
16 the Free Software Foundation, either version 3 of the License, or
17 (at your option) any later version.
18
19 OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
20 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
22 for more details.
23
24 You should have received a copy of the GNU General Public License
25 along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
26
27Class
28 Foam::cellInfo
29
30Description
31 Holds information regarding type of cell. Used in inside/outside
32 determination in cellClassification.
33
34SourceFiles
35 cellInfoI.H
36 cellInfo.C
37
38\*---------------------------------------------------------------------------*/
39
40#ifndef cellInfo_H
41#define cellInfo_H
42
43#include "point.H"
44#include "label.H"
45#include "tensor.H"
46
47// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
48
49namespace Foam
50{
51
52// Forward Declarations
53class polyPatch;
54class polyMesh;
55class cellInfo;
56
59
61/*---------------------------------------------------------------------------*\
62 Class cellInfo Declaration
63\*---------------------------------------------------------------------------*/
64
65class cellInfo
66{
67 // Private Data
68
69 label type_;
70
71
72 // Private Member Functions
73
74 //- Update current cell/face type with neighbouring type.
75 // \return true if information needs to propagate, false otherwise.
76 template<class TrackingData>
77 inline bool update
78 (
79 const cellInfo& w2,
80 const label thisFacei,
81 const label thisCelli,
82 const label neighbourFacei,
83 const label neighbourCelli,
84 TrackingData& td
85 );
86
87
88public:
89
90 // Constructors
91
92 //- Default construct - as cellClassification::NOTSET
93 inline cellInfo();
94
95 //- Construct from cellClassification type
96 inline explicit cellInfo(const label ctype);
97
98
99 // Member Functions
100
101 // Access
102
103 label type() const
104 {
105 return type_;
106 }
107 label& type()
108 {
109 return type_;
110 }
111
112
113 // Needed by MeshWave
114
115 //- Changed or contains original (invalid) value
116 template<class TrackingData>
117 inline bool valid(TrackingData& td) const;
118
119 //- Check for identical geometrical data (eg, cyclics checking)
120 template<class TrackingData>
121 inline bool sameGeometry
122 (
123 const polyMesh&,
124 const cellInfo&,
125 const scalar,
126 TrackingData& td
127 ) const;
128
129 //- Convert any absolute coordinates into relative to (patch)face
130 // centre
131 template<class TrackingData>
132 inline void leaveDomain
133 (
134 const polyMesh&,
135 const polyPatch& patch,
136 const label patchFacei,
137 const point& faceCentre,
138 TrackingData& td
139 );
140
141 //- Reverse of leaveDomain
142 template<class TrackingData>
143 inline void enterDomain
144 (
145 const polyMesh&,
146 const polyPatch& patch,
147 const label patchFacei,
148 const point& faceCentre,
149 TrackingData& td
150 );
151
152 //- Apply rotation matrix to any coordinates
153 template<class TrackingData>
154 inline void transform
155 (
156 const polyMesh&,
157 const tensor& rotTensor,
158 TrackingData& td
159 );
160
161 //- Influence of neighbouring face.
162 template<class TrackingData>
163 inline bool updateCell
164 (
165 const polyMesh&,
166 const label thisCelli,
167 const label neighbourFacei,
168 const cellInfo& neighbourInfo,
169 const scalar tol,
170 TrackingData& td
171 );
172
173 //- Influence of neighbouring cell.
174 template<class TrackingData>
175 inline bool updateFace
176 (
177 const polyMesh&,
178 const label thisFacei,
179 const label neighbourCelli,
180 const cellInfo& neighbourInfo,
181 const scalar tol,
182 TrackingData& td
183 );
184
185 //- Influence of different value on same face.
186 template<class TrackingData>
187 inline bool updateFace
188 (
189 const polyMesh&,
190 const label thisFacei,
191 const cellInfo& neighbourInfo,
192 const scalar tol,
193 TrackingData& td
194 );
195
196 //- Test for equality, with TrackingData
197 template<class TrackingData>
198 inline bool equal(const cellInfo&, TrackingData& td) const;
199
200 //- Interpolate between two values (lerp). Returns true if
201 //- causes changes. Not sure if needs to be specialised between
202 //- face and cell and what index is needed...
203 template<class TrackingData>
204 inline bool interpolate
205 (
206 const polyMesh&,
207 const point& pt,
208 const label i0,
209 const cellInfo& f0,
210 const label i1,
211 const cellInfo& f1,
212 const scalar weight,
213 const scalar tol,
214 TrackingData& td
215 );
216
217
218 // Member Operators
219
220 //- Test for equality
221 inline bool operator==(const cellInfo&) const;
222
223 //- Test for inequality
224 inline bool operator!=(const cellInfo&) const;
225
226
227 // IOstream Operators
228
229 friend Ostream& operator<<(Ostream&, const cellInfo&);
231};
232
233
234// * * * * * * * * * * * * * * * * * Traits * * * * * * * * * * * * * * * * //
235
236//- Contiguous data for cellInfo
237template<> struct is_contiguous<cellInfo> : std::true_type {};
238
239//- Contiguous label data for cellInfo
240template<> struct is_contiguous_label<cellInfo> : std::true_type {};
241
242
243// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
244
245} // End namespace Foam
246
247// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
248
249#include "cellInfoI.H"
250
251// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
252
253#endif
254
255// ************************************************************************* //
#define w2
Definition blockCreate.C:28
An Istream is an abstract base class for all input systems (streams, files, token lists etc)....
Definition Istream.H:60
An Ostream is an abstract base class for all output systems (streams, files, token lists,...
Definition Ostream.H:59
Holds information regarding type of cell. Used in inside/outside determination in cellClassification.
Definition cellInfo.H:61
void transform(const polyMesh &, const tensor &rotTensor, TrackingData &td)
Apply rotation matrix to any coordinates.
Definition cellInfoI.H:142
bool interpolate(const polyMesh &, const point &pt, const label i0, const cellInfo &f0, const label i1, const cellInfo &f1, const scalar weight, const scalar tol, TrackingData &td)
Interpolate between two values (lerp). Returns true if causes changes. Not sure if needs to be specia...
Definition cellInfoI.H:247
bool updateCell(const polyMesh &, const label thisCelli, const label neighbourFacei, const cellInfo &neighbourInfo, const scalar tol, TrackingData &td)
Influence of neighbouring face.
Definition cellInfoI.H:166
bool equal(const cellInfo &, TrackingData &td) const
Test for equality, with TrackingData.
Definition cellInfoI.H:236
bool operator==(const cellInfo &) const
Test for equality.
Definition cellInfoI.H:273
friend Ostream & operator<<(Ostream &, const cellInfo &)
cellInfo()
Default construct - as cellClassification::NOTSET.
Definition cellInfoI.H:91
bool operator!=(const cellInfo &) const
Test for inequality.
Definition cellInfoI.H:282
label & type()
Definition cellInfo.H:109
bool updateFace(const polyMesh &, const label thisFacei, const label neighbourCelli, const cellInfo &neighbourInfo, const scalar tol, TrackingData &td)
Influence of neighbouring cell.
Definition cellInfoI.H:190
bool valid(TrackingData &td) const
Changed or contains original (invalid) value.
Definition cellInfoI.H:106
friend Istream & operator>>(Istream &, cellInfo &)
void enterDomain(const polyMesh &, const polyPatch &patch, const label patchFacei, const point &faceCentre, TrackingData &td)
Reverse of leaveDomain.
Definition cellInfoI.H:153
void leaveDomain(const polyMesh &, const polyPatch &patch, const label patchFacei, const point &faceCentre, TrackingData &td)
Convert any absolute coordinates into relative to (patch)face.
Definition cellInfoI.H:129
label type() const
Definition cellInfo.H:105
bool sameGeometry(const polyMesh &, const cellInfo &, const scalar, TrackingData &td) const
Check for identical geometrical data (eg, cyclics checking).
Definition cellInfoI.H:115
Mesh consisting of general polyhedral cells.
Definition polyMesh.H:79
A patch is a list of labels that address the faces in the global face list.
Definition polyPatch.H:73
mesh update()
wallPoints::trackData td(isBlockedFace, regionToBlockSize)
Namespace for OpenFOAM.
Tensor< scalar > tensor
Definition symmTensor.H:57
Ostream & operator<<(Ostream &, const boundaryPatch &p)
Write boundaryPatch as dictionary entries (without surrounding braces).
Istream & operator>>(Istream &, directionInfo &)
vector point
Point is a vector.
Definition point.H:37
A template class to specify if a data type is composed solely of Foam::label elements.
Definition contiguous.H:82
A template class to specify that a data type can be considered as being contiguous in memory.
Definition contiguous.H:70