2012-10-30 17:58:44 +04:00
Object Detection
=============================
.. highlight :: cpp
2012-12-26 17:51:04 +04:00
ocl::OclCascadeClassifier
2013-09-26 14:04:11 +08:00
-----------------------------
2012-12-26 17:51:04 +04:00
.. ocv:class :: ocl::OclCascadeClassifier : public CascadeClassifier
2012-10-30 17:58:44 +04:00
Cascade classifier class used for object detection. Supports HAAR cascade classifier in the form of cross link ::
2012-12-26 17:51:04 +04:00
class CV_EXPORTS OclCascadeClassifier : public CascadeClassifier
2012-10-30 17:58:44 +04:00
{
public:
2013-07-22 17:53:56 +08:00
void detectMultiScale(oclMat &image, CV_OUT std::vector<cv::Rect>& faces,
double scaleFactor = 1.1, int minNeighbors = 3, int flags = 0,
Size minSize = Size(), Size maxSize = Size());
2012-10-30 17:58:44 +04:00
};
2013-08-06 16:24:09 +02:00
.. note ::
2013-08-02 14:05:08 +02:00
2013-08-06 16:24:09 +02:00
(Ocl) A face detection example using cascade classifiers can be found at opencv_source_code/samples/ocl/facedetect.cpp
2013-08-02 14:05:08 +02:00
2013-10-01 15:57:33 +04:00
ocl::OclCascadeClassifier::detectMultiScale
2012-10-30 17:58:44 +04:00
------------------------------------------------------
2013-07-22 17:53:56 +08:00
Detects objects of different sizes in the input image.
2012-10-30 17:58:44 +04:00
2013-07-22 17:53:56 +08:00
.. ocv:function :: void ocl::OclCascadeClassifier::detectMultiScale(oclMat &image, std::vector<cv::Rect>& faces, double scaleFactor = 1.1, int minNeighbors = 3, int flags = 0, Size minSize = Size(), Size maxSize = Size())
2012-10-30 17:58:44 +04:00
2013-07-22 17:53:56 +08:00
:param faces: Vector of rectangles where each rectangle contains the detected object.
2012-10-30 17:58:44 +04:00
2013-10-01 15:57:33 +04:00
:param image: Matrix of type CV_8U containing an image where objects should be detected.
2012-10-30 17:58:44 +04:00
:param scaleFactor: Parameter specifying how much the image size is reduced at each image scale.
:param minNeighbors: Parameter specifying how many neighbors each candidate rectangle should have to retain it.
2013-09-26 14:04:11 +08:00
:param flags: Parameter with the same meaning for an old cascade as in the function ``cvHaarDetectObjects``. It is not used for a new cascade.
2012-10-30 17:58:44 +04:00
:param minSize: Minimum possible object size. Objects smaller than that are ignored.
2013-07-22 17:53:56 +08:00
:param maxSize: Maximum possible object size. Objects larger than that are ignored.
The function provides a very similar interface with that in CascadeClassifier class, except using oclMat as input image.
2012-10-30 17:58:44 +04:00
ocl::MatchTemplateBuf
2013-09-26 14:04:11 +08:00
-------------------------
2012-12-26 17:51:04 +04:00
.. ocv:struct :: ocl::MatchTemplateBuf
2012-10-30 17:58:44 +04:00
Class providing memory buffers for :ocv:func: `ocl::matchTemplate` function, plus it allows to adjust some specific parameters. ::
struct CV_EXPORTS MatchTemplateBuf
{
Size user_block_size;
oclMat imagef, templf;
std::vector<oclMat> images;
std::vector<oclMat> image_sums;
std::vector<oclMat> image_sqsums;
};
You can use field `user_block_size` to set specific block size for :ocv:func: `ocl::matchTemplate` function. If you leave its default value `Size(0,0)` then automatic estimation of block size will be used (which is optimized for speed). By varying `user_block_size` you can reduce memory requirements at the cost of speed.
ocl::matchTemplate
2013-09-26 14:04:11 +08:00
----------------------
2012-10-30 17:58:44 +04:00
Computes a proximity map for a raster template and an image where the template is searched for.
.. ocv:function :: void ocl::matchTemplate(const oclMat& image, const oclMat& templ, oclMat& result, int method)
.. ocv:function :: void ocl::matchTemplate(const oclMat& image, const oclMat& templ, oclMat& result, int method, MatchTemplateBuf &buf)
:param image: Source image. ``CV_32F`` and ``CV_8U`` depth images (1..4 channels) are supported for now.
:param templ: Template image with the size and type the same as ``image`` .
:param result: Map containing comparison results ( ``CV_32FC1`` ). If ``image`` is *W x H* and ``templ`` is *w x h*, then ``result`` must be *W-w+1 x H-h+1*.
:param method: Specifies the way to compare the template with the image.
2013-01-13 16:27:11 +04:00
:param buf: Optional buffer to avoid extra memory allocations and to adjust some specific parameters. See :ocv:struct:`ocl::MatchTemplateBuf`.
2012-10-30 17:58:44 +04:00
The following methods are supported for the `` CV_8U `` depth images for now:
* `` CV_TM_SQDIFF ``
* `` CV_TM_SQDIFF_NORMED ``
* `` CV_TM_CCORR ``
* `` CV_TM_CCORR_NORMED ``
* `` CV_TM_CCOEFF ``
* `` CV_TM_CCOEFF_NORMED ``
The following methods are supported for the `` CV_32F `` images for now:
* `` CV_TM_SQDIFF ``
* `` CV_TM_CCORR ``
.. seealso :: :ocv:func: `matchTemplate`