Bridges-C++  3.4.5-dev1-6-g935685a
Bridges(C++ API)
Public Member Functions | Protected Member Functions | List of all members
bridges::datastructure::KdTreeElement< K, E > Class Template Reference

This class can be used to create K-d Tree elements, derived from BSTElement. K-D trees can be thought of as the spatial equivalent binary search trees and operate on multiple dimensions (2D and 3D are most common). These trees serve as a representation of the underlying geometrically defined spaces. Specialized versions of these trees include quadtrees and octrees, which subdivide into equal sized quadrants octants at each level, respectively. More...

#include <KdTreeElement.h>

Inheritance diagram for bridges::datastructure::KdTreeElement< K, E >:
bridges::datastructure::BSTElement< K, E > bridges::datastructure::BinTreeElement< E > bridges::datastructure::TreeElement< E > bridges::datastructure::Element< E > bridges::datastructure::DataStructure

Public Member Functions

 KdTreeElement (const K &k, int dim, int th, const KdTreeElement *l, const KdTreeElement *r, const E &val=E(), const string &lab=string())
 
 KdTreeElement (const K &k, int dim, int th=0, const E &val=E(), const string &lab=string())
 
virtual const string getDStype () const override
 
int getDimension () const
 Get Dimension of the partition. More...
 
void setDimension (const int &dim)
 Set partitioning dimension to "dim". More...
 
float getThickness () const
 Get thickness of the partition. More...
 
void setThickness (const float &th)
 Set partitioning dimension to "dim". More...
 
getPartitioner () const
 Get partitioner value. More...
 
void setPartitioner (const K &p)
 Set partitioning dimension to "dim". More...
 
virtual KdTreeElementgetLeft () override
 Get left child. More...
 
virtual const KdTreeElementgetLeft () const override
 Get left child - constant version. More...
 
void setLeft (KdTreeElement *l)
 Sets left child to "l". More...
 
virtual KdTreeElementgetRight () override
 Get right child. More...
 
virtual const KdTreeElementgetRight () const override
 Get right child - Constant version. More...
 
void setRight (KdTreeElement *r)
 Sets right child to "r". More...
 
- Public Member Functions inherited from bridges::datastructure::BSTElement< K, E >
 BSTElement (const K &k, BSTElement *l, BSTElement *r, const E &val=E(), const string &lab=string())
 
 BSTElement (const K &k, const E &val=E(), const string &lab=string())
 
getKey () const
 
void setKey (const K &k)
 
void setLeft (BSTElement *l)
 
void setRight (BSTElement *r)
 
- Public Member Functions inherited from bridges::datastructure::BinTreeElement< E >
 BinTreeElement (BinTreeElement *l, BinTreeElement *r, const E &e=E(), const string &lab=string())
 
 BinTreeElement (const E &e=E(), const string &lab=string())
 
void setLeft (BinTreeElement *l)
 
void setRight (BinTreeElement *r)
 
- Public Member Functions inherited from bridges::datastructure::TreeElement< E >
 TreeElement (const E &e=E(), const string &lab=string())
 Construct a TreeElement from given values. More...
 
vector< TreeElement * > & getChildren ()
 Get the children of this node. More...
 
const vector< TreeElement * > & getChildren () const
 Get the children of this node. More...
 
TreeElementgetChild (const int &n)
 Gets the nth child of this node. More...
 
const TreeElementgetChild (const int &n) const
 Gets the nth child of this node - constant version. More...
 
void addChild (TreeElement *child)
 Adds a child to children. More...
 
void setChild (const size_t &index, TreeElement *kid)
 Sets child at index to "kid". More...
 
- Public Member Functions inherited from bridges::datastructure::Element< E >
 Element (const E &val=E(), const string &lab=string())
 
 Element (const Element &e)
 
Elementoperator= (const Element &e)
 
E & operator= (E const &e)
 
virtual ~Element ()
 
ElementVisualizergetVisualizer ()
 Get the element visualizer object. More...
 
const ElementVisualizergetVisualizer () const
 Get the element visualizer object - constant version. More...
 
