Public Member Functions | Static Public Member Functions | List of all members
fvMeshDistribute Class Reference

Sends/receives parts of mesh+fvfields to neighbouring processors. Used in load balancing. More...

Public Member Functions

 ClassName ("fvMeshDistribute")
 
 fvMeshDistribute (fvMesh &mesh, const scalar mergeTol)
 Construct from mesh and absolute merge tolerance. More...
 
autoPtr< mapDistributePolyMeshdistribute (const labelList &dist)
 Send cells to neighbours according to distribution. More...
 
template<class T >
void saveInternalFields (PtrList< Field< T > > &iflds) const
 
template<class T >
void mapExposedFaces (const mapPolyMesh &map, const PtrList< Field< T > > &oldFlds)
 

Static Public Member Functions

static labelList countCells (const labelList &)
 Helper function: count cells per processor in wanted distribution. More...
 
static void printCoupleInfo (const primitiveMesh &, const labelList &, const labelList &, const labelList &, const labelList &)
 Print some info on coupling data. More...
 
template<class GeoField >
static void printFieldInfo (const fvMesh &)
 Print some field info. More...
 
static void printMeshInfo (const fvMesh &)
 Print some info on mesh. More...
 

Detailed Description

Sends/receives parts of mesh+fvfields to neighbouring processors. Used in load balancing.

Input is per local cell the processor it should move to. Moves meshes and volFields/surfaceFields and returns map which can be used to distribute other.

Notes:

Source files

Definition at line 70 of file fvMeshDistribute.H.

Constructor & Destructor Documentation

fvMeshDistribute ( fvMesh mesh,
const scalar  mergeTol 
)

Construct from mesh and absolute merge tolerance.

Definition at line 1453 of file fvMeshDistribute.C.

References fvMeshDistribute::countCells().

Here is the call graph for this function:

Member Function Documentation

ClassName ( "fvMeshDistribute"  )
Foam::labelList countCells ( const labelList distribution)
static

Helper function: count cells per processor in wanted distribution.

Definition at line 1463 of file fvMeshDistribute.C.

References Foam::abort(), fvMeshDistribute::distribute(), Foam::endl(), Foam::FatalError, FatalErrorInFunction, forAll, and UPstream::nProcs().

Referenced by meshRefinement::balance(), fvMeshDistribute::distribute(), and fvMeshDistribute::fvMeshDistribute().

Here is the call graph for this function:

Here is the caller graph for this function:

Foam::autoPtr< Foam::mapDistributePolyMesh > distribute ( const labelList dist)

Send cells to neighbours according to distribution.

(for every cell the new proc)

Definition at line 1487 of file fvMeshDistribute.C.

References Foam::abort(), fvMeshAdder::add(), polyMesh::boundaryMesh(), fvMeshSubset::cellMap(), polyMesh::cellZones(), polyBoundaryMesh::checkParallelSync(), fvMesh::clearOut(), fvMeshDistribute::countCells(), Foam::endl(), fvMeshSubset::faceFlipMap(), Foam::faceMap(), fvMeshSubset::faceMap(), polyMesh::faceNeighbour(), polyMesh::faceOwner(), polyMesh::faceZones(), Foam::FatalError, FatalErrorInFunction, PstreamBuffers::finishedSends(), forAll, forAllConstIter(), Pstream::gatherList(), Foam::identity(), Foam::inplaceRenumber(), Foam::inplaceReorder(), HashSet< Key, Hash >::insert(), UPstream::myProcNo(), objectRegistry::names(), ZoneMesh< ZoneType, MeshType >::names(), polyBoundaryMesh::names(), primitiveMesh::nCells(), primitiveMesh::nFaces(), primitiveMesh::nInternalFaces(), Foam::nl, UPstream::nonBlocking, primitiveMesh::nPoints(), UPstream::nProcs(), UPstream::parRun(), patches, patchi, fvMeshSubset::patchMap(), fvMeshSubset::pointMap(), polyMesh::pointZones(), Foam::Pout, fvMeshDistribute::printMeshInfo(), Foam::renumber(), polyMesh::resetMotion(), HashTable< T, Key, Hash >::resize(), Pstream::scatterList(), polyMesh::setInstance(), fvMeshSubset::setLargeCellSubset(), List< T >::size(), UPtrList< T >::size(), dictionary::subDict(), fvMeshSubset::subMesh(), fvMesh::time(), Time::timeName(), List< T >::transfer(), Field< Type >::typeName, List< T >::xfer(), HashTable< T, Key, Hash >::xfer(), and Foam::Zero.

