processorCyclicPolyPatch Class Reference

Neighbour processor patch. More...

Inheritance diagram for processorCyclicPolyPatch:
[legend]
Collaboration diagram for processorCyclicPolyPatch:
[legend]

Public Member Functions

 TypeName ("processorCyclic")
 Runtime type information. More...
 
 processorCyclicPolyPatch (const label size, const label start, const label index, const polyBoundaryMesh &bm, const int myProcNo, const int neighbProcNo, const word &referPatchName, const transformType transform=UNKNOWN, const word &patchType=typeName)
 Construct from components. More...
 
 processorCyclicPolyPatch (const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &, const word &patchType)
 Construct from dictionary. More...
 
 processorCyclicPolyPatch (const processorCyclicPolyPatch &, const polyBoundaryMesh &)
 Construct as copy, resetting the boundary mesh. More...
 
 processorCyclicPolyPatch (const processorCyclicPolyPatch &pp, const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart)
 Construct as given the original patch and resetting the. More...
 
 processorCyclicPolyPatch (const processorCyclicPolyPatch &pp, const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart, const word &referPatchName)
 Construct as given the original patch and resetting the. More...
 
 processorCyclicPolyPatch (const processorCyclicPolyPatch &pp, const polyBoundaryMesh &bm, const label index, const labelUList &mapAddressing, const label newStart)
 Construct given the original patch and a map. More...
 
virtual autoPtr< polyPatchclone (const polyBoundaryMesh &bm) const
 Construct and return a clone, resetting the boundary mesh. More...
 
virtual autoPtr< polyPatchclone (const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart) const
 Construct and return a clone, resetting the face list. More...
 
virtual autoPtr< polyPatchclone (const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart, const word &referPatchName) const
 Construct and return a clone, resetting the face list. More...
 
virtual autoPtr< polyPatchclone (const polyBoundaryMesh &bm, const label index, const labelUList &mapAddressing, const label newStart) const
 Construct and return a clone, resetting the face list. More...
 
virtual ~processorCyclicPolyPatch ()
 
const wordreferPatchName () const
 Return name of originating cyclicPolyPatch patch. More...
 
label referPatchID () const
 Referring patchID. More...
 
const coupledPolyPatchreferPatch () const
 
virtual int tag () const
 Return message tag to use for communication. More...
 
virtual bool owner () const
 Does this side own the patch ? More...
 
virtual transformType transform () const
 Type of transform. More...
 
virtual transformTypetransform ()
 Type of transform. More...
 
virtual void transformPosition (pointField &l) const
 Transform a patch-based position from other side to this side. More...
 
virtual void transformPosition (point &l, const label facei) const
 Transform a patch-based position from other side to this side. More...
 
virtual bool separated () const
 Are the planes separated. More...
 
virtual const vectorFieldseparation () const
 If the planes are separated the separation vector. More...
 
virtual bool parallel () const
 Are the cyclic planes parallel. More...
 
virtual const tensorFieldforwardT () const
 Return face transformation tensor. More...
 
virtual const tensorFieldreverseT () const
 Return neighbour-cell transformation tensor. More...
 
virtual const boolListcollocated () const
 Are faces collocated. Either size 0,1 or length of patch. More...
 
virtual void initOrder (PstreamBuffers &, const primitivePatch &) const
 Initialize ordering for primitivePatch. Does not. More...
 
virtual bool order (PstreamBuffers &, const primitivePatch &, labelList &faceMap, labelList &rotation) const
 Return new ordering for primitivePatch. More...
 
virtual void write (Ostream &) const
 Write the polyPatch data as a dictionary. More...
 
- Public Member Functions inherited from processorPolyPatch
 TypeName ("processor")
 Runtime type information. More...
 
 processorPolyPatch (const label size, const label start, const label index, const polyBoundaryMesh &bm, const int myProcNo, const int neighbProcNo, const transformType transform=UNKNOWN, const word &patchType=typeName)
 Construct from components with automatically generated standard name. More...
 
 processorPolyPatch (const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &, const word &patchType)
 Construct from dictionary. More...
 
 processorPolyPatch (const processorPolyPatch &, const polyBoundaryMesh &)
 Construct as copy, resetting the boundary mesh. More...
 
 processorPolyPatch (const processorPolyPatch &pp, const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart)
 Construct as given the original patch and resetting the. More...
 
 processorPolyPatch (const processorPolyPatch &pp, const polyBoundaryMesh &bm, const label index, const labelUList &mapAddressing, const label newStart)
 Construct given the original patch and a map. More...
 
virtual autoPtr< polyPatchclone (const polyBoundaryMesh &bm) const
 Construct and return a clone, resetting the boundary mesh. More...
 
virtual autoPtr< polyPatchclone (const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart) const
 Construct and return a clone, resetting the face list. More...
 
virtual autoPtr< polyPatchclone (const polyBoundaryMesh &bm, const label index, const labelUList &mapAddressing, const label newStart) const
 Construct and return a clone, resetting the face list. More...
 
virtual ~processorPolyPatch ()
 Destructor. More...
 
virtual bool coupled () const
 Return true only if this is a parallel run. More...
 
int myProcNo () const
 Return processor number. More...
 
int neighbProcNo () const
 Return neighbour processor number. More...
 
virtual bool owner () const
 Does the processor own the patch ? More...
 
bool neighbour () const
 Is the processor the patch neighbour ? More...
 
