Ocean
Loading...
Searching...
No Matches
Ocean::KdTree< T > Class Template Reference

This class implements a k-d tree. More...

#include <KdTree.h>

Data Structures

class  Node
 This class defines a node of the k-d tree. More...
 

Public Member Functions

 KdTree (const unsigned int dimension)
 Creates a new k-d tree.
 
 ~KdTree ()=default
 Destructs a k-d tree.
 
bool insert (const T **values, const size_t number)
 Inserts a set of values to this empty tree.
 
const T * nearestNeighbor (const T *value, typename SquareValueTyper< T >::Type &distance) const
 Applies a nearest neighbor search for a given value.
 
size_t radiusSearch (const T *value, const typename SquareValueTyper< T >::Type radius, const T **values, const size_t maxValues) const
 Applies a radius search for neighbors of a given value.
 
unsigned int dimension () const
 Returns the dimension of the tree's values.
 
size_t size () const
 Returns the number of tree nodes.
 

Protected Types

typedef std::vector< T > Elements
 Definition of a vector holding single elements.
 
typedef std::vector< const T * > Pointers
 Definition of a vector holding single pointers.
 

Protected Member Functions

void insertLeft (Node &parent, const T **values, const size_t number, const unsigned int depth)
 Inserts a set of values to a given parent as left children.
 
void insertRight (Node &parent, const T **values, const size_t number, const unsigned int depth)
 Inserts a set of values to a given parent as right children.
 
void nearestNeighbor (Node &node, const T *value, const T *&nearest, typename SquareValueTyper< T >::Type &distance, const unsigned int index) const
 Applies a nearest neighbor search for a given node and value.
 
size_t radiusSearch (Node &node, const T *value, const typename SquareValueTyper< T >::Type radius, const T **values, const size_t maxValues, const unsigned int index) const
 Applies a radius search for neighbors of a given value.
 
SquareValueTyper< T >::Type determineSquareDistance (const T *first, const T *second) const
 Determines the square distance between two values.
 

Static Protected Member Functions

static T median (const T **values, const size_t number, const unsigned int index)
 Returns the median for a given set of values.
 
static void distribute (const T **values, const size_t number, const unsigned int index, const T *&medianValue, Pointers &leftValues, Pointers &rightValues)
 Distributes a given set of values into two subset according to the median.
 

Protected Attributes

std::unique_ptr< Noderoot_
 Root node of this tree.
 
size_t size_ = 0
 Number of nodes.
 
const unsigned int dimension_ = 0u
 Number of dimensions.
 

Detailed Description

template<typename T>
class Ocean::KdTree< T >

This class implements a k-d tree.

In general, k-d trees should be applied for problems with small dimensions only as the performance benefit decreases with increasing dimension significantly.
That means for the number of nodes (n) and the dimension (k) the following should hold: n >> 2^k.

Template Parameters
TThe data type of one element for all dimensions.

Member Typedef Documentation

◆ Elements

template<typename T >
typedef std::vector<T> Ocean::KdTree< T >::Elements
protected

Definition of a vector holding single elements.

◆ Pointers

template<typename T >
typedef std::vector<const T*> Ocean::KdTree< T >::Pointers
protected

Definition of a vector holding single pointers.

Constructor & Destructor Documentation

◆ KdTree()

template<typename T >
Ocean::KdTree< T >::KdTree ( const unsigned int  dimension)
inlineexplicit

Creates a new k-d tree.

Parameters
dimensionNumber of dimensions the tree will have, with range [1, infinity)

◆ ~KdTree()

template<typename T >
Ocean::KdTree< T >::~KdTree ( )
default

Destructs a k-d tree.

Member Function Documentation

◆ determineSquareDistance()

template<typename T >
SquareValueTyper< T >::Type Ocean::KdTree< T >::determineSquareDistance ( const T *  first,
const T *  second 
) const
inlineprotected

Determines the square distance between two values.

Parameters
firstThe first value
secondThe second value
Returns
Square distance

◆ dimension()

template<typename T >
unsigned int Ocean::KdTree< T >::dimension ( ) const
inline

Returns the dimension of the tree's values.

Returns
The tree's dimension

◆ distribute()

template<typename T >
void Ocean::KdTree< T >::distribute ( const T **  values,
const size_t  number,
const unsigned int  index,
const T *&  medianValue,
Pointers leftValues,
Pointers rightValues 
)
staticprotected

Distributes a given set of values into two subset according to the median.

Parameters
valuesThe values to distribute
numberThe number of values
indexDimension index to be used for distribution
medianValueResulting median value
leftValuesResulting left values
rightValuesResulting right values

◆ insert()

template<typename T >
bool Ocean::KdTree< T >::insert ( const T **  values,
const size_t  number 
)

Inserts a set of values to this empty tree.

Beware: Adding elements to an already existing tree with nodes is not supported.

Parameters
valuesThe values to be added
numberThe number of elements to be added, with range [0, infinity)
Returns
True, if succeeded

◆ insertLeft()

template<typename T >
void Ocean::KdTree< T >::insertLeft ( Node parent,
const T **  values,
const size_t  number,
const unsigned int  depth 
)
protected

Inserts a set of values to a given parent as left children.

Parameters
parentThe parent node
valuesThe values to be added
numberThe number of elements to be added
depthCurrent depth of the new nodes

◆ insertRight()

template<typename T >
void Ocean::KdTree< T >::insertRight ( Node parent,
const T **  values,
const size_t  number,
const unsigned int  depth 
)
protected

Inserts a set of values to a given parent as right children.

Parameters
parentThe parent node
valuesThe values to be added
numberThe number of elements to be added
depthCurrent depth of the new nodes

◆ median()

template<typename T >
T Ocean::KdTree< T >::median ( const T **  values,
const size_t  number,
const unsigned int  index 
)
staticprotected

Returns the median for a given set of values.

Parameters
valuesThe values to return the median for
numberThe number of values
indexDimension index
Returns
Resulting median

◆ nearestNeighbor() [1/2]

template<typename T >
const T * Ocean::KdTree< T >::nearestNeighbor ( const T *  value,
typename SquareValueTyper< T >::Type &  distance 
) const

Applies a nearest neighbor search for a given value.

Parameters
valueThe value to be searched
distanceResulting minimal distance
Returns
Resulting nearest neighbor

◆ nearestNeighbor() [2/2]

template<typename T >
void Ocean::KdTree< T >::nearestNeighbor ( Node node,
const T *  value,
const T *&  nearest,
typename SquareValueTyper< T >::Type &  distance,
const unsigned int  index 
) const
protected

Applies a nearest neighbor search for a given node and value.

Parameters
nodeReference node
valueThe value to be searched
nearestResulting nearest value
distanceResulting minimal distance
indexThe index of the dimension for the recent search, with range [0, dimension())

◆ radiusSearch() [1/2]

template<typename T >
size_t Ocean::KdTree< T >::radiusSearch ( const T *  value,
const typename SquareValueTyper< T >::Type  radius,
const T **  values,
const size_t  maxValues 
) const

Applies a radius search for neighbors of a given value.

Beware: Function offers performance boost over brute force search only if radius is so small that relatively few values are returned.

Parameters
valueThe value to be searched
radiusThe neighborhood radius, with range [0, infinity)
valuesFound values within radius distance from a given value
maxValuesLimit number of returned values
Returns
Number of returned values

◆ radiusSearch() [2/2]

template<typename T >
size_t Ocean::KdTree< T >::radiusSearch ( Node node,
const T *  value,
const typename SquareValueTyper< T >::Type  radius,
const T **  values,
const size_t  maxValues,
const unsigned int  index 
) const
protected

Applies a radius search for neighbors of a given value.

Parameters
nodeReference node
valueThe value to be searched
radiusThe neighborhood radius, with range [0, infinity)
valuesFound values within radius distance from a given value
maxValuesLimit number of returned values
indexThe index of the dimension for the recent search, with range [0, dimension())
Returns
Number of returned values

◆ size()

template<typename T >
size_t Ocean::KdTree< T >::size ( ) const
inline

Returns the number of tree nodes.

Returns
Tree size

Field Documentation

◆ dimension_

template<typename T >
const unsigned int Ocean::KdTree< T >::dimension_ = 0u
protected

Number of dimensions.

◆ root_

template<typename T >
std::unique_ptr<Node> Ocean::KdTree< T >::root_
protected

Root node of this tree.

◆ size_

template<typename T >
size_t Ocean::KdTree< T >::size_ = 0
protected

Number of nodes.


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