2011-02-22 20:43:26 +00:00
Image Processing
================
.. highlight :: cpp
2011-06-30 12:06:26 +00:00
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
gpu::meanShiftFiltering
2011-02-22 20:43:26 +00:00
---------------------------
2011-08-30 08:27:23 +00:00
Performs mean-shift filtering for each point of the source image.
2011-02-22 20:43:26 +00:00
2012-05-28 11:22:43 +00:00
.. ocv:function :: void gpu::meanShiftFiltering( const GpuMat& src, GpuMat& dst, int sp, int sr, TermCriteria criteria=TermCriteria(TermCriteria::MAX_ITER + TermCriteria::EPS, 5, 1), Stream& stream=Stream::Null() )
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param src: Source image. Only ``CV_8UC4`` images are supported for now.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param dst: Destination image containing the color of mapped points. It has the same size and type as ``src`` .
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param sp: Spatial window radius.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param sr: Color window radius.
2011-02-22 20:43:26 +00:00
2011-06-16 12:48:23 +00:00
:param criteria: Termination criteria. See :ocv:class:`TermCriteria`.
2011-03-23 10:56:20 +00:00
2011-08-30 08:27:23 +00:00
It maps each point of the source image into another point. As a result, you have a new color and new position of each point.
2011-06-30 12:06:26 +00:00
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
gpu::meanShiftProc
2011-02-22 20:43:26 +00:00
----------------------
2011-08-30 08:27:23 +00:00
Performs a mean-shift procedure and stores information about processed points (their colors and positions) in two images.
2011-02-22 20:43:26 +00:00
2012-05-28 11:22:43 +00:00
.. ocv:function :: void gpu::meanShiftProc( const GpuMat& src, GpuMat& dstr, GpuMat& dstsp, int sp, int sr, TermCriteria criteria=TermCriteria(TermCriteria::MAX_ITER + TermCriteria::EPS, 5, 1), Stream& stream=Stream::Null() )
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param src: Source image. Only ``CV_8UC4`` images are supported for now.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param dstr: Destination image containing the color of mapped points. The size and type is the same as ``src`` .
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
:param dstsp: Destination image containing the position of mapped points. The size is the same as ``src`` size. The type is ``CV_16SC2`` .
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param sp: Spatial window radius.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param sr: Color window radius.
2011-02-22 20:43:26 +00:00
2011-06-16 12:48:23 +00:00
:param criteria: Termination criteria. See :ocv:class:`TermCriteria`.
2011-03-23 10:56:20 +00:00
2011-08-30 08:27:23 +00:00
.. seealso :: :ocv:func: `gpu::meanShiftFiltering`
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
gpu::meanShiftSegmentation
2011-02-22 20:43:26 +00:00
------------------------------
2011-08-30 08:27:23 +00:00
Performs a mean-shift segmentation of the source image and eliminates small segments.
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
.. ocv:function :: void gpu::meanShiftSegmentation(const GpuMat& src, Mat& dst, int sp, int sr, int minsize, TermCriteria criteria = TermCriteria(TermCriteria::MAX_ITER + TermCriteria::EPS, 5, 1))
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param src: Source image. Only ``CV_8UC4`` images are supported for now.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param dst: Segmented image with the same size and type as ``src`` .
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param sp: Spatial window radius.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param sr: Color window radius.
2011-02-22 20:43:26 +00:00
2012-04-13 21:50:59 +00:00
:param minsize: Minimum segment size. Smaller segments are merged.
2011-02-22 20:43:26 +00:00
2011-06-16 12:48:23 +00:00
:param criteria: Termination criteria. See :ocv:class:`TermCriteria`.
2011-03-23 10:56:20 +00:00
2011-06-30 12:06:26 +00:00
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
gpu::integral
2011-02-22 20:43:26 +00:00
-----------------
2012-02-22 10:00:53 +00:00
Computes an integral image.
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
.. ocv:function :: void gpu::integral(const GpuMat& src, GpuMat& sum, Stream& stream = Stream::Null())
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param src: Source image. Only ``CV_8UC1`` images are supported for now.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param sum: Integral image containing 32-bit unsigned integer values packed into ``CV_32SC1`` .
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
:param stream: Stream for the asynchronous version.
.. seealso :: :ocv:func: `integral`
2011-06-30 12:06:26 +00:00
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
gpu::sqrIntegral
2011-02-22 20:43:26 +00:00
--------------------
2011-08-30 08:27:23 +00:00
Computes a squared integral image.
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
.. ocv:function :: void gpu::sqrIntegral(const GpuMat& src, GpuMat& sqsum, Stream& stream = Stream::Null())
2011-03-23 10:56:20 +00:00
2011-03-28 23:16:20 +00:00
:param src: Source image. Only ``CV_8UC1`` images are supported for now.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param sqsum: Squared integral image containing 64-bit unsigned integer values packed into ``CV_64FC1`` .
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
:param stream: Stream for the asynchronous version.
2011-06-30 12:06:26 +00:00
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
gpu::cornerHarris
2011-02-22 20:43:26 +00:00
---------------------
2011-08-30 08:27:23 +00:00
Computes the Harris cornerness criteria at each image pixel.
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
.. ocv:function :: void gpu::cornerHarris(const GpuMat& src, GpuMat& dst, int blockSize, int ksize, double k, int borderType=BORDER_REFLECT101)
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param src: Source image. Only ``CV_8UC1`` and ``CV_32FC1`` images are supported for now.
2011-02-22 20:43:26 +00:00
2011-04-19 11:41:12 +00:00
:param dst: Destination image containing cornerness values. It has the same size as ``src`` and ``CV_32FC1`` type.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param blockSize: Neighborhood size.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param ksize: Aperture parameter for the Sobel operator.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param k: Harris detector free parameter.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param borderType: Pixel extrapolation method. Only ``BORDER_REFLECT101`` and ``BORDER_REPLICATE`` are supported for now.
2011-02-26 11:05:10 +00:00
2011-08-30 08:27:23 +00:00
.. seealso :: :ocv:func: `cornerHarris`
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
gpu::cornerMinEigenVal
2011-02-22 20:43:26 +00:00
--------------------------
2011-08-30 08:27:23 +00:00
Computes the minimum eigen value of a 2x2 derivative covariation matrix at each pixel (the cornerness criteria).
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
.. ocv:function :: void gpu::cornerMinEigenVal(const GpuMat& src, GpuMat& dst, int blockSize, int ksize, int borderType=BORDER_REFLECT101)
2011-02-22 20:43:26 +00:00
2012-03-29 06:50:05 +00:00
.. ocv:function :: void gpu::cornerMinEigenVal(const GpuMat& src, GpuMat& dst, GpuMat& Dx, GpuMat& Dy, int blockSize, int ksize, int borderType=BORDER_REFLECT101)
.. ocv:function :: void gpu::cornerMinEigenVal(const GpuMat& src, GpuMat& dst, GpuMat& Dx, GpuMat& Dy, GpuMat& buf, int blockSize, int ksize, int borderType=BORDER_REFLECT101, Stream& stream = Stream::Null())
2011-03-28 23:16:20 +00:00
:param src: Source image. Only ``CV_8UC1`` and ``CV_32FC1`` images are supported for now.
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
:param dst: Destination image containing cornerness values. The size is the same. The type is ``CV_32FC1`` .
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param blockSize: Neighborhood size.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param ksize: Aperture parameter for the Sobel operator.
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
:param borderType: Pixel extrapolation method. Only ``BORDER_REFLECT101`` and ``BORDER_REPLICATE`` are supported for now.
2011-06-18 20:19:03 +00:00
.. seealso :: :ocv:func: `cornerMinEigenVal`
2011-03-23 10:56:20 +00:00
2011-06-30 12:06:26 +00:00
2011-02-22 20:43:26 +00:00
2012-03-28 07:11:07 +00:00
gpu::MatchTemplateBuf
---------------------
2012-05-28 07:36:14 +00:00
.. ocv:struct :: gpu::MatchTemplateBuf
2011-06-30 12:06:26 +00:00
2012-03-28 07:11:07 +00:00
Class providing memory buffers for :ocv:func: `gpu::matchTemplate` function, plus it allows to adjust some specific parameters. ::
2011-02-22 20:43:26 +00:00
2012-03-28 07:11:07 +00:00
struct CV_EXPORTS MatchTemplateBuf
2011-02-26 11:05:10 +00:00
{
2012-03-28 07:11:07 +00:00
Size user_block_size;
GpuMat imagef, templf;
std::vector<GpuMat> images;
std::vector<GpuMat> image_sums;
std::vector<GpuMat> image_sqsums;
2011-02-26 11:05:10 +00:00
};
2011-02-28 21:26:43 +00:00
2012-03-28 07:11:07 +00:00
You can use field `user_block_size` to set specific block size for :ocv:func: `gpu::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.
2011-02-22 20:43:26 +00:00
2013-04-18 10:45:48 +04:00
2011-03-23 10:56:20 +00:00
gpu::matchTemplate
2011-02-22 20:43:26 +00:00
----------------------
2011-08-30 08:27:23 +00:00
Computes a proximity map for a raster template and an image where the template is searched for.
2011-02-22 20:43:26 +00:00
2012-03-28 07:11:07 +00:00
.. ocv:function :: void gpu::matchTemplate(const GpuMat& image, const GpuMat& templ, GpuMat& result, int method, Stream &stream = Stream::Null())
.. ocv:function :: void gpu::matchTemplate(const GpuMat& image, const GpuMat& templ, GpuMat& result, int method, MatchTemplateBuf &buf, Stream& stream = Stream::Null())
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param image: Source image. ``CV_32F`` and ``CV_8U`` depth images (1..4 channels) are supported for now.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param templ: Template image with the size and type the same as ``image`` .
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
: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*.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param method: Specifies the way to compare the template with the image.
2012-04-03 06:49:13 +00:00
2012-05-29 16:55:46 +00:00
:param buf: Optional buffer to avoid extra memory allocations and to adjust some specific parameters. See :ocv:struct:`gpu::MatchTemplateBuf`.
2012-04-03 06:49:13 +00:00
2012-03-28 07:11:07 +00:00
:param stream: Stream for the asynchronous version.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
The following methods are supported for the `` CV_8U `` depth images for now:
2011-02-26 11:05:10 +00:00
2011-03-31 22:07:17 +00:00
* `` CV_TM_SQDIFF ``
* `` CV_TM_SQDIFF_NORMED ``
* `` CV_TM_CCORR ``
* `` CV_TM_CCORR_NORMED ``
* `` CV_TM_CCOEFF ``
* `` CV_TM_CCOEFF_NORMED ``
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
The following methods are supported for the `` CV_32F `` images for now:
2011-03-23 10:56:20 +00:00
2011-03-31 22:07:17 +00:00
* `` CV_TM_SQDIFF ``
* `` CV_TM_CCORR ``
2011-03-23 10:56:20 +00:00
2011-08-30 08:27:23 +00:00
.. seealso :: :ocv:func: `matchTemplate`
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
gpu::cvtColor
2011-02-22 20:43:26 +00:00
-----------------
2011-08-30 08:27:23 +00:00
Converts an image from one color space to another.
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
.. ocv:function :: void gpu::cvtColor(const GpuMat& src, GpuMat& dst, int code, int dcn = 0, Stream& stream = Stream::Null())
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
:param src: Source image with ``CV_8U`` , ``CV_16U`` , or ``CV_32F`` depth and 1, 3, or 4 channels.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param dst: Destination image with the same size and depth as ``src`` .
2011-02-22 20:43:26 +00:00
2011-06-16 12:48:23 +00:00
:param code: Color space conversion code. For details, see :ocv:func:`cvtColor` . Conversion to/from Luv and Bayer color spaces is not supported.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param dcn: Number of channels in the destination image. If the parameter is 0, the number of the channels is derived automatically from ``src`` and the ``code`` .
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param stream: Stream for the asynchronous version.
2011-02-22 20:43:26 +00:00
2012-04-13 21:50:59 +00:00
3-channel color spaces (like `` HSV `` , `` XYZ `` , and so on) can be stored in a 4-channel image for better performance.
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
.. seealso :: :ocv:func: `cvtColor`
2011-06-30 12:06:26 +00:00
2011-02-22 20:43:26 +00:00
2012-02-22 10:00:53 +00:00
gpu::swapChannels
-----------------
Exchanges the color channels of an image in-place.
.. ocv:function :: void gpu::swapChannels(GpuMat& image, const int dstOrder[4], Stream& stream = Stream::Null())
2012-03-29 06:50:05 +00:00
:param image: Source image. Supports only ``CV_8UC4`` type.
2012-02-22 10:00:53 +00:00
:param dstOrder: Integer array describing how channel values are permutated. The n-th entry of the array contains the number of the channel that is stored in the n-th channel of the output image. E.g. Given an RGBA image, aDstOrder = [3,2,1,0] converts this to ABGR channel order.
:param stream: Stream for the asynchronous version.
The methods support arbitrary permutations of the original channels, including replication.
2011-03-23 10:56:20 +00:00
gpu::rectStdDev
2011-02-22 20:43:26 +00:00
-------------------
2011-08-30 08:27:23 +00:00
Computes a standard deviation of integral images.
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
.. ocv:function :: void gpu::rectStdDev(const GpuMat& src, const GpuMat& sqr, GpuMat& dst, const Rect& rect, Stream& stream = Stream::Null())
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param src: Source image. Only the ``CV_32SC1`` type is supported.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param sqr: Squared source image. Only the ``CV_32FC1`` type is supported.
2011-02-22 20:43:26 +00:00
2011-03-29 21:48:36 +00:00
:param dst: Destination image with the same type and size as ``src`` .
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param rect: Rectangular window.
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
:param stream: Stream for the asynchronous version.
2011-06-30 12:06:26 +00:00
2011-02-22 20:43:26 +00:00
2011-03-23 10:56:20 +00:00
gpu::evenLevels
2011-02-22 20:43:26 +00:00
-------------------
2011-08-30 08:27:23 +00:00
Computes levels with even distribution.
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
.. ocv:function :: void gpu::evenLevels(GpuMat& levels, int nLevels, int lowerLevel, int upperLevel)
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param levels: Destination array. ``levels`` has 1 row, ``nLevels`` columns, and the ``CV_32SC1`` type.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param nLevels: Number of computed levels. ``nLevels`` must be at least 2.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param lowerLevel: Lower boundary value of the lowest level.
2011-02-22 20:43:26 +00:00
2011-02-26 11:05:10 +00:00
:param upperLevel: Upper boundary value of the greatest level.
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
2011-03-23 10:56:20 +00:00
gpu::histEven
2011-02-22 20:43:26 +00:00
-----------------
2011-08-30 08:27:23 +00:00
Calculates a histogram with evenly distributed bins.
.. ocv:function :: void gpu::histEven(const GpuMat& src, GpuMat& hist, int histSize, int lowerLevel, int upperLevel, Stream& stream = Stream::Null())
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
.. ocv:function :: void gpu::histEven(const GpuMat& src, GpuMat& hist, GpuMat& buf, int histSize, int lowerLevel, int upperLevel, Stream& stream = Stream::Null())
2011-02-22 20:43:26 +00:00
2012-05-28 11:22:43 +00:00
.. ocv:function :: void gpu::histEven( const GpuMat& src, GpuMat hist[4], int histSize[4], int lowerLevel[4], int upperLevel[4], Stream& stream=Stream::Null() )
2011-08-30 08:27:23 +00:00
2012-05-28 11:22:43 +00:00
.. ocv:function :: void gpu::histEven( const GpuMat& src, GpuMat hist[4], GpuMat& buf, int histSize[4], int lowerLevel[4], int upperLevel[4], Stream& stream=Stream::Null() )
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param src: Source image. ``CV_8U``, ``CV_16U``, or ``CV_16S`` depth and 1 or 4 channels are supported. For a four-channel image, all channels are processed separately.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param hist: Destination histogram with one row, ``histSize`` columns, and the ``CV_32S`` type.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param histSize: Size of the histogram.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param lowerLevel: Lower boundary of lowest-level bin.
2011-03-23 10:56:20 +00:00
2011-03-28 23:16:20 +00:00
:param upperLevel: Upper boundary of highest-level bin.
2011-03-23 10:56:20 +00:00
2011-08-30 08:27:23 +00:00
:param buf: Optional buffer to avoid extra memory allocations (for many calls with the same sizes).
:param stream: Stream for the asynchronous version.
2011-03-23 10:56:20 +00:00
gpu::histRange
2011-02-22 20:43:26 +00:00
------------------
2011-08-30 08:27:23 +00:00
Calculates a histogram with bins determined by the `` levels `` array.
.. ocv:function :: void gpu::histRange(const GpuMat& src, GpuMat& hist, const GpuMat& levels, Stream& stream = Stream::Null())
.. ocv:function :: void gpu::histRange(const GpuMat& src, GpuMat& hist, const GpuMat& levels, GpuMat& buf, Stream& stream = Stream::Null())
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
:param src: Source image. ``CV_8U`` , ``CV_16U`` , or ``CV_16S`` depth and 1 or 4 channels are supported. For a four-channel image, all channels are processed separately.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param hist: Destination histogram with one row, ``(levels.cols-1)`` columns, and the ``CV_32SC1`` type.
2011-02-22 20:43:26 +00:00
2011-03-28 23:16:20 +00:00
:param levels: Number of levels in the histogram.
2011-02-22 20:43:26 +00:00
2011-08-30 08:27:23 +00:00
:param buf: Optional buffer to avoid extra memory allocations (for many calls with the same sizes).
:param stream: Stream for the asynchronous version.
gpu::calcHist
------------------
Calculates histogram for one channel 8-bit image.
.. ocv:function :: void gpu::calcHist(const GpuMat& src, GpuMat& hist, Stream& stream = Stream::Null())
:param src: Source image.
:param hist: Destination histogram with one row, 256 columns, and the ``CV_32SC1`` type.
:param stream: Stream for the asynchronous version.
gpu::equalizeHist
------------------
Equalizes the histogram of a grayscale image.
.. ocv:function :: void gpu::equalizeHist(const GpuMat& src, GpuMat& dst, Stream& stream = Stream::Null())
.. ocv:function :: void gpu::equalizeHist(const GpuMat& src, GpuMat& dst, GpuMat& hist, GpuMat& buf, Stream& stream = Stream::Null())
:param src: Source image.
:param dst: Destination image.
:param hist: Destination histogram with one row, 256 columns, and the ``CV_32SC1`` type.
:param buf: Optional buffer to avoid extra memory allocations (for many calls with the same sizes).
:param stream: Stream for the asynchronous version.
.. seealso :: :ocv:func: `equalizeHist`
gpu::blendLinear
-------------------
Performs linear blending of two images.
.. ocv:function :: void gpu::blendLinear(const GpuMat& img1, const GpuMat& img2, const GpuMat& weights1, const GpuMat& weights2, GpuMat& result, Stream& stream = Stream::Null())
:param img1: First image. Supports only ``CV_8U`` and ``CV_32F`` depth.
2012-03-29 08:07:57 +00:00
:param img2: Second image. Must have the same size and the same type as ``img1`` .
2011-08-30 08:27:23 +00:00
:param weights1: Weights for first image. Must have tha same size as ``img1`` . Supports only ``CV_32F`` type.
:param weights2: Weights for second image. Must have tha same size as ``img2`` . Supports only ``CV_32F`` type.
:param result: Destination image.
:param stream: Stream for the asynchronous version.
2012-09-08 00:40:06 +04:00
2012-08-29 16:49:07 +04:00
gpu::bilateralFilter
2012-09-08 00:40:06 +04:00
--------------------
2012-08-29 16:49:07 +04:00
Performs bilateral filtering of passed image
2012-10-17 21:24:55 +04:00
.. ocv:function :: void gpu::bilateralFilter( const GpuMat& src, GpuMat& dst, int kernel_size, float sigma_color, float sigma_spatial, int borderMode=BORDER_DEFAULT, Stream& stream=Stream::Null() )
2012-09-08 00:40:06 +04:00
2012-08-29 16:49:07 +04:00
:param src: Source image. Supports only (channles != 2 && depth() != CV_8S && depth() != CV_32S && depth() != CV_64F).
:param dst: Destination imagwe.
:param kernel_size: Kernel window size.
2012-09-08 00:40:06 +04:00
:param sigma_color: Filter sigma in the color space.
:param sigma_spatial: Filter sigma in the coordinate space.
2012-08-29 16:49:07 +04:00
:param borderMode: Border type. See :ocv:func:`borderInterpolate` for details. ``BORDER_REFLECT101`` , ``BORDER_REPLICATE`` , ``BORDER_CONSTANT`` , ``BORDER_REFLECT`` and ``BORDER_WRAP`` are supported for now.
:param stream: Stream for the asynchronous version.
2011-08-30 08:27:23 +00:00
2012-08-29 16:49:07 +04:00
.. seealso ::
2013-04-17 18:20:18 +04:00
:ocv:func: `bilateralFilter`
2012-10-17 21:24:55 +04:00
2013-04-18 10:45:48 +04:00
2012-02-22 10:00:53 +00:00
gpu::alphaComp
-------------------
Composites two images using alpha opacity values contained in each image.
.. ocv:function :: void gpu::alphaComp(const GpuMat& img1, const GpuMat& img2, GpuMat& dst, int alpha_op, Stream& stream = Stream::Null())
:param img1: First image. Supports ``CV_8UC4`` , ``CV_16UC4`` , ``CV_32SC4`` and ``CV_32FC4`` types.
2012-03-29 08:07:57 +00:00
:param img2: Second image. Must have the same size and the same type as ``img1`` .
2012-02-22 10:00:53 +00:00
:param dst: Destination image.
:param alpha_op: Flag specifying the alpha-blending operation:
* **ALPHA_OVER**
2012-04-03 06:49:13 +00:00
* **ALPHA_IN**
* **ALPHA_OUT**
* **ALPHA_ATOP**
* **ALPHA_XOR**
* **ALPHA_PLUS**
* **ALPHA_OVER_PREMUL**
* **ALPHA_IN_PREMUL**
* **ALPHA_OUT_PREMUL**
* **ALPHA_ATOP_PREMUL**
* **ALPHA_XOR_PREMUL**
* **ALPHA_PLUS_PREMUL**
2012-02-22 10:00:53 +00:00
* **ALPHA_PREMUL**
:param stream: Stream for the asynchronous version.
2011-08-30 08:27:23 +00:00
gpu::Canny
-------------------
Finds edges in an image using the [Canny86]_ algorithm.
.. ocv:function :: void gpu::Canny(const GpuMat& image, GpuMat& edges, double low_thresh, double high_thresh, int apperture_size = 3, bool L2gradient = false)
.. ocv:function :: void gpu::Canny(const GpuMat& image, CannyBuf& buf, GpuMat& edges, double low_thresh, double high_thresh, int apperture_size = 3, bool L2gradient = false)
.. ocv:function :: void gpu::Canny(const GpuMat& dx, const GpuMat& dy, GpuMat& edges, double low_thresh, double high_thresh, bool L2gradient = false)
.. ocv:function :: void gpu::Canny(const GpuMat& dx, const GpuMat& dy, CannyBuf& buf, GpuMat& edges, double low_thresh, double high_thresh, bool L2gradient = false)
:param image: Single-channel 8-bit input image.
:param dx: First derivative of image in the vertical direction. Support only ``CV_32S`` type.
:param dy: First derivative of image in the horizontal direction. Support only ``CV_32S`` type.
:param edges: Output edge map. It has the same size and type as ``image`` .
2012-03-29 06:50:05 +00:00
:param low_thresh: First threshold for the hysteresis procedure.
2011-08-30 08:27:23 +00:00
2012-03-29 06:50:05 +00:00
:param high_thresh: Second threshold for the hysteresis procedure.
2011-08-30 08:27:23 +00:00
2012-03-29 06:50:05 +00:00
:param apperture_size: Aperture size for the :ocv:func:`Sobel` operator.
2011-08-30 08:27:23 +00:00
:param L2gradient: Flag indicating whether a more accurate :math:`L_2` norm :math:`=\sqrt{(dI/dx)^2 + (dI/dy)^2}` should be used to compute the image gradient magnitude ( ``L2gradient=true`` ), or a faster default :math:`L_1` norm :math:`=|dI/dx|+|dI/dy|` is enough ( ``L2gradient=false`` ).
:param buf: Optional buffer to avoid extra memory allocations (for many calls with the same sizes).
.. seealso :: :ocv:func: `Canny`
2012-08-15 15:06:09 +04:00
gpu::HoughLines
---------------
Finds lines in a binary image using the classical Hough transform.
.. ocv:function :: void gpu::HoughLines(const GpuMat& src, GpuMat& lines, float rho, float theta, int threshold, bool doSort = false, int maxLines = 4096)
2012-08-23 16:54:48 +04:00
.. ocv:function :: void gpu::HoughLines(const GpuMat& src, GpuMat& lines, HoughLinesBuf& buf, float rho, float theta, int threshold, bool doSort = false, int maxLines = 4096)
2012-08-15 15:06:09 +04:00
:param src: 8-bit, single-channel binary source image.
:param lines: Output vector of lines. Each line is represented by a two-element vector :math:`(\rho, \theta)` . :math:`\rho` is the distance from the coordinate origin :math:`(0,0)` (top-left corner of the image). :math:`\theta` is the line rotation angle in radians ( :math:`0 \sim \textrm{vertical line}, \pi/2 \sim \textrm{horizontal line}` ).
:param rho: Distance resolution of the accumulator in pixels.
:param theta: Angle resolution of the accumulator in radians.
:param threshold: Accumulator threshold parameter. Only those lines are returned that get enough votes ( :math:`>\texttt{threshold}` ).
:param doSort: Performs lines sort by votes.
:param maxLines: Maximum number of output lines.
:param buf: Optional buffer to avoid extra memory allocations (for many calls with the same sizes).
.. seealso :: :ocv:func: `HoughLines`
2012-08-23 16:54:48 +04:00
gpu::HoughLinesDownload
-----------------------
Downloads results from :ocv:func: `gpu::HoughLines` to host memory.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
.. ocv:function :: void gpu::HoughLinesDownload(const GpuMat& d_lines, OutputArray h_lines, OutputArray h_votes = noArray())
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param d_lines: Result of :ocv:func:`gpu::HoughLines` .
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param h_lines: Output host array.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param h_votes: Optional output array for line's votes.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
.. seealso :: :ocv:func: `gpu::HoughLines`
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
gpu::HoughCircles
-----------------
Finds circles in a grayscale image using the Hough transform.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
.. ocv:function :: void gpu::HoughCircles(const GpuMat& src, GpuMat& circles, int method, float dp, float minDist, int cannyThreshold, int votesThreshold, int minRadius, int maxRadius, int maxCircles = 4096)
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
.. ocv:function :: void gpu::HoughCircles(const GpuMat& src, GpuMat& circles, HoughCirclesBuf& buf, int method, float dp, float minDist, int cannyThreshold, int votesThreshold, int minRadius, int maxRadius, int maxCircles = 4096)
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param src: 8-bit, single-channel grayscale input image.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param circles: Output vector of found circles. Each vector is encoded as a 3-element floating-point vector :math:`(x, y, radius)` .
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param method: Detection method to use. Currently, the only implemented method is ``CV_HOUGH_GRADIENT`` , which is basically *21HT* , described in [Yuen90]_.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param dp: Inverse ratio of the accumulator resolution to the image resolution. For example, if ``dp=1`` , the accumulator has the same resolution as the input image. If ``dp=2`` , the accumulator has half as big width and height.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param minDist: Minimum distance between the centers of the detected circles. If the parameter is too small, multiple neighbor circles may be falsely detected in addition to a true one. If it is too large, some circles may be missed.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param cannyThreshold: The higher threshold of the two passed to the :ocv:func:`gpu::Canny` edge detector (the lower one is twice smaller).
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param votesThreshold: The accumulator threshold for the circle centers at the detection stage. The smaller it is, the more false circles may be detected.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param minRadius: Minimum circle radius.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param maxRadius: Maximum circle radius.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param maxCircles: Maximum number of output circles.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param buf: Optional buffer to avoid extra memory allocations (for many calls with the same sizes).
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
.. seealso :: :ocv:func: `HoughCircles`
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
gpu::HoughCirclesDownload
-------------------------
Downloads results from :ocv:func: `gpu::HoughCircles` to host memory.
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
.. ocv:function :: void gpu::HoughCirclesDownload(const GpuMat& d_circles, OutputArray h_circles)
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param d_circles: Result of :ocv:func:`gpu::HoughCircles` .
2012-08-15 15:06:09 +04:00
2012-08-23 16:54:48 +04:00
:param h_circles: Output host array.
.. seealso :: :ocv:func: `gpu::HoughCircles`