294 lines
11 KiB
ReStructuredText
294 lines
11 KiB
ReStructuredText
Cascade Classification
|
|
======================
|
|
|
|
.. highlight:: cpp
|
|
|
|
.. index:: FeatureEvaluator
|
|
|
|
FeatureEvaluator
|
|
----------------
|
|
.. c:type:: FeatureEvaluator
|
|
|
|
Base class for computing feature values in cascade classifiers ::
|
|
|
|
class CV_EXPORTS FeatureEvaluator
|
|
{
|
|
public:
|
|
enum { HAAR = 0, LBP = 1 }; // supported feature types
|
|
virtual ~FeatureEvaluator(); // destructor
|
|
virtual bool read(const FileNode& node);
|
|
virtual Ptr<FeatureEvaluator> clone() const;
|
|
virtual int getFeatureType() const;
|
|
|
|
virtual bool setImage(const Mat& img, Size origWinSize);
|
|
virtual bool setWindow(Point p);
|
|
|
|
virtual double calcOrd(int featureIdx) const;
|
|
virtual int calcCat(int featureIdx) const;
|
|
|
|
static Ptr<FeatureEvaluator> create(int type);
|
|
};
|
|
|
|
|
|
.. index:: FeatureEvaluator::read
|
|
|
|
FeatureEvaluator::read
|
|
--------------------------
|
|
.. ocv:function:: bool FeatureEvaluator::read(const FileNode& node)
|
|
|
|
Reads parameters of features from the ``FileStorage`` node.
|
|
|
|
:param node: File node from which the feature parameters are read.
|
|
|
|
.. index:: FeatureEvaluator::clone
|
|
|
|
FeatureEvaluator::clone
|
|
---------------------------
|
|
.. ocv:function:: Ptr<FeatureEvaluator> FeatureEvaluator::clone() const
|
|
|
|
Returns a full copy of the feature evaluator.
|
|
|
|
.. index:: FeatureEvaluator::getFeatureType
|
|
|
|
FeatureEvaluator::getFeatureType
|
|
------------------------------------
|
|
.. ocv:function:: int FeatureEvaluator::getFeatureType() const
|
|
|
|
Returns the feature type (``HAAR`` or ``LBP`` for now).
|
|
|
|
.. index:: FeatureEvaluator::setImage
|
|
|
|
FeatureEvaluator::setImage
|
|
------------------------------
|
|
.. ocv:function:: bool FeatureEvaluator::setImage(const Mat& img, Size origWinSize)
|
|
|
|
Assigns an image to feature evaluator.
|
|
|
|
:param img: Matrix of the type ``CV_8UC1`` containing an image where the features are computed.
|
|
|
|
:param origWinSize: Size of training images.
|
|
|
|
The method assigns an image, where the features will be computed, to the feature evaluator.
|
|
|
|
.. index:: FeatureEvaluator::setWindow
|
|
|
|
FeatureEvaluator::setWindow
|
|
-------------------------------
|
|
.. ocv:function:: bool FeatureEvaluator::setWindow(Point p)
|
|
|
|
Assigns a window in the current image where the features will be computed.
|
|
|
|
:param p: Upper left point of the window where the features are computed. Size of the window is equal to the size of training images.
|
|
|
|
.. index:: FeatureEvaluator::calcOrd
|
|
|
|
FeatureEvaluator::calcOrd
|
|
-----------------------------
|
|
.. ocv:function:: double FeatureEvaluator::calcOrd(int featureIdx) const
|
|
|
|
Computes the value of an ordered (numerical) feature.
|
|
|
|
:param featureIdx: Index of the feature whose value is computed.
|
|
|
|
The function returns the computed value of an ordered feature.
|
|
|
|
.. index:: FeatureEvaluator::calcCat
|
|
|
|
FeatureEvaluator::calcCat
|
|
-----------------------------
|
|
.. ocv:function:: int FeatureEvaluator::calcCat(int featureIdx) const
|
|
|
|
Computes the value of a categorical feature.
|
|
|
|
:param featureIdx: Index of the feature whose value is computed.
|
|
|
|
The function returns the computed label of a categorical feature, that is, the value from [0,... (number of categories - 1)].
|
|
|
|
.. index:: FeatureEvaluator::create
|
|
|
|
FeatureEvaluator::create
|
|
----------------------------
|
|
.. ocv:function:: static Ptr<FeatureEvaluator> FeatureEvaluator::create(int type)
|
|
|
|
Constructs the feature evaluator.
|
|
|
|
:param type: Type of features evaluated by cascade (``HAAR`` or ``LBP`` for now).
|
|
|
|
.. index:: CascadeClassifier
|
|
|
|
.. _CascadeClassifier:
|
|
|
|
CascadeClassifier
|
|
-----------------
|
|
.. c:type:: CascadeClassifier
|
|
|
|
The cascade classifier class for object detection ::
|
|
|
|
class CascadeClassifier
|
|
{
|
|
public:
|
|
// structure for storing a tree node
|
|
struct CV_EXPORTS DTreeNode
|
|
{
|
|
int featureIdx; // index of the feature on which we perform the split
|
|
float threshold; // split threshold of ordered features only
|
|
int left; // left child index in the tree nodes array
|
|
int right; // right child index in the tree nodes array
|
|
};
|
|
|
|
// structure for storing a decision tree
|
|
struct CV_EXPORTS DTree
|
|
{
|
|
int nodeCount; // nodes count
|
|
};
|
|
|
|
// structure for storing a cascade stage (BOOST only for now)
|
|
struct CV_EXPORTS Stage
|
|
{
|
|
int first; // first tree index in tree array
|
|
int ntrees; // number of trees
|
|
float threshold; // threshold of stage sum
|
|
};
|
|
|
|
enum { BOOST = 0 }; // supported stage types
|
|
|
|
// mode of detection (see parameter flags in function HaarDetectObjects)
|
|
enum { DO_CANNY_PRUNING = CV_HAAR_DO_CANNY_PRUNING,
|
|
SCALE_IMAGE = CV_HAAR_SCALE_IMAGE,
|
|
FIND_BIGGEST_OBJECT = CV_HAAR_FIND_BIGGEST_OBJECT,
|
|
DO_ROUGH_SEARCH = CV_HAAR_DO_ROUGH_SEARCH };
|
|
|
|
CascadeClassifier(); // default constructor
|
|
CascadeClassifier(const string& filename);
|
|
~CascadeClassifier(); // destructor
|
|
|
|
bool empty() const;
|
|
bool load(const string& filename);
|
|
bool read(const FileNode& node);
|
|
|
|
void detectMultiScale( const Mat& image, vector<Rect>& objects,
|
|
double scaleFactor=1.1, int minNeighbors=3,
|
|
int flags=0, Size minSize=Size());
|
|
|
|
bool setImage( Ptr<FeatureEvaluator>&, const Mat& );
|
|
int runAt( Ptr<FeatureEvaluator>&, Point );
|
|
|
|
bool is_stump_based; // true, if the trees are stumps
|
|
|
|
int stageType; // stage type (BOOST only for now)
|
|
int featureType; // feature type (HAAR or LBP for now)
|
|
int ncategories; // number of categories (for categorical features only)
|
|
Size origWinSize; // size of training images
|
|
|
|
vector<Stage> stages; // vector of stages (BOOST for now)
|
|
vector<DTree> classifiers; // vector of decision trees
|
|
vector<DTreeNode> nodes; // vector of tree nodes
|
|
vector<float> leaves; // vector of leaf values
|
|
vector<int> subsets; // subsets of split by categorical feature
|
|
|
|
Ptr<FeatureEvaluator> feval; // pointer to feature evaluator
|
|
Ptr<CvHaarClassifierCascade> oldCascade; // pointer to old cascade
|
|
};
|
|
|
|
|
|
.. index:: CascadeClassifier::CascadeClassifier
|
|
|
|
CascadeClassifier::CascadeClassifier
|
|
----------------------------------------
|
|
.. ocv:function:: CascadeClassifier::CascadeClassifier(const string& filename)
|
|
|
|
Loads a classifier from a file.
|
|
|
|
:param filename: Name of the file from which the classifier is loaded.
|
|
|
|
.. index:: CascadeClassifier::empty
|
|
|
|
CascadeClassifier::empty
|
|
----------------------------
|
|
.. ocv:function:: bool CascadeClassifier::empty() const
|
|
|
|
Checks if the classifier has been loaded or not.
|
|
|
|
.. index:: CascadeClassifier::load
|
|
|
|
CascadeClassifier::load
|
|
---------------------------
|
|
.. ocv:function:: bool CascadeClassifier::load(const string& filename)
|
|
|
|
Loads a classifier from a file. The previous content is destroyed.
|
|
|
|
:param filename: Name of the file from which the classifier is loaded. The file may contain an old HAAR classifier (trained by the haartraining application) or new cascade classifier trained traincascade application.
|
|
|
|
.. index:: CascadeClassifier::read
|
|
|
|
CascadeClassifier::read
|
|
---------------------------
|
|
.. ocv:function:: bool CascadeClassifier::read(const FileNode& node)
|
|
|
|
Reads a classifier from a FileStorage node. The file may contain a new cascade classifier (trained traincascade application) only.
|
|
|
|
.. index:: CascadeClassifier::detectMultiScale
|
|
|
|
CascadeClassifier::detectMultiScale
|
|
---------------------------------------
|
|
.. ocv:function:: void CascadeClassifier::detectMultiScale( const Mat& image, vector<Rect>& objects, double scaleFactor=1.1, int minNeighbors=3, int flags=0, Size minSize=Size())
|
|
|
|
Detects objects of different sizes in the input image. The detected objects are returned as a list of rectangles.
|
|
|
|
:param image: Matrix of the type ``CV_8U`` containing an image where objects are detected.
|
|
|
|
:param objects: Vector of rectangles where each rectangle contains the detected object.
|
|
|
|
:param scaleFactor: Parameter specifying how much the image size is reduced at each image scale.
|
|
|
|
:param minNeighbors: Parameter specifying how many neighbors each candiate rectangle should have to retain it.
|
|
|
|
:param flags: Parameter with the same meaning for an old cascade as in the function ``cvHaarDetectObjects``. It is not used for a new cascade.
|
|
|
|
:param minSize: Minimum possible object size. Objects smaller than that are ignored.
|
|
|
|
.. index:: CascadeClassifier::setImage
|
|
|
|
CascadeClassifier::setImage
|
|
-------------------------------
|
|
.. ocv:function:: bool CascadeClassifier::setImage( Ptr<FeatureEvaluator>& feval, const Mat& image )
|
|
|
|
Sets an image for detection, which is called by ``detectMultiScale`` at each image level.
|
|
|
|
:param feval: Pointer to the feature evaluator that is used for computing features.
|
|
|
|
:param image: Matrix of the type ``CV_8UC1`` containing an image where the features are computed.
|
|
|
|
.. index:: CascadeClassifier::runAt
|
|
|
|
CascadeClassifier::runAt
|
|
----------------------------
|
|
.. ocv:function:: int CascadeClassifier::runAt( Ptr<FeatureEvaluator>& feval, Point pt )
|
|
|
|
Runs the detector at the specified point. Use ``setImage`` to set the image that the detector is working with.
|
|
|
|
:param feval: Feature evaluator that is used for computing features.
|
|
|
|
:param pt: Upper left point of the window where the features are computed. Size of the window is equal to the size of training images.
|
|
|
|
The function returns 1 if the cascade classifier detects an object in the given location.
|
|
Otherwise, it returns negated index of the stage at which the candidate has been rejected.
|
|
|
|
.. index:: groupRectangles
|
|
|
|
groupRectangles
|
|
-------------------
|
|
.. ocv:function:: void groupRectangles(vector<Rect>& rectList, int groupThreshold, double eps=0.2)
|
|
|
|
Groups the object candidate rectangles.
|
|
|
|
:param rectList: Input/output vector of rectangles. Output vector includes retained and grouped rectangles.??
|
|
|
|
:param groupThreshold: Minimum possible number of rectangles minus 1. The threshold is used in a group of rectangles to retain it.??
|
|
|
|
:param eps: Relative difference between sides of the rectangles to merge them into a group.
|
|
|
|
The function is a wrapper for the generic function
|
|
:ref:`partition` . It clusters all the input rectangles using the rectangle equivalence criteria that combines rectangles with similar sizes and similar locations (the similarity is defined by ``eps`` ). When ``eps=0`` , no clustering is done at all. If
|
|
:math:`\texttt{eps}\rightarrow +\inf` , all the rectangles are put in one cluster. Then, the small clusters containing less than or equal to ``groupThreshold`` rectangles are rejected. In each other cluster, the average rectangle is computed and put into the output rectangle list.
|