mirror of
https://github.com/opencv/opencv.git
synced 2025-01-15 20:23:36 +08:00
174 lines
5.2 KiB
ReStructuredText
174 lines
5.2 KiB
ReStructuredText
Matrix Reductions
|
|
=================
|
|
|
|
.. highlight:: cpp
|
|
|
|
.. index:: gpu::meanStdDev
|
|
|
|
gpu::meanStdDev
|
|
-------------------
|
|
.. c:function:: void gpu::meanStdDev(const GpuMat\& mtx, Scalar\& mean, Scalar\& stddev)
|
|
|
|
Computes mean value and standard deviation of matrix elements.
|
|
|
|
:param mtx: Source matrix. ``CV_8UC1`` matrices are supported for now.
|
|
|
|
:param mean: Mean value.
|
|
|
|
:param stddev: Standard deviation value.
|
|
|
|
See also:
|
|
:func:`meanStdDev` .
|
|
|
|
.. index:: gpu::norm
|
|
|
|
gpu::norm
|
|
-------------
|
|
.. c:function:: double gpu::norm(const GpuMat\& src, int normType=NORM_L2)
|
|
|
|
Returns norm of matrix (or of two matrices difference).
|
|
|
|
:param src: Source matrix. Any matrices except 64F are supported.
|
|
|
|
:param normType: Norm type. ``NORM_L1`` , ``NORM_L2`` and ``NORM_INF`` are supported for now.
|
|
|
|
.. c:function:: double norm(const GpuMat\& src, int normType, GpuMat\& buf)
|
|
|
|
* **src** Source matrix. Any matrices except 64F are supported.
|
|
|
|
* **normType** Norm type. ``NORM_L1`` , ``NORM_L2`` and ``NORM_INF`` are supported for now.
|
|
|
|
* **buf** Optional buffer to avoid extra memory allocations. It's resized automatically.
|
|
|
|
.. c:function:: double norm(const GpuMat\& src1, const GpuMat\& src2,
|
|
int normType=NORM_L2)
|
|
|
|
* **src1** First source matrix. ``CV_8UC1`` matrices are supported for now.
|
|
|
|
* **src2** Second source matrix. Must have the same size and type as ``src1``.
|
|
|
|
* **normType** Norm type. ``NORM_L1`` , ``NORM_L2`` and ``NORM_INF`` are supported for now.
|
|
|
|
See also:
|
|
:func:`norm` .
|
|
|
|
.. index:: gpu::sum
|
|
|
|
gpu::sum
|
|
------------
|
|
.. c:function:: Scalar gpu::sum(const GpuMat\& src)
|
|
|
|
.. c:function:: Scalar gpu::sum(const GpuMat\& src, GpuMat\& buf)
|
|
|
|
Returns sum of matrix elements.
|
|
|
|
:param src: Source image of any depth except ``CV_64F`` .
|
|
|
|
:param buf: Optional buffer to avoid extra memory allocations. It's resized automatically.
|
|
|
|
See also:
|
|
:func:`sum` .
|
|
|
|
.. index:: gpu::absSum
|
|
|
|
gpu::absSum
|
|
---------------
|
|
.. c:function:: Scalar gpu::absSum(const GpuMat\& src)
|
|
|
|
.. c:function:: Scalar gpu::absSum(const GpuMat\& src, GpuMat\& buf)
|
|
|
|
Returns sum of matrix elements absolute values.
|
|
|
|
:param src: Source image of any depth except ``CV_64F`` .
|
|
|
|
:param buf: Optional buffer to avoid extra memory allocations. It's resized automatically.
|
|
|
|
.. index:: gpu::sqrSum
|
|
|
|
gpu::sqrSum
|
|
---------------
|
|
.. c:function:: Scalar gpu::sqrSum(const GpuMat\& src)
|
|
|
|
.. c:function:: Scalar gpu::sqrSum(const GpuMat\& src, GpuMat\& buf)
|
|
|
|
Returns squared sum of matrix elements.
|
|
|
|
:param src: Source image of any depth except ``CV_64F`` .
|
|
|
|
:param buf: Optional buffer to avoid extra memory allocations. It's resized automatically.
|
|
|
|
.. index:: gpu::minMax
|
|
|
|
gpu::minMax
|
|
---------------
|
|
.. c:function:: void gpu::minMax(const GpuMat\& src, double* minVal, double* maxVal=0, const GpuMat\& mask=GpuMat())
|
|
|
|
.. c:function:: void gpu::minMax(const GpuMat\& src, double* minVal, double* maxVal, const GpuMat\& mask, GpuMat\& buf)
|
|
|
|
Finds global minimum and maximum matrix elements and returns their values.
|
|
|
|
:param src: Single-channel source image.
|
|
|
|
:param minVal: Pointer to returned minimum value. ``NULL`` if not required.
|
|
|
|
:param maxVal: Pointer to returned maximum value. ``NULL`` if not required.
|
|
|
|
:param mask: Optional mask to select a sub-matrix.
|
|
|
|
:param buf: Optional buffer to avoid extra memory allocations. It's resized automatically.
|
|
|
|
Function doesn't work with ``CV_64F`` images on GPU with compute capability
|
|
:math:`<` 1.3.
|
|
See also:
|
|
:func:`minMaxLoc` .
|
|
|
|
.. index:: gpu::minMaxLoc
|
|
|
|
gpu::minMaxLoc
|
|
------------------
|
|
.. c:function:: void gpu::minMaxLoc(const GpuMat& src, double* minVal, double* maxVal=0, Point* minLoc=0, Point* maxLoc=0, const GpuMat& mask=GpuMat())
|
|
|
|
.. c:function:: void gpu::minMaxLoc(const GpuMat& src, double* minVal, double* maxVal, Point* minLoc, Point* maxLoc, const GpuMat& mask, GpuMat& valbuf, GpuMat& locbuf)
|
|
|
|
Finds global minimum and maximum matrix elements and returns their values with locations.
|
|
|
|
:param src: Single-channel source image.
|
|
|
|
:param minVal: Pointer to returned minimum value. ``NULL`` if not required.
|
|
|
|
:param maxVal: Pointer to returned maximum value. ``NULL`` if not required.
|
|
|
|
:param minValLoc: Pointer to returned minimum location. ``NULL`` if not required.
|
|
|
|
:param maxValLoc: Pointer to returned maximum location. ``NULL`` if not required.
|
|
|
|
:param mask: Optional mask to select a sub-matrix.
|
|
|
|
:param valbuf: Optional values buffer to avoid extra memory allocations. It's resized automatically.
|
|
|
|
:param locbuf: Optional locations buffer to avoid extra memory allocations. It's resized automatically.
|
|
|
|
Function doesn't work with ``CV_64F`` images on GPU with compute capability
|
|
:math:`<` 1.3.
|
|
See also:
|
|
:func:`minMaxLoc` .
|
|
|
|
.. index:: gpu::countNonZero
|
|
|
|
gpu::countNonZero
|
|
---------------------
|
|
.. c:function:: int gpu::countNonZero(const GpuMat\& src)
|
|
|
|
.. c:function:: int gpu::countNonZero(const GpuMat\& src, GpuMat\& buf)
|
|
|
|
Counts non-zero matrix elements.
|
|
|
|
:param src: Single-channel source image.
|
|
|
|
:param buf: Optional buffer to avoid extra memory allocations. It's resized automatically.
|
|
|
|
Function doesn't work with ``CV_64F`` images on GPU with compute capability
|
|
:math:`<` 1.3.
|
|
See also:
|
|
:func:`countNonZero` .
|