Referenced by meshRefinement::balance(), and fvMeshDistribute::countCells().

Here is the caller graph for this function:

void printCoupleInfo ( const primitiveMesh mesh,
const labelList sourceFace,
const labelList sourceProc,
const labelList sourcePatch,
const labelList sourceNewNbrProc 
)
static

Print some info on coupling data.

Definition at line 300 of file fvMeshDistribute.C.

References Foam::abort(), mapAddedPolyMesh::addedFaceMap(), fvMesh::addFvPatches(), fvMeshTools::addPatch(), polyMesh::addZones(), polyPatch::boundaryMesh(), polyMesh::boundaryMesh(), polyMesh::cellZones(), polyTopoChange::changeMesh(), polyPatch::coupled(), polyMesh::defaultRegion, dict, HashTableCore::end(), Foam::endl(), polyPatch::faceCells(), primitiveMesh::faceCentres(), Foam::faceMap(), polyMesh::faceNeighbour(), polyMesh::faceOwner(), polyMesh::faces(), polyMesh::faceZones(), Foam::FatalError, FatalErrorInFunction, HashTable< T, Key, Hash >::find(), Foam::findIndex(), polyMeshAdder::findSharedPoints(), ZoneMesh< ZoneType, MeshType >::findZoneID(), faceZone::flipMap(), forAll, forAllReverse, found, removeCells::getExposedFaces(), Foam::identity(), lessProcPatches::lessProcPatches(), polyMeshAdder::mergePoints(), UPstream::myProcNo(), patchIdentifier::name(), IOobject::name(), polyBoundaryMesh::names(), primitiveMesh::nCells(), processorPolyPatch::neighbProcNo(), polyPatch::New(), newPointi, primitiveMesh::nFaces(), primitiveMesh::nInternalFaces(), Foam::nl, IOobject::NO_READ, mapAddedPolyMesh::nOldInternalFaces(), primitiveMesh::nPoints(), UPstream::nProcs(), mapAddedPolyMesh::oldFaceMap(), processorPolyPatch::owner(), cyclicPolyPatch::owner(), patches, patchi, polyMesh::points(), polyMesh::pointZones(), Foam::Pout, fvMeshTools::reorderPatches(), Foam::returnReduce(), polyTopoChange::setAction(), removeCells::setRefinement(), CompactListList< T, Container >::setSize(), List< T >::setSize(), List< T >::size(), UPtrList< T >::size(), HashTable< T, Key, Hash >::size(), Foam::sortedOrder(), polyPatch::start(), syncTools::swapBoundaryFaceList(), Time::timeName(), coupledPolyPatch::transform(), faceZone::whichFace(), and Foam::xferMove().

Referenced by fvMeshDistribute::printMeshInfo().

Here is the caller graph for this function:

void printFieldInfo ( const fvMesh mesh)
static
void printMeshInfo ( const fvMesh mesh)
static
void saveInternalFields ( PtrList< Field< T > > &  iflds) const

Definition at line 152 of file fvMeshDistributeTemplates.C.

References fld(), forAllConstIter(), and HashTable< T, Key, Hash >::size().

Here is the call graph for this function:

void mapExposedFaces ( const mapPolyMesh map,
const PtrList< Field< T > > &  oldFlds 
)

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