GAMG agglomerated processor interface. More...
Public Member Functions | |
TypeName ("processor") | |
Runtime type information. More... | |
processorGAMGInterface (const label index, const lduInterfacePtrsList &coarseInterfaces, const lduInterface &fineInterface, const labelField &restrictAddressing, const labelField &neighbourRestrictAddressing, const label fineLevelIndex, const label coarseComm) | |
processorGAMGInterface (const label index, const lduInterfacePtrsList &coarseInterfaces, const labelUList &faceCells, const labelUList &faceRestrictAddresssing, const label coarseComm, const label myProcNo, const label neighbProcNo, const tensorField &forwardT, const int tag) | |
Construct from components. More... | |
processorGAMGInterface (const label index, const lduInterfacePtrsList &coarseInterfaces, Istream &is) | |
Construct from Istream. More... | |
virtual | ~processorGAMGInterface ()=default |
Destructor. More... | |
virtual void | initInternalFieldTransfer (const Pstream::commsTypes commsType, const labelUList &iF) const |
Initialise neighbour field transfer. More... | |
virtual void | initInternalFieldTransfer (const Pstream::commsTypes commsType, const labelUList &iF, const labelUList &faceCells) const |
Initialise neighbour field transfer using faceCells mapping. More... | |
virtual tmp< labelField > | internalFieldTransfer (const Pstream::commsTypes commsType, const labelUList &iF) const |
Transfer and return internal field adjacent to the interface. More... | |
virtual label | comm () const |
Processor interface functions. More... | |
virtual int | myProcNo () const |
Return processor number (rank in communicator) More... | |
virtual int | neighbProcNo () const |
Return neighbour processor number (rank in communicator) More... | |
virtual const tensorField & | forwardT () const |
Return face transformation tensor. More... | |
virtual int | tag () const |
Return message tag used for sending. More... | |
virtual void | write (Ostream &os) const |
Write to stream. More... | |
Public Member Functions inherited from GAMGInterface | |
TypeName ("GAMGInterface") | |
Runtime type information. More... | |
declareRunTimeSelectionTable (autoPtr, GAMGInterface, lduInterface,(const label index, const lduInterfacePtrsList &coarseInterfaces, const lduInterface &fineInterface, const labelField &localRestrictAddressing, const labelField &neighbourRestrictAddressing, const label fineLevelIndex, const label coarseComm),(index, coarseInterfaces, fineInterface, localRestrictAddressing, neighbourRestrictAddressing, fineLevelIndex, coarseComm)) | |
declareRunTimeSelectionTable (autoPtr, GAMGInterface, Istream,(const label index, const lduInterfacePtrsList &coarseInterfaces, Istream &is),(index, coarseInterfaces, is)) | |
GAMGInterface (const label index, const lduInterfacePtrsList &coarseInterfaces) | |
Construct from interfaces, restrict addressing set later on. More... | |
GAMGInterface (const label index, const lduInterfacePtrsList &coarseInterfaces, const labelUList &faceCells, const labelUList &faceRestrictAddressing) | |
Construct from interfaces and restrict addressing. More... | |
GAMGInterface (const label index, const lduInterfacePtrsList &coarseInterfaces, Istream &is) | |
Construct from Istream. More... | |
virtual label | size () const |
Return size. More... | |
virtual label | index () const |
virtual const lduInterfacePtrsList & | coarseInterfaces () const |
virtual const labelUList & | faceCells () const |
Return faceCell addressing. More... | |
virtual const labelList & | faceRestrictAddressing () const |
Return (local)face restrict addressing. More... | |
virtual labelList & | faceRestrictAddressing () |
Return non-const access to face restrict addressing. More... | |
template<class Type > | |
tmp< Field< Type > > | interfaceInternalField (const UList< Type > &internalData) const |
Return the interface internal field of the given field. More... | |
template<class Type > | |
tmp< Field< Type > > | interfaceInternalField (const UList< Type > &internalData, const labelUList &faceCells) const |
template<class Type > | |
void | interfaceInternalField (const UList< Type > &internalData, List< Type > &) const |
Get the interface internal field of the given field. More... | |
virtual tmp< labelField > | interfaceInternalField (const labelUList &internalData) const |
Return the values of the given internal data adjacent to. More... | |
virtual tmp< labelField > | interfaceInternalField (const labelUList &internalData, const labelUList &faceCells) const |
void | combine (const GAMGInterface &) |
Merge the next level with this level. More... | |
virtual tmp< scalarField > | agglomerateCoeffs (const scalarField &fineCoeffs) const |
Agglomerating the given fine-level coefficients and return. More... | |
virtual void | write (Ostream &) const =0 |
Write to stream. More... | |
template<class Type > | |
Foam::tmp< Foam::Field< Type > > | interfaceInternalField (const UList< Type > &iF) const |
template<class Type > | |
Foam::tmp< Foam::Field< Type > > | interfaceInternalField (const UList< Type > &iF, const labelUList &faceCells) const |
Public Member Functions inherited from lduInterface | |
TypeName ("lduInterface") | |
Runtime type information. More... | |
lduInterface ()=default | |
Construct null. More... | |
virtual | ~lduInterface ()=default |
Destructor. More... | |
virtual const labelUList & | faceCells () const =0 |
Return faceCell addressing. More... | |
virtual tmp< labelField > | interfaceInternalField (const labelUList &internalData) const =0 |
Return the values of the given internal data adjacent to. More... | |
virtual tmp< labelField > | interfaceInternalField (const labelUList &internalData, const labelUList &faceCells) const =0 |
virtual void | initInternalFieldTransfer (const Pstream::commsTypes commsType, const labelUList &iF) const |
Initialise transfer of internal field adjacent to the interface. More... | |
virtual void | initInternalFieldTransfer (const Pstream::commsTypes commsType, const labelUList &iF, const labelUList &faceCells) const |
virtual tmp< labelField > | internalFieldTransfer (const Pstream::commsTypes commsType, const labelUList &iF) const =0 |
Transfer and return internal field adjacent to the interface. More... | |
Public Member Functions inherited from processorLduInterface | |
TypeName ("processorLduInterface") | |
Runtime type information. More... | |
processorLduInterface ()=default | |
Default construct. More... | |
virtual | ~processorLduInterface ()=default |
Destructor. More... | |
virtual label | comm () const =0 |
Return communicator used for parallel communication. More... | |
virtual int | myProcNo () const =0 |
Return processor number (rank in communicator) More... | |
virtual int | neighbProcNo () const =0 |
Return neighbour processor number (rank in communicator) More... | |
virtual const tensorField & | forwardT () const =0 |
Return face transformation tensor. More... | |
virtual int | tag () const =0 |
Return message tag used for sending. More... | |
template<class Type > | |
void | send (const Pstream::commsTypes commsType, const UList< Type > &f) const |
Raw send function. More... | |
template<class Type > | |
void | receive (const Pstream::commsTypes commsType, UList< Type > &f) const |
Raw receive function. More... | |
template<class Type > | |
tmp< Field< Type > > | receive (const Pstream::commsTypes commsType, const label size) const |
Raw receive function returning field. More... | |
template<class Type > | |
void | compressedSend (const Pstream::commsTypes commsType, const UList< Type > &f) const |
Raw send function with data compression. More... | |
template<class Type > | |
void | compressedReceive (const Pstream::commsTypes commsType, UList< Type > &f) const |
Raw receive function with data compression. More... | |
template<class Type > | |
tmp< Field< Type > > | compressedReceive (const Pstream::commsTypes commsType, const label size) const |
Raw receive function with data compression returning field. More... | |
template<class Type > | |
Foam::tmp< Foam::Field< Type > > | receive (const Pstream::commsTypes commsType, const label size) const |
template<class Type > | |
Foam::tmp< Foam::Field< Type > > | compressedReceive (const Pstream::commsTypes commsType, const label size) const |
Additional Inherited Members | |
Static Public Member Functions inherited from GAMGInterface | |
static autoPtr< GAMGInterface > | New (const label index, const lduInterfacePtrsList &coarseInterfaces, const lduInterface &fineInterface, const labelField &localRestrictAddressing, const labelField &neighbourRestrictAddressing, const label fineLevelIndex, const label coarseComm) |
Return a pointer to a new interface created on freestore given. More... | |
static autoPtr< GAMGInterface > | New (const word &coupleType, const label index, const lduInterfacePtrsList &coarseInterfaces, Istream &is) |
Return a pointer to a new interface created on freestore given. More... | |
Protected Member Functions inherited from GAMGInterface | |
GAMGInterface (const GAMGInterface &)=delete | |
No copy construct. More... | |
void | operator= (const GAMGInterface &)=delete |
No copy assignment. More... | |
Protected Attributes inherited from GAMGInterface | |
const label | index_ |
My index in coarseInterfaces. More... | |
const lduInterfacePtrsList & | coarseInterfaces_ |
All interfaces. More... | |
labelList | faceCells_ |
Face-cell addressing. More... | |
labelList | faceRestrictAddressing_ |
Face restrict addressing. More... | |
GAMG agglomerated processor interface.
Definition at line 52 of file processorGAMGInterface.H.
processorGAMGInterface | ( | const label | index, |
const lduInterfacePtrsList & | coarseInterfaces, | ||
const lduInterface & | fineInterface, | ||
const labelField & | restrictAddressing, | ||
const labelField & | neighbourRestrictAddressing, | ||
const label | fineLevelIndex, | ||
const label | coarseComm | ||
) |
Construct from fine-level interface, local and neighbour restrict addressing
Definition at line 55 of file processorGAMGInterface.C.
References DynamicList< T, SizeMin >::append(), HashTable< T, Key, Hash >::cfind(), GAMGInterface::faceCells_, GAMGInterface::faceRestrictAddressing_, forAll, HashTable< T, Key, Hash >::insert(), processorGAMGInterface::myProcNo(), processorGAMGInterface::neighbProcNo(), Foam::refCast(), UList< T >::size(), and List< T >::transfer().
processorGAMGInterface | ( | const label | index, |
const lduInterfacePtrsList & | coarseInterfaces, | ||
const labelUList & | faceCells, | ||
const labelUList & | faceRestrictAddresssing, | ||
const label | coarseComm, | ||
const label | myProcNo, | ||
const label | neighbProcNo, | ||
const tensorField & | forwardT, | ||
const int | tag | ||
) |
Construct from components.
Definition at line 138 of file processorGAMGInterface.C.
processorGAMGInterface | ( | const label | index, |
const lduInterfacePtrsList & | coarseInterfaces, | ||
Istream & | is | ||
) |
Construct from Istream.
Definition at line 166 of file processorGAMGInterface.C.
|
virtualdefault |
Destructor.
TypeName | ( | "processor" | ) |
Runtime type information.
|
virtual |
Initialise neighbour field transfer.
Reimplemented from lduInterface.
Definition at line 184 of file processorGAMGInterface.C.
|
virtual |
Initialise neighbour field transfer using faceCells mapping.
Reimplemented from lduInterface.
Definition at line 194 of file processorGAMGInterface.C.
|
virtual |
Transfer and return internal field adjacent to the interface.
Implements lduInterface.
Definition at line 205 of file processorGAMGInterface.C.
|
inlinevirtual |
Processor interface functions.
Return communicator used for sending
Implements processorLduInterface.
Definition at line 162 of file processorGAMGInterface.H.
Referenced by processorGAMGInterfaceField::comm().
|
inlinevirtual |
Return processor number (rank in communicator)
Implements processorLduInterface.
Definition at line 168 of file processorGAMGInterface.H.
Referenced by processorGAMGInterfaceField::myProcNo(), and processorGAMGInterface::processorGAMGInterface().
|
inlinevirtual |
Return neighbour processor number (rank in communicator)
Implements processorLduInterface.
Definition at line 174 of file processorGAMGInterface.H.
Referenced by processorGAMGInterfaceField::neighbProcNo(), and processorGAMGInterface::processorGAMGInterface().
|
inlinevirtual |
Return face transformation tensor.
Implements processorLduInterface.
Definition at line 180 of file processorGAMGInterface.H.
Referenced by processorGAMGInterfaceField::forwardT().
|
inlinevirtual |
Return message tag used for sending.
Implements processorLduInterface.
Definition at line 186 of file processorGAMGInterface.H.
|
virtual |
Write to stream.
Implements GAMGInterface.
Definition at line 217 of file processorGAMGInterface.C.
References os(), token::SPACE, and ObukhovLength::write().