const vectorFieldneighbFaceCentres () const
 Return processor-neighbour patch face centres. More...
 
const vectorFieldneighbFaceAreas () const
 Return processor-neighbour patch face areas. More...
 
const vectorFieldneighbFaceCellCentres () const
 Return processor-neighbour patch neighbour cell centres. More...
 
const labelListneighbPoints () const
 Return neighbour point labels. WIP. More...
 
const labelListneighbEdges () const
 Return neighbour edge labels. WIP. More...
 
virtual int tag () const
 Return message tag to use for communication. More...
 
virtual label comm () const
 Return communicator used for communication. More...
 
virtual void transformPosition (pointField &l) const
 Transform a patch-based position from other side to this side. More...
 
virtual void transformPosition (point &, const label facei) const
 Transform a patch-based position from other side to this side. More...
 
virtual void initOrder (PstreamBuffers &, const primitivePatch &) const
 Initialize ordering for primitivePatch. Does not. More...
 
virtual bool order (PstreamBuffers &, const primitivePatch &, labelList &faceMap, labelList &rotation) const
 Return new ordering for primitivePatch. More...
 
virtual void write (Ostream &) const
 Write the polyPatch data as a dictionary. More...
 
- Public Member Functions inherited from coupledPolyPatch
 TypeName ("coupled")
 Runtime type information. More...
 
 coupledPolyPatch (const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm, const word &patchType, const transformType transform)
 Construct from components. More...
 
 coupledPolyPatch (const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm, const word &patchType)
 Construct from dictionary. More...
 
 coupledPolyPatch (const coupledPolyPatch &, const polyBoundaryMesh &bm)
 Copy construct, resetting the boundary mesh. More...
 
 coupledPolyPatch (const coupledPolyPatch &, const labelList &faceCells)
 Copy construct, resetting the faceCells. More...
 
 coupledPolyPatch (const coupledPolyPatch &pp, const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart)
 
 coupledPolyPatch (const coupledPolyPatch &pp, const polyBoundaryMesh &bm, const label index, const labelUList &mapAddressing, const label newStart)
 Construct given the original patch and a map. More...
 
virtual ~coupledPolyPatch ()
 Destructor. More...
 
virtual bool coupled () const
 Return true because this patch is coupled. More...
 
virtual bool owner () const =0
 Does this side own the patch ? More...
 
virtual bool neighbour () const
 Does the coupled side own the patch ? More...
 
virtual transformType transform () const
 Type of transform. More...
 
virtual transformTypetransform ()
 Type of transform. More...
 
virtual void transformPosition (pointField &) const =0
 Transform a patch-based position from other side to this side. More...
 
virtual void transformPosition (point &, const label facei) const =0
 Transform a patch-based position from other side to this side. More...
 
virtual bool separated () const
 Are the planes separated. More...
 
virtual const vectorFieldseparation () const
 If the planes are separated the separation vector. More...
 
virtual bool parallel () const
 Are the cyclic planes parallel. More...
 
virtual const tensorFieldforwardT () const
 Return face transformation tensor. More...
 
virtual const tensorFieldreverseT () const
 Return neighbour-cell transformation tensor. More...
 
virtual const boolListcollocated () const
 Are faces collocated. Either size 0,1 or length of patch. More...
 
scalar matchTolerance () const
 
virtual void calcGeometry (const primitivePatch &referPatch, const pointField &thisCtrs, const vectorField &thisAreas, const pointField &thisCc, const pointField &nbrCtrs, const vectorField &nbrAreas, const pointField &nbrCc)=0
 Calculate the patch geometry. More...
 
virtual void initOrder (PstreamBuffers &, const primitivePatch &) const =0
 Initialize ordering for primitivePatch. Does not. More...
 
virtual bool order (PstreamBuffers &, const primitivePatch &, labelList &faceMap, labelList &rotation) const =0
 Return new ordering for primitivePatch. More...
 
virtual void write (Ostream &os) const
 Write the polyPatch data as a dictionary. More...
 
- Public Member Functions inherited from polyPatch
 TypeName ("patch")
 Runtime type information. More...
 
 declareRunTimeSelectionTable (autoPtr, polyPatch, word,(const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm, const word &patchType),(name, size, start, index, bm, patchType))
 
 declareRunTimeSelectionTable (autoPtr, polyPatch, dictionary,(const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm, const word &patchType),(name, dict, index, bm, patchType))
 
 polyPatch (const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm, const word &patchType)
 Construct from components. More...
 
 polyPatch (const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm, const word &physicalType, const wordList &inGroups)
 Construct from components. More...
 
 polyPatch (const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm, const word &patchType)
 Construct from dictionary. More...
 
 polyPatch (const polyPatch &, const polyBoundaryMesh &)
 Copy construct, resetting the boundary mesh. More...
 
 polyPatch (const polyPatch &pp, const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart)
 
 polyPatch (const polyPatch &pp, const polyBoundaryMesh &bm, const label index, const labelUList &mapAddressing, const label newStart)
 Construct given the original patch and a map. More...
 
 polyPatch (const polyPatch &p)
 Copy construct. More...
 
 polyPatch (const polyPatch &p, const labelList &faceCells)
 Copy construct, setting faceCells. More...
 
virtual autoPtr< polyPatchclone (const labelList &faceCells) const
 Construct and return a clone, setting faceCells. More...
 
virtual autoPtr< polyPatchclone (const polyBoundaryMesh &bm) const
 Construct and return a clone, resetting the boundary mesh. More...
 
