/*========================================================================= Program: Visualization Toolkit Module: $RCSfile: vtkBSPCuts.h,v $ Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen All rights reserved. See Copyright.txt or http://www.kitware.com/Copyright.htm for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the above copyright notice for more information. =========================================================================*/ /*---------------------------------------------------------------------------- Copyright (c) Sandia Corporation See Copyright.txt or http://www.paraview.org/HTML/Copyright.html for details. ----------------------------------------------------------------------------*/ // .NAME vtkBSPCuts - This class represents an axis-aligned Binary Spatial // Partitioning of a 3D space. // // .SECTION Description // This class converts between the vtkKdTree // representation of a tree of vtkKdNodes (used by vtkDistributedDataFilter) // and a compact array representation that might be provided by a // graph partitioning library like Zoltan. Such a representation // could be used in message passing. // // .SECTION See Also // vtkKdTree vtkKdNode vtkDistributedDataFilter #ifndef __vtkBSPCuts_h #define __vtkBSPCuts_h #include "vtkObject.h" class vtkKdNode; class VTK_GRAPHICS_EXPORT vtkBSPCuts : public vtkObject { public: vtkTypeRevisionMacro(vtkBSPCuts, vtkObject); void PrintSelf(ostream& os, vtkIndent indent); static vtkBSPCuts *New(); // Description: // Initialize the cuts with arrays of information. This type of // information would be obtained from a graph partitioning software // package like Zoltan. // // bounds - the bounds (xmin, xmax, ymin, ymax, zmin, zmax) of the // space being partitioned // ncuts - the number cuts, also the size of the following arrays // dim - the dimension along which the cut is made (x/y/z - 0/1/2) // coord - the location of the cut along the axis // lower - array index for the lower region bounded by the cut // upper - array index for the upper region bounded by the cut // lowerDataCoord - optional upper bound of the data in the lower region // upperDataCoord - optional lower bound of the data in the upper region // npoints - optional number of points in the spatial region void CreateCuts(double *bounds, int ncuts, int *dim, double *coord, int *lower, int *upper, double *lowerDataCoord, double *upperDataCoord, int *npoints); // Description: // Initialize the cuts from a tree of vtkKdNode's void CreateCuts(vtkKdNode *kd); // Description: // Return a tree of vtkKdNode's representing the cuts specified // in this object. This is our copy, don't delete it. vtkKdNode *GetKdNodeTree(){return this->Top;} // Description: // Get the number of cuts in the partitioning, which also the size of // the arrays in the array representation of the partitioning. vtkGetMacro(NumberOfCuts, int); // Description: // Get the arrays representing the cuts in the partitioning. int GetArrays(int len, int *dim, double *coord, int *lower, int *upper, double *lowerDataCoord, double *upperDataCoord, int *npoints); void PrintTree(); void PrintArrays(); protected: vtkBSPCuts(); ~vtkBSPCuts(); private: static void DeleteAllDescendants(vtkKdNode *kd); static int CountNodes(vtkKdNode *kd); static void SetMinMaxId(vtkKdNode *kd); static void _PrintTree(vtkKdNode *kd, int depth); void BuildTree(vtkKdNode *kd, int idx); int WriteArray(vtkKdNode *kd, int loc); void ResetArrays(); void AllocateArrays(int size); vtkKdNode *Top; // required cut information int NumberOfCuts;// number of cuts, also length of each array int *Dim; // dimension (x/y/z - 0/1/2) where cut occurs double *Coord; // location of cut along axis int *Lower; // location in arrays of left (lower) child info int *Upper; // location in arrays of right (lower) child info // optional cut information double *LowerDataCoord; // coordinate of uppermost data in lower half double *UpperDataCoord; // coordinate of lowermost data in upper half int *Npoints; // number of data values in partition double Bounds[6]; vtkBSPCuts(const vtkBSPCuts&); // Not implemented void operator=(const vtkBSPCuts&); // Not implemented }; #endif