S
- Type of the space.public class BSPTree<S extends Space> extends Object
BSP trees are an efficient way to represent space partitions and to associate attributes with each cell. Each node in a BSP tree represents a convex region which is partitioned in two convex sub-regions at each side of a cut hyperplane. The root tree contains the complete space.
The main use of such partitions is to use a boolean attribute to define an inside/outside property, hence representing arbitrary polytopes (line segments in 1D, polygons in 2D and polyhedrons in 3D) and to operate on them.
Another example would be to represent Voronoi tesselations, the attribute of each cell holding the defining point of the cell.
The application-defined attributes are shared among copied instances and propagated to split parts. These attributes are not used by the BSP-tree algorithms themselves, so the application can use them for any purpose. Since the tree visiting method holds internal and leaf nodes differently, it is possible to use different classes for internal nodes attributes and leaf nodes attributes. This should be used with care, though, because if the tree is modified in any way after attributes have been set, some internal nodes may become leaf nodes and some leaf nodes may become internal nodes.
One of the main sources for the development of this package was Bruce Naylor, John Amanatides and William Thibault paper Merging BSP Trees Yields Polyhedral Set Operations Proc. Siggraph '90, Computer Graphics 24(4), August 1990, pp 115-124, published by the Association for Computing Machinery (ACM).
Modifier and Type | Class and Description |
---|---|
static interface |
BSPTree.LeafMerger<S extends Space>
This interface gather the merging operations between a BSP tree
leaf and another BSP tree.
|
static interface |
BSPTree.VanishingCutHandler<S extends Space>
This interface handles the corner cases when an internal node cut sub-hyperplane vanishes.
|
Constructor and Description |
---|
BSPTree()
Build a tree having only one root cell representing the whole space.
|
BSPTree(Object attribute)
Build a tree having only one root cell representing the whole space.
|
BSPTree(SubHyperplane<S> cut,
BSPTree<S> plus,
BSPTree<S> minus,
Object attribute)
Build a BSPTree from its underlying elements.
|
Modifier and Type | Method and Description |
---|---|
BSPTree<S> |
copySelf()
Copy the instance.
|
Object |
getAttribute()
Get the attribute associated with the instance.
|
BSPTree<S> |
getCell(Point<S> point,
double tolerance)
Get the cell to which a point belongs.
|
BSPTree<S> |
getCell(Vector<S> point)
Deprecated.
as of 3.3, replaced with
getCell(Point, double) |
List<BSPTree<S>> |
getCloseCuts(Point<S> point,
double maxOffset)
Get the cells whose cut sub-hyperplanes are close to the point.
|
SubHyperplane<S> |
getCut()
Get the cut sub-hyperplane.
|
BSPTree<S> |
getMinus()
Get the tree on the minus side of the cut hyperplane.
|
BSPTree<S> |
getParent()
Get the parent node.
|
BSPTree<S> |
getPlus()
Get the tree on the plus side of the cut hyperplane.
|
boolean |
insertCut(Hyperplane<S> hyperplane)
Insert a cut sub-hyperplane in a node.
|
void |
insertInTree(BSPTree<S> parentTree,
boolean isPlusChild)
Deprecated.
as of 3.4, replaced with
insertInTree(BSPTree, boolean, VanishingCutHandler) |
void |
insertInTree(BSPTree<S> parentTree,
boolean isPlusChild,
BSPTree.VanishingCutHandler<S> vanishingHandler)
Insert the instance into another tree.
|
BSPTree<S> |
merge(BSPTree<S> tree,
BSPTree.LeafMerger<S> leafMerger)
Merge a BSP tree with the instance.
|
BSPTree<S> |
pruneAroundConvexCell(Object cellAttribute,
Object otherLeafsAttributes,
Object internalAttributes)
Prune a tree around a cell.
|
void |
setAttribute(Object attribute)
Associate an attribute with the instance.
|
BSPTree<S> |
split(SubHyperplane<S> sub)
Split a BSP tree by an external sub-hyperplane.
|
void |
visit(BSPTreeVisitor<S> visitor)
Visit the BSP tree nodes.
|
public BSPTree()
public BSPTree(Object attribute)
attribute
- attribute of the tree (may be null)public BSPTree(SubHyperplane<S> cut, BSPTree<S> plus, BSPTree<S> minus, Object attribute)
This method does not perform any verification on consistency of its arguments, it should therefore be used only when then caller knows what it is doing.
This method is mainly useful to build trees
bottom-up. Building trees top-down is realized with the help of
method insertCut
.
cut
- cut sub-hyperplane for the treeplus
- plus side sub-treeminus
- minus side sub-treeattribute
- attribute associated with the node (may be null)insertCut(org.apache.commons.math3.geometry.partitioning.Hyperplane<S>)
public boolean insertCut(Hyperplane<S> hyperplane)
The sub-tree starting at this node will be completely
overwritten. The new cut sub-hyperplane will be built from the
intersection of the provided hyperplane with the cell. If the
hyperplane does intersect the cell, the cell will have two
children cells with null
attributes on each side of
the inserted cut sub-hyperplane. If the hyperplane does not
intersect the cell then no cut hyperplane will be
inserted and the cell will be changed to a leaf cell. The
attribute of the node is never changed.
This method is mainly useful when called on leaf nodes
(i.e. nodes for which getCut
returns
null
), in this case it provides a way to build a
tree top-down (whereas the 4 arguments constructor
is devoted to
build trees bottom-up).
hyperplane
- hyperplane to insert, it will be chopped in
order to fit in the cell defined by the parent nodes of the
instanceBSPTree(SubHyperplane, BSPTree, BSPTree, Object)
public BSPTree<S> copySelf()
The instance created is completely independent of the original one. A deep copy is used, none of the underlying objects are shared (except for the nodes attributes and immutable objects).
public SubHyperplane<S> getCut()
public BSPTree<S> getPlus()
public BSPTree<S> getMinus()
public BSPTree<S> getParent()
public void setAttribute(Object attribute)
attribute
- attribute to associate with the nodegetAttribute()
public Object getAttribute()
setAttribute
methodsetAttribute(java.lang.Object)
public void visit(BSPTreeVisitor<S> visitor)
visitor
- object visiting the tree nodes@Deprecated public BSPTree<S> getCell(Vector<S> point)
getCell(Point, double)
If the returned cell is a leaf node the points belongs to the interior of the node, if the cell is an internal node the points belongs to the node cut sub-hyperplane.
point
- point to checkpublic BSPTree<S> getCell(Point<S> point, double tolerance)
If the returned cell is a leaf node the points belongs to the interior of the node, if the cell is an internal node the points belongs to the node cut sub-hyperplane.
point
- point to checktolerance
- tolerance below which points close to a cut hyperplane
are considered to belong to the hyperplane itselfpublic List<BSPTree<S>> getCloseCuts(Point<S> point, double maxOffset)
point
- point to checkmaxOffset
- offset below which a cut sub-hyperplane is considered
close to the point (in absolute value)public BSPTree<S> merge(BSPTree<S> tree, BSPTree.LeafMerger<S> leafMerger)
All trees are modified (parts of them are reused in the new tree), it is the responsibility of the caller to ensure a copy has been done before if any of the former tree should be preserved, no such copy is done here!
The algorithm used here is directly derived from the one described in the Naylor, Amanatides and Thibault paper (section III, Binary Partitioning of a BSP Tree).
tree
- other tree to merge with the instance (will be
unusable after the operation, as well as the
instance itself)leafMerger
- object implementing the final merging phase
(this is where the semantic of the operation occurs, generally
depending on the attribute of the leaf node)instance <op>
tree
, this value can be ignored if parentTree is not null
since all connections have already been establishedpublic BSPTree<S> split(SubHyperplane<S> sub)
Split a tree in two halves, on each side of the sub-hyperplane. The instance is not modified.
The tree returned is not upward-consistent: despite all of its sub-trees cut sub-hyperplanes (including its own cut sub-hyperplane) are bounded to the current cell, it is not attached to any parent tree yet. This tree is intended to be later inserted into an higher level tree.
The algorithm used here is the one given in Naylor, Amanatides and Thibault paper (section III, Binary Partitioning of a BSP Tree).
sub
- partitioning sub-hyperplane, must be already clipped
to the convex region represented by the instance, will be used as
the cut sub-hyperplane of the returned tree@Deprecated public void insertInTree(BSPTree<S> parentTree, boolean isPlusChild)
insertInTree(BSPTree, boolean, VanishingCutHandler)
The instance itself is modified so its former parent should not be used anymore.
parentTree
- parent tree to connect to (may be null)isPlusChild
- if true and if parentTree is not null, the
resulting tree should be the plus child of its parent, ignored if
parentTree is nullBSPTree.LeafMerger
public void insertInTree(BSPTree<S> parentTree, boolean isPlusChild, BSPTree.VanishingCutHandler<S> vanishingHandler)
The instance itself is modified so its former parent should not be used anymore.
parentTree
- parent tree to connect to (may be null)isPlusChild
- if true and if parentTree is not null, the
resulting tree should be the plus child of its parent, ignored if
parentTree is nullvanishingHandler
- handler to use for handling very rare corner
cases of vanishing cut sub-hyperplanes in internal nodes during mergingBSPTree.LeafMerger
public BSPTree<S> pruneAroundConvexCell(Object cellAttribute, Object otherLeafsAttributes, Object internalAttributes)
This method can be used to extract a convex cell from a tree. The original cell may either be a leaf node or an internal node. If it is an internal node, it's subtree will be ignored (i.e. the extracted cell will be a leaf node in all cases). The original tree to which the original cell belongs is not touched at all, a new independent tree will be built.
cellAttribute
- attribute to set for the leaf node
corresponding to the initial instance cellotherLeafsAttributes
- attribute to set for the other leaf
nodesinternalAttributes
- attribute to set for the internal nodesCopyright © 2003–2016 The Apache Software Foundation. All rights reserved.