Calculates a unique integer (label so might not have enough room - 2G max) for processor + local index. E.g. More...
Public Member Functions | |
globalIndex () | |
Construct null. More... | |
globalIndex (const label localSize) | |
Construct from local max size. Does communication with default. More... | |
globalIndex (const label localSize, const int tag, const label comm, const bool parallel) | |
Construct from local max size. Does communication with given. More... | |
globalIndex (const labelList &offsets) | |
Construct from components. More... | |
globalIndex (labelList &&offsets) | |
Move constructor from components. More... | |
globalIndex (Istream &is) | |
Construct from Istream. More... | |
labelList & | offsets () |
Change after construction. More... | |
label | localSize () const |
My local size. More... | |
label | toGlobal (const label i) const |
From local to global. More... | |
bool | isLocal (const label i) const |
Is on local processor. More... | |
label | toLocal (const label i) const |
From global to local on current processor. More... | |
label | size () const |
Global sum of localSizes. More... | |
label | localSize (const label proci) const |
Size of proci data. More... | |
label | toGlobal (const label proci, const label i) const |
From local to global on proci. More... | |
bool | isLocal (const label proci, const label i) const |
Is on processor proci. More... | |
label | toLocal (const label proci, const label i) const |
From global to local on proci. More... | |
label | whichProcID (const label i) const |
Which processor does global come from? Binary search. More... | |
label | offset (const label proci) const |
Start of proci data. More... | |
template<class Type > | |
void | gather (const label comm, const labelList &procIDs, const UList< Type > &fld, List< Type > &allFld, const int tag=UPstream::msgType(), const Pstream::commsTypes commsType=Pstream::commsTypes::nonBlocking) const |
Collect data in processor order on master (== procIDs[0]). More... | |
template<class Type > | |
void | gather (const label comm, const labelList &procIDs, List< Type > &fld, const int tag=UPstream::msgType(), const Pstream::commsTypes commsType=Pstream::commsTypes::nonBlocking) const |
Inplace collect data in processor order on master. More... | |
template<class Type > | |
void | scatter (const label comm, const labelList &procIDs, const UList< Type > &allFld, UList< Type > &fld, const int tag=UPstream::msgType(), const Pstream::commsTypes commsType=Pstream::commsTypes::nonBlocking) const |
Distribute data in processor order. Requires fld to be sized! More... | |
Static Public Member Functions | |
template<class Type > | |
static void | gather (const labelUList &offsets, const label comm, const labelList &procIDs, const UList< Type > &fld, List< Type > &allFld, const int tag=UPstream::msgType(), const Pstream::commsTypes commsType=Pstream::commsTypes::nonBlocking) |
Collect data in processor order on master (== procIDs[0]). More... | |
template<class Type > | |
static void | gather (const labelUList &offsets, const label comm, const labelList &procIDs, List< Type > &fld, const int tag=UPstream::msgType(), const Pstream::commsTypes commsType=Pstream::commsTypes::nonBlocking) |
Inplace collect data in processor order on master. More... | |
template<class Type > | |
static void | scatter (const labelUList &offsets, const label comm, const labelList &procIDs, const UList< Type > &allFld, UList< Type > &fld, const int tag=UPstream::msgType(), const Pstream::commsTypes commsType=Pstream::commsTypes::nonBlocking) |
Distribute data in processor order. Requires fld to be sized! More... | |
Friends | |
Istream & | operator>> (Istream &is, globalIndex &gi) |
Ostream & | operator<< (Ostream &os, const globalIndex &gi) |
Calculates a unique integer (label so might not have enough room - 2G max) for processor + local index. E.g.
globalIndex globalFaces(mesh.nFaces()); label globalFacei = globalFaces.toGlobal(facei);
Definition at line 63 of file globalIndex.H.
|
inline |
Construct null.
Definition at line 30 of file globalIndexI.H.
globalIndex | ( | const label | localSize | ) |
Construct from local max size. Does communication with default.
communicator and message tag.
Definition at line 68 of file globalIndex.C.
References Foam::exit(), Foam::FatalError, FatalErrorInFunction, Pstream::gatherList(), Foam::labelMax, globalIndex::localSize(), UPstream::msgType(), UPstream::myProcNo(), UPstream::nProcs(), globalIndex::offset(), and Pstream::scatterList().
globalIndex | ( | const label | localSize, |
const int | tag, | ||
const label | comm, | ||
const bool | parallel | ||
) |
Construct from local max size. Does communication with given.
communicator and message tag
Definition at line 30 of file globalIndex.C.
References Foam::exit(), Foam::FatalError, FatalErrorInFunction, Pstream::gatherList(), Foam::labelMax, globalIndex::localSize(), UPstream::myProcNo(), UPstream::nProcs(), globalIndex::offset(), and Pstream::scatterList().
globalIndex | ( | const labelList & | offsets | ) |
Construct from components.
Definition at line 97 of file globalIndex.C.
|
inline |
Move constructor from components.
Definition at line 34 of file globalIndexI.H.
globalIndex | ( | Istream & | is | ) |
Construct from Istream.
Definition at line 103 of file globalIndex.C.
|
inline |
Change after construction.
Definition at line 42 of file globalIndexI.H.
|
inline |
My local size.
Definition at line 60 of file globalIndexI.H.
References UPstream::myProcNo().
Referenced by createShellMesh::calcPointRegions(), simple::decompose(), distributionMapBase::exchangeAddressing(), globalIndex::globalIndex(), regionSplit::nLocalRegions(), and SprayCloud< CloudType >::penetration().
|
inline |
From local to global.
Definition at line 82 of file globalIndexI.H.
References UPstream::myProcNo().
Referenced by nearWallFields::calcAddressing(), decompositionMethod::calcCellCells(), mappedInternalPatchBase::calcMapping(), mappedPatchBase::calcMapping(), createShellMesh::calcPointRegions(), viewFactor::calculate(), refinementParameters::findCells(), distributedTriSurfaceMesh::findNearest(), get_vertex_list(), meshRefinement::getMasterEdges(), GAMGProcAgglomeration::globalCellCells(), addPatchCellLayer::globalEdgeFaces(), Foam::meshCheck::mergeAndWrite(), globalMeshData::mergePoints(), MGridGenGAMGAgglomeration::MGridGenGAMGAgglomeration(), structuredRenumber::renumber(), addPatchCellLayer::setRefinement(), cellsToCellsStabilisation::update(), patchToPatchStabilisation::update(), and streamlines::write().
|
inline |
Is on local processor.
Definition at line 95 of file globalIndexI.H.
References UPstream::myProcNo().
Referenced by decompositionMethod::calcCellCells(), distributionMapBase::calcCompactAddressing(), addPatchCellLayer::calcSidePatch(), refinementParameters::findCells(), and distributionMapBase::renumber().
|
inline |
From global to local on current processor.
FatalError if not on local processor.
Definition at line 117 of file globalIndexI.H.
References UPstream::myProcNo().
Referenced by decompositionMethod::calcCellCells(), distributionMapBase::calcCompactAddressing(), refinementParameters::findCells(), and distributionMapBase::renumber().
|
inline |
Global sum of localSizes.
Definition at line 66 of file globalIndexI.H.
Referenced by nearWallFields::calcAddressing(), mappedInternalPatchBase::calcMapping(), mappedPatchBase::calcMapping(), simple::decompose(), distributedTriSurfaceMesh::globalSize(), regionSplit::nRegions(), and SprayCloud< CloudType >::penetration().
|
inline |
Size of proci data.
Definition at line 54 of file globalIndexI.H.
|
inline |
From local to global on proci.
Definition at line 72 of file globalIndexI.H.
|
inline |
From global to local on proci.
Definition at line 101 of file globalIndexI.H.
References Foam::abort(), Foam::endl(), Foam::FatalError, and FatalErrorInFunction.
|
inline |
Which processor does global come from? Binary search.
Definition at line 123 of file globalIndexI.H.
References Foam::abort(), Foam::FatalError, FatalErrorInFunction, and Foam::findLower().
Referenced by distributionMapBase::calcCompactAddressing(), addPatchCellLayer::calcSidePatch(), refinementParameters::findCells(), get_edge_list(), and distributionMapBase::renumber().
|
inline |
Start of proci data.
Definition at line 48 of file globalIndexI.H.
Referenced by simple::decompose(), globalIndex::globalIndex(), and SprayCloud< CloudType >::penetration().
|
static |
Collect data in processor order on master (== procIDs[0]).
Needs offsets only on master.
Definition at line 31 of file globalIndexTemplates.C.
References UList< T >::begin(), UPstream::blocking, UList< T >::byteSize(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, fld(), UList< T >::last(), UPstream::myProcNo(), UPstream::nRequests(), UIPstream::read(), UPstream::scheduled, List< T >::setSize(), List< T >::size(), UPstream::waitRequests(), and UOPstream::write().
Referenced by globalIndex::gather(), GAMGAgglomeration::procAgglomerateRestrictAddressing(), and GAMGAgglomeration::restrictField().
|
inline |
Collect data in processor order on master (== procIDs[0]).
Needs offsets only on master.
Definition at line 170 of file globalIndex.H.
References fld(), and globalIndex::gather().
|
static |
Inplace collect data in processor order on master.
(== procIDs[0]). Needs offsets only on master.
Definition at line 183 of file globalIndexTemplates.C.
References fld(), and UPstream::myProcNo().
|
inline |
Inplace collect data in processor order on master.
(== procIDs[0]). Needs offsets only on master.
Definition at line 201 of file globalIndex.H.
References fld(), and globalIndex::gather().
|
static |
Distribute data in processor order. Requires fld to be sized!
Definition at line 205 of file globalIndexTemplates.C.
References UList< T >::begin(), UPstream::blocking, UList< T >::byteSize(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, fld(), UPstream::myProcNo(), UPstream::nRequests(), UIPstream::read(), UPstream::scheduled, List< T >::size(), UPstream::waitRequests(), and UOPstream::write().
Referenced by GAMGAgglomeration::prolongField(), and globalIndex::scatter().
|
inline |
Distribute data in processor order. Requires fld to be sized!
Definition at line 230 of file globalIndex.H.
References fld(), and globalIndex::scatter().
|
friend |
|
friend |