LinkVisualizergetLinkVisualizer (const Element *el)
 Returns the LinkVisualizer of element. More...
 
LinkVisualizergetLinkVisualizer (const Element *el) const
 Returns the LinkVisualizer of element. More...
 
string const & getLabel () const
 Gets the label of this element. More...
 
void setLabel (const string &lab)
 Sets label of this element. More...
 
E const & getValue () const
 Gets the object held in the generic object E. More...
 
E & getValue ()
 Gets the object held in the generic object E. More...
 
void setValue (const E &val)
 Sets generic object to "val". More...
 
void setSize (const double &sz)
 Sets size of the element. More...
 
double getSize () const
 Get element size. More...
 
void setColor (const Color &col)
 Set the color of the Element. More...
 
void setColor (const string col)
 Set the color by name. More...
 
Color getColor () const
 Get the current color of the element. More...
 
void setOpacity (double opacity)
 Set opacity of element - use the 4th color component. More...
 
double getOpacity ()
 
void setShape (const Shape &shp)
 Set the shape of the element. More...
 
Shape getShape () const
 Returns the shape of the element. More...
 
void setLocation (const double &locX, const double &locY)
 Sets the location attributes of an element. More...
 
double getLocationX () const
 Gets the X coordinate of the location. More...
 
double getLocationY () const
 Gets the Y coordinate of the location. More...
 
- Public Member Functions inherited from bridges::datastructure::DataStructure
virtual ~DataStructure ()=default
 

Protected Member Functions

virtual const string getElementRepresentation () const override
 get kd tree element representation as JSON string More...
 

Additional Inherited Members

- Static Protected Member Functions inherited from bridges::datastructure::Element< E >
static const string getLinkRepresentation (const LinkVisualizer &lv, const string &src, const string &dest)
 
static void getLinkRepresentation (const LinkVisualizer &lv, const string &src, const string &dest, rapidjson::Document &d)
 
- Protected Attributes inherited from bridges::datastructure::BSTElement< K, E >
key = K()
 
- Protected Attributes inherited from bridges::datastructure::Element< E >
unordered_map< Element *, LinkVisualizerlinks
 

Detailed Description

template<typename K, typename E>
class bridges::datastructure::KdTreeElement< K, E >

This class can be used to create K-d Tree elements, derived from BSTElement. K-D trees can be thought of as the spatial equivalent binary search trees and operate on multiple dimensions (2D and 3D are most common). These trees serve as a representation of the underlying geometrically defined spaces. Specialized versions of these trees include quadtrees and octrees, which subdivide into equal sized quadrants octants at each level, respectively.

This class extends the BSTElement class by adding a dimension property. It also includes a thickness property for displaying the partitioning lines generated by the convex decomposition.

convenient to generate visual representation to allow for use in a binary search tree implementation.

See also
There is a tutorial about K-d Trees : https://bridgesuncc.github.io/tutorials/KdTree.html
 @param K that is the search key type - this is usually a number, integer
    or float
 @param E the application data type
Author
Kalpathi Subramanian
Date
6/18/15, 7/17/16, 12/28/20

Constructor & Destructor Documentation

◆ KdTreeElement() [1/2]

template<typename K , typename E >
bridges::datastructure::KdTreeElement< K, E >::KdTreeElement ( const K &  k,
int  dim,
int  th,
const KdTreeElement< K, E > *  l,
const KdTreeElement< K, E > *  r,
const E &  val = E(),
const string &  lab = string() 
)
inline

Constructs a KdTreeElement with the provided value, label, key, left and right KdTree elements. The defaults will be used if not provided.

Parameters
kThe key for ordering
dimnumber of dimension to be partitioned
ththickness of the line showing the partition
lThe left KdTree Element
rThe right KdTree Element
valThe data to hold
labThe label to show

◆ KdTreeElement() [2/2]

template<typename K , typename E >
bridges::datastructure::KdTreeElement< K, E >::KdTreeElement ( const K &  k,
int  dim,
int  th = 0,
const E &  val = E(),
const string &  lab = string() 
)
inline

