Randomized kd-tree index. More...
#include <opencv2/flann/lsh_index.h>
Public Types | |
typedef Distance::ResultType | DistanceType |
typedef Distance::ElementType | ElementType |
Public Member Functions | |
LshIndex (const Matrix< ElementType > &input_data, const IndexParams ¶ms=LshIndexParams(), Distance d=Distance()) | |
Constructor. More... | |
LshIndex (const LshIndex &) | |
void | buildIndex () CV_OVERRIDE |
Builds the index. More... | |
void | findNeighbors (ResultSet< DistanceType > &result, const ElementType *vec, const SearchParams &) CV_OVERRIDE |
Find set of nearest neighbors to vec. More... | |
IndexParams | getParameters () const CV_OVERRIDE |
flann_algorithm_t | getType () const CV_OVERRIDE |
virtual void | knnSearch (const Matrix< ElementType > &queries, Matrix< int > &indices, Matrix< DistanceType > &dists, int knn, const SearchParams ¶ms) CV_OVERRIDE |
Perform k-nearest neighbor search. More... | |
void | loadIndex (FILE *stream) CV_OVERRIDE |
Loads the index from a stream. More... | |
LshIndex & | operator= (const LshIndex &) |
virtual int | radiusSearch (const Matrix< ElementType > &query, Matrix< int > &indices, Matrix< DistanceType > &dists, float radius, const SearchParams ¶ms) |
Perform radius search. More... | |
void | saveIndex (FILE *stream) CV_OVERRIDE |
Saves the index to a stream. More... | |
size_t | size () const CV_OVERRIDE |
Returns size of index. More... | |
int | usedMemory () const CV_OVERRIDE |
Computes the index memory usage Returns: memory used by the index. More... | |
size_t | veclen () const CV_OVERRIDE |
Returns the length of an index feature. More... | |
Randomized kd-tree index.
Contains the k-d trees and other information for indexing a set of points for nearest-neighbor matching.
typedef Distance::ResultType cvflann::LshIndex< Distance >::DistanceType |
typedef Distance::ElementType cvflann::LshIndex< Distance >::ElementType |
|
inline |
Constructor.
input_data | dataset with the input features |
params | parameters passed to the LSH algorithm |
d | the distance used |
cvflann::LshIndex< Distance >::LshIndex | ( | const LshIndex< Distance > & | ) |
|
inlinevirtual |
Builds the index.
Implements cvflann::NNIndex< Distance >.
References cvflann::lsh::LshTable< ElementType >::add().
|
inlinevirtual |
Find set of nearest neighbors to vec.
Their indices are stored inside the result object.
Params: result = the result object in which the indices of the nearest-neighbors are stored vec = the vector for which to search the nearest neighbors maxCheck = the maximum number of restarts (in a best-bin-first manner)
Implements cvflann::NNIndex< Distance >.
References cvflann::ResultSet< DistanceType >::addPoint(), and cv::max().
|
inlinevirtual |
Implements cvflann::NNIndex< Distance >.
|
inlinevirtual |
Implements cvflann::NNIndex< Distance >.
References cvflann::FLANN_INDEX_LSH.
|
inlinevirtual |
Perform k-nearest neighbor search.
[in] | queries | The query points for which to find the nearest neighbors |
[out] | indices | The indices of the nearest neighbors found |
[out] | dists | Distances to the nearest neighbors found |
[in] | knn | Number of nearest neighbors to return |
[in] | params | Search parameters |
Reimplemented from cvflann::NNIndex< Distance >.
References cvflann::KNNUniqueResultSet< DistanceType >::clear(), cvflann::UniqueResultSet< DistanceType >::copy(), cvflann::get_param(), cv::max(), and cvflann::UniqueResultSet< DistanceType >::sortAndCopy().
|
inlinevirtual |
Loads the index from a stream.
stream | The stream from which the index is loaded |
Implements cvflann::NNIndex< Distance >.
References cvflann::load_value().
LshIndex& cvflann::LshIndex< Distance >::operator= | ( | const LshIndex< Distance > & | ) |
|
inlinevirtualinherited |
Perform radius search.
[in] | query | The query point |
[out] | indices | The indinces of the neighbors found within the given radius |
[out] | dists | The distances to the nearest neighbors found |
[in] | radius | The radius used for search |
[in] | params | Search parameters |
Reimplemented in cvflann::Index< Distance >, cvflann::Index< cv::L2< ElementType > >, and cvflann::Index< cv::L1< ElementType > >.
|
inlinevirtual |
Saves the index to a stream.
stream | The stream to save the index to |
Implements cvflann::NNIndex< Distance >.
References cvflann::save_value().
|
inlinevirtual |
Returns size of index.
Implements cvflann::NNIndex< Distance >.
|
inlinevirtual |
Computes the index memory usage Returns: memory used by the index.
Implements cvflann::NNIndex< Distance >.
|
inlinevirtual |
Returns the length of an index feature.
Implements cvflann::NNIndex< Distance >.