processorPolyPatch Class Reference

Neighbour processor patch. More...

Inheritance diagram for processorPolyPatch:
Collaboration diagram for processorPolyPatch:

Public Member Functions

 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 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-neighbbour patch face centres. More...
 
const vectorFieldneighbFaceAreas () const
 Return processor-neighbbour patch face areas. More...
 
const vectorFieldneighbFaceCellCentres () const
 Return processor-neighbbour patch neighbour cell centres. More...
 
const labelListnbrPoints () const
 Return neighbour point labels. WIP. More...
 
const labelListnbrEdges () 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 const transformertransform () const
 Return null transform between processor patches. More...
 
virtual void initOrder (PstreamBuffers &, const primitivePatch &) const
 Initialise 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)
 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 &)
 Construct as copy, resetting the boundary mesh. More...
 
 coupledPolyPatch (const coupledPolyPatch &pp, const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart)
 Construct given the original patch and resetting the. More...
 
 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...
 
scalar matchTolerance () const
 Return the matching tolerance. 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 dictionary &dict, const label index, const polyBoundaryMesh &bm, const word &patchType)
 Construct from dictionary. More...
 
 polyPatch (const polyPatch &, const polyBoundaryMesh &)
 Copy constructor, resetting the boundary mesh. More...
 
 polyPatch (const polyPatch &pp, const polyBoundaryMesh &bm, const label index, const label newSize, const label newStart)
 Construct given the original patch and resetting the. More...
 
 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 &)
 Copy constructor. More...
 
virtual ~polyPatch ()
 Destructor. More...
 
label start () const
 Return start label of this patch in the polyMesh face list. More...
 
const polyBoundaryMeshboundaryMesh () const
 Return boundaryMesh reference. 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...
 
const vectorField::subField faceCentres () const
 Return face centres. More...
 
const vectorField::subField faceAreas () const
 Return face areas. More...
 
const scalarField::subField magFaceAreas () const
 Return face area magnitudes. More...
 
tmp< vectorFieldfaceCellCentres () const
 Return face cell centres. More...
 
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...
 
void operator= (const polyPatch &)
 Assignment. More...
 
- Public Member Functions inherited from patchIdentifier
 patchIdentifier (const word &name, const label index, const word &physicalType=word::null, const wordList &inGroups=wordList())
 Construct from components. More...
 
 patchIdentifier (const word &name, const dictionary &, const label index)
 Construct from dictionary. More...
 
 patchIdentifier (const patchIdentifier &, const label index)
 Construct from geometric patch, resetting the index. More...
 
virtual ~patchIdentifier ()
 Destructor. More...
 
const wordname () const
 Return name. More...
 
label index () const
 Return the index of this patch in the boundaryMesh. More...
 
const wordphysicalType () const
 Return the optional physical type of the patch. More...
 
wordphysicalType ()
 Return the optional physical type of the patch for modification. More...
 
const wordListinGroups () const
 Return the optional groups patch belongs to. More...
 
wordListinGroups ()
 Return the optional groups patch belongs to for modification. More...
 
bool inGroup (const word &) const
 Test if in group. More...
 
void write (Ostream &) const
 Write patchIdentifier as a dictionary. More...
 
- Public Member Functions inherited from PrimitivePatch< FaceList, PointField >
 PrimitivePatch (const FaceList &faces, const Field< PointType > &points)
 Construct from components. More...
 
 PrimitivePatch (FaceList &&faces, Field< PointType > &&points)
 Move constructor from components. More...
 
 PrimitivePatch (FaceList &&faces, List< PointType > &&points)
 Move constructor from components. More...
 
 PrimitivePatch (FaceList &faces, Field< PointType > &points, const bool reuse)
 Construct from components, reuse storage. More...
 
 PrimitivePatch (const PrimitivePatch< FaceList, PointField > &)
 Copy constructor. More...
 
 PrimitivePatch (PrimitivePatch< FaceList, PointField > &&)
 Move constructor. More...
 
virtual autoPtr< PrimitivePatch< FaceList, PointField > > clone () const
 Construct and return a clone. More...
 
 PrimitivePatch (Istream &, const Field< PointType > &points)
 Construct from Istream. More...
 
virtual ~PrimitivePatch ()
 Destructor. More...
 
const Field< PointType > & points () const
 Return reference to global points. More...
 
