Dynamic mesh redistribution using the distributor specified in decomposeParDict. More...
Public Member Functions | |
TypeName ("distributor") | |
Runtime type information. More... | |
distributor (fvMesh &mesh) | |
Construct from fvMesh. More... | |
distributor (const distributor &)=delete | |
Disallow default bitwise copy construction. More... | |
virtual | ~distributor () |
Destructor. More... | |
virtual bool | update () |
Distribute the. More... | |
virtual void | topoChange (const polyTopoChangeMap &) |
Update corresponding to the given map. More... | |
virtual void | mapMesh (const polyMeshMap &) |
Update from another mesh using the given map. More... | |
virtual void | distribute (const polyDistributionMap &) |
Update corresponding to the given distribution map. More... | |
virtual bool | write (const bool write=true) const |
Write using given format, version and compression. More... | |
void | operator= (const distributor &)=delete |
Disallow default bitwise assignment. More... | |
Public Member Functions inherited from fvMeshDistributor | |
TypeName ("fvMeshDistributor") | |
Runtime type information. More... | |
declareRunTimeSelectionTable (autoPtr, fvMeshDistributor, fvMesh,(fvMesh &mesh),(mesh)) | |
fvMeshDistributor (fvMesh &) | |
Construct from fvMesh. More... | |
fvMeshDistributor (const fvMeshDistributor &)=delete | |
Disallow default bitwise copy construction. More... | |
virtual | ~fvMeshDistributor () |
Destructor. More... | |
fvMesh & | mesh () |
Return the fvMesh. More... | |
const fvMesh & | mesh () const |
Return the fvMesh. More... | |
const dictionary & | dict () const |
Return the dynamicMeshDict/distributor sub-dict. More... | |
virtual bool | dynamic () const |
Is mesh dynamic, i.e. might it change? More... | |
void | operator= (const fvMeshDistributor &)=delete |
Disallow default bitwise assignment. More... | |
Protected Member Functions | |
void | readDict () |
Read the projection parameters from dictionary. More... | |
void | distribute (const labelList &distribution) |
Distribute the mesh and mesh data. More... | |
Protected Attributes | |
autoPtr< decompositionMethod > | distributor_ |
Cache the decomposer/distributor. More... | |
label | redistributionInterval_ |
Time-step interval between redistribution calls. More... | |
scalar | maxImbalance_ |
Maximum imbalance between the ideal number of cells per processor. More... | |
label | timeIndex_ |
The time index used for updating. More... | |
Additional Inherited Members | |
Static Public Member Functions inherited from fvMeshDistributor | |
static autoPtr< fvMeshDistributor > | New (fvMesh &) |
Select, construct and return the fvMeshDistributor. More... | |
Dynamic mesh redistribution using the distributor specified in decomposeParDict.
distributor { type distributor; libs ("libfvMeshDistributors.so"); // How often to redistribute redistributionInterval 10; // Maximum fractional cell distribution imbalance // before rebalancing maxImbalance 0.1; }
Definition at line 71 of file fvMeshDistributorsDistributor.H.
|
explicit |
Construct from fvMesh.
Definition at line 86 of file fvMeshDistributorsDistributor.C.
References distributor::readDict().
|
delete |
Disallow default bitwise copy construction.
|
virtual |
Destructor.
Definition at line 106 of file fvMeshDistributorsDistributor.C.
|
protected |
Read the projection parameters from dictionary.
Definition at line 51 of file fvMeshDistributorsDistributor.C.
References fvMeshDistributor::dict(), dictionary::lookupOrDefault(), distributor::maxImbalance_, and distributor::redistributionInterval_.
Referenced by distributor::distributor().
|
protected |
Distribute the mesh and mesh data.
Definition at line 63 of file fvMeshDistributorsDistributor.C.
References distributor::distribute(), and fvMesh::distribute().
Referenced by distributor::distribute().
TypeName | ( | "distributor" | ) |
Runtime type information.
|
virtual |
Distribute the.
Implements fvMeshDistributor.
Reimplemented in loadBalancer.
Definition at line 112 of file fvMeshDistributorsDistributor.C.
References Foam::endl(), polyMesh::globalData(), Foam::Info, Foam::mag(), primitiveMesh::nCells(), UPstream::nProcs(), globalMeshData::nTotalCells(), Foam::returnReduce(), fvMesh::time(), and TimeState::timeIndex().
|
virtual |
Update corresponding to the given map.
Implements fvMeshDistributor.
Definition at line 157 of file fvMeshDistributorsDistributor.C.
|
virtual |
Update from another mesh using the given map.
Implements fvMeshDistributor.
Definition at line 161 of file fvMeshDistributorsDistributor.C.
|
virtual |
Update corresponding to the given distribution map.
Implements fvMeshDistributor.
Definition at line 165 of file fvMeshDistributorsDistributor.C.
|
virtual |
Write using given format, version and compression.
Reimplemented from fvMeshDistributor.
Definition at line 172 of file fvMeshDistributorsDistributor.C.
|
delete |
Disallow default bitwise assignment.
|
protected |
Cache the decomposer/distributor.
Definition at line 80 of file fvMeshDistributorsDistributor.H.
|
protected |
Time-step interval between redistribution calls.
Definition at line 83 of file fvMeshDistributorsDistributor.H.
Referenced by distributor::readDict().
|
protected |
Maximum imbalance between the ideal number of cells per processor.
and the maximum or minimum as a ratio mag(1 - nCells/idealNcells)
Definition at line 87 of file fvMeshDistributorsDistributor.H.
Referenced by distributor::readDict().
|
protected |
The time index used for updating.
Definition at line 90 of file fvMeshDistributorsDistributor.H.