Constructs a KdTreeElement with the provided value, label, key, setting the left and right KdTreeElement to NULL. The defaults will be used if not provided.

Parameters
kThe key for ordering
dimnumber of dimensions being partitioned
ththickness of the line showing the partition
valThe data to hold
labThe label to show

Member Function Documentation

◆ getDimension()

template<typename K , typename E >
int bridges::datastructure::KdTreeElement< K, E >::getDimension ( ) const
inline

Get Dimension of the partition.

Returns
return the partitioning of this node

◆ getDStype()

template<typename K , typename E >
virtual const string bridges::datastructure::KdTreeElement< K, E >::getDStype ( ) const
inlineoverridevirtual
Returns
the data structure type

Reimplemented from bridges::datastructure::BSTElement< K, E >.

◆ getElementRepresentation()

template<typename K , typename E >
virtual const string bridges::datastructure::KdTreeElement< K, E >::getElementRepresentation ( ) const
inlineoverrideprotectedvirtual

get kd tree element representation as JSON string

Reimplemented from bridges::datastructure::BSTElement< K, E >.

◆ getLeft() [1/2]

template<typename K , typename E >
virtual const KdTreeElement* bridges::datastructure::KdTreeElement< K, E >::getLeft ( ) const
inlineoverridevirtual

Get left child - constant version.

Returns
The left child

Reimplemented from bridges::datastructure::BSTElement< K, E >.

◆ getLeft() [2/2]

template<typename K , typename E >
virtual KdTreeElement* bridges::datastructure::KdTreeElement< K, E >::getLeft ( )
inlineoverridevirtual

Get left child.

Returns
The left child

Reimplemented from bridges::datastructure::BSTElement< K, E >.

◆ getPartitioner()

template<typename K , typename E >
K bridges::datastructure::KdTreeElement< K, E >::getPartitioner ( ) const
inline

Get partitioner value.

Returns
return the partitioner value

◆ getRight() [1/2]

template<typename K , typename E >
virtual const KdTreeElement* bridges::datastructure::KdTreeElement< K, E >::getRight ( ) const
inlineoverridevirtual

Get right child - Constant version.

Returns
The right child

Reimplemented from bridges::datastructure::BSTElement< K, E >.

◆ getRight() [2/2]

template<typename K , typename E >
virtual KdTreeElement* bridges::datastructure::KdTreeElement< K, E >::getRight ( )
inlineoverridevirtual

Get right child.

Returns
The right child

Reimplemented from bridges::datastructure::BSTElement< K, E >.

◆ getThickness()

template<typename K , typename E >
float bridges::datastructure::KdTreeElement< K, E >::getThickness ( ) const
inline

Get thickness of the partition.

Returns
return the partitioner thickness

◆ setDimension()

template<typename K , typename E >
void bridges::datastructure::KdTreeElement< K, E >::setDimension ( const int &  dim)
inline

Set partitioning dimension to "dim".

Parameters
dimThe partitioning dimension of this Kd tree element

◆ setLeft()

template<typename K , typename E >
void bridges::datastructure::KdTreeElement< K, E >::setLeft ( KdTreeElement< K, E > *  l)
inline

Sets left child to "l".

Parameters
lThe left child

◆ setPartitioner()

template<typename K , typename E >
void bridges::datastructure::KdTreeElement< K, E >::setPartitioner ( const K &  p)
inline

Set partitioning dimension to "dim".

Parameters
pThe partitioning dimension value of this Kd tree element

◆ setRight()

template<typename K , typename E >
void bridges::datastructure::KdTreeElement< K, E >::setRight ( KdTreeElement< K, E > *  r)
inline

Sets right child to "r".

Parameters
rThe right BSTElement

◆ setThickness()

template<typename K , typename E >
void bridges::datastructure::KdTreeElement< K, E >::setThickness ( const float &  th)
inline

Set partitioning dimension to "dim".

Parameters
thThe thickness of the partitioner to set

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