label nPoints () const
 Return number of points supporting patch faces. More...
 
label nEdges () const
 Return number of edges in patch. More...
 
const edgeListedges () const
 Return list of edges, address into LOCAL point list. More...
 
label nInternalEdges () const
 Number of internal edges. More...
 
bool isInternalEdge (const label edgeI) const
 Is internal edge? More...
 
const labelListboundaryPoints () const
 Return list of boundary points,. 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< FaceType > & localFaces () const
 Return patch faces addressing into local point list. More...
 
const labelListmeshPoints () const
 Return labelList of mesh points in patch. They are constructed. More...
 
const Map< label > & meshPointMap () const
 Mesh point map. Given the global point index find its. More...
 
const Field< PointType > & 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...
 
label whichEdge (const edge &) const
 Given an edge in local point labels, return its. More...
 
labelList meshEdges (const edgeList &allEdges, const labelListList &cellEdges, const labelList &faceCells) const
 Return labels of patch edges in the global edge list using. More...
 
labelList meshEdges (const edgeList &allEdges, const labelListList &pointEdges) const
 Return labels of patch edges in the global edge list using. More...
 
const Field< PointType > & faceCentres () const
 Return face centres for patch. More...
 
const Field< PointType > & faceAreas () const
 Return face areas for patch. More...
 
const Field< PointType > & faceNormals () const
 Return face normals for patch. More...
 
const Field< PointType > & pointNormals () const
 Return point normals for patch. More...
 
template<class ToPatch >
List< objectHitprojectPoints (const ToPatch &targetPatch, const Field< PointType > &projectionDirection, const intersection::algorithm=intersection::algorithm::fullRay, const intersection::direction=intersection::direction::vector) const
 Project vertices of patch onto another patch. More...
 
