Utilities to produce ghost cells between a collection of data sets of same type.
More...
|
virtual vtkTypeBool | IsA (const char *type) |
| Return 1 if this class is the same type of (or a subclass of) the named class. More...
|
|
vtkDIYGhostUtilities * | NewInstance () const |
|
void | PrintSelf (ostream &os, vtkIndent indent) override |
| Methods invoked by print to print information about the object including superclasses. More...
|
|
| vtkBaseTypeMacro (vtkObject, vtkObjectBase) |
|
virtual void | DebugOn () |
| Turn debugging output on. More...
|
|
virtual void | DebugOff () |
| Turn debugging output off. More...
|
|
bool | GetDebug () |
| Get the value of the debug flag. More...
|
|
void | SetDebug (bool debugFlag) |
| Set the value of the debug flag. More...
|
|
virtual void | Modified () |
| Update the modification time for this object. More...
|
|
virtual vtkMTimeType | GetMTime () |
| Return this object's modified time. More...
|
|
void | PrintSelf (ostream &os, vtkIndent indent) override |
| Methods invoked by print to print information about the object including superclasses. More...
|
|
void | RemoveObserver (unsigned long tag) |
|
void | RemoveObservers (unsigned long event) |
|
void | RemoveObservers (const char *event) |
|
void | RemoveAllObservers () |
|
vtkTypeBool | HasObserver (unsigned long event) |
|
vtkTypeBool | HasObserver (const char *event) |
|
int | InvokeEvent (unsigned long event) |
|
int | InvokeEvent (const char *event) |
|
unsigned long | AddObserver (unsigned long event, vtkCommand *, float priority=0.0f) |
| Allow people to add/remove/invoke observers (callbacks) to any VTK object. More...
|
|
unsigned long | AddObserver (const char *event, vtkCommand *, float priority=0.0f) |
| Allow people to add/remove/invoke observers (callbacks) to any VTK object. More...
|
|
vtkCommand * | GetCommand (unsigned long tag) |
| Allow people to add/remove/invoke observers (callbacks) to any VTK object. More...
|
|
void | RemoveObserver (vtkCommand *) |
| Allow people to add/remove/invoke observers (callbacks) to any VTK object. More...
|
|
void | RemoveObservers (unsigned long event, vtkCommand *) |
| Allow people to add/remove/invoke observers (callbacks) to any VTK object. More...
|
|
void | RemoveObservers (const char *event, vtkCommand *) |
| Allow people to add/remove/invoke observers (callbacks) to any VTK object. More...
|
|
vtkTypeBool | HasObserver (unsigned long event, vtkCommand *) |
| Allow people to add/remove/invoke observers (callbacks) to any VTK object. More...
|
|
vtkTypeBool | HasObserver (const char *event, vtkCommand *) |
| Allow people to add/remove/invoke observers (callbacks) to any VTK object. More...
|
|
template<class U , class T > |
unsigned long | AddObserver (unsigned long event, U observer, void(T::*callback)(), float priority=0.0f) |
| Overloads to AddObserver that allow developers to add class member functions as callbacks for events. More...
|
|
template<class U , class T > |
unsigned long | AddObserver (unsigned long event, U observer, void(T::*callback)(vtkObject *, unsigned long, void *), float priority=0.0f) |
| Overloads to AddObserver that allow developers to add class member functions as callbacks for events. More...
|
|
template<class U , class T > |
unsigned long | AddObserver (unsigned long event, U observer, bool(T::*callback)(vtkObject *, unsigned long, void *), float priority=0.0f) |
| Allow user to set the AbortFlagOn() with the return value of the callback method. More...
|
|
int | InvokeEvent (unsigned long event, void *callData) |
| This method invokes an event and return whether the event was aborted or not. More...
|
|
int | InvokeEvent (const char *event, void *callData) |
| This method invokes an event and return whether the event was aborted or not. More...
|
|
const char * | GetClassName () const |
| Return the class name as a string. More...
|
|
virtual vtkTypeBool | IsA (const char *name) |
| Return 1 if this class is the same type of (or a subclass of) the named class. More...
|
|
virtual vtkIdType | GetNumberOfGenerationsFromBase (const char *name) |
| Given the name of a base class of this class type, return the distance of inheritance between this class type and the named class (how many generations of inheritance are there between this class and the named class). More...
|
|
virtual void | Delete () |
| Delete a VTK object. More...
|
|
virtual void | FastDelete () |
| Delete a reference to this object. More...
|
|
void | InitializeObjectBase () |
|
void | Print (ostream &os) |
| Print an object to an ostream. More...
|
|
virtual void | Register (vtkObjectBase *o) |
| Increase the reference count (mark as used by another object). More...
|
|
virtual void | UnRegister (vtkObjectBase *o) |
| Decrease the reference count (release by another object). More...
|
|
int | GetReferenceCount () |
| Return the current reference count of this object. More...
|
|
void | SetReferenceCount (int) |
| Sets the reference count. More...
|
|
bool | GetIsInMemkind () const |
| A local state flag that remembers whether this object lives in the normal or extended memory space. More...
|
|
virtual void | PrintHeader (ostream &os, vtkIndent indent) |
| Methods invoked by print to print information about the object including superclasses. More...
|
|
virtual void | PrintTrailer (ostream &os, vtkIndent indent) |
| Methods invoked by print to print information about the object including superclasses. More...
|
|
|
template<class DataSetT > |
static void | ExchangeBoundingBoxes (diy::Master &master, const vtkDIYExplicitAssigner &assigner, std::vector< DataSetT * > &inputs) |
| This method exchanges the bounding boxes among blocks. More...
|
|
template<class BlockT > |
static LinkMap | ComputeLinkMapUsingBoundingBoxes (const diy::Master &master) |
|
template<class DataSetT > |
static void | ExchangeGhosts (diy::Master &master, std::vector< DataSetT * > &inputs) |
| This method exchanges ghosts between connected blocks. More...
|
|
template<class DataSetT > |
static void | InitializeGhostArrays (diy::Master &master, std::vector< DataSetT * > &outputs) |
| This methods allocate a point and cell ghost array and fills it with 0. More...
|
|
template<class DataSetT > |
static void | AddGhostArrays (diy::Master &master, std::vector< DataSetT * > &outputs) |
| Adds ghost arrays, which are present in blocks of master , to outputs point and / or cell data. More...
|
|
|
static void | InitializeBlocks (diy::Master &master, std::vector< vtkImageData * > &inputs) |
| Method to be overloaded for each supported type of input data set. More...
|
|
static void | InitializeBlocks (diy::Master &master, std::vector< vtkRectilinearGrid * > &inputs) |
| Method to be overloaded for each supported type of input data set. More...
|
|
static void | InitializeBlocks (diy::Master &master, std::vector< vtkStructuredGrid * > &inputs) |
| Method to be overloaded for each supported type of input data set. More...
|
|
static void | InitializeBlocks (diy::Master &master, std::vector< vtkUnstructuredGrid * > &inputs) |
| Method to be overloaded for each supported type of input data set. More...
|
|
static void | InitializeBlocks (diy::Master &master, std::vector< vtkPolyData * > &inputs) |
| Method to be overloaded for each supported type of input data set. More...
|
|
|
static void | ExchangeBlockStructures (diy::Master &master, std::vector< vtkImageData * > &inputs) |
| Method to be overloaded for each supported type of input data set. More...
|
|
static void | ExchangeBlockStructures (diy::Master &master, std::vector< vtkRectilinearGrid * > &inputs) |
| Method to be overloaded for each supported type of input data set. More...
|
|
static void | ExchangeBlockStructures (diy::Master &master, std::vector< vtkStructuredGrid * > &inputs) |
| Method to be overloaded for each supported type of input data set. More...
|
|
static void | ExchangeBlockStructures (diy::Master &master, std::vector< vtkUnstructuredGrid * > &inputs) |
| Method to be overloaded for each supported type of input data set. More...
|
|
static void | ExchangeBlockStructures (diy::Master &master, std::vector< vtkPolyData * > &inputs) |
| Method to be overloaded for each supported type of input data set. More...
|
|
|
static LinkMap | ComputeLinkMap (const diy::Master &master, std::vector< vtkImageData * > &inputs, int outputGhostLevels) |
| Method to be overloaded for each supported input data set type, that computes the minimal link map being necessary to exchange ghosts. More...
|
|
static LinkMap | ComputeLinkMap (const diy::Master &master, std::vector< vtkRectilinearGrid * > &inputs, int outputGhostLevels) |
| Method to be overloaded for each supported input data set type, that computes the minimal link map being necessary to exchange ghosts. More...
|
|
static LinkMap | ComputeLinkMap (const diy::Master &master, std::vector< vtkStructuredGrid * > &inputs, int outputGhostLevels) |
| Method to be overloaded for each supported input data set type, that computes the minimal link map being necessary to exchange ghosts. More...
|
|
static LinkMap | ComputeLinkMap (const diy::Master &master, std::vector< vtkUnstructuredGrid * > &inputs, int outputGhostLevels) |
| Method to be overloaded for each supported input data set type, that computes the minimal link map being necessary to exchange ghosts. More...
|
|
static LinkMap | ComputeLinkMap (const diy::Master &master, std::vector< vtkPolyData * > &inputs, int outputGhostLevels) |
| Method to be overloaded for each supported input data set type, that computes the minimal link map being necessary to exchange ghosts. More...
|
|
|
static void | EnqueueGhosts (const diy::Master::ProxyWithLink &cp, const diy::BlockID &blockId, vtkImageData *input, ImageDataBlock *block) |
| This method enqueues ghosts between communicating blocks. More...
|
|
static void | EnqueueGhosts (const diy::Master::ProxyWithLink &cp, const diy::BlockID &blockId, vtkRectilinearGrid *input, RectilinearGridBlock *block) |
| This method enqueues ghosts between communicating blocks. More...
|
|
static void | EnqueueGhosts (const diy::Master::ProxyWithLink &cp, const diy::BlockID &blockId, vtkStructuredGrid *input, StructuredGridBlock *block) |
| This method enqueues ghosts between communicating blocks. More...
|
|
static void | EnqueueGhosts (const diy::Master::ProxyWithLink &cp, const diy::BlockID &blockId, vtkUnstructuredGrid *input, UnstructuredGridBlock *block) |
| This method enqueues ghosts between communicating blocks. More...
|
|
static void | EnqueueGhosts (const diy::Master::ProxyWithLink &cp, const diy::BlockID &blockId, vtkPolyData *input, PolyDataBlock *block) |
| This method enqueues ghosts between communicating blocks. More...
|
|
|
static void | DequeueGhosts (const diy::Master::ProxyWithLink &cp, int gid, ImageDataBlockStructure &blockStructure) |
| This method dequeues ghosts sent between communicating blocks. More...
|
|
static void | DequeueGhosts (const diy::Master::ProxyWithLink &cp, int gid, RectilinearGridBlockStructure &blockStructure) |
| This method dequeues ghosts sent between communicating blocks. More...
|
|
static void | DequeueGhosts (const diy::Master::ProxyWithLink &cp, int gid, StructuredGridBlockStructure &blockStructure) |
| This method dequeues ghosts sent between communicating blocks. More...
|
|
static void | DequeueGhosts (const diy::Master::ProxyWithLink &cp, int gid, UnstructuredGridBlockStructure &blockStructure) |
| This method dequeues ghosts sent between communicating blocks. More...
|
|
static void | DequeueGhosts (const diy::Master::ProxyWithLink &cp, int gid, PolyDataBlockStructure &blockStructure) |
| This method dequeues ghosts sent between communicating blocks. More...
|
|
|
static void | DeepCopyInputsAndAllocateGhosts (const diy::Master &master, std::vector< vtkImageData * > &inputs, std::vector< vtkImageData * > &outputs) |
| Method to be overloaded for each supported input data set type, This method allocates ghosts in the output. More...
|
|
static void | DeepCopyInputsAndAllocateGhosts (const diy::Master &master, std::vector< vtkRectilinearGrid * > &inputs, std::vector< vtkRectilinearGrid * > &outputs) |
| Method to be overloaded for each supported input data set type, This method allocates ghosts in the output. More...
|
|
static void | DeepCopyInputsAndAllocateGhosts (const diy::Master &master, std::vector< vtkStructuredGrid * > &inputs, std::vector< vtkStructuredGrid * > &outputs) |
| Method to be overloaded for each supported input data set type, This method allocates ghosts in the output. More...
|
|
static void | DeepCopyInputsAndAllocateGhosts (const diy::Master &master, std::vector< vtkUnstructuredGrid * > &inputs, std::vector< vtkUnstructuredGrid * > &outputs) |
| Method to be overloaded for each supported input data set type, This method allocates ghosts in the output. More...
|
|
static void | DeepCopyInputsAndAllocateGhosts (const diy::Master &master, std::vector< vtkPolyData * > &inputs, std::vector< vtkPolyData * > &outputs) |
| Method to be overloaded for each supported input data set type, This method allocates ghosts in the output. More...
|
|
|
static void | FillGhostArrays (const diy::Master &master, std::vector< vtkImageData * > &outputs) |
| This method sets the ghost arrays in the output. More...
|
|
static void | FillGhostArrays (const diy::Master &master, std::vector< vtkRectilinearGrid * > &outputs) |
| This method sets the ghost arrays in the output. More...
|
|
static void | FillGhostArrays (const diy::Master &master, std::vector< vtkStructuredGrid * > &outputs) |
| This method sets the ghost arrays in the output. More...
|
|
static void | FillGhostArrays (const diy::Master &master, std::vector< vtkUnstructuredGrid * > &outputs) |
| This method sets the ghost arrays in the output. More...
|
|
static void | FillGhostArrays (const diy::Master &master, std::vector< vtkPolyData * > &outputs) |
| This method sets the ghost arrays in the output. More...
|
|
static vtkMallocingFunction | GetCurrentMallocFunction () |
|
static vtkReallocingFunction | GetCurrentReallocFunction () |
|
static vtkFreeingFunction | GetCurrentFreeFunction () |
|
static vtkFreeingFunction | GetAlternateFreeFunction () |
|
using | ImageDataBlock = Block< ImageDataBlockStructure, GridInformation > |
| Block typedefs. More...
|
|
using | RectilinearGridBlock = Block< RectilinearGridBlockStructure, RectilinearGridInformation > |
| Block typedefs. More...
|
|
using | StructuredGridBlock = Block< StructuredGridBlockStructure, StructuredGridInformation > |
| Block typedefs. More...
|
|
using | UnstructuredDataBlock = Block< UnstructuredDataBlockStructure, UnstructuredDataInformation > |
| Block typedefs. More...
|
|
using | UnstructuredGridBlock = Block< UnstructuredGridBlockStructure, UnstructuredGridInformation > |
| Block typedefs. More...
|
|
using | PolyDataBlock = Block< PolyDataBlockStructure, PolyDataInformation > |
| Block typedefs. More...
|
|
template<class DataSetT > |
static int | GenerateGhostCells (std::vector< DataSetT * > &inputsDS, std::vector< DataSetT * > &outputsDS, int outputGhostLevels, vtkMultiProcessController *controller) |
| Main pipeline generating ghosts. More...
|
|
| vtkDIYGhostUtilities () |
| Block typedefs. More...
|
|
| ~vtkDIYGhostUtilities () override |
| Block typedefs. More...
|
|
template<class DataSetT > |
static void | InitializeGhostPointArray (typename DataSetTypeToBlockTypeConverter< DataSetT >::BlockType *block, DataSetT *output) |
| This method will set all ghosts points in output to zero. More...
|
|
template<class DataSetT > |
static void | InitializeGhostCellArray (typename DataSetTypeToBlockTypeConverter< DataSetT >::BlockType *block, DataSetT *output) |
| This method will set all ghosts cells in output to zero. More...
|
|
static void | CloneGeometricStructures (std::vector< vtkImageData * > &inputs, std::vector< vtkImageData * > &outputs) |
| Block typedefs. More...
|
|
static void | CloneGeometricStructures (std::vector< vtkRectilinearGrid * > &inputs, std::vector< vtkRectilinearGrid * > &outputs) |
| Block typedefs. More...
|
|
static void | CloneGeometricStructures (std::vector< vtkStructuredGrid * > &inputs, std::vector< vtkStructuredGrid * > &outputs) |
| Block typedefs. More...
|
|
static void | CloneGeometricStructures (std::vector< vtkUnstructuredGrid * > &inputs, std::vector< vtkUnstructuredGrid * > &outputs) |
| Block typedefs. More...
|
|
static void | CloneGeometricStructures (std::vector< vtkPolyData * > &inputs, std::vector< vtkPolyData * > &outputs) |
| Block typedefs. More...
|
|
Utilities to produce ghost cells between a collection of data sets of same type.
vtkDIYGhostUtilities is a set of utilities which produce ghost cells between a collection of data sets of same type, using DIY.
Ghosts are computed from scratch, even if parts of the input already own ghosts. In such instance, ghosts are treated as if they didn't exist in the input.
Mixed types in the input vtkCompositeDataSet
are supported, in the sense that ghost cells are only exchanged between blocks of same type. Similarly, ghosts are exchanged between blocks that connect.
Blocks connect with different criteria depending on their types:
vtkImageData
: Blocks connect if they share face / edge / corner, if they share same dimension (1D / 2D / 3D), and if they have same orientation matrix and same spacing.
vtkRectilinearGrid
: Blocks connect if the x, y, and z coordinate arrays match at their interfaces.
vtkStructuredGrid
: Blocks connect if external faces of the grids are mangled together, regardless of relative inner orientation. In other words, if grid 1 is spanned by (i1, j1, k1) indexing, and grid 2 is spanned by (i2, j2, k2) indexing, if on one face, (j1, k1) connects with (-i2, -j2), those 2 grids are connected and will exchange ghosts. Two grids partially fitting are discarded. In order for 2 grids to fit, one corner from one face of one grid needs to be an existing point in one face of the second grid. Additionally, every points from this corner on both grids need to match until the opposite corner (opposite w.r.t. each dimension) is reached, and this opposite corner of the grid junction needs to be a corner of either grid.
vtkUnstructuredGrid
: Blocks connect if the external surface of neighboring grids match. To do so, only points are looked at. If at least one point matches a point in a neighboring grid, then they are connected. If there are no point global ids in the input, the 3D position of the points is used to determine if grids match, up to floating point precision in the coordinates. Note that integer coordinates can be used with this pipeline. If global ids are present in the input point data, then the pipeline will only look at matching global ids, and ignore point positions.
vtkPolyData
: Blocks connect if the boundary edges of neighboring poly data match. The filter behaves the same way it does with vtkUnstructuredGrid
. Point positions are used to match points if point global ids are not present, and point global ids are used instead if they are present.
- Note
- Currently, only
vtkImageData
, vtkRectilinearGrid
, vtkStructuredGrid
and vtkUnstructuredGrid
are implemented. Unless there is determining structural data added to subclasses of those classes, this filter should work well on subclasses of supported types.
Definition at line 99 of file vtkDIYGhostUtilities.h.