2010-05-12 01:44:00 +08:00
|
|
|
/*M///////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
|
|
|
|
//
|
|
|
|
// By downloading, copying, installing or using the software you agree to this license.
|
|
|
|
// If you do not agree to this license, do not download, install,
|
|
|
|
// copy or use the software.
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// License Agreement
|
|
|
|
// For Open Source Computer Vision Library
|
|
|
|
//
|
|
|
|
// Copyright (C) 2000-2008, Intel Corporation, all rights reserved.
|
|
|
|
// Copyright (C) 2009, Willow Garage Inc., all rights reserved.
|
|
|
|
// Third party copyrights are property of their respective owners.
|
|
|
|
//
|
|
|
|
// Redistribution and use in source and binary forms, with or without modification,
|
|
|
|
// are permitted provided that the following conditions are met:
|
|
|
|
//
|
|
|
|
// * Redistribution's of source code must retain the above copyright notice,
|
|
|
|
// this list of conditions and the following disclaimer.
|
|
|
|
//
|
|
|
|
// * Redistribution's in binary form must reproduce the above copyright notice,
|
|
|
|
// this list of conditions and the following disclaimer in the documentation
|
|
|
|
// and/or other materials provided with the distribution.
|
|
|
|
//
|
|
|
|
// * The name of the copyright holders may not be used to endorse or promote products
|
|
|
|
// derived from this software without specific prior written permission.
|
|
|
|
//
|
|
|
|
// This software is provided by the copyright holders and contributors "as is" and
|
|
|
|
// any express or implied warranties, including, but not limited to, the implied
|
|
|
|
// warranties of merchantability and fitness for a particular purpose are disclaimed.
|
|
|
|
// In no event shall the Intel Corporation or contributors be liable for any direct,
|
|
|
|
// indirect, incidental, special, exemplary, or consequential damages
|
|
|
|
// (including, but not limited to, procurement of substitute goods or services;
|
|
|
|
// loss of use, data, or profits; or business interruption) however caused
|
|
|
|
// and on any theory of liability, whether in contract, strict liability,
|
|
|
|
// or tort (including negligence or otherwise) arising in any way out of
|
|
|
|
// the use of this software, even if advised of the possibility of such damage.
|
|
|
|
//
|
|
|
|
//M*/
|
|
|
|
|
2016-09-30 17:46:29 +08:00
|
|
|
#ifndef OPENCV_FEATURES_2D_HPP
|
|
|
|
#define OPENCV_FEATURES_2D_HPP
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2017-10-13 16:01:48 +08:00
|
|
|
#include "opencv2/opencv_modules.hpp"
|
2013-03-29 16:59:55 +08:00
|
|
|
#include "opencv2/core.hpp"
|
2017-10-13 16:01:48 +08:00
|
|
|
|
|
|
|
#ifdef HAVE_OPENCV_FLANN
|
2013-04-08 04:24:39 +08:00
|
|
|
#include "opencv2/flann/miniflann.hpp"
|
2017-10-13 16:01:48 +08:00
|
|
|
#endif
|
2010-05-12 15:33:21 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/**
|
|
|
|
@defgroup features2d 2D Features Framework
|
|
|
|
@{
|
|
|
|
@defgroup features2d_main Feature Detection and Description
|
|
|
|
@defgroup features2d_match Descriptor Matchers
|
|
|
|
|
2024-03-06 13:50:31 +08:00
|
|
|
Matchers of keypoint descriptors in OpenCV have wrappers with a common interface that enables
|
|
|
|
you to easily switch between different algorithms solving the same problem. This section is
|
|
|
|
devoted to matching descriptors that are represented as vectors in a multidimensional space.
|
|
|
|
All objects that implement vector descriptor matchers inherit the DescriptorMatcher interface.
|
2014-11-19 21:13:41 +08:00
|
|
|
|
|
|
|
@defgroup features2d_draw Drawing Function of Keypoints and Matches
|
|
|
|
|
2019-08-31 06:47:04 +08:00
|
|
|
@defgroup feature2d_hal Hardware Acceleration Layer
|
|
|
|
@{
|
|
|
|
@defgroup features2d_hal_interface Interface
|
|
|
|
@}
|
2014-11-19 21:13:41 +08:00
|
|
|
@}
|
|
|
|
*/
|
|
|
|
|
2010-05-26 20:34:48 +08:00
|
|
|
namespace cv
|
|
|
|
{
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2021-04-03 20:11:38 +08:00
|
|
|
//! @addtogroup features2d_main
|
2014-11-19 21:13:41 +08:00
|
|
|
//! @{
|
|
|
|
|
2013-03-26 18:58:09 +08:00
|
|
|
// //! writes vector of keypoints to the file storage
|
|
|
|
// CV_EXPORTS void write(FileStorage& fs, const String& name, const std::vector<KeyPoint>& keypoints);
|
|
|
|
// //! reads vector of keypoints from the specified file storage node
|
|
|
|
// CV_EXPORTS void read(const FileNode& node, CV_OUT std::vector<KeyPoint>& keypoints);
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief A class filters a vector of keypoints.
|
|
|
|
|
|
|
|
Because now it is difficult to provide a convenient interface for all usage scenarios of the
|
|
|
|
keypoints filter class, it has only several needed by now static methods.
|
2011-05-02 01:38:52 +08:00
|
|
|
*/
|
|
|
|
class CV_EXPORTS KeyPointsFilter
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
KeyPointsFilter(){}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Remove keypoints within borderPixels of an image edge.
|
|
|
|
*/
|
2013-02-25 00:14:01 +08:00
|
|
|
static void runByImageBorder( std::vector<KeyPoint>& keypoints, Size imageSize, int borderSize );
|
2011-05-02 01:38:52 +08:00
|
|
|
/*
|
|
|
|
* Remove keypoints of sizes out of range.
|
|
|
|
*/
|
2013-02-25 00:14:01 +08:00
|
|
|
static void runByKeypointSize( std::vector<KeyPoint>& keypoints, float minSize,
|
2012-03-15 22:36:01 +08:00
|
|
|
float maxSize=FLT_MAX );
|
2011-05-05 18:10:46 +08:00
|
|
|
/*
|
|
|
|
* Remove keypoints from some image by mask for pixels of this image.
|
|
|
|
*/
|
2013-02-25 00:14:01 +08:00
|
|
|
static void runByPixelsMask( std::vector<KeyPoint>& keypoints, const Mat& mask );
|
2022-10-08 00:07:51 +08:00
|
|
|
/*
|
|
|
|
* Remove objects from some image and a vector of points by mask for pixels of this image
|
|
|
|
*/
|
|
|
|
static void runByPixelsMask2VectorPoint(std::vector<KeyPoint> &keypoints, std::vector<std::vector<Point> > &removeFrom, const Mat &mask);
|
2011-06-01 02:18:02 +08:00
|
|
|
/*
|
|
|
|
* Remove duplicated keypoints.
|
|
|
|
*/
|
2013-02-25 00:14:01 +08:00
|
|
|
static void removeDuplicated( std::vector<KeyPoint>& keypoints );
|
2017-05-29 16:59:20 +08:00
|
|
|
/*
|
|
|
|
* Remove duplicated keypoints and sort the remaining keypoints
|
|
|
|
*/
|
|
|
|
static void removeDuplicatedSorted( std::vector<KeyPoint>& keypoints );
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2012-03-15 22:36:01 +08:00
|
|
|
/*
|
|
|
|
* Retain the specified number of the best keypoints (according to the response)
|
2011-05-21 06:25:53 +08:00
|
|
|
*/
|
2013-02-25 00:14:01 +08:00
|
|
|
static void retainBest( std::vector<KeyPoint>& keypoints, int npoints );
|
2010-05-12 01:44:00 +08:00
|
|
|
};
|
|
|
|
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2012-03-15 22:36:01 +08:00
|
|
|
/************************************ Base Classes ************************************/
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Abstract base class for 2D image feature detectors and descriptor extractors
|
|
|
|
*/
|
2018-09-27 00:11:40 +08:00
|
|
|
class CV_EXPORTS_W Feature2D : public Algorithm
|
2010-05-12 01:44:00 +08:00
|
|
|
{
|
|
|
|
public:
|
2014-10-14 03:01:45 +08:00
|
|
|
virtual ~Feature2D();
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Detects keypoints in an image (first variant) or image set (second variant).
|
|
|
|
|
|
|
|
@param image Image.
|
|
|
|
@param keypoints The detected keypoints. In the second variant of the method keypoints[i] is a set
|
|
|
|
of keypoints detected in images[i] .
|
|
|
|
@param mask Mask specifying where to look for keypoints (optional). It must be a 8-bit integer
|
|
|
|
matrix with non-zero values in the region of interest.
|
2010-05-12 01:44:00 +08:00
|
|
|
*/
|
2014-10-14 03:01:45 +08:00
|
|
|
CV_WRAP virtual void detect( InputArray image,
|
|
|
|
CV_OUT std::vector<KeyPoint>& keypoints,
|
|
|
|
InputArray mask=noArray() );
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @overload
|
|
|
|
@param images Image set.
|
|
|
|
@param keypoints The detected keypoints. In the second variant of the method keypoints[i] is a set
|
|
|
|
of keypoints detected in images[i] .
|
|
|
|
@param masks Masks for each input image specifying where to look for keypoints (optional).
|
|
|
|
masks[i] is a mask for images[i].
|
|
|
|
*/
|
2016-10-16 17:33:12 +08:00
|
|
|
CV_WRAP virtual void detect( InputArrayOfArrays images,
|
|
|
|
CV_OUT std::vector<std::vector<KeyPoint> >& keypoints,
|
2014-10-16 02:49:17 +08:00
|
|
|
InputArrayOfArrays masks=noArray() );
|
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Computes the descriptors for a set of keypoints detected in an image (first variant) or image set
|
|
|
|
(second variant).
|
|
|
|
|
|
|
|
@param image Image.
|
|
|
|
@param keypoints Input collection of keypoints. Keypoints for which a descriptor cannot be
|
|
|
|
computed are removed. Sometimes new keypoints can be added, for example: SIFT duplicates keypoint
|
|
|
|
with several dominant orientations (for each orientation).
|
|
|
|
@param descriptors Computed descriptors. In the second variant of the method descriptors[i] are
|
|
|
|
descriptors computed for a keypoints[i]. Row j is the keypoints (or keypoints[i]) is the
|
|
|
|
descriptor for keypoint j-th keypoint.
|
2012-03-15 22:36:01 +08:00
|
|
|
*/
|
2014-10-14 03:01:45 +08:00
|
|
|
CV_WRAP virtual void compute( InputArray image,
|
|
|
|
CV_OUT CV_IN_OUT std::vector<KeyPoint>& keypoints,
|
|
|
|
OutputArray descriptors );
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @overload
|
|
|
|
|
|
|
|
@param images Image set.
|
|
|
|
@param keypoints Input collection of keypoints. Keypoints for which a descriptor cannot be
|
|
|
|
computed are removed. Sometimes new keypoints can be added, for example: SIFT duplicates keypoint
|
|
|
|
with several dominant orientations (for each orientation).
|
|
|
|
@param descriptors Computed descriptors. In the second variant of the method descriptors[i] are
|
|
|
|
descriptors computed for a keypoints[i]. Row j is the keypoints (or keypoints[i]) is the
|
|
|
|
descriptor for keypoint j-th keypoint.
|
|
|
|
*/
|
2016-10-16 17:33:12 +08:00
|
|
|
CV_WRAP virtual void compute( InputArrayOfArrays images,
|
|
|
|
CV_OUT CV_IN_OUT std::vector<std::vector<KeyPoint> >& keypoints,
|
2014-10-16 02:49:17 +08:00
|
|
|
OutputArrayOfArrays descriptors );
|
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** Detects keypoints and computes the descriptors */
|
2014-10-14 03:01:45 +08:00
|
|
|
CV_WRAP virtual void detectAndCompute( InputArray image, InputArray mask,
|
|
|
|
CV_OUT std::vector<KeyPoint>& keypoints,
|
|
|
|
OutputArray descriptors,
|
|
|
|
bool useProvidedKeypoints=false );
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2014-10-14 03:01:45 +08:00
|
|
|
CV_WRAP virtual int descriptorSize() const;
|
|
|
|
CV_WRAP virtual int descriptorType() const;
|
|
|
|
CV_WRAP virtual int defaultNorm() const;
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2016-10-16 17:33:12 +08:00
|
|
|
CV_WRAP void write( const String& fileName ) const;
|
|
|
|
|
|
|
|
CV_WRAP void read( const String& fileName );
|
|
|
|
|
2018-03-15 21:16:54 +08:00
|
|
|
virtual void write( FileStorage&) const CV_OVERRIDE;
|
2016-10-16 17:33:12 +08:00
|
|
|
|
2017-07-27 20:34:32 +08:00
|
|
|
// see corresponding cv::Algorithm method
|
2018-03-15 21:16:54 +08:00
|
|
|
CV_WRAP virtual void read( const FileNode&) CV_OVERRIDE;
|
2016-10-16 17:33:12 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
//! Return true if detector object is empty
|
2018-03-15 21:16:54 +08:00
|
|
|
CV_WRAP virtual bool empty() const CV_OVERRIDE;
|
|
|
|
CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
|
2017-07-27 20:34:32 +08:00
|
|
|
|
|
|
|
// see corresponding cv::Algorithm method
|
2022-12-09 07:37:39 +08:00
|
|
|
CV_WRAP inline void write(FileStorage& fs, const String& name) const { Algorithm::write(fs, name); }
|
2010-05-12 01:44:00 +08:00
|
|
|
};
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** Feature detectors in OpenCV have wrappers with a common interface that enables you to easily switch
|
|
|
|
between different algorithms solving the same problem. All objects that implement keypoint detectors
|
|
|
|
inherit the FeatureDetector interface. */
|
2014-10-14 03:01:45 +08:00
|
|
|
typedef Feature2D FeatureDetector;
|
2014-11-19 21:13:41 +08:00
|
|
|
|
|
|
|
/** Extractors of keypoint descriptors in OpenCV have wrappers with a common interface that enables you
|
|
|
|
to easily switch between different algorithms solving the same problem. This section is devoted to
|
|
|
|
computing descriptors represented as vectors in a multidimensional space. All objects that implement
|
|
|
|
the vector descriptor extractors inherit the DescriptorExtractor interface.
|
|
|
|
*/
|
2014-10-14 03:01:45 +08:00
|
|
|
typedef Feature2D DescriptorExtractor;
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2020-04-21 14:58:21 +08:00
|
|
|
|
2020-08-03 22:11:55 +08:00
|
|
|
/** @brief Class for implementing the wrapper which makes detectors and extractors to be affine invariant,
|
|
|
|
described as ASIFT in @cite YM11 .
|
|
|
|
*/
|
|
|
|
class CV_EXPORTS_W AffineFeature : public Feature2D
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
@param backend The detector/extractor you want to use as backend.
|
|
|
|
@param maxTilt The highest power index of tilt factor. 5 is used in the paper as tilt sampling range n.
|
|
|
|
@param minTilt The lowest power index of tilt factor. 0 is used in the paper.
|
|
|
|
@param tiltStep Tilt sampling step \f$\delta_t\f$ in Algorithm 1 in the paper.
|
|
|
|
@param rotateStepBase Rotation sampling step factor b in Algorithm 1 in the paper.
|
|
|
|
*/
|
|
|
|
CV_WRAP static Ptr<AffineFeature> create(const Ptr<Feature2D>& backend,
|
|
|
|
int maxTilt = 5, int minTilt = 0, float tiltStep = 1.4142135623730951f, float rotateStepBase = 72);
|
|
|
|
|
|
|
|
CV_WRAP virtual void setViewParams(const std::vector<float>& tilts, const std::vector<float>& rolls) = 0;
|
|
|
|
CV_WRAP virtual void getViewParams(std::vector<float>& tilts, std::vector<float>& rolls) const = 0;
|
|
|
|
CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef AffineFeature AffineFeatureDetector;
|
|
|
|
typedef AffineFeature AffineDescriptorExtractor;
|
|
|
|
|
|
|
|
|
2020-04-21 14:58:21 +08:00
|
|
|
/** @brief Class for extracting keypoints and computing descriptors using the Scale Invariant Feature Transform
|
|
|
|
(SIFT) algorithm by D. Lowe @cite Lowe04 .
|
|
|
|
*/
|
|
|
|
class CV_EXPORTS_W SIFT : public Feature2D
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
@param nfeatures The number of best features to retain. The features are ranked by their scores
|
|
|
|
(measured in SIFT algorithm as the local contrast)
|
|
|
|
|
|
|
|
@param nOctaveLayers The number of layers in each octave. 3 is the value used in D. Lowe paper. The
|
|
|
|
number of octaves is computed automatically from the image resolution.
|
|
|
|
|
|
|
|
@param contrastThreshold The contrast threshold used to filter out weak features in semi-uniform
|
|
|
|
(low-contrast) regions. The larger the threshold, the less features are produced by the detector.
|
|
|
|
|
2020-06-25 19:34:31 +08:00
|
|
|
@note The contrast threshold will be divided by nOctaveLayers when the filtering is applied. When
|
|
|
|
nOctaveLayers is set to default and if you want to use the value used in D. Lowe paper, 0.03, set
|
|
|
|
this argument to 0.09.
|
|
|
|
|
2020-04-21 14:58:21 +08:00
|
|
|
@param edgeThreshold The threshold used to filter out edge-like features. Note that the its meaning
|
|
|
|
is different from the contrastThreshold, i.e. the larger the edgeThreshold, the less features are
|
|
|
|
filtered out (more features are retained).
|
|
|
|
|
|
|
|
@param sigma The sigma of the Gaussian applied to the input image at the octave \#0. If your image
|
|
|
|
is captured with a weak camera with soft lenses, you might want to reduce the number.
|
2023-02-17 15:35:54 +08:00
|
|
|
|
|
|
|
@param enable_precise_upscale Whether to enable precise upscaling in the scale pyramid, which maps
|
|
|
|
index \f$\texttt{x}\f$ to \f$\texttt{2x}\f$. This prevents localization bias. The option
|
2023-02-17 23:57:38 +08:00
|
|
|
is disabled by default.
|
2020-04-21 14:58:21 +08:00
|
|
|
*/
|
|
|
|
CV_WRAP static Ptr<SIFT> create(int nfeatures = 0, int nOctaveLayers = 3,
|
|
|
|
double contrastThreshold = 0.04, double edgeThreshold = 10,
|
2023-02-17 23:57:38 +08:00
|
|
|
double sigma = 1.6, bool enable_precise_upscale = false);
|
2020-06-25 19:34:31 +08:00
|
|
|
|
2020-08-17 18:28:44 +08:00
|
|
|
/** @brief Create SIFT with specified descriptorType.
|
|
|
|
@param nfeatures The number of best features to retain. The features are ranked by their scores
|
|
|
|
(measured in SIFT algorithm as the local contrast)
|
|
|
|
|
|
|
|
@param nOctaveLayers The number of layers in each octave. 3 is the value used in D. Lowe paper. The
|
|
|
|
number of octaves is computed automatically from the image resolution.
|
|
|
|
|
|
|
|
@param contrastThreshold The contrast threshold used to filter out weak features in semi-uniform
|
|
|
|
(low-contrast) regions. The larger the threshold, the less features are produced by the detector.
|
|
|
|
|
|
|
|
@note The contrast threshold will be divided by nOctaveLayers when the filtering is applied. When
|
|
|
|
nOctaveLayers is set to default and if you want to use the value used in D. Lowe paper, 0.03, set
|
|
|
|
this argument to 0.09.
|
|
|
|
|
|
|
|
@param edgeThreshold The threshold used to filter out edge-like features. Note that the its meaning
|
|
|
|
is different from the contrastThreshold, i.e. the larger the edgeThreshold, the less features are
|
|
|
|
filtered out (more features are retained).
|
|
|
|
|
|
|
|
@param sigma The sigma of the Gaussian applied to the input image at the octave \#0. If your image
|
|
|
|
is captured with a weak camera with soft lenses, you might want to reduce the number.
|
|
|
|
|
|
|
|
@param descriptorType The type of descriptors. Only CV_32F and CV_8U are supported.
|
2023-02-17 15:35:54 +08:00
|
|
|
|
|
|
|
@param enable_precise_upscale Whether to enable precise upscaling in the scale pyramid, which maps
|
|
|
|
index \f$\texttt{x}\f$ to \f$\texttt{2x}\f$. This prevents localization bias. The option
|
2023-02-18 05:07:45 +08:00
|
|
|
is disabled by default.
|
2020-08-17 18:28:44 +08:00
|
|
|
*/
|
|
|
|
CV_WRAP static Ptr<SIFT> create(int nfeatures, int nOctaveLayers,
|
|
|
|
double contrastThreshold, double edgeThreshold,
|
2023-02-18 05:07:45 +08:00
|
|
|
double sigma, int descriptorType, bool enable_precise_upscale = false);
|
2020-08-17 18:28:44 +08:00
|
|
|
|
2020-06-25 19:34:31 +08:00
|
|
|
CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
|
2022-12-21 21:03:00 +08:00
|
|
|
|
|
|
|
CV_WRAP virtual void setNFeatures(int maxFeatures) = 0;
|
|
|
|
CV_WRAP virtual int getNFeatures() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setNOctaveLayers(int nOctaveLayers) = 0;
|
|
|
|
CV_WRAP virtual int getNOctaveLayers() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setContrastThreshold(double contrastThreshold) = 0;
|
|
|
|
CV_WRAP virtual double getContrastThreshold() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setEdgeThreshold(double edgeThreshold) = 0;
|
|
|
|
CV_WRAP virtual double getEdgeThreshold() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setSigma(double sigma) = 0;
|
|
|
|
CV_WRAP virtual double getSigma() const = 0;
|
2020-04-21 14:58:21 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
typedef SIFT SiftFeatureDetector;
|
|
|
|
typedef SIFT SiftDescriptorExtractor;
|
|
|
|
|
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Class implementing the ORB (*oriented BRIEF*) keypoint detector and descriptor extractor
|
|
|
|
|
2014-11-26 19:21:08 +08:00
|
|
|
described in @cite RRKB11 . The algorithm uses FAST in pyramids to detect stable keypoints, selects
|
2014-11-19 21:13:41 +08:00
|
|
|
the strongest features using FAST or Harris response, finds their orientation using first-order
|
|
|
|
moments and computes the descriptors using BRIEF (where the coordinates of random point pairs (or
|
|
|
|
k-tuples) are rotated according to the measured orientation).
|
|
|
|
*/
|
2012-07-06 23:41:57 +08:00
|
|
|
class CV_EXPORTS_W ORB : public Feature2D
|
2012-03-15 22:36:01 +08:00
|
|
|
{
|
|
|
|
public:
|
2018-09-21 23:12:35 +08:00
|
|
|
enum ScoreType { HARRIS_SCORE=0, FAST_SCORE=1 };
|
|
|
|
static const int kBytes = 32;
|
2014-10-19 00:44:26 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief The ORB constructor
|
|
|
|
|
|
|
|
@param nfeatures The maximum number of features to retain.
|
|
|
|
@param scaleFactor Pyramid decimation ratio, greater than 1. scaleFactor==2 means the classical
|
|
|
|
pyramid, where each next level has 4x less pixels than the previous, but such a big scale factor
|
|
|
|
will degrade feature matching scores dramatically. On the other hand, too close to 1 scale factor
|
|
|
|
will mean that to cover certain scale range you will need more pyramid levels and so the speed
|
|
|
|
will suffer.
|
|
|
|
@param nlevels The number of pyramid levels. The smallest level will have linear size equal to
|
2018-01-25 20:23:59 +08:00
|
|
|
input_image_linear_size/pow(scaleFactor, nlevels - firstLevel).
|
2014-11-19 21:13:41 +08:00
|
|
|
@param edgeThreshold This is size of the border where the features are not detected. It should
|
|
|
|
roughly match the patchSize parameter.
|
2018-02-01 21:58:35 +08:00
|
|
|
@param firstLevel The level of pyramid to put source image to. Previous layers are filled
|
2018-01-25 20:23:59 +08:00
|
|
|
with upscaled source image.
|
2014-11-21 16:28:14 +08:00
|
|
|
@param WTA_K The number of points that produce each element of the oriented BRIEF descriptor. The
|
2014-11-19 21:13:41 +08:00
|
|
|
default value 2 means the BRIEF where we take a random point pair and compare their brightnesses,
|
|
|
|
so we get 0/1 response. Other possible values are 3 and 4. For example, 3 means that we take 3
|
|
|
|
random points (of course, those point coordinates are random, but they are generated from the
|
|
|
|
pre-defined seed, so each element of BRIEF descriptor is computed deterministically from the pixel
|
|
|
|
rectangle), find point of maximum brightness and output index of the winner (0, 1 or 2). Such
|
|
|
|
output will occupy 2 bits, and therefore it will need a special variant of Hamming distance,
|
2014-11-21 16:28:14 +08:00
|
|
|
denoted as NORM_HAMMING2 (2 bits per bin). When WTA_K=4, we take 4 random points to compute each
|
2014-11-19 21:13:41 +08:00
|
|
|
bin (that will also occupy 2 bits with possible values 0, 1, 2 or 3).
|
2014-11-21 16:28:14 +08:00
|
|
|
@param scoreType The default HARRIS_SCORE means that Harris algorithm is used to rank features
|
2014-11-19 21:13:41 +08:00
|
|
|
(the score is written to KeyPoint::score and is used to retain best nfeatures features);
|
2014-11-21 16:28:14 +08:00
|
|
|
FAST_SCORE is alternative value of the parameter that produces slightly less stable keypoints,
|
2014-11-19 21:13:41 +08:00
|
|
|
but it is a little faster to compute.
|
|
|
|
@param patchSize size of the patch used by the oriented BRIEF descriptor. Of course, on smaller
|
|
|
|
pyramid layers the perceived image area covered by a feature will be larger.
|
2019-06-05 18:44:03 +08:00
|
|
|
@param fastThreshold the fast threshold
|
2014-11-19 21:13:41 +08:00
|
|
|
*/
|
2014-10-19 00:44:26 +08:00
|
|
|
CV_WRAP static Ptr<ORB> create(int nfeatures=500, float scaleFactor=1.2f, int nlevels=8, int edgeThreshold=31,
|
2018-09-21 23:12:35 +08:00
|
|
|
int firstLevel=0, int WTA_K=2, ORB::ScoreType scoreType=ORB::HARRIS_SCORE, int patchSize=31, int fastThreshold=20);
|
2014-10-19 00:44:26 +08:00
|
|
|
|
|
|
|
CV_WRAP virtual void setMaxFeatures(int maxFeatures) = 0;
|
|
|
|
CV_WRAP virtual int getMaxFeatures() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setScaleFactor(double scaleFactor) = 0;
|
|
|
|
CV_WRAP virtual double getScaleFactor() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setNLevels(int nlevels) = 0;
|
|
|
|
CV_WRAP virtual int getNLevels() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setEdgeThreshold(int edgeThreshold) = 0;
|
|
|
|
CV_WRAP virtual int getEdgeThreshold() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setFirstLevel(int firstLevel) = 0;
|
|
|
|
CV_WRAP virtual int getFirstLevel() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setWTA_K(int wta_k) = 0;
|
|
|
|
CV_WRAP virtual int getWTA_K() const = 0;
|
|
|
|
|
2018-09-21 23:12:35 +08:00
|
|
|
CV_WRAP virtual void setScoreType(ORB::ScoreType scoreType) = 0;
|
|
|
|
CV_WRAP virtual ORB::ScoreType getScoreType() const = 0;
|
2010-06-04 13:30:09 +08:00
|
|
|
|
2014-10-19 00:44:26 +08:00
|
|
|
CV_WRAP virtual void setPatchSize(int patchSize) = 0;
|
|
|
|
CV_WRAP virtual int getPatchSize() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setFastThreshold(int fastThreshold) = 0;
|
|
|
|
CV_WRAP virtual int getFastThreshold() const = 0;
|
2018-03-15 21:16:54 +08:00
|
|
|
CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
|
2010-05-12 01:44:00 +08:00
|
|
|
};
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2024-07-31 21:11:00 +08:00
|
|
|
/** @example samples/python/snippets/mser.py
|
|
|
|
An example using Maximally stable extremal region(MSER) extractor in python
|
|
|
|
*/
|
|
|
|
|
2015-11-05 22:17:18 +08:00
|
|
|
/** @brief Maximally stable extremal region extractor
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2015-11-05 22:17:18 +08:00
|
|
|
The class encapsulates all the parameters of the %MSER extraction algorithm (see [wiki
|
|
|
|
article](http://en.wikipedia.org/wiki/Maximally_stable_extremal_regions)).
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2015-11-05 22:17:18 +08:00
|
|
|
- there are two different implementation of %MSER: one for grey image, one for color image
|
|
|
|
|
|
|
|
- the grey image algorithm is taken from: @cite nister2008linear ; the paper claims to be faster
|
|
|
|
than union-find method; it actually get 1.5~2m/s on my centrino L7200 1.2GHz laptop.
|
|
|
|
|
|
|
|
- the color image algorithm is taken from: @cite forssen2007maximally ; it should be much slower
|
2021-03-19 05:30:12 +08:00
|
|
|
than grey image method ( 3~4 times )
|
2015-11-05 22:17:18 +08:00
|
|
|
|
2015-12-16 21:36:03 +08:00
|
|
|
- (Python) A complete example showing the use of the %MSER detector can be found at samples/python/mser.py
|
2015-11-05 22:17:18 +08:00
|
|
|
*/
|
2014-10-14 03:01:45 +08:00
|
|
|
class CV_EXPORTS_W MSER : public Feature2D
|
2010-05-12 01:44:00 +08:00
|
|
|
{
|
|
|
|
public:
|
2019-12-26 19:45:03 +08:00
|
|
|
/** @brief Full constructor for %MSER detector
|
2015-11-05 22:17:18 +08:00
|
|
|
|
2021-04-03 20:11:38 +08:00
|
|
|
@param delta it compares \f$(size_{i}-size_{i-delta})/size_{i-delta}\f$
|
|
|
|
@param min_area prune the area which smaller than minArea
|
|
|
|
@param max_area prune the area which bigger than maxArea
|
|
|
|
@param max_variation prune the area have similar size to its children
|
|
|
|
@param min_diversity for color image, trace back to cut off mser with diversity less than min_diversity
|
|
|
|
@param max_evolution for color image, the evolution steps
|
|
|
|
@param area_threshold for color image, the area threshold to cause re-initialize
|
|
|
|
@param min_margin for color image, ignore too small margin
|
|
|
|
@param edge_blur_size for color image, the aperture size for edge blur
|
2015-11-05 22:17:18 +08:00
|
|
|
*/
|
2021-04-03 20:11:38 +08:00
|
|
|
CV_WRAP static Ptr<MSER> create( int delta=5, int min_area=60, int max_area=14400,
|
|
|
|
double max_variation=0.25, double min_diversity=.2,
|
|
|
|
int max_evolution=200, double area_threshold=1.01,
|
|
|
|
double min_margin=0.003, int edge_blur_size=5 );
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2015-11-05 22:17:18 +08:00
|
|
|
/** @brief Detect %MSER regions
|
|
|
|
|
2016-08-12 01:20:36 +08:00
|
|
|
@param image input image (8UC1, 8UC3 or 8UC4, must be greater or equal than 3x3)
|
2015-11-05 22:17:18 +08:00
|
|
|
@param msers resulting list of point sets
|
|
|
|
@param bboxes resulting bounding boxes
|
|
|
|
*/
|
2014-10-17 01:59:38 +08:00
|
|
|
CV_WRAP virtual void detectRegions( InputArray image,
|
2015-01-01 17:30:44 +08:00
|
|
|
CV_OUT std::vector<std::vector<Point> >& msers,
|
2016-02-12 20:55:06 +08:00
|
|
|
CV_OUT std::vector<Rect>& bboxes ) = 0;
|
2014-10-19 00:44:26 +08:00
|
|
|
|
|
|
|
CV_WRAP virtual void setDelta(int delta) = 0;
|
|
|
|
CV_WRAP virtual int getDelta() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setMinArea(int minArea) = 0;
|
|
|
|
CV_WRAP virtual int getMinArea() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setMaxArea(int maxArea) = 0;
|
|
|
|
CV_WRAP virtual int getMaxArea() const = 0;
|
|
|
|
|
2022-12-21 21:03:00 +08:00
|
|
|
CV_WRAP virtual void setMaxVariation(double maxVariation) = 0;
|
|
|
|
CV_WRAP virtual double getMaxVariation() const = 0;
|
|
|
|
|
2021-05-28 07:16:24 +08:00
|
|
|
CV_WRAP virtual void setMinDiversity(double minDiversity) = 0;
|
|
|
|
CV_WRAP virtual double getMinDiversity() const = 0;
|
|
|
|
|
2022-12-21 21:03:00 +08:00
|
|
|
CV_WRAP virtual void setMaxEvolution(int maxEvolution) = 0;
|
|
|
|
CV_WRAP virtual int getMaxEvolution() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setAreaThreshold(double areaThreshold) = 0;
|
|
|
|
CV_WRAP virtual double getAreaThreshold() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setMinMargin(double min_margin) = 0;
|
|
|
|
CV_WRAP virtual double getMinMargin() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setEdgeBlurSize(int edge_blur_size) = 0;
|
|
|
|
CV_WRAP virtual int getEdgeBlurSize() const = 0;
|
|
|
|
|
2014-10-19 00:44:26 +08:00
|
|
|
CV_WRAP virtual void setPass2Only(bool f) = 0;
|
|
|
|
CV_WRAP virtual bool getPass2Only() const = 0;
|
2022-12-21 21:03:00 +08:00
|
|
|
|
2018-03-15 21:16:54 +08:00
|
|
|
CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
|
2010-05-12 01:44:00 +08:00
|
|
|
};
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2018-09-21 23:12:35 +08:00
|
|
|
|
2021-06-27 16:22:18 +08:00
|
|
|
/** @brief Wrapping class for feature detection using the FAST method.
|
|
|
|
|
|
|
|
Check @ref tutorial_py_fast "the corresponding tutorial" for more details.
|
2018-09-21 23:12:35 +08:00
|
|
|
*/
|
|
|
|
class CV_EXPORTS_W FastFeatureDetector : public Feature2D
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
enum DetectorType
|
|
|
|
{
|
|
|
|
TYPE_5_8 = 0, TYPE_7_12 = 1, TYPE_9_16 = 2
|
|
|
|
};
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
THRESHOLD = 10000, NONMAX_SUPPRESSION=10001, FAST_N=10002
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
CV_WRAP static Ptr<FastFeatureDetector> create( int threshold=10,
|
|
|
|
bool nonmaxSuppression=true,
|
|
|
|
FastFeatureDetector::DetectorType type=FastFeatureDetector::TYPE_9_16 );
|
|
|
|
|
|
|
|
CV_WRAP virtual void setThreshold(int threshold) = 0;
|
|
|
|
CV_WRAP virtual int getThreshold() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setNonmaxSuppression(bool f) = 0;
|
|
|
|
CV_WRAP virtual bool getNonmaxSuppression() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setType(FastFeatureDetector::DetectorType type) = 0;
|
|
|
|
CV_WRAP virtual FastFeatureDetector::DetectorType getType() const = 0;
|
|
|
|
CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
|
|
|
|
};
|
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Detects corners using the FAST algorithm
|
|
|
|
|
|
|
|
@param image grayscale image where keypoints (corners) are detected.
|
|
|
|
@param keypoints keypoints detected on the image.
|
|
|
|
@param threshold threshold on difference between intensity of the central pixel and pixels of a
|
|
|
|
circle around this pixel.
|
2021-06-27 16:22:18 +08:00
|
|
|
@param nonmaxSuppression if true, non-maximum suppression is applied to detected keypoints (corners).
|
2014-11-19 21:13:41 +08:00
|
|
|
@param type one of the three neighborhoods as defined in the paper:
|
2014-11-21 16:28:14 +08:00
|
|
|
FastFeatureDetector::TYPE_9_16, FastFeatureDetector::TYPE_7_12,
|
|
|
|
FastFeatureDetector::TYPE_5_8
|
2014-11-19 21:13:41 +08:00
|
|
|
|
2014-11-26 19:21:08 +08:00
|
|
|
Detects corners using the FAST algorithm by @cite Rosten06 .
|
2014-11-19 21:13:41 +08:00
|
|
|
|
2021-06-27 16:22:18 +08:00
|
|
|
Check @ref tutorial_py_fast "the corresponding tutorial" for more details.
|
2014-11-19 21:13:41 +08:00
|
|
|
*/
|
2013-02-25 00:14:01 +08:00
|
|
|
CV_EXPORTS void FAST( InputArray image, CV_OUT std::vector<KeyPoint>& keypoints,
|
2021-06-27 16:22:18 +08:00
|
|
|
int threshold, bool nonmaxSuppression=true, FastFeatureDetector::DetectorType type=FastFeatureDetector::TYPE_9_16 );
|
2012-03-15 22:36:01 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
|
|
|
|
/** @brief Wrapping class for feature detection using the goodFeaturesToTrack function. :
|
|
|
|
*/
|
2014-10-14 03:01:45 +08:00
|
|
|
class CV_EXPORTS_W GFTTDetector : public Feature2D
|
2010-05-12 01:44:00 +08:00
|
|
|
{
|
|
|
|
public:
|
2014-10-14 03:01:45 +08:00
|
|
|
CV_WRAP static Ptr<GFTTDetector> create( int maxCorners=1000, double qualityLevel=0.01, double minDistance=1,
|
|
|
|
int blockSize=3, bool useHarrisDetector=false, double k=0.04 );
|
2017-09-22 22:04:43 +08:00
|
|
|
CV_WRAP static Ptr<GFTTDetector> create( int maxCorners, double qualityLevel, double minDistance,
|
|
|
|
int blockSize, int gradiantSize, bool useHarrisDetector=false, double k=0.04 );
|
2014-10-19 00:44:26 +08:00
|
|
|
CV_WRAP virtual void setMaxFeatures(int maxFeatures) = 0;
|
|
|
|
CV_WRAP virtual int getMaxFeatures() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setQualityLevel(double qlevel) = 0;
|
|
|
|
CV_WRAP virtual double getQualityLevel() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setMinDistance(double minDistance) = 0;
|
|
|
|
CV_WRAP virtual double getMinDistance() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setBlockSize(int blockSize) = 0;
|
|
|
|
CV_WRAP virtual int getBlockSize() const = 0;
|
|
|
|
|
2022-12-21 21:03:00 +08:00
|
|
|
CV_WRAP virtual void setGradientSize(int gradientSize_) = 0;
|
|
|
|
CV_WRAP virtual int getGradientSize() = 0;
|
|
|
|
|
2014-10-19 00:44:26 +08:00
|
|
|
CV_WRAP virtual void setHarrisDetector(bool val) = 0;
|
|
|
|
CV_WRAP virtual bool getHarrisDetector() const = 0;
|
|
|
|
|
|
|
|
CV_WRAP virtual void setK(double k) = 0;
|
|
|
|
CV_WRAP virtual double getK() const = 0;
|
2018-03-15 21:16:54 +08:00
|
|
|
CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
|
2010-05-12 01:44:00 +08:00
|
|
|
};
|
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Class for extracting blobs from an image. :
|
|
|
|
|
|
|
|
The class implements a simple algorithm for extracting blobs from an image:
|
|
|
|
|
|
|
|
1. Convert the source image to binary images by applying thresholding with several thresholds from
|
|
|
|
minThreshold (inclusive) to maxThreshold (exclusive) with distance thresholdStep between
|
|
|
|
neighboring thresholds.
|
|
|
|
2. Extract connected components from every binary image by findContours and calculate their
|
|
|
|
centers.
|
|
|
|
3. Group centers from several binary images by their coordinates. Close centers form one group that
|
|
|
|
corresponds to one blob, which is controlled by the minDistBetweenBlobs parameter.
|
|
|
|
4. From the groups, estimate final centers of blobs and their radiuses and return as locations and
|
|
|
|
sizes of keypoints.
|
|
|
|
|
|
|
|
This class performs several filtrations of returned blobs. You should set filterBy\* to true/false
|
|
|
|
to turn on/off corresponding filtration. Available filtrations:
|
|
|
|
|
|
|
|
- **By color**. This filter compares the intensity of a binary image at the center of a blob to
|
|
|
|
blobColor. If they differ, the blob is filtered out. Use blobColor = 0 to extract dark blobs
|
|
|
|
and blobColor = 255 to extract light blobs.
|
|
|
|
- **By area**. Extracted blobs have an area between minArea (inclusive) and maxArea (exclusive).
|
|
|
|
- **By circularity**. Extracted blobs have circularity
|
|
|
|
(\f$\frac{4*\pi*Area}{perimeter * perimeter}\f$) between minCircularity (inclusive) and
|
|
|
|
maxCircularity (exclusive).
|
|
|
|
- **By ratio of the minimum inertia to maximum inertia**. Extracted blobs have this ratio
|
|
|
|
between minInertiaRatio (inclusive) and maxInertiaRatio (exclusive).
|
|
|
|
- **By convexity**. Extracted blobs have convexity (area / area of blob convex hull) between
|
|
|
|
minConvexity (inclusive) and maxConvexity (exclusive).
|
|
|
|
|
|
|
|
Default values of parameters are tuned to extract dark circular blobs.
|
|
|
|
*/
|
2014-10-14 03:01:45 +08:00
|
|
|
class CV_EXPORTS_W SimpleBlobDetector : public Feature2D
|
2010-12-27 17:15:08 +08:00
|
|
|
{
|
|
|
|
public:
|
2012-03-12 19:39:48 +08:00
|
|
|
struct CV_EXPORTS_W_SIMPLE Params
|
2010-12-27 17:15:08 +08:00
|
|
|
{
|
2012-03-12 19:39:48 +08:00
|
|
|
CV_WRAP Params();
|
|
|
|
CV_PROP_RW float thresholdStep;
|
|
|
|
CV_PROP_RW float minThreshold;
|
|
|
|
CV_PROP_RW float maxThreshold;
|
|
|
|
CV_PROP_RW size_t minRepeatability;
|
|
|
|
CV_PROP_RW float minDistBetweenBlobs;
|
2011-06-09 19:07:08 +08:00
|
|
|
|
2012-03-12 19:39:48 +08:00
|
|
|
CV_PROP_RW bool filterByColor;
|
|
|
|
CV_PROP_RW uchar blobColor;
|
2011-06-09 19:07:08 +08:00
|
|
|
|
2012-03-12 19:39:48 +08:00
|
|
|
CV_PROP_RW bool filterByArea;
|
|
|
|
CV_PROP_RW float minArea, maxArea;
|
2011-06-09 19:07:08 +08:00
|
|
|
|
2012-03-12 19:39:48 +08:00
|
|
|
CV_PROP_RW bool filterByCircularity;
|
|
|
|
CV_PROP_RW float minCircularity, maxCircularity;
|
2011-06-09 19:07:08 +08:00
|
|
|
|
2012-03-12 19:39:48 +08:00
|
|
|
CV_PROP_RW bool filterByInertia;
|
|
|
|
CV_PROP_RW float minInertiaRatio, maxInertiaRatio;
|
2011-06-09 19:07:08 +08:00
|
|
|
|
2012-03-12 19:39:48 +08:00
|
|
|
CV_PROP_RW bool filterByConvexity;
|
|
|
|
CV_PROP_RW float minConvexity, maxConvexity;
|
2011-08-10 17:17:37 +08:00
|
|
|
|
2022-10-08 00:07:51 +08:00
|
|
|
CV_PROP_RW bool collectContours;
|
|
|
|
|
2011-08-10 17:17:37 +08:00
|
|
|
void read( const FileNode& fn );
|
|
|
|
void write( FileStorage& fs ) const;
|
2010-12-27 17:15:08 +08:00
|
|
|
};
|
|
|
|
|
2014-10-14 03:01:45 +08:00
|
|
|
CV_WRAP static Ptr<SimpleBlobDetector>
|
|
|
|
create(const SimpleBlobDetector::Params ¶meters = SimpleBlobDetector::Params());
|
2022-12-21 21:03:00 +08:00
|
|
|
|
|
|
|
CV_WRAP virtual void setParams(const SimpleBlobDetector::Params& params ) = 0;
|
|
|
|
CV_WRAP virtual SimpleBlobDetector::Params getParams() const = 0;
|
|
|
|
|
2018-03-15 21:16:54 +08:00
|
|
|
CV_WRAP virtual String getDefaultName() const CV_OVERRIDE;
|
2023-01-09 19:08:02 +08:00
|
|
|
CV_WRAP virtual const std::vector<std::vector<cv::Point> >& getBlobContours() const = 0;
|
2010-12-27 17:15:08 +08:00
|
|
|
};
|
|
|
|
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2010-05-12 01:44:00 +08:00
|
|
|
/****************************************************************************************\
|
2012-04-30 22:33:52 +08:00
|
|
|
* Distance *
|
2010-05-12 01:44:00 +08:00
|
|
|
\****************************************************************************************/
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2010-05-12 01:44:00 +08:00
|
|
|
template<typename T>
|
|
|
|
struct CV_EXPORTS Accumulator
|
|
|
|
{
|
|
|
|
typedef T Type;
|
|
|
|
};
|
|
|
|
|
2010-11-25 18:05:03 +08:00
|
|
|
template<> struct Accumulator<unsigned char> { typedef float Type; };
|
|
|
|
template<> struct Accumulator<unsigned short> { typedef float Type; };
|
|
|
|
template<> struct Accumulator<char> { typedef float Type; };
|
|
|
|
template<> struct Accumulator<short> { typedef float Type; };
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2011-08-08 21:18:12 +08:00
|
|
|
/*
|
2011-08-08 22:03:37 +08:00
|
|
|
* Squared Euclidean distance functor
|
2011-08-08 21:18:12 +08:00
|
|
|
*/
|
|
|
|
template<class T>
|
|
|
|
struct CV_EXPORTS SL2
|
|
|
|
{
|
2018-09-21 23:12:35 +08:00
|
|
|
static const NormTypes normType = NORM_L2SQR;
|
2011-08-08 21:18:12 +08:00
|
|
|
typedef T ValueType;
|
|
|
|
typedef typename Accumulator<T>::Type ResultType;
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2011-08-08 21:18:12 +08:00
|
|
|
ResultType operator()( const T* a, const T* b, int size ) const
|
|
|
|
{
|
2011-10-11 23:13:53 +08:00
|
|
|
return normL2Sqr<ValueType, ResultType>(a, b, size);
|
2011-08-08 21:18:12 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2010-05-12 01:44:00 +08:00
|
|
|
/*
|
2011-08-05 22:05:41 +08:00
|
|
|
* Euclidean distance functor
|
2010-05-12 01:44:00 +08:00
|
|
|
*/
|
|
|
|
template<class T>
|
2017-01-25 19:20:57 +08:00
|
|
|
struct L2
|
2010-05-12 01:44:00 +08:00
|
|
|
{
|
2018-09-21 23:12:35 +08:00
|
|
|
static const NormTypes normType = NORM_L2;
|
2010-05-12 01:44:00 +08:00
|
|
|
typedef T ValueType;
|
|
|
|
typedef typename Accumulator<T>::Type ResultType;
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2010-05-12 01:44:00 +08:00
|
|
|
ResultType operator()( const T* a, const T* b, int size ) const
|
|
|
|
{
|
2013-02-25 00:14:01 +08:00
|
|
|
return (ResultType)std::sqrt((double)normL2Sqr<ValueType, ResultType>(a, b, size));
|
2010-05-12 01:44:00 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2010-06-28 21:06:24 +08:00
|
|
|
/*
|
|
|
|
* Manhattan distance (city block distance) functor
|
|
|
|
*/
|
|
|
|
template<class T>
|
2017-01-25 19:20:57 +08:00
|
|
|
struct L1
|
2010-06-28 21:06:24 +08:00
|
|
|
{
|
2018-09-21 23:12:35 +08:00
|
|
|
static const NormTypes normType = NORM_L1;
|
2010-06-28 21:06:24 +08:00
|
|
|
typedef T ValueType;
|
|
|
|
typedef typename Accumulator<T>::Type ResultType;
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2010-06-28 21:06:24 +08:00
|
|
|
ResultType operator()( const T* a, const T* b, int size ) const
|
|
|
|
{
|
2011-10-11 23:13:53 +08:00
|
|
|
return normL1<ValueType, ResultType>(a, b, size);
|
2010-06-28 21:06:24 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2024-03-06 13:50:31 +08:00
|
|
|
//! @} features2d_main
|
|
|
|
|
2010-05-12 01:44:00 +08:00
|
|
|
/****************************************************************************************\
|
|
|
|
* DescriptorMatcher *
|
|
|
|
\****************************************************************************************/
|
2014-11-19 21:13:41 +08:00
|
|
|
|
|
|
|
//! @addtogroup features2d_match
|
|
|
|
//! @{
|
|
|
|
|
|
|
|
/** @brief Abstract base class for matching keypoint descriptors.
|
|
|
|
|
|
|
|
It has two groups of match methods: for matching descriptors of an image with another image or with
|
|
|
|
an image set.
|
2010-05-12 01:44:00 +08:00
|
|
|
*/
|
2012-03-15 22:36:01 +08:00
|
|
|
class CV_EXPORTS_W DescriptorMatcher : public Algorithm
|
2010-05-12 01:44:00 +08:00
|
|
|
{
|
|
|
|
public:
|
2018-09-21 23:12:35 +08:00
|
|
|
enum MatcherType
|
2016-10-08 03:58:57 +08:00
|
|
|
{
|
|
|
|
FLANNBASED = 1,
|
|
|
|
BRUTEFORCE = 2,
|
|
|
|
BRUTEFORCE_L1 = 3,
|
|
|
|
BRUTEFORCE_HAMMING = 4,
|
|
|
|
BRUTEFORCE_HAMMINGLUT = 5,
|
|
|
|
BRUTEFORCE_SL2 = 6
|
|
|
|
};
|
2018-09-21 23:12:35 +08:00
|
|
|
|
2010-11-23 02:27:08 +08:00
|
|
|
virtual ~DescriptorMatcher();
|
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Adds descriptors to train a CPU(trainDescCollectionis) or GPU(utrainDescCollectionis) descriptor
|
|
|
|
collection.
|
|
|
|
|
|
|
|
If the collection is not empty, the new descriptors are added to existing train descriptors.
|
|
|
|
|
|
|
|
@param descriptors Descriptors to add. Each descriptors[i] is a set of descriptors from the same
|
|
|
|
train image.
|
2010-05-12 01:44:00 +08:00
|
|
|
*/
|
2014-01-15 14:01:40 +08:00
|
|
|
CV_WRAP virtual void add( InputArrayOfArrays descriptors );
|
2014-11-19 21:13:41 +08:00
|
|
|
|
|
|
|
/** @brief Returns a constant link to the train descriptor collection trainDescCollection .
|
2010-05-12 01:44:00 +08:00
|
|
|
*/
|
2013-02-25 00:14:01 +08:00
|
|
|
CV_WRAP const std::vector<Mat>& getTrainDescriptors() const;
|
2014-11-19 21:13:41 +08:00
|
|
|
|
|
|
|
/** @brief Clears the train descriptor collections.
|
2010-05-12 01:44:00 +08:00
|
|
|
*/
|
2018-03-15 21:16:54 +08:00
|
|
|
CV_WRAP virtual void clear() CV_OVERRIDE;
|
2010-10-29 16:44:42 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Returns true if there are no train descriptors in the both collections.
|
2010-11-23 02:27:08 +08:00
|
|
|
*/
|
2018-03-15 21:16:54 +08:00
|
|
|
CV_WRAP virtual bool empty() const CV_OVERRIDE;
|
2014-11-19 21:13:41 +08:00
|
|
|
|
|
|
|
/** @brief Returns true if the descriptor matcher supports masking permissible matches.
|
2010-11-23 02:27:08 +08:00
|
|
|
*/
|
2011-09-15 19:10:06 +08:00
|
|
|
CV_WRAP virtual bool isMaskSupported() const = 0;
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Trains a descriptor matcher
|
|
|
|
|
|
|
|
Trains a descriptor matcher (for example, the flann index). In all methods to match, the method
|
|
|
|
train() is run every time before matching. Some descriptor matchers (for example, BruteForceMatcher)
|
|
|
|
have an empty implementation of this method. Other matchers really train their inner structures (for
|
|
|
|
example, FlannBasedMatcher trains flann::Index ).
|
2010-05-12 01:44:00 +08:00
|
|
|
*/
|
2011-09-15 19:10:06 +08:00
|
|
|
CV_WRAP virtual void train();
|
2014-11-19 21:13:41 +08:00
|
|
|
|
|
|
|
/** @brief Finds the best match for each descriptor from a query set.
|
|
|
|
|
|
|
|
@param queryDescriptors Query set of descriptors.
|
|
|
|
@param trainDescriptors Train set of descriptors. This set is not added to the train descriptors
|
|
|
|
collection stored in the class object.
|
|
|
|
@param matches Matches. If a query descriptor is masked out in mask , no match is added for this
|
|
|
|
descriptor. So, matches size may be smaller than the query descriptors count.
|
|
|
|
@param mask Mask specifying permissible matches between an input query and train matrices of
|
|
|
|
descriptors.
|
|
|
|
|
|
|
|
In the first variant of this method, the train descriptors are passed as an input argument. In the
|
|
|
|
second variant of the method, train descriptors collection that was set by DescriptorMatcher::add is
|
|
|
|
used. Optional mask (or masks) can be passed to specify which query and training descriptors can be
|
|
|
|
matched. Namely, queryDescriptors[i] can be matched with trainDescriptors[j] only if
|
|
|
|
mask.at\<uchar\>(i,j) is non-zero.
|
2010-06-11 17:38:39 +08:00
|
|
|
*/
|
2013-12-27 17:04:02 +08:00
|
|
|
CV_WRAP void match( InputArray queryDescriptors, InputArray trainDescriptors,
|
2014-01-24 23:39:05 +08:00
|
|
|
CV_OUT std::vector<DMatch>& matches, InputArray mask=noArray() ) const;
|
2014-11-19 21:13:41 +08:00
|
|
|
|
|
|
|
/** @brief Finds the k best matches for each descriptor from a query set.
|
|
|
|
|
|
|
|
@param queryDescriptors Query set of descriptors.
|
|
|
|
@param trainDescriptors Train set of descriptors. This set is not added to the train descriptors
|
|
|
|
collection stored in the class object.
|
|
|
|
@param mask Mask specifying permissible matches between an input query and train matrices of
|
|
|
|
descriptors.
|
|
|
|
@param matches Matches. Each matches[i] is k or less matches for the same query descriptor.
|
|
|
|
@param k Count of best matches found per each query descriptor or less if a query descriptor has
|
|
|
|
less than k possible matches in total.
|
|
|
|
@param compactResult Parameter used when the mask (or masks) is not empty. If compactResult is
|
|
|
|
false, the matches vector has the same size as queryDescriptors rows. If compactResult is true,
|
|
|
|
the matches vector does not contain matches for fully masked-out query descriptors.
|
|
|
|
|
|
|
|
These extended variants of DescriptorMatcher::match methods find several best matches for each query
|
|
|
|
descriptor. The matches are returned in the distance increasing order. See DescriptorMatcher::match
|
|
|
|
for the details about query and train descriptors.
|
|
|
|
*/
|
2013-12-27 17:04:02 +08:00
|
|
|
CV_WRAP void knnMatch( InputArray queryDescriptors, InputArray trainDescriptors,
|
2013-02-25 00:14:01 +08:00
|
|
|
CV_OUT std::vector<std::vector<DMatch> >& matches, int k,
|
2014-01-24 23:39:05 +08:00
|
|
|
InputArray mask=noArray(), bool compactResult=false ) const;
|
2014-11-19 21:13:41 +08:00
|
|
|
|
|
|
|
/** @brief For each query descriptor, finds the training descriptors not farther than the specified distance.
|
|
|
|
|
|
|
|
@param queryDescriptors Query set of descriptors.
|
|
|
|
@param trainDescriptors Train set of descriptors. This set is not added to the train descriptors
|
|
|
|
collection stored in the class object.
|
|
|
|
@param matches Found matches.
|
|
|
|
@param compactResult Parameter used when the mask (or masks) is not empty. If compactResult is
|
|
|
|
false, the matches vector has the same size as queryDescriptors rows. If compactResult is true,
|
|
|
|
the matches vector does not contain matches for fully masked-out query descriptors.
|
|
|
|
@param maxDistance Threshold for the distance between matched descriptors. Distance means here
|
|
|
|
metric distance (e.g. Hamming distance), not the distance between coordinates (which is measured
|
|
|
|
in Pixels)!
|
|
|
|
@param mask Mask specifying permissible matches between an input query and train matrices of
|
|
|
|
descriptors.
|
|
|
|
|
|
|
|
For each query descriptor, the methods find such training descriptors that the distance between the
|
|
|
|
query descriptor and the training descriptor is equal or smaller than maxDistance. Found matches are
|
|
|
|
returned in the distance increasing order.
|
|
|
|
*/
|
2016-10-08 03:58:57 +08:00
|
|
|
CV_WRAP void radiusMatch( InputArray queryDescriptors, InputArray trainDescriptors,
|
2016-10-16 17:33:12 +08:00
|
|
|
CV_OUT std::vector<std::vector<DMatch> >& matches, float maxDistance,
|
2014-01-24 23:39:05 +08:00
|
|
|
InputArray mask=noArray(), bool compactResult=false ) const;
|
2014-11-19 21:13:41 +08:00
|
|
|
|
|
|
|
/** @overload
|
|
|
|
@param queryDescriptors Query set of descriptors.
|
|
|
|
@param matches Matches. If a query descriptor is masked out in mask , no match is added for this
|
|
|
|
descriptor. So, matches size may be smaller than the query descriptors count.
|
|
|
|
@param masks Set of masks. Each masks[i] specifies permissible matches between the input query
|
|
|
|
descriptors and stored train descriptors from the i-th image trainDescCollection[i].
|
|
|
|
*/
|
2013-12-27 17:04:02 +08:00
|
|
|
CV_WRAP void match( InputArray queryDescriptors, CV_OUT std::vector<DMatch>& matches,
|
2014-02-17 07:00:20 +08:00
|
|
|
InputArrayOfArrays masks=noArray() );
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @overload
|
|
|
|
@param queryDescriptors Query set of descriptors.
|
|
|
|
@param matches Matches. Each matches[i] is k or less matches for the same query descriptor.
|
|
|
|
@param k Count of best matches found per each query descriptor or less if a query descriptor has
|
|
|
|
less than k possible matches in total.
|
|
|
|
@param masks Set of masks. Each masks[i] specifies permissible matches between the input query
|
|
|
|
descriptors and stored train descriptors from the i-th image trainDescCollection[i].
|
|
|
|
@param compactResult Parameter used when the mask (or masks) is not empty. If compactResult is
|
|
|
|
false, the matches vector has the same size as queryDescriptors rows. If compactResult is true,
|
|
|
|
the matches vector does not contain matches for fully masked-out query descriptors.
|
|
|
|
*/
|
2013-12-27 17:04:02 +08:00
|
|
|
CV_WRAP void knnMatch( InputArray queryDescriptors, CV_OUT std::vector<std::vector<DMatch> >& matches, int k,
|
2014-02-17 07:00:20 +08:00
|
|
|
InputArrayOfArrays masks=noArray(), bool compactResult=false );
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @overload
|
|
|
|
@param queryDescriptors Query set of descriptors.
|
|
|
|
@param matches Found matches.
|
|
|
|
@param maxDistance Threshold for the distance between matched descriptors. Distance means here
|
|
|
|
metric distance (e.g. Hamming distance), not the distance between coordinates (which is measured
|
|
|
|
in Pixels)!
|
|
|
|
@param masks Set of masks. Each masks[i] specifies permissible matches between the input query
|
|
|
|
descriptors and stored train descriptors from the i-th image trainDescCollection[i].
|
|
|
|
@param compactResult Parameter used when the mask (or masks) is not empty. If compactResult is
|
|
|
|
false, the matches vector has the same size as queryDescriptors rows. If compactResult is true,
|
|
|
|
the matches vector does not contain matches for fully masked-out query descriptors.
|
|
|
|
*/
|
2016-10-16 17:33:12 +08:00
|
|
|
CV_WRAP void radiusMatch( InputArray queryDescriptors, CV_OUT std::vector<std::vector<DMatch> >& matches, float maxDistance,
|
2014-02-17 07:00:20 +08:00
|
|
|
InputArrayOfArrays masks=noArray(), bool compactResult=false );
|
2010-06-16 16:56:53 +08:00
|
|
|
|
2016-10-08 06:13:01 +08:00
|
|
|
|
2016-10-08 03:58:57 +08:00
|
|
|
CV_WRAP void write( const String& fileName ) const
|
|
|
|
{
|
|
|
|
FileStorage fs(fileName, FileStorage::WRITE);
|
|
|
|
write(fs);
|
|
|
|
}
|
|
|
|
|
|
|
|
CV_WRAP void read( const String& fileName )
|
|
|
|
{
|
|
|
|
FileStorage fs(fileName, FileStorage::READ);
|
|
|
|
read(fs.root());
|
|
|
|
}
|
2010-10-29 16:44:42 +08:00
|
|
|
// Reads matcher object from a file node
|
2017-07-27 20:34:32 +08:00
|
|
|
// see corresponding cv::Algorithm method
|
2018-03-15 21:16:54 +08:00
|
|
|
CV_WRAP virtual void read( const FileNode& ) CV_OVERRIDE;
|
2010-10-29 16:44:42 +08:00
|
|
|
// Writes matcher object to a file storage
|
2018-03-15 21:16:54 +08:00
|
|
|
virtual void write( FileStorage& ) const CV_OVERRIDE;
|
2010-11-23 02:27:08 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Clones the matcher.
|
|
|
|
|
|
|
|
@param emptyTrainData If emptyTrainData is false, the method creates a deep copy of the object,
|
|
|
|
that is, copies both parameters and train data. If emptyTrainData is true, the method creates an
|
|
|
|
object copy with the current parameters but with empty train data.
|
|
|
|
*/
|
2021-09-09 21:20:45 +08:00
|
|
|
CV_WRAP CV_NODISCARD_STD virtual Ptr<DescriptorMatcher> clone( bool emptyTrainData=false ) const = 0;
|
2010-10-29 16:44:42 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Creates a descriptor matcher of a given type with the default parameters (using default
|
|
|
|
constructor).
|
|
|
|
|
|
|
|
@param descriptorMatcherType Descriptor matcher type. Now the following matcher types are
|
|
|
|
supported:
|
|
|
|
- `BruteForce` (it uses L2 )
|
|
|
|
- `BruteForce-L1`
|
|
|
|
- `BruteForce-Hamming`
|
|
|
|
- `BruteForce-Hamming(2)`
|
|
|
|
- `FlannBased`
|
|
|
|
*/
|
2013-03-23 00:37:49 +08:00
|
|
|
CV_WRAP static Ptr<DescriptorMatcher> create( const String& descriptorMatcherType );
|
2016-10-08 06:13:01 +08:00
|
|
|
|
2018-09-21 23:12:35 +08:00
|
|
|
CV_WRAP static Ptr<DescriptorMatcher> create( const DescriptorMatcher::MatcherType& matcherType );
|
2016-10-08 06:13:01 +08:00
|
|
|
|
2017-07-27 20:34:32 +08:00
|
|
|
|
|
|
|
// see corresponding cv::Algorithm method
|
2022-12-09 07:37:39 +08:00
|
|
|
CV_WRAP inline void write(FileStorage& fs, const String& name) const { Algorithm::write(fs, name); }
|
2022-12-10 05:05:17 +08:00
|
|
|
#if CV_VERSION_MAJOR < 5
|
|
|
|
inline void write(const Ptr<FileStorage>& fs, const String& name) const { CV_Assert(fs); Algorithm::write(*fs, name); }
|
|
|
|
#endif
|
2017-07-27 20:34:32 +08:00
|
|
|
|
2010-10-29 16:44:42 +08:00
|
|
|
protected:
|
2014-11-19 21:13:41 +08:00
|
|
|
/**
|
2010-10-29 16:44:42 +08:00
|
|
|
* Class to work with descriptors from several images as with one merged matrix.
|
2010-11-23 02:27:08 +08:00
|
|
|
* It is used e.g. in FlannBasedMatcher.
|
2010-06-16 16:56:53 +08:00
|
|
|
*/
|
2010-10-29 22:39:23 +08:00
|
|
|
class CV_EXPORTS DescriptorCollection
|
2010-10-29 16:44:42 +08:00
|
|
|
{
|
|
|
|
public:
|
2010-11-23 02:27:08 +08:00
|
|
|
DescriptorCollection();
|
|
|
|
DescriptorCollection( const DescriptorCollection& collection );
|
|
|
|
virtual ~DescriptorCollection();
|
2010-06-16 16:56:53 +08:00
|
|
|
|
2010-11-23 02:27:08 +08:00
|
|
|
// Vector of matrices "descriptors" will be merged to one matrix "mergedDescriptors" here.
|
2013-02-25 00:14:01 +08:00
|
|
|
void set( const std::vector<Mat>& descriptors );
|
2010-10-29 16:44:42 +08:00
|
|
|
virtual void clear();
|
2010-06-16 16:56:53 +08:00
|
|
|
|
2010-11-23 02:27:08 +08:00
|
|
|
const Mat& getDescriptors() const;
|
2022-05-26 20:30:41 +08:00
|
|
|
Mat getDescriptor( int imgIdx, int localDescIdx ) const;
|
|
|
|
Mat getDescriptor( int globalDescIdx ) const;
|
2010-10-29 16:44:42 +08:00
|
|
|
void getLocalIdx( int globalDescIdx, int& imgIdx, int& localDescIdx ) const;
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2010-11-23 02:27:08 +08:00
|
|
|
int size() const;
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2010-10-29 16:44:42 +08:00
|
|
|
protected:
|
2010-11-23 02:27:08 +08:00
|
|
|
Mat mergedDescriptors;
|
2013-02-25 00:14:01 +08:00
|
|
|
std::vector<int> startIdxs;
|
2010-10-29 16:44:42 +08:00
|
|
|
};
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
//! In fact the matching is implemented only by the following two methods. These methods suppose
|
|
|
|
//! that the class object has been trained already. Public match methods call these methods
|
|
|
|
//! after calling train().
|
2013-12-27 17:04:02 +08:00
|
|
|
virtual void knnMatchImpl( InputArray queryDescriptors, std::vector<std::vector<DMatch> >& matches, int k,
|
2014-01-24 23:39:05 +08:00
|
|
|
InputArrayOfArrays masks=noArray(), bool compactResult=false ) = 0;
|
2013-12-27 17:04:02 +08:00
|
|
|
virtual void radiusMatchImpl( InputArray queryDescriptors, std::vector<std::vector<DMatch> >& matches, float maxDistance,
|
2014-01-24 23:39:05 +08:00
|
|
|
InputArrayOfArrays masks=noArray(), bool compactResult=false ) = 0;
|
2010-06-16 16:56:53 +08:00
|
|
|
|
2014-02-17 07:00:20 +08:00
|
|
|
static bool isPossibleMatch( InputArray mask, int queryIdx, int trainIdx );
|
|
|
|
static bool isMaskedOut( InputArrayOfArrays masks, int queryIdx );
|
2010-10-29 16:44:42 +08:00
|
|
|
|
2021-09-09 21:20:45 +08:00
|
|
|
CV_NODISCARD_STD static Mat clone_op( Mat m ) { return m.clone(); }
|
2014-02-17 07:00:20 +08:00
|
|
|
void checkMasks( InputArrayOfArrays masks, int queryDescriptorsCount ) const;
|
2010-10-29 16:44:42 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
//! Collection of descriptors from train images.
|
2013-02-25 00:14:01 +08:00
|
|
|
std::vector<Mat> trainDescCollection;
|
2013-12-27 17:04:02 +08:00
|
|
|
std::vector<UMat> utrainDescCollection;
|
2010-05-12 01:44:00 +08:00
|
|
|
};
|
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Brute-force descriptor matcher.
|
|
|
|
|
|
|
|
For each descriptor in the first set, this matcher finds the closest descriptor in the second set
|
|
|
|
by trying each one. This descriptor matcher supports masking permissible matches of descriptor
|
|
|
|
sets.
|
2010-05-12 01:44:00 +08:00
|
|
|
*/
|
2012-07-12 01:13:43 +08:00
|
|
|
class CV_EXPORTS_W BFMatcher : public DescriptorMatcher
|
2010-11-03 18:00:24 +08:00
|
|
|
{
|
|
|
|
public:
|
2016-10-08 03:58:57 +08:00
|
|
|
/** @brief Brute-force matcher constructor (obsolete). Please use BFMatcher.create()
|
2016-10-08 06:13:01 +08:00
|
|
|
*
|
|
|
|
*
|
2016-10-08 03:58:57 +08:00
|
|
|
*/
|
2016-10-08 06:13:01 +08:00
|
|
|
CV_WRAP BFMatcher( int normType=NORM_L2, bool crossCheck=false );
|
|
|
|
|
2016-10-08 03:58:57 +08:00
|
|
|
virtual ~BFMatcher() {}
|
|
|
|
|
2018-03-15 21:16:54 +08:00
|
|
|
virtual bool isMaskSupported() const CV_OVERRIDE { return true; }
|
2014-11-19 21:13:41 +08:00
|
|
|
|
2017-08-11 20:18:53 +08:00
|
|
|
/** @brief Brute-force matcher create method.
|
2014-11-21 16:28:14 +08:00
|
|
|
@param normType One of NORM_L1, NORM_L2, NORM_HAMMING, NORM_HAMMING2. L1 and L2 norms are
|
|
|
|
preferable choices for SIFT and SURF descriptors, NORM_HAMMING should be used with ORB, BRISK and
|
|
|
|
BRIEF, NORM_HAMMING2 should be used with ORB when WTA_K==3 or 4 (see ORB::ORB constructor
|
2014-11-19 21:13:41 +08:00
|
|
|
description).
|
|
|
|
@param crossCheck If it is false, this is will be default BFMatcher behaviour when it finds the k
|
|
|
|
nearest neighbors for each query descriptor. If crossCheck==true, then the knnMatch() method with
|
|
|
|
k=1 will only return pairs (i,j) such that for i-th query descriptor the j-th descriptor in the
|
|
|
|
matcher's collection is the nearest and vice versa, i.e. the BFMatcher will only return consistent
|
|
|
|
pairs. Such technique usually produces best results with minimal number of outliers when there are
|
|
|
|
enough matches. This is alternative to the ratio test, used by D. Lowe in SIFT paper.
|
2016-10-08 06:13:01 +08:00
|
|
|
*/
|
|
|
|
CV_WRAP static Ptr<BFMatcher> create( int normType=NORM_L2, bool crossCheck=false ) ;
|
|
|
|
|
2021-09-09 21:20:45 +08:00
|
|
|
CV_NODISCARD_STD virtual Ptr<DescriptorMatcher> clone( bool emptyTrainData=false ) const CV_OVERRIDE;
|
2010-11-03 18:00:24 +08:00
|
|
|
protected:
|
2013-12-27 17:04:02 +08:00
|
|
|
virtual void knnMatchImpl( InputArray queryDescriptors, std::vector<std::vector<DMatch> >& matches, int k,
|
2018-03-15 21:16:54 +08:00
|
|
|
InputArrayOfArrays masks=noArray(), bool compactResult=false ) CV_OVERRIDE;
|
2013-12-27 17:04:02 +08:00
|
|
|
virtual void radiusMatchImpl( InputArray queryDescriptors, std::vector<std::vector<DMatch> >& matches, float maxDistance,
|
2018-03-15 21:16:54 +08:00
|
|
|
InputArrayOfArrays masks=noArray(), bool compactResult=false ) CV_OVERRIDE;
|
2010-11-03 18:00:24 +08:00
|
|
|
|
2012-03-15 22:36:01 +08:00
|
|
|
int normType;
|
|
|
|
bool crossCheck;
|
2010-11-03 18:00:24 +08:00
|
|
|
};
|
|
|
|
|
2017-10-13 16:01:48 +08:00
|
|
|
#if defined(HAVE_OPENCV_FLANN) || defined(CV_DOXYGEN)
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Flann-based descriptor matcher.
|
|
|
|
|
2016-09-01 04:12:52 +08:00
|
|
|
This matcher trains cv::flann::Index on a train descriptor collection and calls its nearest search
|
2014-11-19 21:13:41 +08:00
|
|
|
methods to find the best matches. So, this matcher may be faster when matching a large train
|
|
|
|
collection than the brute force matcher. FlannBasedMatcher does not support masking permissible
|
|
|
|
matches of descriptor sets because flann::Index does not support this. :
|
2010-05-12 01:44:00 +08:00
|
|
|
*/
|
2011-09-15 19:10:06 +08:00
|
|
|
class CV_EXPORTS_W FlannBasedMatcher : public DescriptorMatcher
|
2010-05-12 01:44:00 +08:00
|
|
|
{
|
|
|
|
public:
|
2016-10-08 06:13:01 +08:00
|
|
|
CV_WRAP FlannBasedMatcher( const Ptr<flann::IndexParams>& indexParams=makePtr<flann::KDTreeIndexParams>(),
|
2013-08-13 21:30:14 +08:00
|
|
|
const Ptr<flann::SearchParams>& searchParams=makePtr<flann::SearchParams>() );
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2018-03-15 21:16:54 +08:00
|
|
|
virtual void add( InputArrayOfArrays descriptors ) CV_OVERRIDE;
|
|
|
|
virtual void clear() CV_OVERRIDE;
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2011-08-04 22:13:07 +08:00
|
|
|
// Reads matcher object from a file node
|
2018-03-15 21:16:54 +08:00
|
|
|
virtual void read( const FileNode& ) CV_OVERRIDE;
|
2011-08-04 22:13:07 +08:00
|
|
|
// Writes matcher object to a file storage
|
2018-03-15 21:16:54 +08:00
|
|
|
virtual void write( FileStorage& ) const CV_OVERRIDE;
|
2011-08-04 22:13:07 +08:00
|
|
|
|
2018-03-15 21:16:54 +08:00
|
|
|
virtual void train() CV_OVERRIDE;
|
|
|
|
virtual bool isMaskSupported() const CV_OVERRIDE;
|
2012-05-29 18:36:19 +08:00
|
|
|
|
2016-10-08 03:58:57 +08:00
|
|
|
CV_WRAP static Ptr<FlannBasedMatcher> create();
|
2016-10-08 06:13:01 +08:00
|
|
|
|
2021-09-09 21:20:45 +08:00
|
|
|
CV_NODISCARD_STD virtual Ptr<DescriptorMatcher> clone( bool emptyTrainData=false ) const CV_OVERRIDE;
|
2010-11-23 02:27:08 +08:00
|
|
|
protected:
|
|
|
|
static void convertToDMatches( const DescriptorCollection& descriptors,
|
|
|
|
const Mat& indices, const Mat& distances,
|
2013-02-25 00:14:01 +08:00
|
|
|
std::vector<std::vector<DMatch> >& matches );
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2013-12-27 17:04:02 +08:00
|
|
|
virtual void knnMatchImpl( InputArray queryDescriptors, std::vector<std::vector<DMatch> >& matches, int k,
|
2018-03-15 21:16:54 +08:00
|
|
|
InputArrayOfArrays masks=noArray(), bool compactResult=false ) CV_OVERRIDE;
|
2013-12-27 17:04:02 +08:00
|
|
|
virtual void radiusMatchImpl( InputArray queryDescriptors, std::vector<std::vector<DMatch> >& matches, float maxDistance,
|
2018-03-15 21:16:54 +08:00
|
|
|
InputArrayOfArrays masks=noArray(), bool compactResult=false ) CV_OVERRIDE;
|
2010-11-23 02:27:08 +08:00
|
|
|
|
2010-10-29 16:44:42 +08:00
|
|
|
Ptr<flann::IndexParams> indexParams;
|
|
|
|
Ptr<flann::SearchParams> searchParams;
|
2011-02-02 23:47:08 +08:00
|
|
|
Ptr<flann::Index> flannIndex;
|
2010-10-29 16:44:42 +08:00
|
|
|
|
|
|
|
DescriptorCollection mergedDescriptors;
|
|
|
|
int addedDescCount;
|
2010-05-12 01:44:00 +08:00
|
|
|
};
|
|
|
|
|
2017-10-13 16:01:48 +08:00
|
|
|
#endif
|
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
//! @} features2d_match
|
2010-05-12 01:44:00 +08:00
|
|
|
|
2010-08-05 20:19:26 +08:00
|
|
|
/****************************************************************************************\
|
|
|
|
* Drawing functions *
|
|
|
|
\****************************************************************************************/
|
2014-11-19 21:13:41 +08:00
|
|
|
|
|
|
|
//! @addtogroup features2d_draw
|
|
|
|
//! @{
|
|
|
|
|
2018-09-21 23:12:35 +08:00
|
|
|
enum struct DrawMatchesFlags
|
2010-06-12 01:15:43 +08:00
|
|
|
{
|
2018-09-21 23:12:35 +08:00
|
|
|
DEFAULT = 0, //!< Output image matrix will be created (Mat::create),
|
|
|
|
//!< i.e. existing memory of output image may be reused.
|
|
|
|
//!< Two source image, matches and single keypoints will be drawn.
|
|
|
|
//!< For each keypoint only the center point will be drawn (without
|
|
|
|
//!< the circle around keypoint with keypoint size and orientation).
|
|
|
|
DRAW_OVER_OUTIMG = 1, //!< Output image matrix will not be created (Mat::create).
|
|
|
|
//!< Matches will be drawn on existing content of output image.
|
|
|
|
NOT_DRAW_SINGLE_POINTS = 2, //!< Single keypoints will not be drawn.
|
|
|
|
DRAW_RICH_KEYPOINTS = 4 //!< For each keypoint the circle around keypoint with keypoint size and
|
|
|
|
//!< orientation will be drawn.
|
2010-06-12 01:15:43 +08:00
|
|
|
};
|
2018-11-08 00:23:21 +08:00
|
|
|
CV_ENUM_FLAGS(DrawMatchesFlags)
|
2010-06-12 01:15:43 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Draws keypoints.
|
|
|
|
|
|
|
|
@param image Source image.
|
|
|
|
@param keypoints Keypoints from the source image.
|
|
|
|
@param outImage Output image. Its content depends on the flags value defining what is drawn in the
|
|
|
|
output image. See possible flags bit values below.
|
|
|
|
@param color Color of keypoints.
|
|
|
|
@param flags Flags setting drawing features. Possible flags bit values are defined by
|
|
|
|
DrawMatchesFlags. See details above in drawMatches .
|
|
|
|
|
|
|
|
@note
|
2018-12-11 21:01:41 +08:00
|
|
|
For Python API, flags are modified as cv.DRAW_MATCHES_FLAGS_DEFAULT,
|
|
|
|
cv.DRAW_MATCHES_FLAGS_DRAW_RICH_KEYPOINTS, cv.DRAW_MATCHES_FLAGS_DRAW_OVER_OUTIMG,
|
|
|
|
cv.DRAW_MATCHES_FLAGS_NOT_DRAW_SINGLE_POINTS
|
2014-11-19 21:13:41 +08:00
|
|
|
*/
|
2014-02-05 14:55:26 +08:00
|
|
|
CV_EXPORTS_W void drawKeypoints( InputArray image, const std::vector<KeyPoint>& keypoints, InputOutputArray outImage,
|
2018-09-21 23:12:35 +08:00
|
|
|
const Scalar& color=Scalar::all(-1), DrawMatchesFlags flags=DrawMatchesFlags::DEFAULT );
|
2010-08-04 00:28:52 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @brief Draws the found matches of keypoints from two images.
|
|
|
|
|
|
|
|
@param img1 First source image.
|
|
|
|
@param keypoints1 Keypoints from the first source image.
|
|
|
|
@param img2 Second source image.
|
|
|
|
@param keypoints2 Keypoints from the second source image.
|
|
|
|
@param matches1to2 Matches from the first image to the second one, which means that keypoints1[i]
|
|
|
|
has a corresponding point in keypoints2[matches[i]] .
|
|
|
|
@param outImg Output image. Its content depends on the flags value defining what is drawn in the
|
|
|
|
output image. See possible flags bit values below.
|
|
|
|
@param matchColor Color of matches (lines and connected keypoints). If matchColor==Scalar::all(-1)
|
|
|
|
, the color is generated randomly.
|
|
|
|
@param singlePointColor Color of single keypoints (circles), which means that keypoints do not
|
|
|
|
have the matches. If singlePointColor==Scalar::all(-1) , the color is generated randomly.
|
|
|
|
@param matchesMask Mask determining which matches are drawn. If the mask is empty, all matches are
|
|
|
|
drawn.
|
|
|
|
@param flags Flags setting drawing features. Possible flags bit values are defined by
|
|
|
|
DrawMatchesFlags.
|
|
|
|
|
|
|
|
This function draws matches of keypoints from two images in the output image. Match is a line
|
|
|
|
connecting two keypoints (circles). See cv::DrawMatchesFlags.
|
|
|
|
*/
|
2014-02-04 20:34:18 +08:00
|
|
|
CV_EXPORTS_W void drawMatches( InputArray img1, const std::vector<KeyPoint>& keypoints1,
|
|
|
|
InputArray img2, const std::vector<KeyPoint>& keypoints2,
|
2014-02-05 14:55:26 +08:00
|
|
|
const std::vector<DMatch>& matches1to2, InputOutputArray outImg,
|
2010-08-04 00:28:52 +08:00
|
|
|
const Scalar& matchColor=Scalar::all(-1), const Scalar& singlePointColor=Scalar::all(-1),
|
2018-09-21 23:12:35 +08:00
|
|
|
const std::vector<char>& matchesMask=std::vector<char>(), DrawMatchesFlags flags=DrawMatchesFlags::DEFAULT );
|
2010-08-04 00:28:52 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
/** @overload */
|
2021-06-07 21:55:23 +08:00
|
|
|
CV_EXPORTS_W void drawMatches( InputArray img1, const std::vector<KeyPoint>& keypoints1,
|
|
|
|
InputArray img2, const std::vector<KeyPoint>& keypoints2,
|
|
|
|
const std::vector<DMatch>& matches1to2, InputOutputArray outImg,
|
|
|
|
const int matchesThickness, const Scalar& matchColor=Scalar::all(-1),
|
|
|
|
const Scalar& singlePointColor=Scalar::all(-1), const std::vector<char>& matchesMask=std::vector<char>(),
|
2021-06-20 02:36:27 +08:00
|
|
|
DrawMatchesFlags flags=DrawMatchesFlags::DEFAULT );
|
2021-06-07 21:55:23 +08:00
|
|
|
|
2014-02-04 20:34:18 +08:00
|
|
|
CV_EXPORTS_AS(drawMatchesKnn) void drawMatches( InputArray img1, const std::vector<KeyPoint>& keypoints1,
|
|
|
|
InputArray img2, const std::vector<KeyPoint>& keypoints2,
|
2014-02-05 14:55:26 +08:00
|
|
|
const std::vector<std::vector<DMatch> >& matches1to2, InputOutputArray outImg,
|
2010-08-04 00:28:52 +08:00
|
|
|
const Scalar& matchColor=Scalar::all(-1), const Scalar& singlePointColor=Scalar::all(-1),
|
2018-09-21 23:12:35 +08:00
|
|
|
const std::vector<std::vector<char> >& matchesMask=std::vector<std::vector<char> >(), DrawMatchesFlags flags=DrawMatchesFlags::DEFAULT );
|
2010-06-12 01:15:43 +08:00
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
//! @} features2d_draw
|
|
|
|
|
2010-08-05 20:19:26 +08:00
|
|
|
/****************************************************************************************\
|
2010-09-24 00:17:48 +08:00
|
|
|
* Functions to evaluate the feature detectors and [generic] descriptor extractors *
|
2010-08-05 20:19:26 +08:00
|
|
|
\****************************************************************************************/
|
|
|
|
|
2024-03-06 13:50:31 +08:00
|
|
|
//! @addtogroup features2d_main
|
|
|
|
//! @{
|
|
|
|
|
2010-08-05 20:19:26 +08:00
|
|
|
CV_EXPORTS void evaluateFeatureDetector( const Mat& img1, const Mat& img2, const Mat& H1to2,
|
2013-02-25 00:14:01 +08:00
|
|
|
std::vector<KeyPoint>* keypoints1, std::vector<KeyPoint>* keypoints2,
|
2010-08-05 20:19:26 +08:00
|
|
|
float& repeatability, int& correspCount,
|
|
|
|
const Ptr<FeatureDetector>& fdetector=Ptr<FeatureDetector>() );
|
|
|
|
|
2013-02-25 00:14:01 +08:00
|
|
|
CV_EXPORTS void computeRecallPrecisionCurve( const std::vector<std::vector<DMatch> >& matches1to2,
|
|
|
|
const std::vector<std::vector<uchar> >& correctMatches1to2Mask,
|
|
|
|
std::vector<Point2f>& recallPrecisionCurve );
|
2011-05-20 20:14:35 +08:00
|
|
|
|
2013-02-25 00:14:01 +08:00
|
|
|
CV_EXPORTS float getRecall( const std::vector<Point2f>& recallPrecisionCurve, float l_precision );
|
|
|
|
CV_EXPORTS int getNearestPoint( const std::vector<Point2f>& recallPrecisionCurve, float l_precision );
|
2010-08-05 20:19:26 +08:00
|
|
|
|
2024-03-06 13:50:31 +08:00
|
|
|
//! @}
|
|
|
|
|
2014-11-19 21:13:41 +08:00
|
|
|
|
2010-08-05 20:19:26 +08:00
|
|
|
} /* namespace cv */
|
2010-05-12 01:44:00 +08:00
|
|
|
|
|
|
|
#endif
|