fixed memory leak in flann index
This commit is contained in:
parent
5603617b7c
commit
32d7c1950a
@ -318,12 +318,14 @@ buildIndex_(void*& index, const Mat& wholedata, const Mat& data, const IndexPara
|
|||||||
|
|
||||||
::cvflann::Matrix<ElementType> dataset((ElementType*)data.data, data.rows, data.cols);
|
::cvflann::Matrix<ElementType> dataset((ElementType*)data.data, data.rows, data.cols);
|
||||||
|
|
||||||
IndexType* _index = NULL;
|
// currently, additional index support is the lsh algorithm only.
|
||||||
if( !index || getParam<flann_algorithm_t>(params, "algorithm", FLANN_INDEX_LINEAR) != FLANN_INDEX_LSH) // currently, additional index support is the lsh algorithm only.
|
if( !index || getParam<flann_algorithm_t>(params, "algorithm", FLANN_INDEX_LINEAR) != FLANN_INDEX_LSH)
|
||||||
{
|
{
|
||||||
_index = new IndexType(dataset, get_params(params), dist);
|
Ptr<IndexType> _index = makePtr<IndexType>(dataset, get_params(params), dist);
|
||||||
_index->buildIndex();
|
_index->buildIndex();
|
||||||
index = _index;
|
index = _index;
|
||||||
|
// HACK to prevent object destruction
|
||||||
|
_index.obj = NULL;
|
||||||
}
|
}
|
||||||
else // build additional lsh index
|
else // build additional lsh index
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user