47 int main(
int argc,
char *argv[])
60 Info<<
"Orienting faceZone " << zoneName
61 <<
" such that " << outsidePoint <<
" is outside" 70 <<
"Face zone " << fZone.
name()
71 <<
" is not parallel synchronised." 72 <<
" Any coupled face also needs its coupled version to be included" 73 <<
" and with opposite flipMap." 79 const indirectPrimitivePatch patch
100 label nProtected = 0;
104 const label meshFacei = faceLabels[facei];
110 && bm[patchi].coupled()
111 && !isMasterFace[meshFacei]
120 Info<<
"Protected from visiting " 122 <<
" slaves of coupled faces" <<
nl <<
endl;
126 labelList nMasterFaces(patch.nEdges(), 0);
130 const label meshFacei = faceLabels[facei];
132 if (isMasterFace[meshFacei])
134 const labelList& fEdges = patch.faceEdges()[facei];
137 nMasterFaces[fEdges[fEdgeI]]++;
152 label nProtected = 0;
154 forAll(nMasterFaces, edgeI)
156 if (nMasterFaces[edgeI] > 2)
163 Info<<
"Protected from visiting " 165 <<
" non-manifold edges" <<
nl <<
endl;
187 forAll(allFaceInfo, facei)
191 unsetFacei = globalFaces.toGlobal(facei);
203 label proci = globalFaces.whichProcID(unsetFacei);
204 label seedFacei = globalFaces.toLocal(proci, unsetFacei);
205 Info<<
"Seeding from processor " << proci <<
" face " << seedFacei
212 vector d = outsidePoint-patch.faceCentres()[seedFacei];
213 const vector& fn = patch.faceNormals()[seedFacei];
223 Pout<<
"Face " << seedFacei <<
" at " 224 << patch.faceCentres()[seedFacei]
225 <<
" with normal " << fn
226 <<
" needs to be flipped." <<
endl;
230 Pout<<
"Face " << seedFacei <<
" at " 231 << patch.faceCentres()[seedFacei]
232 <<
" with normal " << fn
233 <<
" points in positive direction (cos = " << (fn&d)/
mag(d)
238 const labelList& fEdges = patch.faceEdges()[seedFacei];
241 label edgeI = fEdges[fEdgeI];
259 changedEdges.
append(edgeI);
260 changedInfo.
append(edgeInfo);
303 const label meshFacei = faceLabels[i];
307 allFaceInfo[i].flipStatus();
314 const label meshFacei = faceLabels[i];
320 && bm[patchi].coupled()
321 && !isMasterFace[meshFacei]
338 <<
"Incorrect status for face " << meshFacei
348 boolList newFlipMap(allFaceInfo.size(),
false);
350 forAll(allFaceInfo, facei)
354 newFlipMap[facei] =
false;
358 newFlipMap[facei] =
true;
363 <<
"Problem : unvisited face " << facei
368 if (fZone.
flipMap()[facei] != newFlipMap[facei])
377 Info<<
"Flipping " << nChanged <<
" out of " 378 << globalFaces.size() <<
" faces." <<
nl <<
endl;
380 mesh.
faceZones()[zoneName].resetAddressing(faceLabels, newFlipMap);
const polyBoundaryMesh & boundaryMesh() const
Return boundary mesh.
#define forAll(list, i)
Loop across all elements in list.
intWM_LABEL_SIZE_t label
A label is an int32_t or int64_t as specified by the pre-processor macro WM_LABEL_SIZE.
bool updateEdge(const polyMesh &mesh, const indirectPrimitivePatch &patch, const label edgeI, const label facei, const patchFaceOrientation &faceInfo, const scalar tol, TrackingData &td)
Influence of face on edge.
errorManipArg< error, int > exit(error &err, const int errNo=1)
#define FatalErrorInFunction
Report an error message using Foam::FatalError.
label nInternalFaces() const
const labelListList & pointEdges() const
Wave propagation of information along patch. Every iteration information goes through one layer of fa...
void size(const label)
Override size to be inconsistent with allocated storage.
const boolList & flipMap() const
Return face flip map.
static int myProcNo(const label communicator=0)
Number of this process (starting from masterNo() = 0)
Ostream & endl(Ostream &os)
Add newline and flush stream.
virtual bool checkParallelSync(const bool report=false) const
Check whether all procs have faces synchronised. Return.
static SLList< string > validArgs
A list of valid (mandatory) arguments.
Transport of orientation for use in PatchEdgeFaceWave.
PrimitivePatch< IndirectList< face >, const pointField & > indirectPrimitivePatch
Foam::indirectPrimitivePatch.
virtual const pointField & points() const
Return raw points.
Calculates a unique integer (label so might not have enough room - 2G max) for processor + local inde...
A class for handling words, derived from string.
DynamicList< T, SizeInc, SizeMult, SizeDiv > & append(const T &)
Append an element at the end of the list.
void flip()
Reverse orientation.
static const label labelMax
const word & name() const
Return name.
virtual const faceList & faces() const
Return raw faces.
errorManip< error > abort(error &err)
bool isInternalFace(const label faceIndex) const
Return true if given face label is internal to the mesh.
void reduce(const List< UPstream::commsStruct > &comms, T &Value, const BinaryOp &bop, const int tag, const label comm)
const edgeList & edges() const
Return mesh edges. Uses calcEdges.
const vectorField & faceCentres() const
prefixOSstream Pout(cout, "Pout")
const meshFaceZones & faceZones() const
Return face zones.
T argRead(const label index) const
Read a value from the argument at index.
dimensioned< scalar > mag(const dimensioned< Type > &)
T returnReduce(const T &Value, const BinaryOp &bop, const int tag=Pstream::msgType(), const label comm=UPstream::worldComm)
A subset of mesh faces organised as a primitive patch.
virtual bool write(const bool write=true) const
Write using setting from DB.
Foam::argList args(argc, argv)
A List with indirect addressing.
label whichPatch(const label faceIndex) const
Return patch index for a given face label.