template<class ToPatch >
List< objectHitprojectFaceCentres (const ToPatch &targetPatch, const Field< PointType > &projectionDirection, const intersection::algorithm=intersection::algorithm::fullRay, const intersection::direction=intersection::direction::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...
 
void clearOut ()
 
void clearGeom ()
 
void clearTopology ()
 
void clearPatchMeshAddr ()
 
virtual void movePoints (const Field< PointType > &)
 Correct patch after moving points. More...
 
void operator= (const PrimitivePatch< FaceList, PointField > &)
 Assignment operator. More...
 
void operator= (PrimitivePatch< FaceList, PointField > &&)
 Move assignment operator. More...
 
template<class ToPatch >
Foam::List< Foam::objectHitprojectPoints (const ToPatch &targetPatch, const Field< PointType > &projectionDirection, const intersection::algorithm alg, const intersection::direction dir) const
 
template<class ToPatch >
Foam::List< Foam::objectHitprojectFaceCentres (const ToPatch &targetPatch, const Field< PointType > &projectionDirection, const intersection::algorithm alg, const intersection::direction dir) const
 

Static Public Member Functions

static word newName (const label myProcNo, const label neighbProcNo)
 Return the name of a processorPolyPatch. 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 a pointer to a new patch created on freestore from. More...
 
static autoPtr< polyPatchNew (const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm)
 Return a pointer to a new patch created on freestore from. More...
 
static autoPtr< polyPatchNew (const word &patchType, const word &name, const dictionary &dict, const label index, const polyBoundaryMesh &bm)
 Return a pointer to a new patch created on freestore from. 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...
 

Protected Member Functions

 processorPolyPatch (const word &name, const label size, const label start, const label index, const polyBoundaryMesh &bm, const int myProcNo, const int neighbProcNo, const word &patchType=typeName)
 Construct from components with specified name. More...
 
void initCalcGeometry (PstreamBuffers &)
 Initialise the calculation of the patch geometry. More...
 
void calcGeometry (PstreamBuffers &)
 Calculate the patch geometry. 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
virtual void initOrder (ownToNbrOrderData &ownToNbr, autoPtr< ownToNbrDebugOrderData > &ownToNbrDebugPtr, const primitivePatch &) const
 Initialise ordering for the given primitivePatch. Fills the. More...
 
virtual bool order (const ownToNbrOrderData &ownToNbr, const autoPtr< ownToNbrDebugOrderData > &ownToNbrDebugPtr, const primitivePatch &, labelList &faceMap, labelList &rotation) const
 Return new ordering for the given primitivePatch. More...
 
- Protected Member Functions inherited from polyPatch
virtual void clearGeom ()
 Clear geometry. More...
 
virtual void rename (const wordList &newNames)
 Reset the patch name. More...
 
virtual void reorder (const labelUList &newToOldIndex)
 Reset the patch index. More...
 

Additional Inherited Members

- Public Types inherited from PrimitivePatch< FaceList, PointField >
enum  surfaceTopo { MANIFOLD, OPEN, ILLEGAL }
 Enumeration defining the surface type. Used in check routines. More...
 
typedef FaceList FaceListType
 
typedef std::remove_reference< FaceList >::type::value_type FaceType
 
typedef PointField PointFieldType
 
typedef std::remove_reference< PointField >::type::value_type PointType
 
- 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 (const fileName &, const primitivePatch &)
 Write a patch in OBJ format. More...
 
static void writeOBJ (const fileName &, const pointField &, const pointField &)
 Write lines between two lists of points in OBJ format. More...
 
static void writeOBJ (const fileName &, const pointField &, const labelListList &)
 Write a set of paths in OBJ format. More...
 
- Protected Attributes inherited from coupledPolyPatch
const scalar matchTolerance_
 Local matching tolerance. More...
 
autoPtr< ownToOwnOrderDataownToOwnOrderDataPtr_
 Data to pass from owner.initOrder to owner.order. More...
 
- Protected Attributes inherited from patchIdentifier
word name_
 Name of patch. More...
 
label index_
 Index of patch in boundary. More...
 
word physicalType_
 Optional physical type. More...
 
wordList inGroups_
 Optional groups patch belongs to. More...
 
- Static Protected Attributes inherited from coupledPolyPatch
static const scalar defaultMatchTol_ = 1e-4
 Default matching tolerance. More...
 

Detailed Description

Neighbour processor patch.

Note: morph patch face ordering tries to do a geometric ordering. (assumes faces coincident) Hence will have problems when cyclics are present.

Source files

Definition at line 55 of file processorPolyPatch.H.

Constructor & Destructor Documentation

◆ processorPolyPatch() [1/6]

processorPolyPatch ( const word name,
const label  size,
const label  start,
const label  index,
const polyBoundaryMesh bm,
const int  myProcNo,
const int  neighbProcNo,
const word patchType = typeName 
)
protected

Construct from components with specified name.

Definition at line 50 of file processorPolyPatch.C.

Referenced by processorPolyPatch::clone(), and processorPolyPatch::processorPolyPatch().

Here is the caller graph for this function:

◆ processorPolyPatch() [2/6]

processorPolyPatch ( const label  size,
const label  start,
const label  index,
const polyBoundaryMesh bm,
const int  myProcNo,
const int  neighbProcNo,
const word patchType = typeName 
)

Construct from components with automatically generated standard name.

Definition at line 71 of file processorPolyPatch.C.

References processorPolyPatch::processorPolyPatch().

Here is the call graph for this function:

◆ processorPolyPatch() [3/6]

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

Construct from dictionary.

Definition at line 99 of file processorPolyPatch.C.

References processorPolyPatch::processorPolyPatch().

Here is the call graph for this function:

◆ processorPolyPatch() [4/6]

processorPolyPatch ( const processorPolyPatch pp,
const polyBoundaryMesh bm 
)

Construct as copy, resetting the boundary mesh.

Definition at line 117 of file processorPolyPatch.C.

References processorPolyPatch::processorPolyPatch().

Here is the call graph for this function:

◆ processorPolyPatch() [5/6]

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.

face list and boundary mesh information

Definition at line 132 of file processorPolyPatch.C.

References processorPolyPatch::processorPolyPatch().

Here is the call graph for this function:

◆ processorPolyPatch() [6/6]

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

Construct given the original patch and a map.

Definition at line 150 of file processorPolyPatch.C.

◆ ~processorPolyPatch()

~processorPolyPatch ( )
virtual

Destructor.

Definition at line 169 of file processorPolyPatch.C.

References processorPolyPatch::newName().

Referenced by processorPolyPatch::clone().

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

Member Function Documentation

◆ initCalcGeometry()

void initCalcGeometry ( PstreamBuffers pBufs)
protectedvirtual

Initialise the calculation of the patch geometry.

Implements coupledPolyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 192 of file processorPolyPatch.C.

References UPstream::parRun().

Referenced by processorCyclicPolyPatch::initCalcGeometry(), and processorPolyPatch::initMovePoints().

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

◆ calcGeometry()

void calcGeometry ( PstreamBuffers pBufs)
protectedvirtual

Calculate the patch geometry.

Implements coupledPolyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 206 of file processorPolyPatch.C.

References Foam::endl(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, forAll, processorPolyPatch::initMovePoints(), Foam::mag(), mesh, Foam::name(), fileName::name(), UPstream::parRun(), path(), points, Foam::Pout, Foam::sqr(), and Foam::meshTools::writeOBJ().

Referenced by processorCyclicPolyPatch::calcGeometry(), and processorPolyPatch::movePoints().

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

◆ initMovePoints()

void initMovePoints ( PstreamBuffers pBufs,
const pointField p 
)
protectedvirtual

Initialise the patches for moving points.

Implements coupledPolyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 301 of file processorPolyPatch.C.

References processorPolyPatch::initCalcGeometry(), processorPolyPatch::movePoints(), and polyPatch::movePoints().

Referenced by processorPolyPatch::calcGeometry().

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

◆ movePoints()

void movePoints ( PstreamBuffers pBufs,
const pointField  
)
protectedvirtual

Correct patches after moving points.

Implements coupledPolyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 312 of file processorPolyPatch.C.

References processorPolyPatch::calcGeometry().

Referenced by processorPolyPatch::initMovePoints().

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

◆ initUpdateMesh()

void initUpdateMesh ( PstreamBuffers pBufs)
protectedvirtual

Initialise the update of the patch topology.

Implements coupledPolyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 321 of file processorPolyPatch.C.

References f(), Foam::findIndex(), polyPatch::initUpdateMesh(), nPoints, and UPstream::parRun().

Referenced by processorCyclicPolyPatch::initUpdateMesh().

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

◆ updateMesh()

void updateMesh ( PstreamBuffers pBufs)
protectedvirtual

Update of the patch topology.

Implements coupledPolyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 368 of file processorPolyPatch.C.

References PrimitivePatch< FaceList, PointField >::clearOut(), f(), forAll, nPoints, UPstream::parRun(), List< T >::size(), and polyPatch::updateMesh().

Referenced by processorCyclicPolyPatch::updateMesh().

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

◆ TypeName()

TypeName ( "processor"  )

Runtime type information.

◆ clone() [1/3]

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

Construct and return a clone, resetting the boundary mesh.

Reimplemented from polyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 175 of file processorPolyPatch.H.

References PrimitivePatch< FaceList, PointField >::clone(), and processorPolyPatch::processorPolyPatch().

Here is the call graph for this function:

◆ clone() [2/3]

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 polyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 183 of file processorPolyPatch.H.

References PrimitivePatch< FaceList, PointField >::clone(), and processorPolyPatch::processorPolyPatch().

Here is the call graph for this function:

◆ clone() [3/3]

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 polyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 206 of file processorPolyPatch.H.

References processorPolyPatch::processorPolyPatch(), and processorPolyPatch::~processorPolyPatch().

Here is the call graph for this function:

◆ coupled()

virtual bool coupled ( ) const
inlinevirtual

Return true only if this is a parallel run.

Reimplemented from coupledPolyPatch.

Definition at line 234 of file processorPolyPatch.H.

References UPstream::parRun().

Here is the call graph for this function:

◆ myProcNo()

int myProcNo ( ) const
inline

Return processor number.

Definition at line 247 of file processorPolyPatch.H.

Referenced by processorCyclicPolyPatch::calcGeometry(), processorFvPatch::myProcNo(), and processorPointPatch::myProcNo().

Here is the caller graph for this function:

◆ neighbProcNo()

◆ owner()

virtual bool owner ( ) const
inlinevirtual

Does the processor own the patch ?

Implements coupledPolyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 259 of file processorPolyPatch.H.

Referenced by processorPolyPatch::neighbour(), and fvMeshDistribute::printCoupleInfo().

Here is the caller graph for this function:

◆ neighbour()

bool neighbour ( ) const
inlinevirtual

Is the processor the patch neighbour ?

Reimplemented from coupledPolyPatch.

Definition at line 265 of file processorPolyPatch.H.

References processorPolyPatch::newName(), and processorPolyPatch::owner().

Here is the call graph for this function:

◆ newName()

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

Return the name of a processorPolyPatch.

constructed from the processor IDs

Definition at line 179 of file processorPolyPatch.C.

References Foam::name().

Referenced by processorPolyPatch::neighbour(), processorCyclicPolyPatch::newName(), and processorPolyPatch::~processorPolyPatch().

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

◆ neighbFaceCentres()

const vectorField& neighbFaceCentres ( ) const
inline

Return processor-neighbbour patch face centres.

Definition at line 279 of file processorPolyPatch.H.

◆ neighbFaceAreas()

const vectorField& neighbFaceAreas ( ) const
inline

Return processor-neighbbour patch face areas.

Definition at line 285 of file processorPolyPatch.H.

◆ neighbFaceCellCentres()

const vectorField& neighbFaceCellCentres ( ) const
inline

Return processor-neighbbour patch neighbour cell centres.

Definition at line 291 of file processorPolyPatch.H.

References processorPolyPatch::nbrEdges(), and processorPolyPatch::nbrPoints().

Here is the call graph for this function:

◆ nbrPoints()

const Foam::labelList & nbrPoints ( ) const

Return neighbour point labels. WIP.

Definition at line 480 of file processorPolyPatch.C.

References Foam::abort(), Foam::FatalError, FatalErrorInFunction, and Foam::name().

Referenced by PointEdgeWave< Type, TrackingData >::countPatchType(), processorPolyPatch::neighbFaceCellCentres(), syncTools::syncEdgeMap(), and syncTools::syncPointMap().

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

◆ nbrEdges()

const Foam::labelList & nbrEdges ( ) const

Return neighbour edge labels. WIP.

Definition at line 492 of file processorPolyPatch.C.

References Foam::abort(), Foam::FatalError, FatalErrorInFunction, processorPolyPatch::initOrder(), and Foam::name().

Referenced by processorPolyPatch::neighbFaceCellCentres().

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

◆ tag()

virtual int tag ( ) const
inlinevirtual

Return message tag to use for communication.

Reimplemented in processorCyclicPolyPatch.

Definition at line 303 of file processorPolyPatch.H.

References UPstream::msgType().

Referenced by processorPointPatch::tag().

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

◆ comm()

virtual label comm ( ) const
inlinevirtual

Return communicator used for communication.

Definition at line 309 of file processorPolyPatch.H.

References polyPatch::boundaryMesh(), polyMesh::comm(), and polyBoundaryMesh::mesh().

Referenced by processorFvPatch::comm(), and processorPointPatch::comm().

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

◆ transform()

virtual const transformer& transform ( ) const
inlinevirtual

Return null transform between processor patches.

Implements coupledPolyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 315 of file processorPolyPatch.H.

References Foam::faceMap(), processorPolyPatch::initOrder(), transformer::null, processorPolyPatch::order(), and processorPolyPatch::write().

Referenced by PointEdgeWave< Type, TrackingData >::countPatchType(), FaceCellWave< Type, TrackingData >::handleProcPatches(), and processorFvPatch::transform().

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

◆ initOrder()

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

Initialise ordering for primitivePatch. Does not.

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

Implements coupledPolyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 505 of file processorPolyPatch.C.

References coupledPolyPatch::initOrder(), processorPolyPatch::order(), and UPstream::parRun().

Referenced by processorCyclicPolyPatch::initOrder(), processorPolyPatch::nbrEdges(), and processorPolyPatch::transform().

Here is the call graph for this function:
Here is the caller 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.

Implements coupledPolyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 543 of file processorPolyPatch.C.

References coupledPolyPatch::order(), UPstream::parRun(), Foam::transform(), and coupledPolyPatch::ownToNbrOrderData::transform().

Referenced by processorPolyPatch::initOrder(), processorCyclicPolyPatch::order(), and processorPolyPatch::transform().

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

◆ write()

void write ( Ostream os) const
virtual

Write the polyPatch data as a dictionary.

Reimplemented from coupledPolyPatch.

Reimplemented in processorCyclicPolyPatch.

Definition at line 587 of file processorPolyPatch.C.

References coupledPolyPatch::write(), and Foam::writeEntry().

Referenced by processorPolyPatch::transform(), and processorCyclicPolyPatch::write().

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

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