#include <vtkKdTree.h>
Inheritance diagram for vtkKdTree:
Creates a k-d tree decomposition of one data set or the combined result of multiple datasets. Decomposition is based off of the data set cell centers.
Responds to region intersection queries, indicating whether a k-d tree spatial region intersects:
an axis aligned box a sphere an arbitrary vtkCell a view frustrum defined by an axis-aligned rectangle in the view plane an arbitrary region expressed as vtkPlanes
Can depth sort all regions or any subset of regions with respect to a vtkCamera.
Can create a list of cell Ids for each region for each data set. Two lists are available - all cells with centroid in the region, and all cells that intersect the region but whose centroid lies in another region.
If there is no specification of minimum number of cells per region or maximum number of levels in the tree, the tree is built to a maximum of 20 levels or until less than 100 cells would be in each region.
For the purpose of removing duplicate points quickly from large data sets, or for finding nearby points, we added another mode for building the locator. BuildLocatorFromPoints will build a k-d tree from one or more vtkPoints objects. This can be followed by BuildMapForDuplicatePoints which returns a mapping from the original ids to a subset of the ids that is unique within a supplied tolerance, or you can use FindPoint and FindClosestPoint to locate points in the original set that the tree was built from. You can't create cell lists from this locator, but you perform all the other queries on the tree structure if you wish, and you can get a list of the points in any spatial region.
Definition at line 96 of file vtkKdTree.h.
Public Types | |
typedef vtkLocator | Superclass |
Public Member Functions | |
virtual const char * | GetClassName () |
virtual int | IsA (const char *type) |
void | PrintSelf (ostream &os, vtkIndent indent) |
virtual double | GetFudgeFactor () |
virtual void | SetFudgeFactor (double) |
void | OmitXPartitioning () |
void | OmitYPartitioning () |
void | OmitZPartitioning () |
void | OmitXYPartitioning () |
void | OmitYZPartitioning () |
void | OmitZXPartitioning () |
void | OmitNoPartitioning () |
void | SetDataSet (vtkDataSet *set) |
void | SetNthDataSet (int index, vtkDataSet *set) |
void | RemoveDataSet (int index) |
void | RemoveDataSet (vtkDataSet *set) |
void | AddDataSet (vtkDataSet *set) |
int | GetNumberOfDataSets () |
vtkDataSet * | GetDataSet (int n) |
vtkDataSet * | GetDataSet () |
int | GetDataSet (vtkDataSet *set) |
int | GetNumberOfRegions () |
void | PrintRegion (int id) |
void | CreateCellLists (int DataSet, int *regionReqList, int reqListSize) |
void | CreateCellLists (vtkDataSet *set, int *regionReqList, int reqListSize) |
void | CreateCellLists (int *regionReqList, int listSize) |
void | CreateCellLists () |
void | DeleteCellLists () |
vtkIdList * | GetCellList (int regionID) |
vtkIdList * | GetBoundaryCellList (int regionID) |
int * | AllGetRegionContainingCell () |
int | DepthOrderAllRegions (vtkCamera *camera, vtkIntArray *orderedList) |
void | BuildLocator () |
vtkIdTypeArray * | BuildMapForDuplicatePoints (float tolerance) |
vtkIdTypeArray * | GetPointsInRegion (int regionId) |
void | FreeSearchStructure () |
void | GenerateRepresentation (int level, vtkPolyData *pd) |
void | GenerateRepresentation (int *regionList, int len, vtkPolyData *pd) |
virtual void | PrintTiming (ostream &os, vtkIndent indent) |
int | NewGeometry () |
int | NewGeometry (vtkDataSet **sets, int numDataSets) |
virtual void | TimingOn () |
virtual void | TimingOff () |
virtual void | SetTiming (int) |
virtual int | GetTiming () |
virtual void | SetMinCells (int) |
virtual int | GetMinCells () |
void | GetBounds (float *bounds) |
void | GetBounds (double *bounds) |
void | GetRegionBounds (int regionID, float bounds[6]) |
void | GetRegionBounds (int regionID, double bounds[6]) |
void | GetRegionDataBounds (int regionID, float bounds[6]) |
void | GetRegionDataBounds (int regionID, double bounds[6]) |
void | PrintTree () |
void | PrintVerboseTree () |
virtual void | SetIncludeRegionBoundaryCells (int) |
virtual int | GetIncludeRegionBoundaryCells () |
virtual void | IncludeRegionBoundaryCellsOn () |
virtual void | IncludeRegionBoundaryCellsOff () |
vtkIdType | GetCellLists (vtkIntArray *regions, int set, vtkIdList *inRegionCells, vtkIdList *onBoundaryCells) |
vtkIdType | GetCellLists (vtkIntArray *regions, vtkDataSet *set, vtkIdList *inRegionCells, vtkIdList *onBoundaryCells) |
vtkIdType | GetCellLists (vtkIntArray *regions, vtkIdList *inRegionCells, vtkIdList *onBoundaryCells) |
int | GetRegionContainingCell (vtkDataSet *set, vtkIdType cellID) |
int | GetRegionContainingCell (int set, vtkIdType cellID) |
int | GetRegionContainingCell (vtkIdType cellID) |
int | GetRegionContainingPoint (float x, float y, float z) |
int | GetRegionContainingPoint (double x, double y, double z) |
int | DepthOrderRegions (vtkIntArray *regionIds, vtkCamera *camera, vtkIntArray *orderedList) |
int | IntersectsBox (int regionId, float *x) |
int | IntersectsBox (int regionId, double *x) |
int | IntersectsBox (int regionId, float xmin, float xmax, float ymin, float ymax, float zmin, float zmax) |
int | IntersectsBox (int regionId, double xmin, double xmax, double ymin, double ymax, double zmin, double zmax) |
int | IntersectsBox (int *ids, int len, float *x) |
int | IntersectsBox (int *ids, int len, double *x) |
int | IntersectsBox (int *ids, int len, float x0, float x1, float y0, float y1, float z0, float z1) |
int | IntersectsBox (int *ids, int len, double x0, double x1, double y0, double y1, double z0, double z1) |
int | IntersectsSphere2 (int regionId, float x, float y, float z, float rSquared) |
int | IntersectsSphere2 (int regionId, double x, double y, double z, double rSquared) |
int | IntersectsSphere2 (int *ids, int len, float x, float y, float z, float rSquared) |
int | IntersectsSphere2 (int *ids, int len, double x, double y, double z, double rSquared) |
int | IntersectsRegion (int regionId, vtkPlanes *planes) |
int | IntersectsRegion (int regionId, vtkPlanes *planes, int nvertices, float *vertices) |
int | IntersectsRegion (int regionId, vtkPlanes *planes, int nvertices, double *vertices) |
int | IntersectsRegion (int *ids, int len, vtkPlanes *planes) |
int | IntersectsRegion (int *ids, int len, vtkPlanes *planes, int nvertices, float *vertices) |
int | IntersectsRegion (int *ids, int len, vtkPlanes *planes, int nvertices, double *vertices) |
int | IntersectsCell (int regionId, vtkCell *cell, int cellRegion=-1) |
int | IntersectsCell (int regionId, int cellId, int cellRegion=-1) |
int | IntersectsCell (int regionId, vtkDataSet *Set, int cellId, int cellRegion=-1) |
int | IntersectsCell (int *ids, int len, vtkCell *cell, int cellRegion=-1) |
int | IntersectsCell (int *ids, int len, int cellId, int cellRegion=-1) |
int | IntersectsCell (int *ids, int len, vtkDataSet *set, int cellId, int cellRegion=-1) |
int | IntersectsFrustum (int regionId, vtkRenderer *ren, float x0, float x1, float y0, float y1) |
int | IntersectsFrustum (int regionId, vtkRenderer *ren, double x0, double x1, double y0, double y1) |
int | IntersectsFrustum (int *ids, int len, vtkRenderer *ren, float x0, float x1, float y0, float y1) |
int | IntersectsFrustum (int *ids, int len, vtkRenderer *ren, double x0, double x1, double y0, double y1) |
int | MinimalNumberOfConvexSubRegions (vtkIntArray *regionIdList, double **convexRegionBounds) |
virtual void | ComputeIntersectionsUsingDataBoundsOn () |
virtual void | ComputeIntersectionsUsingDataBoundsOff () |
virtual void | SetComputeIntersectionsUsingDataBounds (int) |
virtual int | GetComputeIntersectionsUsingDataBounds () |
void | BuildLocatorFromPoints (vtkPoints *ptArray) |
void | BuildLocatorFromPoints (vtkPoints **ptArray, int numPtArrays) |
vtkIdType | FindPoint (float *x) |
vtkIdType | FindPoint (double *x) |
vtkIdType | FindPoint (float x, float y, float z) |
vtkIdType | FindPoint (double x, double y, double z) |
vtkIdType | FindClosestPoint (float *x, float &dist2) |
vtkIdType | FindClosestPoint (double *x, double &dist2) |
vtkIdType | FindClosestPoint (float x, float y, float z, float &dist2) |
vtkIdType | FindClosestPoint (double x, double y, double z, double &dist2) |
vtkIdType | FindClosestPointInRegion (int regionId, float *x, float &dist2) |
vtkIdType | FindClosestPointInRegion (int regionId, float x, float y, float z, float &dist2) |
virtual void | GenerateRepresentationUsingDataBoundsOn () |
virtual void | GenerateRepresentationUsingDataBoundsOff () |
virtual void | SetGenerateRepresentationUsingDataBounds (int) |
virtual int | GetGenerateRepresentationUsingDataBounds () |
Static Public Member Functions | |
int | IsTypeOf (const char *type) |
vtkKdTree * | SafeDownCast (vtkObject *o) |
vtkKdTree * | New () |
void | SetCellBounds (vtkCell *cell, double *bounds) |
Protected Types | |
enum | { XDIM = 0, YDIM = 1, ZDIM = 2 } |
Protected Member Functions | |
vtkKdTree () | |
~vtkKdTree () | |
void | UpdateBuildTime () |
void | BuildRegionList () |
virtual int | SelectCutDirection (vtkKdNode *kd) |
void | SetActualLevel () |
void | GetRegionsAtLevel (int level, vtkKdNode **nodes) |
int | GetNumberOfCells () |
int | GetDataSetsNumberOfCells (int set1, int set2) |
void | ComputeCellCenter (vtkDataSet *set, int cellId, float *center) |
void | ComputeCellCenter (vtkDataSet *set, int cellId, double *center) |
float * | ComputeCellCenters () |
float * | ComputeCellCenters (int set) |
float * | ComputeCellCenters (vtkDataSet *set) |
Static Protected Member Functions | |
void | DeleteNodes (vtkKdNode *nd) |
void | GetLeafNodeIds (vtkKdNode *node, vtkIntArray *ids) |
Protected Attributes | |
int | ValidDirections |
vtkKdNode * | Top |
vtkKdNode ** | RegionList |
vtkTimerLog * | TimerLog |
|
Reimplemented from vtkLocator. Reimplemented in vtkPKdTree. Definition at line 99 of file vtkKdTree.h. |
|
Definition at line 558 of file vtkKdTree.h. |
|
|
|
|
|
Reimplemented from vtkLocator. Reimplemented in vtkPKdTree. |
|
Return 1 if this class type is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeRevisionMacro found in vtkSetGet.h. Reimplemented from vtkLocator. Reimplemented in vtkPKdTree. |
|
Return 1 if this class is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeRevisionMacro found in vtkSetGet.h. Reimplemented from vtkLocator. Reimplemented in vtkPKdTree. |
|
Reimplemented from vtkLocator. Reimplemented in vtkPKdTree. |
|
Methods invoked by print to print information about the object including superclasses. Typically not called by the user (use Print() instead) but used in the hierarchical print process to combine the output of several classes. Reimplemented from vtkLocator. Reimplemented in vtkPKdTree. |
|
Create an object with Debug turned off, modified time initialized to zero, and reference counting on. Reimplemented from vtkObject. Reimplemented in vtkPKdTree. |
|
Turn on timing of the k-d tree build |
|
Turn on timing of the k-d tree build |
|
Turn on timing of the k-d tree build |
|
Turn on timing of the k-d tree build |
|
Minimum number of cells per spatial region |
|
Minimum number of cells per spatial region |
|
Some algorithms on k-d trees require a value that is a very small distance relative to the diameter of the entire space divided by the k-d tree. This factor is the maximum axis-aligned width of the space multipled by 10e-6. |
|
|
|
Omit partitions along the X axis, yielding shafts in the X direction |
|
Omit partitions along the Y axis, yielding shafts in the Y direction |
|
Omit partitions along the Z axis, yielding shafts in the Z direction |
|
Omit partitions along the X and Y axes, yielding slabs along Z |
|
Omit partitions along the Y and Z axes, yielding slabs along X |
|
Omit partitions along the Z and X axes, yielding slabs along Y |
|
Partition along all three axes - this is the default |
|
This class can compute a spatial decomposition based on the cells in a list of one or more input data sets. SetDataSet sets the first data set in the list to the named set. SetNthDataSet sets the data set at index N to the data set named. RemoveData set takes either the data set itself or an index and removes that data set from the list of data sets. AddDataSet adds a data set to the list of data sets. Reimplemented from vtkLocator. |
|
|
|
|
|
|
|
|
|
Get the number of data sets included in spatial paritioning Definition at line 160 of file vtkKdTree.h. |
|
Get the nth defined data set in the spatial partitioning. (If you used SetNthDataSet to define 0,1 and 3 and ask for data set 2, you get 3.) |
|
Build the locator from the points/cells defining this dataset. Reimplemented from vtkLocator. Definition at line 167 of file vtkKdTree.h. References vtkLocator::GetDataSet(). |
|
Get handle for one of the data sets included in spatial paritioning. Handles can change after RemoveDataSet. |
|
Get the spatial bounds of the entire k-d tree space. Sets bounds array to xmin, xmax, ymin, ymax, zmin, zmax. |
|
Get the spatial bounds of the entire k-d tree space. Sets bounds array to xmin, xmax, ymin, ymax, zmin, zmax. |
|
The number of leaf nodes of the tree, the spatial regions Definition at line 181 of file vtkKdTree.h. |
|
Get the spatial bounds of k-d tree region |
|
Get the spatial bounds of k-d tree region |
|
Get the bounds of the data within the k-d tree region |
|
Get the bounds of the data within the k-d tree region |
|
Print out nodes of kd tree |
|
Print out nodes of kd tree |
|
Print out leaf node data for given id |
|
Create a list for each of the requested regions, listing the IDs of all cells whose centroid falls in the region. These lists are obtained with GetCellList(). If no DataSet is specified, the cell list is created for DataSet 0. If no list of requested regions is provided, the cell lists for all regions are created. When CreateCellLists is called again, the lists created on the previous call are deleted. |
|
|
|
|
|
|
|
If IncludeRegionBoundaryCells is ON, CreateCellLists() will also create a list of cells which intersect a given region, but are not assigned to the region. These lists are obtained with GetBoundaryCellList(). Default is OFF. |
|
If IncludeRegionBoundaryCells is ON, CreateCellLists() will also create a list of cells which intersect a given region, but are not assigned to the region. These lists are obtained with GetBoundaryCellList(). Default is OFF. |
|
If IncludeRegionBoundaryCells is ON, CreateCellLists() will also create a list of cells which intersect a given region, but are not assigned to the region. These lists are obtained with GetBoundaryCellList(). Default is OFF. |
|
If IncludeRegionBoundaryCells is ON, CreateCellLists() will also create a list of cells which intersect a given region, but are not assigned to the region. These lists are obtained with GetBoundaryCellList(). Default is OFF. |
|
Free the memory used by the cell lists. |
|
Get the cell list for a region. This returns a pointer to vtkKdTree's memory, so don't free it. |
|
The cell list obtained with GetCellList is the list of all cells such that their centroid is contained in the spatial region. It may also be desirable to get a list of all cells intersecting a spatial region, but with centroid in some other region. This is that list. This list is computed in CreateCellLists() if and only if IncludeRegionBoundaryCells is ON. This returns a pointer to KdTree's memory, so don't free it. |
|
For a list of regions, get two cell lists. The first lists the IDs all cells whose centroids lie in one of the regions. The second lists the IDs of all cells that intersect the regions, but whose centroid lies in a region not on the list. The total number of cell IDs written to both lists is returned. Either list pointer passed in can be NULL, and it will be ignored. If there are multiple data sets, you must specify which data set you wish cell IDs for. The caller should delete these two lists when done. This method uses the cell lists created in CreateCellLists(). If the cell list for any of the requested regions does not exist, then this method will call CreateCellLists() to create cell lists for *every* region of the k-d tree. You must remember to DeleteCellLists() when done with all calls to this method, as cell lists can require a great deal of memory. |
|
For a list of regions, get two cell lists. The first lists the IDs all cells whose centroids lie in one of the regions. The second lists the IDs of all cells that intersect the regions, but whose centroid lies in a region not on the list. The total number of cell IDs written to both lists is returned. Either list pointer passed in can be NULL, and it will be ignored. If there are multiple data sets, you must specify which data set you wish cell IDs for. The caller should delete these two lists when done. This method uses the cell lists created in CreateCellLists(). If the cell list for any of the requested regions does not exist, then this method will call CreateCellLists() to create cell lists for *every* region of the k-d tree. You must remember to DeleteCellLists() when done with all calls to this method, as cell lists can require a great deal of memory. |
|
For a list of regions, get two cell lists. The first lists the IDs all cells whose centroids lie in one of the regions. The second lists the IDs of all cells that intersect the regions, but whose centroid lies in a region not on the list. The total number of cell IDs written to both lists is returned. Either list pointer passed in can be NULL, and it will be ignored. If there are multiple data sets, you must specify which data set you wish cell IDs for. The caller should delete these two lists when done. This method uses the cell lists created in CreateCellLists(). If the cell list for any of the requested regions does not exist, then this method will call CreateCellLists() to create cell lists for *every* region of the k-d tree. You must remember to DeleteCellLists() when done with all calls to this method, as cell lists can require a great deal of memory. |
|
Get the id of the region containing the cell centroid. If no DataSet is specified, assume DataSet 0. If you need the region ID for every cell, use AllGetRegionContainingCell instead. It is more efficient. |
|
Get the id of the region containing the cell centroid. If no DataSet is specified, assume DataSet 0. If you need the region ID for every cell, use AllGetRegionContainingCell instead. It is more efficient. |
|
Get the id of the region containing the cell centroid. If no DataSet is specified, assume DataSet 0. If you need the region ID for every cell, use AllGetRegionContainingCell instead. It is more efficient. |
|
Get a list (in order by data set by cell id) of the region IDs of the region containing the centroid for each cell. This is faster than calling GetRegionContainingCell for each cell in the DataSet. vtkKdTree uses this list, so don't delete it. |
|
Get the id of the region containing the specified location. |
|
Get the id of the region containing the specified location. |
|
Given a vtkCamera, this function creates a list of the k-d tree region IDs in order from front to back with respect to the camera's direction of projection. The number of regions in the ordered list is returned. (This is not actually sorting the regions on their distance from the view plane, but there is no region on the list which blocks a region that appears earlier on the list.) |
|
Given a vtkCamera, and a list of k-d tree region IDs, this function creates an ordered list of those IDs in front to back order with respect to the camera's direction of projection. The number of regions in the ordered list is returned. |
|
Determine whether a region of the spatial decomposition intersects an axis aligned box. |
|
Determine whether a region of the spatial decomposition intersects an axis aligned box. |
|
Determine whether a region of the spatial decomposition intersects an axis aligned box. |
|
Determine whether a region of the spatial decomposition intersects an axis aligned box. |
|
Compute a list of the Ids of all regions that intersect the specified axis aligned box. Returns: the number of ids in the list. |
|
Compute a list of the Ids of all regions that intersect the specified axis aligned box. Returns: the number of ids in the list. |
|
Compute a list of the Ids of all regions that intersect the specified axis aligned box. Returns: the number of ids in the list. |
|
Compute a list of the Ids of all regions that intersect the specified axis aligned box. Returns: the number of ids in the list. |
|
Determine whether a region of the spatial decomposition intersects a sphere, given the center of the sphere and the square of it's radius. |
|
Determine whether a region of the spatial decomposition intersects a sphere, given the center of the sphere and the square of it's radius. |
|
Compute a list of the Ids of all regions that intersect the specified sphere. The sphere is given by it's center and the square of it's radius. Returns: the number of ids in the list. |
|
Compute a list of the Ids of all regions that intersect the specified sphere. The sphere is given by it's center and the square of it's radius. Returns: the number of ids in the list. |
|
Determine whether a region of the spatial decomposition intersects the convex region "inside" a set of planes. Planes must be defined as vtkPlanes (i.e. outward pointing normals). If you can provide the vertices of the convex region (as 3-tuples) it will save an expensive calculation. |
|
Determine whether a region of the spatial decomposition intersects the convex region "inside" a set of planes. Planes must be defined as vtkPlanes (i.e. outward pointing normals). If you can provide the vertices of the convex region (as 3-tuples) it will save an expensive calculation. |
|
Determine whether a region of the spatial decomposition intersects the convex region "inside" a set of planes. Planes must be defined as vtkPlanes (i.e. outward pointing normals). If you can provide the vertices of the convex region (as 3-tuples) it will save an expensive calculation. |
|
Compute a list of the Ids of all regions that intersect the convex region "inside" a set of planes. Planes must be defined as vtkPlanes (i.e. outward pointing normals). If you can provide the vertices of the convex region (as 3-tuples) it will save an expensive calculation. Returns: the number of ids in the list. |
|
Compute a list of the Ids of all regions that intersect the convex region "inside" a set of planes. Planes must be defined as vtkPlanes (i.e. outward pointing normals). If you can provide the vertices of the convex region (as 3-tuples) it will save an expensive calculation. Returns: the number of ids in the list. |
|
Compute a list of the Ids of all regions that intersect the convex region "inside" a set of planes. Planes must be defined as vtkPlanes (i.e. outward pointing normals). If you can provide the vertices of the convex region (as 3-tuples) it will save an expensive calculation. Returns: the number of ids in the list. |
|
Determine whether a region of the spatial decomposition intersects the given cell. If a cell Id is given, and no data set is specified, data set 0 is assumed. If you already know the region that the cell centroid lies in, (perhaps from a previous call to AllGetRegionContainingCell), provide that as the last argument to make the computation quicker. |
|
Determine whether a region of the spatial decomposition intersects the given cell. If a cell Id is given, and no data set is specified, data set 0 is assumed. If you already know the region that the cell centroid lies in, (perhaps from a previous call to AllGetRegionContainingCell), provide that as the last argument to make the computation quicker. |
|
Determine whether a region of the spatial decomposition intersects the given cell. If a cell Id is given, and no data set is specified, data set 0 is assumed. If you already know the region that the cell centroid lies in, (perhaps from a previous call to AllGetRegionContainingCell), provide that as the last argument to make the computation quicker. |
|
Compute a list of the Ids of all regions that intersect the given cell. If a cell Id is given, and no data set is specified, data set 0 is assumed. If you already know the region that the cell centroid lies in, provide that as the last argument to make the computation quicker. Returns the number of regions the cell intersects. |
|
Compute a list of the Ids of all regions that intersect the given cell. If a cell Id is given, and no data set is specified, data set 0 is assumed. If you already know the region that the cell centroid lies in, provide that as the last argument to make the computation quicker. Returns the number of regions the cell intersects. |
|
Compute a list of the Ids of all regions that intersect the given cell. If a cell Id is given, and no data set is specified, data set 0 is assumed. If you already know the region that the cell centroid lies in, provide that as the last argument to make the computation quicker. Returns the number of regions the cell intersects. |
|
Determine whether a region of the spatial decomposition intersects a region which is the view frustum obtained from an axis aligned rectangular viewport. Viewport coordinates range from -1 to +1 in x and y directions. |
|
Determine whether a region of the spatial decomposition intersects a region which is the view frustum obtained from an axis aligned rectangular viewport. Viewport coordinates range from -1 to +1 in x and y directions. |
|
Compute a list of the Ids of all regions that intersect a region specified by the view frustum obtained from an axis aligned rectangular viewport. Returns: the number of ids in the list. |
|
Compute a list of the Ids of all regions that intersect a region specified by the view frustum obtained from an axis aligned rectangular viewport. Returns: the number of ids in the list. |
|
Given a list of region IDs, determine the decomposition of these regions into the minimal number of convex subregions. Due to the way the k-d tree is constructed, those convex subregions will be axis-aligned boxes. Return the minimal number of such convex regions that compose the original region list. This call will set convexRegionBounds to point to a list of the bounds of these regions. Caller should free this. There will be six values for each convex subregion (xmin, xmax, ymin, ymax, zmin, zmax). If the regions in the regionIdList form a box already, a "1" is returned and the second argument contains the bounds of the box. |
|
When computing the intersection of k-d tree regions with other objects, we use the spatial bounds of the region. To use the tighter bound of the bounding box of the data within the region, set this variable ON. |
|
When computing the intersection of k-d tree regions with other objects, we use the spatial bounds of the region. To use the tighter bound of the bounding box of the data within the region, set this variable ON. |
|
When computing the intersection of k-d tree regions with other objects, we use the spatial bounds of the region. To use the tighter bound of the bounding box of the data within the region, set this variable ON. |
|
When computing the intersection of k-d tree regions with other objects, we use the spatial bounds of the region. To use the tighter bound of the bounding box of the data within the region, set this variable ON. |
|
Create the k-d tree decomposition of the cells of the data set or data sets. Cells are assigned to k-d tree spatial regions based on the location of their centroids. Implements vtkLocator. Reimplemented in vtkPKdTree. |
|
This is a special purpose locator that builds a k-d tree to find duplicate and near-by points. It builds the tree from one or more vtkPoints objects instead of from the cells of a vtkDataSet. This build would normally be followed by BuildMapForDuplicatePoints, FindPoint, or FindClosestPoint. Since this will build a normal k-d tree, all the region intersection queries will still work, as will most other calls except those that have "Cell" in the name. This method works most efficiently when the point arrays are float arrays. |
|
This is a special purpose locator that builds a k-d tree to find duplicate and near-by points. It builds the tree from one or more vtkPoints objects instead of from the cells of a vtkDataSet. This build would normally be followed by BuildMapForDuplicatePoints, FindPoint, or FindClosestPoint. Since this will build a normal k-d tree, all the region intersection queries will still work, as will most other calls except those that have "Cell" in the name. This method works most efficiently when the point arrays are float arrays. |
|
This call returns a mapping from the original point IDs supplied to BuildLocatorFromPoints to a subset of those IDs that is unique within the specified tolerance. If points 2, 5, and 12 are the same, then IdMap[2] = IdMap[5] = IdMap[12] = 2 (or 5 or 12). "original point IDs" - For point IDs we start at 0 for the first point in the first vtkPoints object, and increase by 1 for subsequent points and subsequent vtkPoints objects. You must have called BuildLocatorFromPoints() before calling this. You are responsible for deleting the returned array. |
|
Find the Id of the point that was previously supplied to BuildLocatorFromPoints(). Returns -1 if the point was not in the original array. |
|
Find the Id of the point that was previously supplied to BuildLocatorFromPoints(). Returns -1 if the point was not in the original array. |
|
Find the Id of the point that was previously supplied to BuildLocatorFromPoints(). Returns -1 if the point was not in the original array. |
|
Find the Id of the point that was previously supplied to BuildLocatorFromPoints(). Returns -1 if the point was not in the original array. |
|
Find the Id of the point that was previously supplied to BuildLocatorFromPoints() which is closest to the given point. Set the square of the distance between the two points. |
|
Find the Id of the point that was previously supplied to BuildLocatorFromPoints() which is closest to the given point. Set the square of the distance between the two points. |
|
Find the Id of the point that was previously supplied to BuildLocatorFromPoints() which is closest to the given point. Set the square of the distance between the two points. |
|
Find the Id of the point that was previously supplied to BuildLocatorFromPoints() which is closest to the given point. Set the square of the distance between the two points. |
|
Find the Id of the point in the given region which is closest to the given point. Return the ID of the point, and set the square of the distance of between the points. |
|
Find the Id of the point in the given region which is closest to the given point. Return the ID of the point, and set the square of the distance of between the points. |
|
Get a list of the original IDs of all points in a region. You must have called BuildLocatorFromPoints before calling this. |
|
Delete the k-d tree data structure. Also delete any cell lists that were computed with CreateCellLists(). Implements vtkLocator. |
|
Create a polydata representation of the boundaries of the k-d tree regions. If level equals GetLevel(), the leaf nodes are represented. Implements vtkLocator. |
|
Generate a polygonal representation of a list of regions. Only leaf nodes have region IDs, so these will be leaf nodes. |
|
The polydata representation of the k-d tree shows the boundaries of the k-d tree decomposition spatial regions. The data inside the regions may not occupy the entire space. To draw just the bounds of the data in the regions, set this variable ON. |
|
The polydata representation of the k-d tree shows the boundaries of the k-d tree decomposition spatial regions. The data inside the regions may not occupy the entire space. To draw just the bounds of the data in the regions, set this variable ON. |
|
The polydata representation of the k-d tree shows the boundaries of the k-d tree decomposition spatial regions. The data inside the regions may not occupy the entire space. To draw just the bounds of the data in the regions, set this variable ON. |
|
The polydata representation of the k-d tree shows the boundaries of the k-d tree decomposition spatial regions. The data inside the regions may not occupy the entire space. To draw just the bounds of the data in the regions, set this variable ON. |
|
Print timing of k-d tree build Reimplemented in vtkPKdTree. |
|
Return 1 if the geometry of the input data sets has changed since the last time the k-d tree was built. |
|
Return 1 if the geometry of these data sets differs for the geometry of the last data sets used to build the k-d tree. |
|
Write six floats to the bounds array giving the bounds of the specified cell. |
|
Save enough state so NewGeometry() can work, and update the BuildTime time stamp. |
|
|
|
|
|
|
|
Definition at line 578 of file vtkKdTree.h. |
|
Get back a list of the nodes at a specified level, nodes must be preallocated to hold 2^^(level) node structures. |
|
Adds to the vtkIntArray the list of region IDs of all leaf nodes in the given node. |
|
Returns the total number of cells in all the data sets |
|
Returns the total number of cells in data set 1 through data set 2. |
|
Get or compute the center of one cell. If the DataSet is NULL, the first DataSet is used. This is the point used in determining to which spatial region the cell is assigned. |
|
|
|
Compute and return a pointer to a list of all cell centers, in order by data set by cell Id. If a DataSet is specified cell centers for cells of that data only are returned. If no DataSet is specified, the cell centers of cells in all DataSets are returned. The caller should free the list of cell centers when done. |
|
|
|
|
|
Definition at line 565 of file vtkKdTree.h. |
|
Definition at line 568 of file vtkKdTree.h. |
|
Definition at line 569 of file vtkKdTree.h. |
|
Definition at line 572 of file vtkKdTree.h. |