The class K_neighbor_search<Traits, GeneralDistance, Splitter, SpatialTree> implements approximate k-nearest and k-furthest neighbor searching using standard search on a tree using a general distance class. The tree may be built with extended or unextended nodes.
#include <CGAL/K_neighbor_search.h>
Expects for the first template argument an implementation of the concept SearchTraits, for example CGAL::Cartesian_d<double>.
Expects for the second template argument a model of the concept GeneralDistance. If Traits is CGAL::Search_traits_adapter<Key,PointPropertyMap,BaseTraits> the default type is CGAL::Distance_for_point_adapter<Key,PointPropertyMap,CGAL::Euclidean_distance<Traits> >, and CGAL::Euclidean_distance<Traits> otherwise.
Expects for fourth template argument an implementation of the concept SpatialTree. The default type is CGAL::Kd_tree<Traits, Splitter, CGAL::Tag_false>. The template argument CGAL::Tag_false makes that the tree is built with unextended nodes.
|
| Point type. |
|
| Number type. |
|
| Distance type. |
|
| Pair of point and transformed distance. |
| |
Bidirectional iterator with value type Point_with_distance
for enumerating approximate neighbors.
|
|
| Query item type. |
|
| The tree type. |
| |||||
Constructor for searching approximately k neighbors of the query item q
in the points stored in tree using
distance class d and approximation factor eps. sorted indicates
if the computed sequence of k-nearest neighbors needs to be sorted.
|
|
| Returns an iterator to the approximate neighbors. |
|
| Past-the-end iterator. |
|
| Inserts statistics of the search process into the output stream s. |
CGAL::Orthogonal_k_neighbor_search<Traits, OrthogonalDistance, Splitter, SpatialTree>.