73 bool zoneFlip =
false;
116 if (!isA<processorPolyPatch>(pp))
129 || isA<coupledPolyPatch>(pp)
145 Info<<
"Removing zero-sized patch " << pp.
name()
146 <<
" type " << pp.type()
147 <<
" at position " << patchi <<
endl;
156 if (isA<processorPolyPatch>(pp))
173 Info<<
"Removing empty processor patch " << pp.
name()
174 <<
" at position " << patchi <<
endl;
180 if (nAllPatches != nOldPatches)
189 Info<<
"No patches removed." <<
endl;
192 delete allPatches[i];
207 isA<cyclicPolyPatch>(patches[patchi])
208 && refCast<const cyclicPolyPatch>(patches[patchi]).owner()
212 refCast<const cyclicPolyPatch>(patches[
patchi]);
217 Pout<<
"Writing " << cycPatch.
name()
218 <<
" faces to " << str.name() <<
endl;
230 Pout<<
"Writing " << nbrPatch.
name()
231 <<
" faces to " << str.
name() <<
endl;
242 OFstream str(prefix+cycPatch.
name()+nbrPatch.name()+
"_match.obj");
245 Pout<<
"Writing cyclic match as lines between face centres to " 257 str<<
"l " << vertI-1 <<
' ' << vertI <<
nl;
265 template<
class CombineOp>
270 const CombineOp& cop,
271 const point& nullValue
277 <<
"Number of values " << points.
size()
278 <<
" is not equal to the number of points in the mesh " 285 bool hasTransformation =
false;
297 isA<processorPolyPatch>(pp)
299 && refCast<const processorPolyPatch>(pp).owner()
303 refCast<const processorPolyPatch>(pp);
313 label nbrPointi = nbrPts[pointi];
314 if (nbrPointi >= 0 && nbrPointi < patchInfo.size())
316 patchInfo[nbrPointi] = points[meshPts[pointi]];
338 isA<processorPolyPatch>(pp)
340 && !refCast<const processorPolyPatch>(pp).owner()
344 refCast<const processorPolyPatch>(pp);
355 fromNbr >> nbrPatchInfo;
358 nbrPatchInfo.setSize(procPatch.
nPoints(), nullValue);
362 hasTransformation =
true;
374 label meshPointi = meshPts[pointi];
375 points[meshPointi] = nbrPatchInfo[pointi];
388 isA<cyclicPolyPatch>(pp)
389 && refCast<const cyclicPolyPatch>(pp).owner()
393 refCast<const cyclicPolyPatch>(pp);
404 const edge&
e = coupledPoints[i];
405 label point0 = meshPts[e[0]];
406 patchPoints[i] = points[point0];
411 hasTransformation =
true;
421 const edge&
e = coupledPoints[i];
422 label point1 = nbrMeshPts[e[1]];
423 points[point1] = patchPoints[i];
437 if (hasTransformation)
440 <<
"There are decomposed cyclics in this mesh with" 441 <<
" transformations." << endl
442 <<
"This is not supported. The result will be incorrect" 473 int main(
int argc,
char *argv[])
497 const Switch writeCyclicMatch
509 if (writeCyclicMatch)
511 writeCyclicMatchObjs(
"initial_", mesh);
518 forAll(patchSources, addedI)
520 const dictionary& dict = patchSources[addedI];
521 addedPatchNames.insert(dict.
lookup(
"name"));
528 if (patchSources.size())
540 if (!isA<processorPolyPatch>(pp))
552 startFacei += pp.size();
556 forAll(patchSources, addedI)
558 const dictionary& dict = patchSources[addedI];
562 label destPatchi = patches.findPatchID(patchName);
564 if (destPatchi == -1)
568 destPatchi = allPatches.size();
570 Info<<
"Adding new patch " << patchName
571 <<
" as patch " << destPatchi
572 <<
" from " << patchDict <<
endl;
574 patchDict.set(
"nFaces", 0);
575 patchDict.set(
"startFace", startFacei);
591 Info<<
"Patch '" << patchName <<
"' already exists. Only " 592 <<
"moving patch faces - type will remain the same" <<
endl;
601 if (isA<processorPolyPatch>(pp))
613 startFacei += pp.size();
632 forAll(patchSources, addedI)
634 const dictionary& dict = patchSources[addedI];
637 label destPatchi = patches.findPatchID(patchName);
639 if (destPatchi == -1)
642 <<
"patch " << patchName <<
" not added. Problem." 646 const word sourceType(dict.
lookup(
"constructFrom"));
648 if (sourceType ==
"patches")
661 const polyPatch& pp = patches[iter.key()];
663 Info<<
"Moving faces from patch " << pp.
name()
664 <<
" to patch " << destPatchi <<
endl;
678 else if (sourceType ==
"set")
685 <<
" faces from faceSet " << faces.name() <<
endl;
694 label facei = patchFaces[i];
699 <<
"Face " << facei <<
" specified in set " 701 <<
" is not an external face of the mesh." << endl
702 <<
"This application can only repatch existing boundary" 718 <<
"Invalid source type " << sourceType << endl
727 Info<<
"Doing topology modification to order faces." <<
nl <<
endl;
731 if (writeCyclicMatch)
733 writeCyclicMatchObjs(
"coupled_", mesh);
739 Info<<
"Not synchronising points." <<
nl <<
endl;
752 point(great, great, great)
765 Info<<
"Removing patches with no faces in them." <<
nl<<
endl;
766 filterPatches(mesh, addedPatchNames);
769 if (writeCyclicMatch)
771 writeCyclicMatchObjs(
"final_", mesh);
const polyBoundaryMesh & boundaryMesh() const
Return boundary mesh.
const labelList & sharedPointLabels() const
Return indices of local points that are globally shared.
virtual const fileName & name() const
Return the name of the stream.
label nPoints() const
Return number of points supporting patch faces.
scalar diff(const triad &A, const triad &B)
Return a quantity of the difference between two triads.
A HashTable with keys but without contents.
void append(T *)
Append an element at the end of the list.
virtual tmp< scalarField > movePoints(const pointField &)
Move points, returns volumes swept by faces in motion.
static void listCombineScatter(const List< commsStruct > &comms, List< T > &Value, const int tag, const label comm)
Scatter data. Reverse of combineGather.
#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.
const word & name() const
Return name.
A class for handling file names.
const labelList & nbrPoints() const
Return neighbour point labels. WIP.
errorManipArg< error, int > exit(error &err, const int errNo=1)
const edgeList & coupledPoints() const
Return connected points (from patch local to neighbour patch local)
Class describing modification of a face.
void off()
Switch the function objects off.
A list of keyword definitions, which are a keyword followed by any number of values (e...
dimensioned< Type > max(const dimensioned< Type > &, const dimensioned< Type > &)
#define FatalErrorInFunction
Report an error message using Foam::FatalError.
label nInternalFaces() const
A list that is sorted upon construction or when explicitly requested with the sort() method...
Various mesh related information for a parallel run. Upon construction, constructs all info using par...
static unsigned int defaultPrecision()
Return the default precision.
void size(const label)
Override size to be inconsistent with allocated storage.
const boolList & flipMap() const
Return face flip map.
static word defaultRegion
Return the default region name.
Ostream & endl(Ostream &os)
Add newline and flush stream.
bool optionFound(const word &opt) const
Return true if the named option is found.
A simple wrapper around bool so that it can be read as a word: true/false, on/off, yes/no, y/n, t/f, or none/any.
label whichFace(const label globalCellID) const
Helper function to re-direct to zone::localID(...)
virtual const transformer & transform() const
Return transformation between the coupled patches.
static word timeName(const scalar, const int precision=precision_)
Return time name of given scalar time.
const cyclicPolyPatch & nbrPatch() const
IOdictionary systemDict(const word &dictName, const argList &args, const objectRegistry &ob, const word ®ionName=polyMesh::defaultRegion)
static void listCombineGather(const List< commsStruct > &comms, List< T > &Value, const CombineOp &cop, const int tag, const label comm)
bool optionReadIfPresent(const word &opt, T &) const
Read a value from the named option if present.
const labelList & meshPoints() const
Return labelList of mesh points in patch. They are constructed.
Neighbour processor patch.
virtual const pointField & points() const
Return raw points.
const dictionary & subDict(const word &) const
Find and return a sub-dictionary.
Input inter-processor communications stream.
virtual autoPtr< polyPatch > clone(const polyBoundaryMesh &bm) const
Construct and return a clone, resetting the boundary mesh.
label nGlobalPoints() const
Return number of globally shared points.
const fileName & pointsInstance() const
Return the current instance directory for points.
A 1D vector of objects of type <T> that resizes itself as necessary to accept the new objects...
An edge is a list of two point labels. The functionality it provides supports the discretisation on a...
bool found(const Key &) const
Return true if hashedEntry is found in table.
A class for handling words, derived from string.
word name() const
Return file name (part beyond last /)
virtual const labelList & faceOwner() const
Return face owner.
const Field< PointType > & points() const
Return reference to global points.
const globalMeshData & globalData() const
Return parallel info.
virtual const faceList & faces() const
Return raw faces.
int neighbProcNo() const
Return neighbour processor number.
forAllConstIter(PtrDictionary< phaseModel >, mixture.phases(), phase)
errorManip< error > abort(error &err)
void addPatches(const List< polyPatch *> &, const bool validBoundary=true)
Add boundary patches.
defineTemplateTypeNameAndDebug(IOPtrList< ensightPart >, 0)
bool isInternalFace(const label faceIndex) const
Return true if given face label is internal to the mesh.
void removeBoundary()
Remove boundary patches.
bool checkParallelSync(const bool report=false) const
Check whether all procs have all patches and in same order. Return.
Type gMax(const FieldField< Field, Type > &f)
Output inter-processor communications stream.
void setInstance(const fileName &)
Set the instance for mesh files.
label size() const
Return the number of elements in the UPtrList.
const vectorField & faceCentres() const
label whichZone(const label objectIndex) const
Given a global object index, return the zone it is in.
A PtrList of objects of type <T> with automated input and output.
virtual const transformer & transform() const
Return null transform between processor patches.
static bool & parRun()
Is this a parallel run?
vector point
Point is a vector.
T lookupOrDefault(const word &, const T &, bool recursive=false, bool patternMatch=true) const
Find and return a T,.
const functionObjectList & functionObjects() const
Return the list of function objects.
#define WarningInFunction
Report a warning using Foam::Warning.
Type gAverage(const FieldField< Field, Type > &f)
A templated 1D list of pointers to objects of type <T>, where the size of the array is known and used...
prefixOSstream Pout(cout, "Pout")
const meshFaceZones & faceZones() const
Return face zones.
Direct mesh changes based on v1.3 polyTopoChange syntax.
label start() const
Return start label of this patch in the polyMesh face list.
dimensioned< scalar > mag(const dimensioned< Type > &)
static autoPtr< polyPatch > New(const word &patchType, const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm)
Return a pointer to a new patch created on freestore from.
T returnReduce(const T &Value, const BinaryOp &bop, const int tag=Pstream::msgType(), const label comm=UPstream::worldComm)
An auto-pointer similar to the STL auto_ptr but with automatic casting to a reference to the type and...
const doubleScalar e
Elementary charge.
Mesh consisting of general polyhedral cells.
A subset of mesh faces organised as a primitive patch.
autoPtr< mapPolyMesh > changeMesh(polyMesh &mesh, const bool inflate, const bool syncParallel=true, const bool orderCells=false, const bool orderPoints=false)
Inplace changes mesh without change of patches.
virtual bool write(const bool write=true) const
Write using setting from DB.
A patch is a list of labels that address the faces in the global face list.
Foam::argList args(argc, argv)
const labelList & sharedPointAddr() const
Return addressing into the complete globally shared points.
ITstream & lookup(const word &, bool recursive=false, bool patternMatch=true) const
Find and return an entry data stream.
label setAction(const topoAction &action)
For compatibility with polyTopoChange: set topological action.