virtual autoPtr< polyPatchclone (const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart) const
 
virtual autoPtr< polyPatchclone (const polyBoundaryMesh &bm, const label index, const labelUList &mapAddressing, const label newStart) const
 
virtual ~polyPatch ()
 Destructor. More...
 
virtual void newInternalProcFaces (label &, label &) const
 Return number of new internal of this polyPatch faces. More...
 
virtual const labelUListnbrCells () const
 Return nbrCells. More...
 
virtual label neighbPolyPatchID () const
 Return nbr patchID. More...
 
virtual refPtr< labelListListmapCollocatedFaces () const
 Return mapped collocated faces. More...
 
virtual bool masterImplicit () const
 Return implicit master. More...
 
virtual word neighbRegionID () const
 Return neighbour region name. More...
 
label offset () const
 The offset where this patch starts in the boundary face list. More...
 
label start () const
 Return start label of this patch in the polyMesh face list. More...
 
labelRange range () const
 Return start/size range of this patch. More...
 
const polyBoundaryMeshboundaryMesh () const
 Return boundaryMesh reference. More...
 
virtual bool coupled () const
 Return true if this patch is geometrically coupled (i.e. faces and. More...
 
template<class T >
const UIndirectList< TpatchInternalList (const UList< T > &internalValues) const
 Extract face cell data. More...
 
template<class T >
const List< T >::subList patchSlice (const UList< T > &l) const
 Slice list to patch. More...
 
template<class T >
const Field< T >::subField patchSlice (const Field< T > &l) const
 Slice Field to patch. More...
 
virtual void write (Ostream &os) const
 Write the polyPatch data as a dictionary. More...
 
const vectorField::subField faceCentres () const
 Return face centres. More...
 
const vectorField::subField faceAreas () const
 Return face normals. More...
 
tmp< vectorFieldfaceCellCentres () const
 Return face cell centres. More...
 
tmp< scalarFieldareaFraction () const
 
const labelUListfaceCells () const
 Return face-cell addressing. More...
 
const labelListmeshEdges () const
 Return global edge index for local edges. More...
 
virtual void clearAddressing ()
 Clear addressing. More...
 
label whichFace (const label l) const
 Return label of face in patch from global face label. More...
 
virtual void initOrder (PstreamBuffers &, const primitivePatch &) const
 Initialize ordering for primitivePatch. Does not. More...
 
virtual bool order (PstreamBuffers &, const primitivePatch &, labelList &faceMap, labelList &rotation) const
 Return new ordering for primitivePatch. More...
 
virtual bool changeTopology () const
 
virtual bool setTopology (polyTopoChange &)
 Collect topology changes in a polyTopoChange object. More...
 
void operator= (const polyPatch &)
 Assignment. More...
 
- Public Member Functions inherited from patchIdentifier
 patchIdentifier (const patchIdentifier &)=default
 Copy construct. More...
 
patchIdentifieroperator= (const patchIdentifier &)=default
 Copy assignment. More...
 
virtual ~patchIdentifier ()=default
 Destructor. More...
 
 patchIdentifier ()
 Default construct. Uses name="", index=0. More...
 
 patchIdentifier (const word &name, const label index)
 Construct from mandatory components. More...
 
 patchIdentifier (const word &name, const label index, const word &physicalType, const wordList &inGroups=wordList())
 Construct from components. More...
 
 patchIdentifier (const word &name, const dictionary &dict, const label index)
 Construct from dictionary. More...
 
 patchIdentifier (const patchIdentifier &ident, const label index)
 Copy construct, resetting the index. More...
 
const wordname () const noexcept
 The patch name. More...
 
wordname () noexcept
 Modifiable patch name. More...
 
label index () const noexcept
 The index of this patch in the boundaryMesh. More...
 
label & index () noexcept
 Modifiable index of this patch in the boundaryMesh. More...
 
const wordphysicalType () const noexcept
 The (optional) physical type of the patch. More...
 
wordphysicalType () noexcept
 Modifiable (optional) physical type of the patch. More...
 
const wordListinGroups () const noexcept
 The (optional) groups that the patch belongs to. More...
 
wordListinGroups () noexcept
 Modifiable (optional) groups that the patch belongs to. More...
 
bool inGroup (const word &name) const
 True if given name is in a group. More...
 
void write (Ostream &os) const
 
- Public Member Functions inherited from PrimitivePatch< FaceList, PointField >
 PrimitivePatch (const FaceList &faces, const PointField &points)
 Construct from components. More...
 
 PrimitivePatch (FaceList &&faces, const PointField &points)
 Construct from components, transferring faces. More...
 
 PrimitivePatch (FaceList &faces, PointField &points, const bool reuse)
 Construct from components, reuse storage. More...
 
 PrimitivePatch (const PrimitivePatch< FaceList, PointField > &pp)
 Copy construct. More...
 
virtual ~PrimitivePatch ()
 Destructor. More...
 
void clearOut ()
 
void clearGeom ()
 
void clearTopology ()
 
void clearPatchMeshAddr ()
 
void swap (PrimitivePatch &)=delete
 Suppress direct swapping, since storage containers may be const. More...
 
const Field< point_type > & points () const noexcept
 Return reference to global points. More...
 
label nFaces () const noexcept
 Number of faces in the patch. More...
 
label nPoints () const
 Number of points supporting patch faces. More...
 
label nEdges () const
 Number of edges in patch. More...
 
const edgeListedges () const
 Return list of edges, address into LOCAL point list. More...
 
const edgeList::subList internalEdges () const
 Return sub-list of internal edges, address into LOCAL point list. More...
 
const edgeList::subList boundaryEdges () const
 Return sub-list of boundary edges, address into LOCAL point list. More...
 
label nInternalEdges () const
 Number of internal edges. More...
 
label nBoundaryEdges () const
 Number of boundary edges == (nEdges() - nInternalEdges()) More...
 
bool isInternalEdge (const label edgei) const
 Is internal edge? More...
 
const labelListboundaryPoints () const
 Return list of boundary points, address into LOCAL point list. More...
 
const labelListListfaceFaces () const
 Return face-face addressing. More...
 
const labelListListedgeFaces () const
 Return edge-face addressing. More...
 
const labelListListfaceEdges () const
 Return face-edge addressing. More...
 
const labelListListpointEdges () const
 Return point-edge addressing. More...
 
const labelListListpointFaces () const
 Return point-face addressing. More...
 
const List< face_type > & localFaces () const
 Return patch faces addressing into local point list. More...
 
labelList boundaryFaces () const
 
labelList uniqBoundaryFaces () const
 
const labelListmeshPoints () const
 Return labelList of mesh points in patch. More...
 
const Map< label > & meshPointMap () const
 Mesh point map. More...
 
const Field< point_type > & localPoints () const
 Return pointField of points in patch. More...
 
const labelListlocalPointOrder () const
 Return orders the local points for most efficient search. More...
 
label whichPoint (const label gp) const
 Given a global point index, return the local point index. More...
 
edge meshEdge (const label edgei) const
 From patch edge to global edge using meshPoints. More...
 
edge meshEdge (const edge &e) const
 From patch edge to global edge using meshPoints. More...
 
label findEdge (const edge &e) const
 
labelList meshEdges (const edgeList &allEdges, const labelListList &cellEdges, const labelList &faceCells) const
 
labelList meshEdges (const edgeList &allEdges, const labelListList &pointEdges) const
 
label meshEdge (const label edgei, const edgeList &allEdges, const labelListList &pointEdges) const
 
labelList meshEdges (const labelUList &edgeLabels, const edgeList &allEdges, const labelListList &pointEdges) const
 
const Field< point_type > & faceCentres () const
 Return face centres for patch. More...
 
const Field< point_type > & faceAreas () const
 Return face area vectors for patch. More...
 
const Field< scalar > & magFaceAreas () const
 Return face area magnitudes for patch. More...
 
const Field< point_type > & faceNormals () const
 Return face unit normals for patch. More...
 
const Field< point_type > & pointNormals () const
 Return point normals for patch. More...
 
bool hasFaceAreas () const
 
bool hasFaceCentres () const
 
bool hasFaceNormals () const
 
bool hasPointNormals () const
 
bool hasBoundaryPoints () const
 
bool hasEdges () const
 
bool hasFaceFaces () const
 
bool hasEdgeFaces () const
 
bool hasFaceEdges () const
 
bool hasPointEdges () const
 
bool hasPointFaces () const
 
bool hasMeshPointMap () const
 
template<class ToPatch >
List< objectHitprojectPoints (const ToPatch &targetPatch, const Field< point_type > &projectionDirection, const intersection::algorithm=intersection::FULL_RAY, const intersection::direction=intersection::VECTOR) const
 Project vertices of patch onto another patch. More...
 
template<class ToPatch >
List< objectHitprojectFaceCentres (const ToPatch &targetPatch, const Field< point_type > &projectionDirection, const intersection::algorithm=intersection::FULL_RAY, const intersection::direction=intersection::VECTOR) const
 Project vertices of patch onto another patch. More...
 
const labelListListedgeLoops () const
 Return list of closed loops of boundary vertices. More...
 
surfaceTopo surfaceType () const
 Calculate surface type formed by patch. More...
 
bool checkTopology (const bool report=false, labelHashSet *setPtr=nullptr) const
 Check surface formed by patch for manifoldness (see above). More...
 
bool checkPointManifold (const bool report=false, labelHashSet *setPtr=nullptr) const
 Checks primitivePatch for faces sharing point but not edge. More...
 
virtual void movePoints (const Field< point_type > &)
 Correct patch after moving points. More...
 
void operator= (const PrimitivePatch< FaceList, PointField > &rhs)
 Copy assign faces. Leave points alone (could be a reference). More...
 
void operator= (PrimitivePatch< FaceList, PointField > &&rhs)
 Move assign faces. Leave points alone (could be a reference). More...
 
label whichEdge (const edge &e) const
 Identical to findEdge. More...
 
template<class ToPatch >
Foam::List< Foam::objectHitprojectPoints (const ToPatch &targetPatch, const Field< typename Foam::PrimitivePatch< FaceList, PointField >::point_type > &projectionDirection, const intersection::algorithm alg, const intersection::direction dir) const
 
template<class ToPatch >
Foam::List< Foam::objectHitprojectFaceCentres (const ToPatch &targetPatch, const Field< typename Foam::PrimitivePatch< FaceList, PointField >::point_type > &projectionDirection, const intersection::algorithm alg, const intersection::direction dir) const
 
- Public Member Functions inherited from PrimitivePatchBase
 ClassName ("PrimitivePatch")
 Runtime type information. More...
 
 PrimitivePatchBase ()=default
 Default construct. More...
 

Static Public Member Functions

static word newName (const word &cyclicPolyPatchName, const label myProcNo, const label neighbProcNo)
 Return the name of a processorCyclicPolyPatch. More...
 
static labelList patchIDs (const word &cyclicPolyPatchName, const polyBoundaryMesh &bm)
 Return the indices of a processorCyclicPolyPatchs. More...
 
- Static Public Member Functions inherited from processorPolyPatch
static word newName (const label myProcNo, const label neighbProcNo)
 Return the name of a processorPolyPatch. More...
 
static label matchFace (const face &localFace, const pointField &localPts, const face &masterFace, const pointField &masterPts, const bool sameOrientation, const scalar absTolSqr, scalar &matchDistSqr)
 Returns rotation. More...
 
- Static Public Member Functions inherited from coupledPolyPatch
static scalarField calcFaceTol (const UList< face > &faces, const pointField &points, const pointField &faceCentres)
 Calculate typical tolerance per face. Is currently max distance. More...
 
- Static Public Member Functions inherited from polyPatch
static autoPtr< polyPatchNew (const word &patchType, const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm)
 Return pointer to a new patch created on freestore from components. More...
 
static autoPtr< polyPatchNew (const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm)
 Return pointer to a new patch created on freestore from dictionary. More...
 
static autoPtr< polyPatchNew (const word &patchType, const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm)
 Return pointer to a new patch created on freestore from dictionary. More...
 
static bool constraintType (const word &pt)
 Return true if the given type is a constraint type. More...
 
static wordList constraintTypes ()
 Return a list of all the constraint patch types. More...
 
- Static Public Member Functions inherited from patchIdentifier
static word defaultName (const label n=-1)
 Default patch name: "patch" or "patchN". More...
 

Protected Member Functions

void initGeometry (PstreamBuffers &)
 Initialise the calculation of the patch geometry. More...
 
void calcGeometry (PstreamBuffers &)
 Calculate the patch geometry. More...
 
virtual void calcGeometry (const primitivePatch &referPatch, const pointField &thisCtrs, const vectorField &thisAreas, const pointField &thisCc, const pointField &nbrCtrs, const vectorField &nbrAreas, const pointField &nbrCc)
 Calculate the patch geometry with externally. More...
 
void initMovePoints (PstreamBuffers &, const pointField &)
 Initialise the patches for moving points. More...
 
void movePoints (PstreamBuffers &, const pointField &)
 Correct patches after moving points. More...
 
virtual void initUpdateMesh (PstreamBuffers &)
 Initialise the update of the patch topology. More...
 
virtual void updateMesh (PstreamBuffers &)
 Update of the patch topology. More...
 
- Protected Member Functions inherited from processorPolyPatch
 processorPolyPatch (const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm, const int myProcNo, const int neighbProcNo, const transformType transform=UNKNOWN, const word &patchType=typeName)
 Construct from components with specified name. More...
 
void initGeometry (PstreamBuffers &)
 Initialise the calculation of the patch geometry. More...
 
void calcGeometry (PstreamBuffers &)
 Calculate the patch geometry. More...
 
virtual void calcGeometry (const primitivePatch &referPatch, const pointField &thisCtrs, const vectorField &thisAreas, const pointField &thisCc, const pointField &nbrCtrs, const vectorField &nbrAreas, const pointField &nbrCc)
 Calculate the patch geometry with externally. More...
 
void initMovePoints (PstreamBuffers &, const pointField &)
 Initialise the patches for moving points. More...
 
void movePoints (PstreamBuffers &, const pointField &)
 Correct patches after moving points. More...
 
virtual void initUpdateMesh (PstreamBuffers &)
 Initialise the update of the patch topology. More...
 
virtual void updateMesh (PstreamBuffers &)
 Update of the patch topology. More...
 
- Protected Member Functions inherited from coupledPolyPatch
void calcTransformTensors (const vectorField &Cf, const vectorField &Cr, const vectorField &nf, const vectorField &nr, const scalarField &smallDist, const scalar absTol, const transformType=UNKNOWN) const
 Calculate the transformation tensors. More...
 
virtual void initGeometry (PstreamBuffers &)=0
 Initialise the calculation of the patch geometry. More...
 
virtual void calcGeometry (PstreamBuffers &)=0
 Calculate the patch geometry. More...
 
virtual void initMovePoints (PstreamBuffers &, const pointField &)=0
 Initialise the patches for moving points. More...
 
virtual void movePoints (PstreamBuffers &, const pointField &)=0
 Correct patches after moving points. More...
 
virtual void initUpdateMesh (PstreamBuffers &)=0
 Initialise the update of the patch topology. More...
 
virtual void updateMesh (PstreamBuffers &)=0
 Update of the patch topology. More...
 
- Protected Member Functions inherited from polyPatch
virtual void initGeometry (PstreamBuffers &)
 Initialise the calculation of the patch geometry. More...
 
virtual void calcGeometry (PstreamBuffers &)
 Calculate the patch geometry. More...
 
virtual void initMovePoints (PstreamBuffers &, const pointField &)
 Initialise the patches for moving points. More...
 
virtual void movePoints (PstreamBuffers &, const pointField &p)
 Correct patches after moving points. More...
 
virtual void initUpdateMesh (PstreamBuffers &)
 Initialise the update of the patch topology. More...
 
virtual void updateMesh (PstreamBuffers &)
 Update of the patch topology. More...
 
virtual void clearGeom ()
 Clear geometry. More...
 
virtual void movePoints (const Field< point_type > &)
 Inherit movePoints from primitivePatch. More...
 

Additional Inherited Members

- Public Types inherited from coupledPolyPatch
enum  transformType {
  UNKNOWN , ROTATIONAL , TRANSLATIONAL , COINCIDENTFULLMATCH ,
  NOORDERING
}
 
- Public Types inherited from PrimitivePatch< FaceList, PointField >
enum  surfaceTopo { MANIFOLD , OPEN , ILLEGAL }
 Enumeration defining the surface type. Used in check routines. More...
 
typedef std::remove_reference< FaceList >::type::value_type face_type
 The face type. More...
 
typedef std::remove_reference< PointField >::type::value_type point_type
 The point type. More...
 
typedef FaceList FaceListType
 The face list type. More...
 
typedef PointField PointFieldType
 The point field type. More...
 
typedef face_type FaceType
 Deprecated(2020-03) prefer face_type typedef. More...
 
- Static Public Attributes inherited from coupledPolyPatch
static const Enum< transformTypetransformTypeNames
 
- Static Public Attributes inherited from polyPatch
static int disallowGenericPolyPatch
 Debug switch to disallow the use of genericPolyPatch. More...
 
- Static Protected Member Functions inherited from coupledPolyPatch
static void writeOBJ (Ostream &os, const point &pt)
 Write point in OBJ format. More...
 
static void writeOBJ (Ostream &, const pointField &, const labelList &)
 Write selected points in OBJ format. More...
 
static void writeOBJ (const fileName &, const UList< face > &, const pointField &)
 Write patch. More...
 
static void writeOBJ (Ostream &os, const point &p0, const point &p1, label &vertI)
 Write edge in OBJ format. More...
 
static pointField getAnchorPoints (const UList< face > &, const pointField &, const transformType)
 Get a unique anchor point for all faces. More...
 
static label getRotation (const pointField &points, const face &f, const point &anchor, const scalar tol)
 Get the number of vertices face f needs to be rotated such that. More...
 

Detailed Description

Neighbour processor patch.

Note: morph patch face ordering is geometric.

Source files

Definition at line 52 of file processorCyclicPolyPatch.H.

Constructor & Destructor Documentation

◆ processorCyclicPolyPatch() [1/6]

processorCyclicPolyPatch ( const label  size,
const label  start,
const label  index,
const polyBoundaryMesh bm,
const int  myProcNo,
const int  neighbProcNo,
const word referPatchName,
const transformType  transform = UNKNOWN,
const word patchType = typeName 
)

Construct from components.

Definition at line 45 of file processorCyclicPolyPatch.C.

References Foam::transform().

Here is the call graph for this function:

◆ processorCyclicPolyPatch() [2/6]

processorCyclicPolyPatch ( const word name,
const dictionary dict,
const label  index,
const polyBoundaryMesh bm,
const word patchType 
)

Construct from dictionary.

Definition at line 76 of file processorCyclicPolyPatch.C.

◆ processorCyclicPolyPatch() [3/6]

Construct as copy, resetting the boundary mesh.

Definition at line 92 of file processorCyclicPolyPatch.C.

◆ processorCyclicPolyPatch() [4/6]

processorCyclicPolyPatch ( const processorCyclicPolyPatch pp,
const polyBoundaryMesh bm,
const label  index,
const label  newSize,
const label  newStart 
)

Construct as given the original patch and resetting the.

face list and boundary mesh information

Definition at line 105 of file processorCyclicPolyPatch.C.

◆ processorCyclicPolyPatch() [5/6]

processorCyclicPolyPatch ( const processorCyclicPolyPatch pp,
const polyBoundaryMesh bm,
const label  index,
const label  newSize,
const label  newStart,
const word referPatchName 
)

Construct as given the original patch and resetting the.

face list, boundary mesh information and referPatch

Definition at line 121 of file processorCyclicPolyPatch.C.

◆ processorCyclicPolyPatch() [6/6]

processorCyclicPolyPatch ( const processorCyclicPolyPatch pp,
const polyBoundaryMesh bm,
const label  index,
const labelUList mapAddressing,
const label  newStart 
)

Construct given the original patch and a map.

Definition at line 138 of file processorCyclicPolyPatch.C.

◆ ~processorCyclicPolyPatch()

Definition at line 156 of file processorCyclicPolyPatch.C.

Member Function Documentation

◆ initGeometry()

void initGeometry ( PstreamBuffers pBufs)
protectedvirtual

Initialise the calculation of the patch geometry.

Reimplemented from processorPolyPatch.

Definition at line 233 of file processorCyclicPolyPatch.C.

References processorPolyPatch::initGeometry().

Here is the call graph for this function:

◆ calcGeometry() [1/2]

void calcGeometry ( PstreamBuffers pBufs)
protectedvirtual

Calculate the patch geometry.

Reimplemented from processorPolyPatch.

Definition at line 240 of file processorCyclicPolyPatch.C.

References faBoundaryMesh::calcGeometry(), coupledPolyPatch::calcGeometry(), cyclicPolyPatch::neighbPatch(), and UPstream::parRun().

Here is the call graph for this function:

◆ calcGeometry() [2/2]

virtual void calcGeometry ( const primitivePatch referPatch,
const pointField thisCtrs,
const vectorField thisAreas,
const pointField thisCc,
const pointField nbrCtrs,
const vectorField nbrAreas,
const pointField nbrCc 
)
inlineprotectedvirtual

Calculate the patch geometry with externally.

provided geometry

Reimplemented from processorPolyPatch.

Definition at line 80 of file processorCyclicPolyPatch.H.

◆ initMovePoints()

void initMovePoints ( PstreamBuffers pBufs,
const pointField p 
)
protectedvirtual

Initialise the patches for moving points.

Reimplemented from processorPolyPatch.

Definition at line 286 of file processorCyclicPolyPatch.C.

◆ movePoints()

void movePoints ( PstreamBuffers pBufs,
const pointField  
)
protectedvirtual

Correct patches after moving points.

Reimplemented from processorPolyPatch.

Definition at line 297 of file processorCyclicPolyPatch.C.

◆ initUpdateMesh()

void initUpdateMesh ( PstreamBuffers pBufs)
protectedvirtual

Initialise the update of the patch topology.

Reimplemented from processorPolyPatch.

Definition at line 307 of file processorCyclicPolyPatch.C.

References processorPolyPatch::initUpdateMesh().

Here is the call graph for this function:

◆ updateMesh()

void updateMesh ( PstreamBuffers pBufs)
protectedvirtual

Update of the patch topology.

Reimplemented from processorPolyPatch.

Definition at line 313 of file processorCyclicPolyPatch.C.

References motionSmootherAlgo::updateMesh().

Here is the call graph for this function:

◆ TypeName()

TypeName ( "processorCyclic"  )

Runtime type information.

◆ clone() [1/4]

virtual autoPtr< polyPatch > clone ( const polyBoundaryMesh bm) const
inlinevirtual

Construct and return a clone, resetting the boundary mesh.

Reimplemented from processorPolyPatch.

Definition at line 181 of file processorCyclicPolyPatch.H.

◆ clone() [2/4]

virtual autoPtr< polyPatch > clone ( const polyBoundaryMesh bm,
const label  index,
const label  newSize,
const label  newStart 
) const
inlinevirtual

Construct and return a clone, resetting the face list.

and boundary mesh

Reimplemented from processorPolyPatch.

Definition at line 188 of file processorCyclicPolyPatch.H.

◆ clone() [3/4]

virtual autoPtr< polyPatch > clone ( const polyBoundaryMesh bm,
const label  index,
const label  newSize,
const label  newStart,
const word referPatchName 
) const
inlinevirtual

Construct and return a clone, resetting the face list.

and boundary mesh

Definition at line 211 of file processorCyclicPolyPatch.H.

◆ clone() [4/4]

virtual autoPtr< polyPatch > clone ( const polyBoundaryMesh bm,
const label  index,
const labelUList mapAddressing,
const label  newStart 
) const
inlinevirtual

Construct and return a clone, resetting the face list.

and boundary mesh

Reimplemented from processorPolyPatch.

Definition at line 236 of file processorCyclicPolyPatch.H.

◆ referPatchName()

const word & referPatchName ( ) const
inline

Return name of originating cyclicPolyPatch patch.

Definition at line 265 of file processorCyclicPolyPatch.H.

◆ newName()

Foam::word newName ( const word cyclicPolyPatchName,
const label  myProcNo,
const label  neighbProcNo 
)
static

Return the name of a processorCyclicPolyPatch.

constructed from cyclicPolyPatch name and the processor IDs

Definition at line 162 of file processorCyclicPolyPatch.C.

References processorPolyPatch::newName().

Here is the call graph for this function:

◆ patchIDs()

Foam::labelList patchIDs ( const word cyclicPolyPatchName,
const polyBoundaryMesh bm 
)
static

Return the indices of a processorCyclicPolyPatchs.

constructed from the given cyclicPolyPatch

Definition at line 176 of file processorCyclicPolyPatch.C.

References polyBoundaryMesh::indices(), and wordRe::REGEX.

Here is the call graph for this function:

◆ referPatchID()

label referPatchID ( ) const
inline

Referring patchID.

Definition at line 288 of file processorCyclicPolyPatch.H.

References Foam::endl(), Foam::exit(), Foam::FatalError, and FatalErrorInFunction.

Referenced by processorCyclicPolyPatch::referPatch().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ referPatch()

const coupledPolyPatch & referPatch ( ) const
inline

Definition at line 308 of file processorCyclicPolyPatch.H.

References processorCyclicPolyPatch::referPatchID().

Referenced by processorCyclicPolyPatch::collocated(), processorCyclicPolyPatch::forwardT(), processorCyclicPolyPatch::owner(), processorCyclicPolyPatch::parallel(), processorCyclicPolyPatch::reverseT(), processorCyclicPolyPatch::separated(), processorCyclicPolyPatch::separation(), processorCyclicPolyPatch::transform(), and processorCyclicPolyPatch::transformPosition().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ tag()

int tag ( ) const
virtual

Return message tag to use for communication.

Reimplemented from processorPolyPatch.

Definition at line 193 of file processorCyclicPolyPatch.C.

References Foam::endl(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, UPstream::msgType(), patchIdentifier::name(), Foam::name(), cyclicPolyPatch::neighbPatch(), Foam::nl, and Foam::Pout.

Referenced by processorCyclicFvPatch::tag(), and processorCyclicPointPatch::tag().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ owner()

virtual bool owner ( ) const
inlinevirtual

Does this side own the patch ?

Reimplemented from processorPolyPatch.

Definition at line 318 of file processorCyclicPolyPatch.H.

References coupledPolyPatch::owner(), and processorCyclicPolyPatch::referPatch().

Here is the call graph for this function:

◆ transform() [1/2]

virtual transformType transform ( ) const
inlinevirtual

Type of transform.

Reimplemented from coupledPolyPatch.

Definition at line 324 of file processorCyclicPolyPatch.H.

References processorCyclicPolyPatch::referPatch(), and coupledPolyPatch::transform().

Here is the call graph for this function:

◆ transform() [2/2]

virtual transformType & transform ( )
inlinevirtual

Type of transform.

This is currently only for use when collapsing generated meshes that can have zero area faces.

Reimplemented from coupledPolyPatch.

Definition at line 332 of file processorCyclicPolyPatch.H.

◆ transformPosition() [1/2]

virtual void transformPosition ( pointField l) const
inlinevirtual

Transform a patch-based position from other side to this side.

Reimplemented from processorPolyPatch.

Definition at line 338 of file processorCyclicPolyPatch.H.

References processorCyclicPolyPatch::referPatch(), and coupledPolyPatch::transformPosition().

Here is the call graph for this function:

◆ transformPosition() [2/2]

virtual void transformPosition ( point l,
const label  facei 
) const
inlinevirtual

Transform a patch-based position from other side to this side.

Reimplemented from processorPolyPatch.

Definition at line 344 of file processorCyclicPolyPatch.H.

References processorCyclicPolyPatch::referPatch(), and coupledPolyPatch::transformPosition().

Here is the call graph for this function:

◆ separated()

virtual bool separated ( ) const
inlinevirtual

Are the planes separated.

Reimplemented from coupledPolyPatch.

Definition at line 350 of file processorCyclicPolyPatch.H.

References processorCyclicPolyPatch::referPatch(), and coupledPolyPatch::separated().

Here is the call graph for this function:

◆ separation()

virtual const vectorField & separation ( ) const
inlinevirtual

If the planes are separated the separation vector.

Reimplemented from coupledPolyPatch.

Definition at line 356 of file processorCyclicPolyPatch.H.

References processorCyclicPolyPatch::referPatch(), and coupledPolyPatch::separation().

Here is the call graph for this function:

◆ parallel()

virtual bool parallel ( ) const
inlinevirtual

Are the cyclic planes parallel.

Reimplemented from coupledPolyPatch.

Definition at line 362 of file processorCyclicPolyPatch.H.

References coupledPolyPatch::parallel(), and processorCyclicPolyPatch::referPatch().

Referenced by processorCyclicFvPatch::parallel().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ forwardT()

virtual const tensorField & forwardT ( ) const
inlinevirtual

Return face transformation tensor.

Reimplemented from coupledPolyPatch.

Definition at line 368 of file processorCyclicPolyPatch.H.

References coupledPolyPatch::forwardT(), and processorCyclicPolyPatch::referPatch().

Referenced by processorCyclicFvPatch::forwardT(), and processorCyclicPointPatchField< Type >::swapAddSeparated().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ reverseT()

virtual const tensorField & reverseT ( ) const
inlinevirtual

Return neighbour-cell transformation tensor.

Reimplemented from coupledPolyPatch.

Definition at line 374 of file processorCyclicPolyPatch.H.

References processorCyclicPolyPatch::referPatch(), and coupledPolyPatch::reverseT().

Referenced by processorCyclicFvPatch::reverseT().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ collocated()

virtual const boolList & collocated ( ) const
inlinevirtual

Are faces collocated. Either size 0,1 or length of patch.

Reimplemented from coupledPolyPatch.

Definition at line 380 of file processorCyclicPolyPatch.H.

References coupledPolyPatch::collocated(), and processorCyclicPolyPatch::referPatch().

Here is the call graph for this function:

◆ initOrder()

void initOrder ( PstreamBuffers pBufs,
const primitivePatch pp 
) const
virtual

Initialize ordering for primitivePatch. Does not.

refer to *this (except for name() and type() etc.)

Reimplemented from processorPolyPatch.

Definition at line 320 of file processorCyclicPolyPatch.C.

References PrimitivePatch< FaceList, PointField >::localFaces(), and PrimitivePatch< FaceList, PointField >::localPoints().

Here is the call graph for this function:

◆ order()

bool order ( PstreamBuffers pBufs,
const primitivePatch pp,
labelList faceMap,
labelList rotation 
) const
virtual

Return new ordering for primitivePatch.

Ordering is -faceMap: for every face index of the new face -rotation:for every new face the clockwise shift of the original face. Return false if nothing changes (faceMap is identity, rotation is 0), true otherwise.

Reimplemented from processorPolyPatch.

Definition at line 335 of file processorCyclicPolyPatch.C.

References Foam::faceMap(), cyclicPolyPatch::initOrder(), cyclicPolyPatch::neighbPatch(), cyclicPolyPatch::order(), and autoPtr< T >::reset().

Here is the call graph for this function:

◆ write()

void write ( Ostream os) const
virtual

Write the polyPatch data as a dictionary.

Reimplemented from processorPolyPatch.

Definition at line 368 of file processorCyclicPolyPatch.C.

References os(), ObukhovLength::write(), Ostream::writeEntry(), and Ostream::writeEntryIfDifferent().

Here is the call graph for this function:

The documentation for this class was generated from the following files: