The class splits a binary space partitioning tree node according to the median distance to the vantage point. More...
Classes | |
struct | SplitInfo |
A struct that contains an information about the split. More... | |
Public Types | |
typedef MatType::elem_type | ElemType |
The matrix element type. More... | |
typedef BoundType::MetricType | MetricType |
The bounding shape type. More... | |
Static Public Member Functions | |
template < typename VecType > | |
static bool | AssignToLeftNode (const VecType &point, const SplitInfo &splitInfo) |
Indicates that a point should be assigned to the left subtree. More... | |
static size_t | PerformSplit (MatType &data, const size_t begin, const size_t count, const SplitInfo &splitInfo) |
Perform the split process according to the information about the split. More... | |
static size_t | PerformSplit (MatType &data, const size_t begin, const size_t count, const SplitInfo &splitInfo, std::vector< size_t > &oldFromNew) |
Perform the split process according to the information about the split and return the list of changed indices. More... | |
static bool | SplitNode (const BoundType &bound, MatType &data, const size_t begin, const size_t count, SplitInfo &splitInfo) |
Split the node according to the distance to a vantage point. More... | |
The class splits a binary space partitioning tree node according to the median distance to the vantage point.
Thus points that are closer to the vantage point belong to the left subtree and points that are farther from the vantage point belong to the right subtree.
Definition at line 32 of file vantage_point_split.hpp.
typedef MatType::elem_type ElemType |
The matrix element type.
Definition at line 36 of file vantage_point_split.hpp.
typedef BoundType::MetricType MetricType |
The bounding shape type.
Definition at line 38 of file vantage_point_split.hpp.
|
inlinestatic |
Indicates that a point should be assigned to the left subtree.
This method returns true if a point should be assigned to the left subtree, i.e., if the distance from the point to the vantage point is less then the median value. Otherwise it returns false.
point | The point that is being assigned. |
splitInfo | An information about the split. |
Definition at line 136 of file vantage_point_split.hpp.
References VantagePointSplit< BoundType, MatType, MaxNumSamples >::SplitInfo::metric, VantagePointSplit< BoundType, MatType, MaxNumSamples >::SplitInfo::mu, and VantagePointSplit< BoundType, MatType, MaxNumSamples >::SplitInfo::vantagePoint.
|
inlinestatic |
Perform the split process according to the information about the split.
This will order the dataset such that points that belong to the left subtree are on the left of the split column, and points from the right subtree are on the right side of the split column.
data | The dataset used by the binary space tree. |
begin | Index of the starting point in the dataset that belongs to this node. |
count | Number of points in this node. |
splitInfo | The information about the split. |
Definition at line 92 of file vantage_point_split.hpp.
|
inlinestatic |
Perform the split process according to the information about the split and return the list of changed indices.
This will order the dataset such that points that belong to the left subtree are on the left of the split column, and points from the right subtree are on the right side of the split column.
data | The dataset used by the binary space tree. |
begin | Index of the starting point in the dataset that belongs to this node. |
count | Number of points in this node. |
splitInfo | The information about the split. |
oldFromNew | Vector which will be filled with the old positions for each new point. |
Definition at line 116 of file vantage_point_split.hpp.
|
static |
Split the node according to the distance to a vantage point.
bound | The bound used for this node. |
data | The dataset used by the binary space tree. |
begin | Index of the starting point in the dataset that belongs to this node. |
count | Number of points in this node. |
splitInfo | An information about the split. This information contains the vantage point and the median distance to the vantage point. |
Referenced by VantagePointSplit< BoundType, MatType, MaxNumSamples >::SplitInfo::SplitInfo().