OpenCV
4.5.1
Open Source Computer Vision
|
Functions | |
GMat | cv::gapi::concatHor (const GMat &src1, const GMat &src2) |
Applies horizontal concatenation to given matrices. More... | |
GMat | cv::gapi::concatHor (const std::vector< GMat > &v) |
GMat | cv::gapi::concatVert (const GMat &src1, const GMat &src2) |
Applies vertical concatenation to given matrices. More... | |
GMat | cv::gapi::concatVert (const std::vector< GMat > &v) |
GMat | cv::gapi::convertTo (const GMat &src, int rdepth, double alpha=1, double beta=0) |
Converts a matrix to another data depth with optional scaling. More... | |
GMat | cv::gapi::copy (const GMat &in) |
Makes a copy of the input image. Note that this copy may be not real (no actual data copied). Use this function to maintain graph contracts, e.g when graph's input needs to be passed directly to output, like in Streaming mode. More... | |
GFrame | cv::gapi::copy (const GFrame &in) |
Makes a copy of the input frame. Note that this copy may be not real (no actual data copied). Use this function to maintain graph contracts, e.g when graph's input needs to be passed directly to output, like in Streaming mode. More... | |
GMat | cv::gapi::crop (const GMat &src, const Rect &rect) |
Crops a 2D matrix. More... | |
GMat | cv::gapi::flip (const GMat &src, int flipCode) |
Flips a 2D matrix around vertical, horizontal, or both axes. More... | |
GMat | cv::gapi::LUT (const GMat &src, const Mat &lut) |
Performs a look-up table transform of a matrix. More... | |
GMat | cv::gapi::merge3 (const GMat &src1, const GMat &src2, const GMat &src3) |
Creates one 3-channel matrix out of 3 single-channel ones. More... | |
GMat | cv::gapi::merge4 (const GMat &src1, const GMat &src2, const GMat &src3, const GMat &src4) |
Creates one 4-channel matrix out of 4 single-channel ones. More... | |
GMat | cv::gapi::normalize (const GMat &src, double alpha, double beta, int norm_type, int ddepth=-1) |
Normalizes the norm or value range of an array. More... | |
GMat | cv::gapi::remap (const GMat &src, const Mat &map1, const Mat &map2, int interpolation, int borderMode=BORDER_CONSTANT, const Scalar &borderValue=Scalar()) |
Applies a generic geometrical transformation to an image. More... | |
GMat | cv::gapi::resize (const GMat &src, const Size &dsize, double fx=0, double fy=0, int interpolation=INTER_LINEAR) |
Resizes an image. More... | |
GMatP | cv::gapi::resizeP (const GMatP &src, const Size &dsize, int interpolation=cv::INTER_LINEAR) |
Resizes a planar image. More... | |
std::tuple< GMat, GMat, GMat > | cv::gapi::split3 (const GMat &src) |
Divides a 3-channel matrix into 3 single-channel matrices. More... | |
std::tuple< GMat, GMat, GMat, GMat > | cv::gapi::split4 (const GMat &src) |
Divides a 4-channel matrix into 4 single-channel matrices. More... | |
GMat | cv::gapi::warpAffine (const GMat &src, const Mat &M, const Size &dsize, int flags=cv::INTER_LINEAR, int borderMode=cv::BORDER_CONSTANT, const Scalar &borderValue=Scalar()) |
Applies an affine transformation to an image. More... | |
GMat | cv::gapi::warpPerspective (const GMat &src, const Mat &M, const Size &dsize, int flags=cv::INTER_LINEAR, int borderMode=cv::BORDER_CONSTANT, const Scalar &borderValue=Scalar()) |
Applies a perspective transformation to an image. More... | |
#include <opencv2/gapi/core.hpp>
Applies horizontal concatenation to given matrices.
The function horizontally concatenates two GMat matrices (with the same number of rows).
Output matrix must the same number of rows and depth as the src1 and src2, and the sum of cols of the src1 and src2. Supported matrix data types are CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1.
src1 | first input matrix to be considered for horizontal concatenation. |
src2 | second input matrix to be considered for horizontal concatenation. |
#include <opencv2/gapi/core.hpp>
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. The function horizontally concatenates given number of GMat matrices (with the same number of columns). Output matrix must the same number of columns and depth as the input matrices, and the sum of rows of input matrices.
v | vector of input matrices to be concatenated horizontally. |
#include <opencv2/gapi/core.hpp>
Applies vertical concatenation to given matrices.
The function vertically concatenates two GMat matrices (with the same number of cols).
Output matrix must the same number of cols and depth as the src1 and src2, and the sum of rows of the src1 and src2. Supported matrix data types are CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1.
src1 | first input matrix to be considered for vertical concatenation. |
src2 | second input matrix to be considered for vertical concatenation. |
#include <opencv2/gapi/core.hpp>
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. The function vertically concatenates given number of GMat matrices (with the same number of columns). Output matrix must the same number of columns and depth as the input matrices, and the sum of rows of input matrices.
v | vector of input matrices to be concatenated vertically. |
#include <opencv2/gapi/core.hpp>
Converts a matrix to another data depth with optional scaling.
The method converts source pixel values to the target data depth. saturate_cast<> is applied at the end to avoid possible overflows:
\[m(x,y) = saturate \_ cast<rType>( \alpha (*this)(x,y) + \beta )\]
Output matrix must be of the same size as input one.
src | input matrix to be converted from. |
rdepth | desired output matrix depth or, rather, the depth since the number of channels are the same as the input has; if rdepth is negative, the output matrix will have the same depth as the input. |
alpha | optional scale factor. |
beta | optional delta added to the scaled values. |
#include <opencv2/gapi/streaming/format.hpp>
Makes a copy of the input image. Note that this copy may be not real (no actual data copied). Use this function to maintain graph contracts, e.g when graph's input needs to be passed directly to output, like in Streaming mode.
in | Input image |
#include <opencv2/gapi/streaming/format.hpp>
Makes a copy of the input frame. Note that this copy may be not real (no actual data copied). Use this function to maintain graph contracts, e.g when graph's input needs to be passed directly to output, like in Streaming mode.
in | Input frame |
#include <opencv2/gapi/core.hpp>
Crops a 2D matrix.
The function crops the matrix by given cv::Rect.
Output matrix must be of the same depth as input one, size is specified by given rect size.
src | input matrix. |
rect | a rect to crop a matrix to |
#include <opencv2/gapi/core.hpp>
Flips a 2D matrix around vertical, horizontal, or both axes.
The function flips the matrix in one of three different ways (row and column indices are 0-based):
\[\texttt{dst} _{ij} = \left\{ \begin{array}{l l} \texttt{src} _{\texttt{src.rows}-i-1,j} & if\; \texttt{flipCode} = 0 \\ \texttt{src} _{i, \texttt{src.cols} -j-1} & if\; \texttt{flipCode} > 0 \\ \texttt{src} _{ \texttt{src.rows} -i-1, \texttt{src.cols} -j-1} & if\; \texttt{flipCode} < 0 \\ \end{array} \right.\]
The example scenarios of using the function are the following: Vertical flipping of the image (flipCode == 0) to switch between top-left and bottom-left image origin. This is a typical operation in video processing on Microsoft Windows* OS. Horizontal flipping of the image with the subsequent horizontal shift and absolute difference calculation to check for a vertical-axis symmetry (flipCode > 0). Simultaneous horizontal and vertical flipping of the image with the subsequent shift and absolute difference calculation to check for a central symmetry (flipCode < 0). Reversing the order of point arrays (flipCode > 0 or flipCode == 0). Output image must be of the same depth as input one, size should be correct for given flipCode.
src | input matrix. |
flipCode | a flag to specify how to flip the array; 0 means flipping around the x-axis and positive value (for example, 1) means flipping around y-axis. Negative value (for example, -1) means flipping around both axes. |
#include <opencv2/gapi/core.hpp>
Performs a look-up table transform of a matrix.
The function LUT fills the output matrix with values from the look-up table. Indices of the entries are taken from the input matrix. That is, the function processes each element of src as follows:
\[\texttt{dst} (I) \leftarrow \texttt{lut(src(I))}\]
Supported matrix data types are CV_8UC1. Output is a matrix of the same size and number of channels as src, and the same depth as lut.
src | input matrix of 8-bit elements. |
lut | look-up table of 256 elements; in case of multi-channel input array, the table should either have a single channel (in this case the same table is used for all channels) or the same number of channels as in the input matrix. |
#include <opencv2/gapi/core.hpp>
Creates one 3-channel matrix out of 3 single-channel ones.
The function merges several matrices to make a single multi-channel matrix. That is, each element of the output matrix will be a concatenation of the elements of the input matrices, where elements of i-th input matrix are treated as mv[i].channels()-element vectors. Output matrix must be of CV_8UC3 type.
The function split3 does the reverse operation.
GMat cv::gapi::merge4 | ( | const GMat & | src1, |
const GMat & | src2, | ||
const GMat & | src3, | ||
const GMat & | src4 | ||
) |
#include <opencv2/gapi/core.hpp>
Creates one 4-channel matrix out of 4 single-channel ones.
The function merges several matrices to make a single multi-channel matrix. That is, each element of the output matrix will be a concatenation of the elements of the input matrices, where elements of i-th input matrix are treated as mv[i].channels()-element vectors. Output matrix must be of CV_8UC4 type.
The function split4 does the reverse operation.
GMat cv::gapi::normalize | ( | const GMat & | src, |
double | alpha, | ||
double | beta, | ||
int | norm_type, | ||
int | ddepth = -1 |
||
) |
#include <opencv2/gapi/core.hpp>
Normalizes the norm or value range of an array.
The function normalizes scale and shift the input array elements so that
\[\| \texttt{dst} \| _{L_p}= \texttt{alpha}\]
(where p=Inf, 1 or 2) when normType=NORM_INF, NORM_L1, or NORM_L2, respectively; or so that
\[\min _I \texttt{dst} (I)= \texttt{alpha} , \, \, \max _I \texttt{dst} (I)= \texttt{beta}\]
when normType=NORM_MINMAX (for dense arrays only).
src | input array. |
alpha | norm value to normalize to or the lower range boundary in case of the range normalization. |
beta | upper range boundary in case of the range normalization; it is not used for the norm normalization. |
norm_type | normalization type (see cv::NormTypes). |
ddepth | when negative, the output array has the same type as src; otherwise, it has the same number of channels as src and the depth =ddepth. |
GMat cv::gapi::remap | ( | const GMat & | src, |
const Mat & | map1, | ||
const Mat & | map2, | ||
int | interpolation, | ||
int | borderMode = BORDER_CONSTANT , |
||
const Scalar & | borderValue = Scalar() |
||
) |
#include <opencv2/gapi/core.hpp>
Applies a generic geometrical transformation to an image.
The function remap transforms the source image using the specified map:
\[\texttt{dst} (x,y) = \texttt{src} (map_x(x,y),map_y(x,y))\]
where values of pixels with non-integer coordinates are computed using one of available interpolation methods. \(map_x\) and \(map_y\) can be encoded as separate floating-point maps in \(map_1\) and \(map_2\) respectively, or interleaved floating-point maps of \((x,y)\) in \(map_1\), or fixed-point maps created by using convertMaps. The reason you might want to convert from floating to fixed-point representations of a map is that they can yield much faster (2x) remapping operations. In the converted case, \(map_1\) contains pairs (cvFloor(x), cvFloor(y)) and \(map_2\) contains indices in a table of interpolation coefficients. Output image must be of the same size and depth as input one.
src | Source image. |
map1 | The first map of either (x,y) points or just x values having the type CV_16SC2, CV_32FC1, or CV_32FC2. |
map2 | The second map of y values having the type CV_16UC1, CV_32FC1, or none (empty map if map1 is (x,y) points), respectively. |
interpolation | Interpolation method (see cv::InterpolationFlags). The methods INTER_AREA and INTER_LINEAR_EXACT are not supported by this function. |
borderMode | Pixel extrapolation method (see cv::BorderTypes). When borderMode=BORDER_TRANSPARENT, it means that the pixels in the destination image that corresponds to the "outliers" in the source image are not modified by the function. |
borderValue | Value used in case of a constant border. By default, it is 0. |
GMat cv::gapi::resize | ( | const GMat & | src, |
const Size & | dsize, | ||
double | fx = 0 , |
||
double | fy = 0 , |
||
int | interpolation = INTER_LINEAR |
||
) |
#include <opencv2/gapi/core.hpp>
Resizes an image.
The function resizes the image src down to or up to the specified size.
Output image size will have the size dsize (when dsize is non-zero) or the size computed from src.size(), fx, and fy; the depth of output is the same as of src.
If you want to resize src so that it fits the pre-created dst, you may call the function as follows:
If you want to decimate the image by factor of 2 in each direction, you can call the function this way:
To shrink an image, it will generally look best with cv::INTER_AREA interpolation, whereas to enlarge an image, it will generally look best with cv::INTER_CUBIC (slow) or cv::INTER_LINEAR (faster but still looks OK).
src | input image. |
dsize | output image size; if it equals zero, it is computed as: \[\texttt{dsize = Size(round(fx*src.cols), round(fy*src.rows))}\] Either dsize or both fx and fy must be non-zero. |
fx | scale factor along the horizontal axis; when it equals 0, it is computed as \[\texttt{(double)dsize.width/src.cols}\] |
fy | scale factor along the vertical axis; when it equals 0, it is computed as \[\texttt{(double)dsize.height/src.rows}\] |
interpolation | interpolation method, see cv::InterpolationFlags |
GMatP cv::gapi::resizeP | ( | const GMatP & | src, |
const Size & | dsize, | ||
int | interpolation = cv::INTER_LINEAR |
||
) |
#include <opencv2/gapi/core.hpp>
Resizes a planar image.
The function resizes the image src down to or up to the specified size. Planar image memory layout is three planes laying in the memory contiguously, so the image height should be plane_height*plane_number, image type is CV_8UC1.
Output image size will have the size dsize, the depth of output is the same as of src.
src | input image, must be of CV_8UC1 type; |
dsize | output image size; |
interpolation | interpolation method, only cv::INTER_LINEAR is supported at the moment |
#include <opencv2/gapi/core.hpp>
Divides a 3-channel matrix into 3 single-channel matrices.
The function splits a 3-channel matrix into 3 single-channel matrices:
\[\texttt{mv} [c](I) = \texttt{src} (I)_c\]
All output matrices must be of CV_8UC1 type.
The function merge3 does the reverse operation.
src | input CV_8UC3 matrix. |
#include <opencv2/gapi/core.hpp>
Divides a 4-channel matrix into 4 single-channel matrices.
The function splits a 4-channel matrix into 4 single-channel matrices:
\[\texttt{mv} [c](I) = \texttt{src} (I)_c\]
All output matrices must be of CV_8UC1 type.
The function merge4 does the reverse operation.
src | input CV_8UC4 matrix. |
GMat cv::gapi::warpAffine | ( | const GMat & | src, |
const Mat & | M, | ||
const Size & | dsize, | ||
int | flags = cv::INTER_LINEAR , |
||
int | borderMode = cv::BORDER_CONSTANT , |
||
const Scalar & | borderValue = Scalar() |
||
) |
#include <opencv2/gapi/core.hpp>
Applies an affine transformation to an image.
The function warpAffine transforms the source image using the specified matrix:
\[\texttt{dst} (x,y) = \texttt{src} ( \texttt{M} _{11} x + \texttt{M} _{12} y + \texttt{M} _{13}, \texttt{M} _{21} x + \texttt{M} _{22} y + \texttt{M} _{23})\]
when the flag WARP_INVERSE_MAP is set. Otherwise, the transformation is first inverted with invertAffineTransform and then put in the formula above instead of M. The function cannot operate in-place.
src | input image. |
M | \(2\times 3\) transformation matrix. |
dsize | size of the output image. |
flags | combination of interpolation methods (see InterpolationFlags) and the optional flag WARP_INVERSE_MAP that means that M is the inverse transformation ( \(\texttt{dst}\rightarrow\texttt{src}\) ). |
borderMode | pixel extrapolation method (see BorderTypes); borderMode=BORDER_TRANSPARENT isn't supported |
borderValue | value used in case of a constant border; by default, it is 0. |
GMat cv::gapi::warpPerspective | ( | const GMat & | src, |
const Mat & | M, | ||
const Size & | dsize, | ||
int | flags = cv::INTER_LINEAR , |
||
int | borderMode = cv::BORDER_CONSTANT , |
||
const Scalar & | borderValue = Scalar() |
||
) |
#include <opencv2/gapi/core.hpp>
Applies a perspective transformation to an image.
The function warpPerspective transforms the source image using the specified matrix:
\[\texttt{dst} (x,y) = \texttt{src} \left ( \frac{M_{11} x + M_{12} y + M_{13}}{M_{31} x + M_{32} y + M_{33}} , \frac{M_{21} x + M_{22} y + M_{23}}{M_{31} x + M_{32} y + M_{33}} \right )\]
when the flag WARP_INVERSE_MAP is set. Otherwise, the transformation is first inverted with invert and then put in the formula above instead of M. The function cannot operate in-place.
src | input image. |
M | \(3\times 3\) transformation matrix. |
dsize | size of the output image. |
flags | combination of interpolation methods (INTER_LINEAR or INTER_NEAREST) and the optional flag WARP_INVERSE_MAP, that sets M as the inverse transformation ( \(\texttt{dst}\rightarrow\texttt{src}\) ). |
borderMode | pixel extrapolation method (BORDER_CONSTANT or BORDER_REPLICATE). |
borderValue | value used in case of a constant border; by default, it equals 0. |