Update to 2.0.0 tree from current Fremantle build
[opencv] / 3rdparty / flann / algorithms / linear_index.h
1 /***********************************************************************
2  * Software License Agreement (BSD License)
3  *
4  * Copyright 2008-2009  Marius Muja (mariusm@cs.ubc.ca). All rights reserved.
5  * Copyright 2008-2009  David G. Lowe (lowe@cs.ubc.ca). All rights reserved.
6  *
7  * THE BSD LICENSE
8  *
9  * Redistribution and use in source and binary forms, with or without
10  * modification, are permitted provided that the following conditions
11  * are met:
12  *
13  * 1. Redistributions of source code must retain the above copyright
14  *    notice, this list of conditions and the following disclaimer.
15  * 2. Redistributions in binary form must reproduce the above copyright
16  *    notice, this list of conditions and the following disclaimer in the
17  *    documentation and/or other materials provided with the distribution.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
20  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
21  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
22  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
23  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
24  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
28  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29  *************************************************************************/
30
31 #ifndef LINEARSEARCH_H
32 #define LINEARSEARCH_H
33
34 #include "constants.h"
35 #include "nn_index.h"
36
37 namespace flann
38 {
39
40 class LinearIndex : public NNIndex {
41
42         const Matrix<float> dataset;
43
44 public:
45
46         LinearIndex(const Matrix<float>& inputData, const LinearIndexParams& params = LinearIndexParams() ) : dataset(inputData)
47         {
48         }
49
50     flann_algorithm_t getType() const
51     {
52         return LINEAR;
53     }
54
55
56         int size() const
57         {
58                 return dataset.rows;
59         }
60
61         int veclen() const
62         {
63                 return dataset.cols;
64         }
65
66
67         int usedMemory() const
68         {
69                 return 0;
70         }
71
72         void buildIndex()
73         {
74                 /* nothing to do here for linear search */
75         }
76
77     void saveIndex(FILE* /*stream*/)
78     {
79                 /* nothing to do here for linear search */
80     }
81
82
83     void loadIndex(FILE* /*stream*/)
84     {
85                 /* nothing to do here for linear search */
86     }
87
88         void findNeighbors(ResultSet& resultSet, const float* /*vec*/, const SearchParams& /*searchParams*/)
89         {
90                 for (int i=0;i<dataset.rows;++i) {
91                         resultSet.addPoint(dataset[i],i);
92                 }
93         }
94
95 //    Params estimateSearchParams(float precision, Matrix<float>* testset = NULL)
96 //    {
97 //        Params params;
98 //        return params;
99 //    }
100
101 };
102
103 }
104
105 #endif // LINEARSEARCH_H