ARX  1.0
The next-generation open source augmented reality toolkit.
Loading...
Searching...
No Matches
OCVFeatureDetector.h
Go to the documentation of this file.
1/*
2 * OCVFeatureDetector.h
3 * artoolkitX
4 *
5 * This file is part of artoolkitX.
6 *
7 * artoolkitX is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU Lesser General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * artoolkitX is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU Lesser General Public License for more details.
16 *
17 * You should have received a copy of the GNU Lesser General Public License
18 * along with artoolkitX. If not, see <http://www.gnu.org/licenses/>.
19 *
20 * As a special exception, the copyright holders of this library give you
21 * permission to link this library with independent modules to produce an
22 * executable, regardless of the license terms of these independent modules, and to
23 * copy and distribute the resulting executable under terms of your choice,
24 * provided that you also meet, for each linked independent module, the terms and
25 * conditions of the license of that module. An independent module is a module
26 * which is neither derived from nor based on this library. If you modify this
27 * library, you may extend this exception to your version of the library, but you
28 * are not obligated to do so. If you do not wish to do so, delete this exception
29 * statement from your version.
30 *
31 * Copyright 2018 Realmax, Inc.
32 * Copyright 2015 Daqri, LLC.
33 * Copyright 2010-2015 ARToolworks, Inc.
34 *
35 * Author(s): Philip Lamb, Daniel Bell.
36 *
37 */
38
39#ifndef OCVFEATUREDETECTOR_H
40#define OCVFEATUREDETECTOR_H
41#include <opencv2/features2d.hpp>
42#include <vector>
43#include <map>
44
46{
47public:
49
50 bool AddDescriptorsToDictionary(int id, cv::Mat descriptors);
51
52 std::vector<cv::KeyPoint> DetectFeatures(cv::Mat frame, cv::Mat mask);
53
54 cv::Mat CalcDescriptors(cv::Mat frame, std::vector<cv::KeyPoint> kp);
55
56 std::vector< std::vector<cv::DMatch> > MatchFeatures(cv::Mat first_desc, cv::Mat desc);
57
58 void SetFeatureDetector(int detectorType);
59
60private:
61 void CreateAkazeFeatureDetector();
62 void CreateORBFeatureDetector();
63 void CreateKazeFeatureDetector();
64 void CreateBriskFeatureDetector();
65
66 std::map<int, cv::Mat> _visualDictionary;
67 cv::Ptr<cv::DescriptorMatcher> _matcher;
68 cv::Ptr<cv::Feature2D> _featureDetector;
69 float _akaze_thresh;
70};
71
72#endif //OCVFEATUREDETECTOR
Definition: OCVFeatureDetector.h:46
bool AddDescriptorsToDictionary(int id, cv::Mat descriptors)
Definition: OCVFeatureDetector.cpp:89
OCVFeatureDetector()
Definition: OCVFeatureDetector.cpp:43
cv::Mat CalcDescriptors(cv::Mat frame, std::vector< cv::KeyPoint > kp)
Definition: OCVFeatureDetector.cpp:105
std::vector< cv::KeyPoint > DetectFeatures(cv::Mat frame, cv::Mat mask)
Definition: OCVFeatureDetector.cpp:98
std::vector< std::vector< cv::DMatch > > MatchFeatures(cv::Mat first_desc, cv::Mat desc)
Definition: OCVFeatureDetector.cpp:112
void SetFeatureDetector(int detectorType)
Definition: OCVFeatureDetector.cpp:47