Simplest concrete lduMesh that stores the addressing needed by lduMatrix. More...
Public Member Functions | |
ClassName ("lduPrimitiveMesh") | |
lduPrimitiveMesh (const label nCells) | |
Construct from number of cells. More... | |
lduPrimitiveMesh (const label nCells, labelList &l, labelList &u, const label comm, bool reuse) | |
Construct from components but without interfaces. Add interfaces. More... | |
void | addInterfaces (lduInterfacePtrsList &interfaces, const lduSchedule &ps) |
Add interfaces to a mesh constructed without. More... | |
lduPrimitiveMesh (const label nCells, labelList &l, labelList &u, PtrList< const lduInterface > &primitiveInterfaces, const lduSchedule &ps, const label comm) | |
Construct from components and re-use storage. More... | |
lduPrimitiveMesh (const label comm, const labelList &procAgglomMap, const labelList &procIDs, const lduMesh &myMesh, const PtrList< lduPrimitiveMesh > &otherMeshes, labelList &cellOffsets, labelList &faceOffsets, labelListList &faceMap, labelListList &boundaryMap, labelListListList &boundaryFaceMap) | |
Construct by combining multiple meshes. The meshes come from. More... | |
virtual | ~lduPrimitiveMesh ()=default |
Destructor. More... | |
virtual bool | hasDb () const |
Return true if thisDb() is a valid DB. More... | |
virtual const lduAddressing & | lduAddr () const |
Return ldu addressing. More... | |
virtual lduAddressing & | lduAddr () |
Return non-const ldu addressing. More... | |
virtual lduInterfacePtrsList | interfaces () const |
virtual lduInterfacePtrsList & | interfaces () |
PtrList< const lduInterface > & | primitiveInterfaces () |
Return a non-const list of primitive interfaces. More... | |
const lduInterfacePtrsList & | rawInterfaces () const |
Return a list of pointers for each patch. More... | |
virtual label | comm () const |
Return communicator used for parallel communication. More... | |
virtual const labelUList & | lowerAddr () const |
Return Lower addressing. More... | |
virtual const labelUList & | upperAddr () const |
Return Upper addressing. More... | |
virtual labelList & | lowerAddr () |
Return non-const Lower addressing. More... | |
virtual labelList & | upperAddr () |
Return non-const Upper addressing. More... | |
virtual const labelUList & | patchAddr (const label i) const |
Return patch addressing. More... | |
virtual const lduSchedule & | patchSchedule () const |
Return patch evaluation schedule. More... | |
template<class ProcPatch > | |
Foam::lduSchedule | nonBlockingSchedule (const lduInterfacePtrsList &interfaces) |
Public Member Functions inherited from lduMesh | |
TypeName ("lduMesh") | |
Runtime type information. More... | |
virtual | ~lduMesh ()=default |
Destructor. More... | |
virtual bool | hasDb () const =0 |
Return true if thisDb() is a valid DB. More... | |
virtual const objectRegistry & | thisDb () const |
Return the object registry. More... | |
virtual const lduAddressing & | lduAddr () const =0 |
Return ldu addressing. More... | |
virtual lduInterfacePtrsList | interfaces () const =0 |
virtual label | comm () const =0 |
Return communicator used for parallel communication. More... | |
template<class T , class BinaryOp > | |
void | reduce (T &Value, const BinaryOp &bop) const |
Helper: reduce with current communicator. More... | |
InfoProxy< lduMesh > | info () const |
Return info proxy. More... | |
Public Member Functions inherited from lduAddressing | |
lduAddressing (const label nEqns) | |
Construct with size (number of equations) More... | |
virtual | ~lduAddressing () |
Destructor. More... | |
label | size () const |
Return number of equations. More... | |
virtual const labelUList & | lowerAddr () const =0 |
Return lower addressing. More... | |
virtual const labelUList & | upperAddr () const =0 |
Return upper addressing. More... | |
virtual const labelUList & | patchAddr (const label patchNo) const =0 |
Return patch to internal addressing given patch number. More... | |
virtual const lduSchedule & | patchSchedule () const =0 |
Return patch field evaluation schedule. More... | |
void | clearOut () |
Clear additional addressing. More... | |
const labelUList & | losortAddr () const |
Return losort addressing. More... | |
const labelUList & | ownerStartAddr () const |
Return owner start addressing. More... | |
const labelUList & | losortStartAddr () const |
Return losort start addressing. More... | |
label | triIndex (const label a, const label b) const |
Return off-diagonal index given owner and neighbour label. More... | |
Tuple2< label, scalar > | band () const |
Calculate bandwidth and profile of addressing. More... | |
Static Public Member Functions | |
static const lduMesh & | mesh (const lduMesh &mesh0, const PtrList< lduPrimitiveMesh > &otherMeshes, const label meshI) |
Select either mesh0 (meshI is 0) or otherMeshes[meshI-1]. More... | |
static void | gather (const label comm, const lduMesh &mesh, const labelList &procIDs, PtrList< lduPrimitiveMesh > &otherMeshes) |
Gather meshes from other processors onto procIDs[0]. More... | |
template<class ProcPatch > | |
static lduSchedule | nonBlockingSchedule (const lduInterfacePtrsList &) |
Get non-scheduled send/receive schedule. More... | |
static labelList | upperTriOrder (const label nCells, const labelUList &lower, const labelUList &upper) |
Calculate upper-triangular order. More... | |
static void | checkUpperTriangular (const label size, const labelUList &l, const labelUList &u) |
Check if in upper-triangular ordering. More... | |
static labelListList | globalCellCells (const lduMesh &mesh, const globalIndex &globalNumbering) |
Calculate global cell-cells. More... | |
Simplest concrete lduMesh that stores the addressing needed by lduMatrix.
Definition at line 52 of file lduPrimitiveMesh.H.
|
explicit |
Construct from number of cells.
Definition at line 369 of file lduPrimitiveMesh.C.
lduPrimitiveMesh | ( | const label | nCells, |
labelList & | l, | ||
labelList & | u, | ||
const label | comm, | ||
bool | reuse | ||
) |
Construct from components but without interfaces. Add interfaces.
separately using addInterfaces
Definition at line 333 of file lduPrimitiveMesh.C.
lduPrimitiveMesh | ( | const label | nCells, |
labelList & | l, | ||
labelList & | u, | ||
PtrList< const lduInterface > & | primitiveInterfaces, | ||
const lduSchedule & | ps, | ||
const label | comm | ||
) |
Construct from components and re-use storage.
Definition at line 379 of file lduPrimitiveMesh.C.
References forAll, lduPrimitiveMesh::primitiveInterfaces(), UPtrList< T >::set(), and UPtrList< T >::setSize().
lduPrimitiveMesh | ( | const label | comm, |
const labelList & | procAgglomMap, | ||
const labelList & | procIDs, | ||
const lduMesh & | myMesh, | ||
const PtrList< lduPrimitiveMesh > & | otherMeshes, | ||
labelList & | cellOffsets, | ||
labelList & | faceOffsets, | ||
labelListList & | faceMap, | ||
labelListList & | boundaryMap, | ||
labelListListList & | boundaryFaceMap | ||
) |
Construct by combining multiple meshes. The meshes come from.
processors procIDs: procIDs[0] : local processor (myMesh) procIDs[i] : processor where otherMeshes[i-1] comes from procAgglomMap : for every processor which processor it agglomerates onto. The new processor numbers are in compact numbering (so ranks in communicator comm), i.e. similar to cell-restrict-addressing. We need this information to be able to map inter-processor interfaces cellOffsets : for every processor the offset it gets in the mesh faceMap : for every processor, for every face, the destination face. Negative for flipped faces. boundaryMap : for every processor, for every patch, -1 or the new patch index in the mesh. boundaryFaceMap : for every processor, for every patch, for every patch face:
Definition at line 410 of file lduPrimitiveMesh.C.
References Foam::abort(), HashTable< T, Key, Hash >::cfind(), lduPrimitiveMesh::checkUpperTriangular(), lduPrimitiveMesh::comm(), lduMesh::comm(), Foam::endl(), Foam::exit(), lduInterface::faceCells(), Foam::faceMap(), Foam::FatalError, FatalErrorInFunction, UList< T >::find(), Foam::findIndices(), forAll, forAllConstIters, Foam::inplaceReorder(), fvMesh::interfaces(), lduPrimitiveMesh::interfaces(), lduMesh::interfaces(), UList< T >::last(), lduMesh::lduAddr(), lduAddressing::lowerAddr(), Foam::max(), mesh, Foam::min(), UPstream::msgType(), processorLduInterface::myProcNo(), processorFaPatch::myProcNo(), n, processorLduInterface::neighbProcNo(), Foam::Pout, UPtrList< T >::set(), List< T >::setSize(), UPtrList< T >::setSize(), lduAddressing::size(), HashTable< T, Key, Hash >::size(), UPtrList< T >::size(), UList< T >::size(), Foam::sortedOrder(), lduAddressing::upperAddr(), lduPrimitiveMesh::upperTriOrder(), WarningInFunction, and Foam::Zero.
|
virtualdefault |
Destructor.
ClassName | ( | "lduPrimitiveMesh" | ) |
void addInterfaces | ( | lduInterfacePtrsList & | interfaces, |
const lduSchedule & | ps | ||
) |
Add interfaces to a mesh constructed without.
Definition at line 348 of file lduPrimitiveMesh.C.
References forAll, and List< T >::setSize().
|
inlinevirtual |
Return true if thisDb() is a valid DB.
Implements lduMesh.
Reimplemented in lduPrimitiveMeshAssembly.
Definition at line 181 of file lduPrimitiveMesh.H.
|
inlinevirtual |
Return ldu addressing.
Implements lduMesh.
Definition at line 187 of file lduPrimitiveMesh.H.
Referenced by fvMatrix< Type >::createOrUpdateLduPrimitiveAssembly(), and lduPrimitiveMeshAssembly::update().
|
inlinevirtual |
Return non-const ldu addressing.
Definition at line 193 of file lduPrimitiveMesh.H.
|
inlinevirtual |
Return a list of pointers for each patch with only those pointing to interfaces being set
Implements lduMesh.
Definition at line 200 of file lduPrimitiveMesh.H.
Referenced by lduPrimitiveMesh::lduPrimitiveMesh(), lduPrimitiveMesh::nonBlockingSchedule(), and lduPrimitiveMeshAssembly::update().
|
inlinevirtual |
Return a non-const list of pointers for each patch with only those pointing to interfaces being set
Definition at line 207 of file lduPrimitiveMesh.H.
|
inline |
Return a non-const list of primitive interfaces.
Definition at line 213 of file lduPrimitiveMesh.H.
Referenced by lduPrimitiveMesh::lduPrimitiveMesh(), and lduPrimitiveMeshAssembly::update().
|
inline |
Return a list of pointers for each patch.
with only those pointing to interfaces being set (reference to cached interfaces)
Definition at line 221 of file lduPrimitiveMesh.H.
|
inlinevirtual |
Return communicator used for parallel communication.
Implements lduMesh.
Definition at line 227 of file lduPrimitiveMesh.H.
Referenced by lduPrimitiveMesh::lduPrimitiveMesh(), and lduPrimitiveMeshAssembly::lduPrimitiveMeshAssembly().
|
inlinevirtual |
Return Lower addressing.
Implements lduAddressing.
Definition at line 233 of file lduPrimitiveMesh.H.
Referenced by lduPrimitiveMeshAssembly::update().
|
inlinevirtual |
Return Upper addressing.
Implements lduAddressing.
Definition at line 239 of file lduPrimitiveMesh.H.
Referenced by lduPrimitiveMeshAssembly::update().
|
inlinevirtual |
Return non-const Lower addressing.
Definition at line 245 of file lduPrimitiveMesh.H.
|
inlinevirtual |
Return non-const Upper addressing.
Definition at line 251 of file lduPrimitiveMesh.H.
|
inlinevirtual |
Return patch addressing.
Implements lduAddressing.
Reimplemented in lduPrimitiveMeshAssembly.
Definition at line 257 of file lduPrimitiveMesh.H.
|
inlinevirtual |
Return patch evaluation schedule.
Implements lduAddressing.
Definition at line 263 of file lduPrimitiveMesh.H.
|
static |
Select either mesh0 (meshI is 0) or otherMeshes[meshI-1].
Definition at line 1071 of file lduPrimitiveMesh.C.
Referenced by fvMatrix< Type >::lduMeshPtr().
|
static |
Gather meshes from other processors onto procIDs[0].
Received meshes get GAMGInterface and communicator comm
Definition at line 1082 of file lduPrimitiveMesh.C.
References forAll, UList< T >::found(), interface(), fvMesh::interfaces(), fvMesh::lduAddr(), lduAddressing::lowerAddr(), mesh, UPstream::msgType(), processorFaPatch::myProcNo(), Time::New(), lduAddressing::patchSchedule(), Foam::readLabel(), Foam::refCast(), UPstream::scheduled, PtrList< T >::set(), UPtrList< T >::set(), PtrList< T >::setSize(), lduAddressing::size(), UPtrList< T >::size(), UList< T >::size(), and lduAddressing::upperAddr().
Referenced by GAMGAgglomeration::procAgglomerateLduAddressing().
|
static |
Get non-scheduled send/receive schedule.
Referenced by viewFactor::initialise().
|
static |
Calculate upper-triangular order.
Definition at line 258 of file lduPrimitiveMesh.C.
References Foam::exit(), Foam::FatalError, FatalErrorInFunction, forAll, UList< T >::last(), DynamicList< T, SizeMin >::resize(), Foam::sortedOrder(), and Foam::Zero.
Referenced by fvMeshPrimitiveLduAddressing::addAddressing(), lduPrimitiveMesh::lduPrimitiveMesh(), and lduPrimitiveMeshAssembly::update().
|
static |
Check if in upper-triangular ordering.
Definition at line 64 of file lduPrimitiveMesh.C.
References Foam::abort(), Foam::FatalError, FatalErrorInFunction, forAll, lduAddressing::size(), and UList< T >::size().
Referenced by lduPrimitiveMesh::lduPrimitiveMesh(), and lduPrimitiveMeshAssembly::update().
|
static |
Calculate global cell-cells.
Definition at line 117 of file lduPrimitiveMesh.C.
References fvMesh::comm(), forAll, Foam::identity(), fvMesh::interfaces(), fvMesh::lduAddr(), globalIndex::localStart(), lduAddressing::lowerAddr(), mesh, processorFaPatch::myProcNo(), UPstream::nonBlocking, UPstream::parRun(), PtrList< T >::set(), UPtrList< T >::set(), List< T >::setSize(), lduAddressing::size(), UPtrList< T >::size(), lduAddressing::upperAddr(), UPstream::waitRequests(), and Foam::Zero.
Foam::lduSchedule nonBlockingSchedule | ( | const lduInterfacePtrsList & | interfaces | ) |
Definition at line 34 of file lduPrimitiveMeshTemplates.C.
References forAll, lduPrimitiveMesh::interfaces(), UPtrList< T >::set(), and UPtrList< T >::size().