pub struct Mat { /* private fields */ }
Expand description
n-dimensional dense array class \anchor CVMat_Details
The class Mat represents an n-dimensional dense numerical single-channel or multi-channel array. It
can be used to store real or complex-valued vectors and matrices, grayscale or color images, voxel
volumes, vector fields, point clouds, tensors, histograms (though, very high-dimensional histograms
may be better stored in a SparseMat ). The data layout of the array M
is defined by the array
M.step[]
, so that the address of element , where
, is
computed as:
In case of a 2-dimensional array, the above formula is reduced to:
Note that
M.step[i] >= M.step[i+1]
(in fact, M.step[i] >= M.step[i+1]*M.size[i+1]
). This means
that 2-dimensional matrices are stored row-by-row, 3-dimensional matrices are stored plane-by-plane,
and so on. M.step[M.dims-1] is minimal and always equal to the element size M.elemSize() .
So, the data layout in Mat is compatible with the majority of dense array types from the standard toolkits and SDKs, such as Numpy (ndarray), Win32 (independent device bitmaps), and others, that is, with any array that uses steps (or strides) to compute the position of a pixel. Due to this compatibility, it is possible to make a Mat header for user-allocated data and process it in-place using OpenCV functions.
There are many different ways to create a Mat object. The most popular options are listed below:
- Use the create(nrows, ncols, type) method or the similar Mat(nrows, ncols, type[, fillValue]) constructor. A new array of the specified size and type is allocated. type has the same meaning as in the cvCreateMat method. For example, CV_8UC1 means a 8-bit single-channel array, CV_32FC2 means a 2-channel (complex) floating-point array, and so on.
// make a 7x7 complex matrix filled with 1+3j.
Mat M(7,7,CV_32FC2,Scalar(1,3));
// and now turn M to a 100x60 15-channel 8-bit matrix.
// The old content will be deallocated
M.create(100,60,CV_8UC(15));
As noted in the introduction to this chapter, create() allocates only a new array when the shape or type of the current array are different from the specified ones.
- Create a multi-dimensional array:
// create a 100x100x100 8-bit array
int sz[] = {100, 100, 100};
Mat bigCube(3, sz, CV_8U, Scalar::all(0));
It passes the number of dimensions =1 to the Mat constructor but the created array will be 2-dimensional with the number of columns set to 1. So, Mat::dims is always >= 2 (can also be 0 when the array is empty).
-
Use a copy constructor or assignment operator where there can be an array or expression on the right side (see below). As noted in the introduction, the array assignment is an O(1) operation because it only copies the header and increases the reference counter. The Mat::clone() method can be used to get a full (deep) copy of the array when you need it.
-
Construct a header for a part of another array. It can be a single row, single column, several rows, several columns, rectangular region in the array (called a minor in algebra) or a diagonal. Such operations are also O(1) because the new header references the same data. You can actually modify a part of the array using this feature, for example:
// add the 5-th row, multiplied by 3 to the 3rd row
M.row(3) = M.row(3) + M.row(5)*3;
// now copy the 7-th column to the 1-st column
// M.col(1) = M.col(7); // this will not work
Mat M1 = M.col(1);
M.col(7).copyTo(M1);
// create a new 320x240 image
Mat img(Size(320,240),CV_8UC3);
// select a ROI
Mat roi(img, Rect(10,10,100,100));
// fill the ROI with (0,255,0) (which is green in RGB space);
// the original 320x240 image will be modified
roi = Scalar(0,255,0);
Due to the additional datastart and dataend members, it is possible to compute a relative sub-array position in the main container array using locateROI():
Mat A = Mat::eye(10, 10, CV_32S);
// extracts A columns, 1 (inclusive) to 3 (exclusive).
Mat B = A(Range::all(), Range(1, 3));
// extracts B rows, 5 (inclusive) to 9 (exclusive).
// that is, C \~ A(Range(5, 9), Range(1, 3))
Mat C = B(Range(5, 9), Range::all());
Size size; Point ofs;
C.locateROI(size, ofs);
// size will be (width=10,height=10) and the ofs will be (x=1, y=5)
As in case of whole matrices, if you need a deep copy, use the clone()
method of the extracted
sub-matrices.
-
Make a header for user-allocated data. It can be useful to do the following: -# Process “foreign” data using OpenCV (for example, when you implement a DirectShow* filter or a processing module for gstreamer, and so on). For example:
Mat process_video_frame(const unsigned char* pixels, int width, int height, int step) { // wrap input buffer Mat img(height, width, CV_8UC3, (unsigned char*)pixels, step); Mat result; GaussianBlur(img, result, Size(7, 7), 1.5, 1.5); return result; }
-# Quickly initialize small matrices and/or get a super-fast element access.
double m[3][3] = {{a, b, c}, {d, e, f}, {g, h, i}}; Mat M = Mat(3, 3, CV_64F, m).inv();
.
-
Use MATLAB-style array initializers, zeros(), ones(), eye(), for example:
// create a double-precision identity matrix and add it to M.
M += Mat::eye(M.rows, M.cols, CV_64F);
- Use a comma-separated initializer:
// create a 3x3 double-precision identity matrix
Mat M = (Mat_<double>(3,3) << 1, 0, 0, 0, 1, 0, 0, 0, 1);
With this approach, you first call a constructor of the Mat class with the proper parameters, and
then you just put << operator
followed by comma-separated values that can be constants,
variables, expressions, and so on. Also, note the extra parentheses required to avoid compilation
errors.
Once the array is created, it is automatically managed via a reference-counting mechanism. If the array header is built on top of user-allocated data, you should handle the data by yourself. The array data is deallocated when no one points to it. If you want to release the data pointed by a array header before the array destructor is called, use Mat::release().
The next important thing to learn about the array class is element access. This manual already
described how to compute an address of each array element. Normally, you are not required to use the
formula directly in the code. If you know the array element type (which can be retrieved using the
method Mat::type() ), you can access the element of a 2-dimensional array as:
M.at<double>(i,j) += 1.f;
assuming that M
is a double-precision floating-point array. There are several variants of the method
at for a different number of dimensions.
If you need to process a whole row of a 2D array, the most efficient way is to get the pointer to the row first, and then just use the plain C operator [] :
// compute sum of positive matrix elements
// (assuming that M is a double-precision matrix)
double sum=0;
for(int i = 0; i < M.rows; i++)
{
const double* Mi = M.ptr<double>(i);
for(int j = 0; j < M.cols; j++)
sum += std::max(Mi[j], 0.);
}
Some operations, like the one above, do not actually depend on the array shape. They just process elements of an array one by one (or elements from multiple arrays that have the same coordinates, for example, array addition). Such operations are called element-wise. It makes sense to check whether all the input/output arrays are continuous, namely, have no gaps at the end of each row. If yes, process them as a long single row:
// compute the sum of positive matrix elements, optimized variant
double sum=0;
int cols = M.cols, rows = M.rows;
if(M.isContinuous())
{
cols *= rows;
rows = 1;
}
for(int i = 0; i < rows; i++)
{
const double* Mi = M.ptr<double>(i);
for(int j = 0; j < cols; j++)
sum += std::max(Mi[j], 0.);
}
In case of the continuous matrix, the outer loop body is executed just once. So, the overhead is smaller, which is especially noticeable in case of small matrices.
Finally, there are STL-style iterators that are smart enough to skip gaps between successive rows:
// compute sum of positive matrix elements, iterator-based variant
double sum=0;
MatConstIterator_<double> it = M.begin<double>(), it_end = M.end<double>();
for(; it != it_end; ++it)
sum += std::max(*it, 0.);
The matrix iterators are random-access iterators, so they can be passed to any STL algorithm, including std::sort().
Note: Matrix Expressions and arithmetic see MatExpr
Implementations§
Source§impl Mat
impl Mat
Sourcepub fn from_exact_iter<T: DataType>(
s: impl ExactSizeIterator<Item = T>,
) -> Result<Self>
pub fn from_exact_iter<T: DataType>( s: impl ExactSizeIterator<Item = T>, ) -> Result<Self>
Create new Mat
from the iterator of known size
Sourcepub fn from_slice<T: DataType>(s: &[T]) -> Result<BoxedRef<'_, Self>>
pub fn from_slice<T: DataType>(s: &[T]) -> Result<BoxedRef<'_, Self>>
Create a new Mat
from a single-dimensional slice
Sourcepub fn from_bytes<T: DataType>(s: &[u8]) -> Result<BoxedRef<'_, Self>>
pub fn from_bytes<T: DataType>(s: &[u8]) -> Result<BoxedRef<'_, Self>>
Create a new Mat
from a single-dimensional byte slice
Sourcepub fn from_bytes_mut<T: DataType>(
s: &mut [u8],
) -> Result<BoxedRefMut<'_, Self>>
pub fn from_bytes_mut<T: DataType>( s: &mut [u8], ) -> Result<BoxedRefMut<'_, Self>>
Create a new Mat
from a mutable single-dimensional byte slice
Sourcepub fn from_slice_mut<T: DataType>(s: &mut [T]) -> Result<BoxedRefMut<'_, Self>>
pub fn from_slice_mut<T: DataType>(s: &mut [T]) -> Result<BoxedRefMut<'_, Self>>
Create a new Mat
from a mutable single-dimensional slice
Sourcepub fn from_slice_2d<T: DataType>(s: &[impl AsRef<[T]>]) -> Result<Self>
pub fn from_slice_2d<T: DataType>(s: &[impl AsRef<[T]>]) -> Result<Self>
Create a new Mat
by copying the data from a slice of slices
Every subslice must have the same length, otherwise an error is returned.
Sourcepub fn new_rows_cols_with_data<T: DataType>(
rows: i32,
cols: i32,
data: &[T],
) -> Result<BoxedRef<'_, Self>>
pub fn new_rows_cols_with_data<T: DataType>( rows: i32, cols: i32, data: &[T], ) -> Result<BoxedRef<'_, Self>>
Create a new Mat
that references a single-dimensional slice with custom shape
Sourcepub fn new_rows_cols_with_bytes<T: DataType>(
rows: i32,
cols: i32,
data: &[u8],
) -> Result<BoxedRef<'_, Self>>
pub fn new_rows_cols_with_bytes<T: DataType>( rows: i32, cols: i32, data: &[u8], ) -> Result<BoxedRef<'_, Self>>
Create a new Mat
that references a single-dimensional byte slice with custom shape
Sourcepub fn new_rows_cols_with_data_mut<T: DataType>(
rows: i32,
cols: i32,
data: &mut [T],
) -> Result<BoxedRefMut<'_, Self>>
pub fn new_rows_cols_with_data_mut<T: DataType>( rows: i32, cols: i32, data: &mut [T], ) -> Result<BoxedRefMut<'_, Self>>
Create a new mutable Mat
that references a single-dimensional slice with custom shape
Sourcepub fn new_rows_cols_with_bytes_mut<T: DataType>(
rows: i32,
cols: i32,
data: &mut [u8],
) -> Result<BoxedRefMut<'_, Self>>
pub fn new_rows_cols_with_bytes_mut<T: DataType>( rows: i32, cols: i32, data: &mut [u8], ) -> Result<BoxedRefMut<'_, Self>>
Create a new mutable Mat
that references a single-dimensional byte slice with custom shape
Sourcepub fn new_size_with_data<T: DataType>(
size: Size,
data: &[T],
) -> Result<BoxedRef<'_, Self>>
pub fn new_size_with_data<T: DataType>( size: Size, data: &[T], ) -> Result<BoxedRef<'_, Self>>
Create a new Mat
that references a single-dimensional slice with custom shape
Sourcepub fn new_size_with_data_mut<T: DataType>(
size: Size,
data: &mut [T],
) -> Result<BoxedRefMut<'_, Self>>
pub fn new_size_with_data_mut<T: DataType>( size: Size, data: &mut [T], ) -> Result<BoxedRefMut<'_, Self>>
Create a new mutable Mat
that references a single-dimensional slice with custom shape
Sourcepub fn new_nd_with_data<'data, T: DataType>(
sizes: &[i32],
data: &'data [T],
) -> Result<BoxedRef<'data, Self>>
pub fn new_nd_with_data<'data, T: DataType>( sizes: &[i32], data: &'data [T], ) -> Result<BoxedRef<'data, Self>>
Create a new Mat
that references a single-dimensional slice with custom shape
Sourcepub fn new_nd_with_data_mut<'data, T: DataType>(
sizes: &[i32],
data: &'data mut [T],
) -> Result<BoxedRefMut<'data, Self>>
pub fn new_nd_with_data_mut<'data, T: DataType>( sizes: &[i32], data: &'data mut [T], ) -> Result<BoxedRefMut<'data, Self>>
Create a new Mat
that references a single-dimensional slice with custom shape
Source§impl Mat
impl Mat
Sourcepub fn default() -> Mat
pub fn default() -> Mat
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
Sourcepub unsafe fn new_rows_cols(rows: i32, cols: i32, typ: i32) -> Result<Mat>
pub unsafe fn new_rows_cols(rows: i32, cols: i32, typ: i32) -> Result<Mat>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- rows: Number of rows in a 2D array.
- cols: Number of columns in a 2D array.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
Sourcepub unsafe fn new_size(size: Size, typ: i32) -> Result<Mat>
pub unsafe fn new_size(size: Size, typ: i32) -> Result<Mat>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- size: 2D array size: Size(cols, rows) . In the Size() constructor, the number of rows and the number of columns go in the reverse order.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
Sourcepub fn new_rows_cols_with_default(
rows: i32,
cols: i32,
typ: i32,
s: Scalar,
) -> Result<Mat>
pub fn new_rows_cols_with_default( rows: i32, cols: i32, typ: i32, s: Scalar, ) -> Result<Mat>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- rows: Number of rows in a 2D array.
- cols: Number of columns in a 2D array.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
- s: An optional value to initialize each matrix element with. To set all the matrix elements to the particular value after the construction, use the assignment operator Mat::operator=(const Scalar& value) .
Sourcepub fn new_size_with_default(size: Size, typ: i32, s: Scalar) -> Result<Mat>
pub fn new_size_with_default(size: Size, typ: i32, s: Scalar) -> Result<Mat>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- size: 2D array size: Size(cols, rows) . In the Size() constructor, the number of rows and the number of columns go in the reverse order.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
- s: An optional value to initialize each matrix element with. To set all the matrix elements to the particular value after the construction, use the assignment operator Mat::operator=(const Scalar& value) .
Sourcepub unsafe fn new_nd(sizes: &[i32], typ: i32) -> Result<Mat>
pub unsafe fn new_nd(sizes: &[i32], typ: i32) -> Result<Mat>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- ndims: Array dimensionality.
- sizes: Array of integers specifying an n-dimensional array shape.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
Sourcepub unsafe fn new_nd_vec(sizes: &Vector<i32>, typ: i32) -> Result<Mat>
pub unsafe fn new_nd_vec(sizes: &Vector<i32>, typ: i32) -> Result<Mat>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- sizes: Array of integers specifying an n-dimensional array shape.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
Sourcepub fn new_nd_with_default(sizes: &[i32], typ: i32, s: Scalar) -> Result<Mat>
pub fn new_nd_with_default(sizes: &[i32], typ: i32, s: Scalar) -> Result<Mat>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- ndims: Array dimensionality.
- sizes: Array of integers specifying an n-dimensional array shape.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
- s: An optional value to initialize each matrix element with. To set all the matrix elements to the particular value after the construction, use the assignment operator Mat::operator=(const Scalar& value) .
Sourcepub fn new_nd_vec_with_default(
sizes: &Vector<i32>,
typ: i32,
s: Scalar,
) -> Result<Mat>
pub fn new_nd_vec_with_default( sizes: &Vector<i32>, typ: i32, s: Scalar, ) -> Result<Mat>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- sizes: Array of integers specifying an n-dimensional array shape.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
- s: An optional value to initialize each matrix element with. To set all the matrix elements to the particular value after the construction, use the assignment operator Mat::operator=(const Scalar& value) .
Sourcepub fn copy(m: &impl MatTraitConst) -> Result<BoxedRef<'_, Mat>>
pub fn copy(m: &impl MatTraitConst) -> Result<BoxedRef<'_, Mat>>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- m: Array that (as a whole or partly) is assigned to the constructed matrix. No data is copied by these constructors. Instead, the header pointing to m data or its sub-array is constructed and associated with it. The reference counter, if any, is incremented. So, when you modify the matrix formed using such a constructor, you also modify the corresponding elements of m . If you want to have an independent copy of the sub-array, use Mat::clone() .
Sourcepub fn copy_mut(m: &mut impl MatTrait) -> Result<BoxedRefMut<'_, Mat>>
pub fn copy_mut(m: &mut impl MatTrait) -> Result<BoxedRefMut<'_, Mat>>
@overload
§Parameters
- m: Array that (as a whole or partly) is assigned to the constructed matrix. No data is copied by these constructors. Instead, the header pointing to m data or its sub-array is constructed and associated with it. The reference counter, if any, is incremented. So, when you modify the matrix formed using such a constructor, you also modify the corresponding elements of m . If you want to have an independent copy of the sub-array, use Mat::clone() .
Sourcepub unsafe fn new_rows_cols_with_data_unsafe(
rows: i32,
cols: i32,
typ: i32,
data: *mut c_void,
step: size_t,
) -> Result<Mat>
pub unsafe fn new_rows_cols_with_data_unsafe( rows: i32, cols: i32, typ: i32, data: *mut c_void, step: size_t, ) -> Result<Mat>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- rows: Number of rows in a 2D array.
- cols: Number of columns in a 2D array.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
- data: Pointer to the user data. Matrix constructors that take data and step parameters do not allocate matrix data. Instead, they just initialize the matrix header that points to the specified data, which means that no data is copied. This operation is very efficient and can be used to process external data using OpenCV functions. The external data is not automatically deallocated, so you should take care of it.
- step: Number of bytes each matrix row occupies. The value should include the padding bytes at the end of each row, if any. If the parameter is missing (set to AUTO_STEP ), no padding is assumed and the actual step is calculated as cols*elemSize(). See Mat::elemSize.
§C++ default parameters
- step: AUTO_STEP
Sourcepub unsafe fn new_rows_cols_with_data_unsafe_def(
rows: i32,
cols: i32,
typ: i32,
data: *mut c_void,
) -> Result<Mat>
pub unsafe fn new_rows_cols_with_data_unsafe_def( rows: i32, cols: i32, typ: i32, data: *mut c_void, ) -> Result<Mat>
@overload
§Parameters
- rows: Number of rows in a 2D array.
- cols: Number of columns in a 2D array.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
- data: Pointer to the user data. Matrix constructors that take data and step parameters do not allocate matrix data. Instead, they just initialize the matrix header that points to the specified data, which means that no data is copied. This operation is very efficient and can be used to process external data using OpenCV functions. The external data is not automatically deallocated, so you should take care of it.
- step: Number of bytes each matrix row occupies. The value should include the padding bytes at the end of each row, if any. If the parameter is missing (set to AUTO_STEP ), no padding is assumed and the actual step is calculated as cols*elemSize(). See Mat::elemSize.
§Note
This alternative version of [new_rows_cols_with_data_unsafe] function uses the following default values for its arguments:
- step: AUTO_STEP
Sourcepub unsafe fn new_size_with_data_unsafe(
size: Size,
typ: i32,
data: *mut c_void,
step: size_t,
) -> Result<Mat>
pub unsafe fn new_size_with_data_unsafe( size: Size, typ: i32, data: *mut c_void, step: size_t, ) -> Result<Mat>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- size: 2D array size: Size(cols, rows) . In the Size() constructor, the number of rows and the number of columns go in the reverse order.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
- data: Pointer to the user data. Matrix constructors that take data and step parameters do not allocate matrix data. Instead, they just initialize the matrix header that points to the specified data, which means that no data is copied. This operation is very efficient and can be used to process external data using OpenCV functions. The external data is not automatically deallocated, so you should take care of it.
- step: Number of bytes each matrix row occupies. The value should include the padding bytes at the end of each row, if any. If the parameter is missing (set to AUTO_STEP ), no padding is assumed and the actual step is calculated as cols*elemSize(). See Mat::elemSize.
§C++ default parameters
- step: AUTO_STEP
Sourcepub unsafe fn new_size_with_data_unsafe_def(
size: Size,
typ: i32,
data: *mut c_void,
) -> Result<Mat>
pub unsafe fn new_size_with_data_unsafe_def( size: Size, typ: i32, data: *mut c_void, ) -> Result<Mat>
@overload
§Parameters
- size: 2D array size: Size(cols, rows) . In the Size() constructor, the number of rows and the number of columns go in the reverse order.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
- data: Pointer to the user data. Matrix constructors that take data and step parameters do not allocate matrix data. Instead, they just initialize the matrix header that points to the specified data, which means that no data is copied. This operation is very efficient and can be used to process external data using OpenCV functions. The external data is not automatically deallocated, so you should take care of it.
- step: Number of bytes each matrix row occupies. The value should include the padding bytes at the end of each row, if any. If the parameter is missing (set to AUTO_STEP ), no padding is assumed and the actual step is calculated as cols*elemSize(). See Mat::elemSize.
§Note
This alternative version of [new_size_with_data_unsafe] function uses the following default values for its arguments:
- step: AUTO_STEP
Sourcepub unsafe fn new_nd_with_data_unsafe(
sizes: &[i32],
typ: i32,
data: *mut c_void,
steps: Option<&[size_t]>,
) -> Result<Mat>
pub unsafe fn new_nd_with_data_unsafe( sizes: &[i32], typ: i32, data: *mut c_void, steps: Option<&[size_t]>, ) -> Result<Mat>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- ndims: Array dimensionality.
- sizes: Array of integers specifying an n-dimensional array shape.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
- data: Pointer to the user data. Matrix constructors that take data and step parameters do not allocate matrix data. Instead, they just initialize the matrix header that points to the specified data, which means that no data is copied. This operation is very efficient and can be used to process external data using OpenCV functions. The external data is not automatically deallocated, so you should take care of it.
- steps: Array of ndims-1 steps in case of a multi-dimensional array (the last step is always set to the element size). If not specified, the matrix is assumed to be continuous.
§C++ default parameters
- steps: 0
Sourcepub unsafe fn new_nd_with_data_unsafe_def(
sizes: &[i32],
typ: i32,
data: *mut c_void,
) -> Result<Mat>
pub unsafe fn new_nd_with_data_unsafe_def( sizes: &[i32], typ: i32, data: *mut c_void, ) -> Result<Mat>
@overload
§Parameters
- ndims: Array dimensionality.
- sizes: Array of integers specifying an n-dimensional array shape.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
- data: Pointer to the user data. Matrix constructors that take data and step parameters do not allocate matrix data. Instead, they just initialize the matrix header that points to the specified data, which means that no data is copied. This operation is very efficient and can be used to process external data using OpenCV functions. The external data is not automatically deallocated, so you should take care of it.
- steps: Array of ndims-1 steps in case of a multi-dimensional array (the last step is always set to the element size). If not specified, the matrix is assumed to be continuous.
§Note
This alternative version of [new_nd_with_data_unsafe] function uses the following default values for its arguments:
- steps: 0
Sourcepub unsafe fn new_nd_vec_with_data_unsafe(
sizes: &Vector<i32>,
typ: i32,
data: *mut c_void,
steps: Option<&[size_t]>,
) -> Result<Mat>
pub unsafe fn new_nd_vec_with_data_unsafe( sizes: &Vector<i32>, typ: i32, data: *mut c_void, steps: Option<&[size_t]>, ) -> Result<Mat>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- sizes: Array of integers specifying an n-dimensional array shape.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
- data: Pointer to the user data. Matrix constructors that take data and step parameters do not allocate matrix data. Instead, they just initialize the matrix header that points to the specified data, which means that no data is copied. This operation is very efficient and can be used to process external data using OpenCV functions. The external data is not automatically deallocated, so you should take care of it.
- steps: Array of ndims-1 steps in case of a multi-dimensional array (the last step is always set to the element size). If not specified, the matrix is assumed to be continuous.
§C++ default parameters
- steps: 0
Sourcepub unsafe fn new_nd_vec_with_data_unsafe_def(
sizes: &Vector<i32>,
typ: i32,
data: *mut c_void,
) -> Result<Mat>
pub unsafe fn new_nd_vec_with_data_unsafe_def( sizes: &Vector<i32>, typ: i32, data: *mut c_void, ) -> Result<Mat>
@overload
§Parameters
- sizes: Array of integers specifying an n-dimensional array shape.
- type: Array type. Use CV_8UC1, …, CV_64FC4 to create 1-4 channel matrices, or CV_8UC(n), …, CV_64FC(n) to create multi-channel (up to CV_CN_MAX channels) matrices.
- data: Pointer to the user data. Matrix constructors that take data and step parameters do not allocate matrix data. Instead, they just initialize the matrix header that points to the specified data, which means that no data is copied. This operation is very efficient and can be used to process external data using OpenCV functions. The external data is not automatically deallocated, so you should take care of it.
- steps: Array of ndims-1 steps in case of a multi-dimensional array (the last step is always set to the element size). If not specified, the matrix is assumed to be continuous.
§Note
This alternative version of [new_nd_vec_with_data_unsafe] function uses the following default values for its arguments:
- steps: 0
Sourcepub fn rowscols<'boxed>(
m: &'boxed impl MatTraitConst,
row_range: &impl RangeTraitConst,
col_range: &impl RangeTraitConst,
) -> Result<BoxedRef<'boxed, Mat>>
pub fn rowscols<'boxed>( m: &'boxed impl MatTraitConst, row_range: &impl RangeTraitConst, col_range: &impl RangeTraitConst, ) -> Result<BoxedRef<'boxed, Mat>>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- m: Array that (as a whole or partly) is assigned to the constructed matrix. No data is copied by these constructors. Instead, the header pointing to m data or its sub-array is constructed and associated with it. The reference counter, if any, is incremented. So, when you modify the matrix formed using such a constructor, you also modify the corresponding elements of m . If you want to have an independent copy of the sub-array, use Mat::clone() .
- rowRange: Range of the m rows to take. As usual, the range start is inclusive and the range end is exclusive. Use Range::all() to take all the rows.
- colRange: Range of the m columns to take. Use Range::all() to take all the columns.
§C++ default parameters
- col_range: Range::all()
Sourcepub fn rowscols_def_mut<'boxed>(
m: &'boxed mut impl MatTrait,
row_range: &impl RangeTraitConst,
) -> Result<BoxedRefMut<'boxed, Mat>>
pub fn rowscols_def_mut<'boxed>( m: &'boxed mut impl MatTrait, row_range: &impl RangeTraitConst, ) -> Result<BoxedRefMut<'boxed, Mat>>
@overload
§Parameters
- m: Array that (as a whole or partly) is assigned to the constructed matrix. No data is copied by these constructors. Instead, the header pointing to m data or its sub-array is constructed and associated with it. The reference counter, if any, is incremented. So, when you modify the matrix formed using such a constructor, you also modify the corresponding elements of m . If you want to have an independent copy of the sub-array, use Mat::clone() .
- rowRange: Range of the m rows to take. As usual, the range start is inclusive and the range end is exclusive. Use Range::all() to take all the rows.
- colRange: Range of the m columns to take. Use Range::all() to take all the columns.
§Note
This alternative version of [rowscols] function uses the following default values for its arguments:
- col_range: Range::all()
Sourcepub fn rowscols_def<'boxed>(
m: &'boxed impl MatTraitConst,
row_range: &impl RangeTraitConst,
) -> Result<BoxedRef<'boxed, Mat>>
pub fn rowscols_def<'boxed>( m: &'boxed impl MatTraitConst, row_range: &impl RangeTraitConst, ) -> Result<BoxedRef<'boxed, Mat>>
@overload
§Parameters
- m: Array that (as a whole or partly) is assigned to the constructed matrix. No data is copied by these constructors. Instead, the header pointing to m data or its sub-array is constructed and associated with it. The reference counter, if any, is incremented. So, when you modify the matrix formed using such a constructor, you also modify the corresponding elements of m . If you want to have an independent copy of the sub-array, use Mat::clone() .
- rowRange: Range of the m rows to take. As usual, the range start is inclusive and the range end is exclusive. Use Range::all() to take all the rows.
- colRange: Range of the m columns to take. Use Range::all() to take all the columns.
§Note
This alternative version of [rowscols] function uses the following default values for its arguments:
- col_range: Range::all()
Sourcepub fn rowscols_mut<'boxed>(
m: &'boxed mut impl MatTrait,
row_range: &impl RangeTraitConst,
col_range: &impl RangeTraitConst,
) -> Result<BoxedRefMut<'boxed, Mat>>
pub fn rowscols_mut<'boxed>( m: &'boxed mut impl MatTrait, row_range: &impl RangeTraitConst, col_range: &impl RangeTraitConst, ) -> Result<BoxedRefMut<'boxed, Mat>>
@overload
§Parameters
- m: Array that (as a whole or partly) is assigned to the constructed matrix. No data is copied by these constructors. Instead, the header pointing to m data or its sub-array is constructed and associated with it. The reference counter, if any, is incremented. So, when you modify the matrix formed using such a constructor, you also modify the corresponding elements of m . If you want to have an independent copy of the sub-array, use Mat::clone() .
- rowRange: Range of the m rows to take. As usual, the range start is inclusive and the range end is exclusive. Use Range::all() to take all the rows.
- colRange: Range of the m columns to take. Use Range::all() to take all the columns.
§C++ default parameters
- col_range: Range::all()
Sourcepub fn roi(m: &impl MatTraitConst, roi: Rect) -> Result<BoxedRef<'_, Mat>>
pub fn roi(m: &impl MatTraitConst, roi: Rect) -> Result<BoxedRef<'_, Mat>>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- m: Array that (as a whole or partly) is assigned to the constructed matrix. No data is copied by these constructors. Instead, the header pointing to m data or its sub-array is constructed and associated with it. The reference counter, if any, is incremented. So, when you modify the matrix formed using such a constructor, you also modify the corresponding elements of m . If you want to have an independent copy of the sub-array, use Mat::clone() .
- roi: Region of interest.
Sourcepub fn roi_mut(m: &mut impl MatTrait, roi: Rect) -> Result<BoxedRefMut<'_, Mat>>
pub fn roi_mut(m: &mut impl MatTrait, roi: Rect) -> Result<BoxedRefMut<'_, Mat>>
@overload
§Parameters
- m: Array that (as a whole or partly) is assigned to the constructed matrix. No data is copied by these constructors. Instead, the header pointing to m data or its sub-array is constructed and associated with it. The reference counter, if any, is incremented. So, when you modify the matrix formed using such a constructor, you also modify the corresponding elements of m . If you want to have an independent copy of the sub-array, use Mat::clone() .
- roi: Region of interest.
Sourcepub fn ranges<'boxed>(
m: &'boxed impl MatTraitConst,
ranges: &Vector<Range>,
) -> Result<BoxedRef<'boxed, Mat>>
pub fn ranges<'boxed>( m: &'boxed impl MatTraitConst, ranges: &Vector<Range>, ) -> Result<BoxedRef<'boxed, Mat>>
These are various constructors that form a matrix. As noted in the AutomaticAllocation, often the default constructor is enough, and the proper matrix will be allocated by an OpenCV function. The constructed matrix can further be assigned to another matrix or matrix expression or can be allocated with Mat::create . In the former case, the old content is de-referenced.
§Overloaded parameters
§Parameters
- m: Array that (as a whole or partly) is assigned to the constructed matrix. No data is copied by these constructors. Instead, the header pointing to m data or its sub-array is constructed and associated with it. The reference counter, if any, is incremented. So, when you modify the matrix formed using such a constructor, you also modify the corresponding elements of m . If you want to have an independent copy of the sub-array, use Mat::clone() .
- ranges: Array of selected ranges of m along each dimensionality.
Sourcepub fn ranges_mut<'boxed>(
m: &'boxed mut impl MatTrait,
ranges: &Vector<Range>,
) -> Result<BoxedRefMut<'boxed, Mat>>
pub fn ranges_mut<'boxed>( m: &'boxed mut impl MatTrait, ranges: &Vector<Range>, ) -> Result<BoxedRefMut<'boxed, Mat>>
@overload
§Parameters
- m: Array that (as a whole or partly) is assigned to the constructed matrix. No data is copied by these constructors. Instead, the header pointing to m data or its sub-array is constructed and associated with it. The reference counter, if any, is incremented. So, when you modify the matrix formed using such a constructor, you also modify the corresponding elements of m . If you want to have an independent copy of the sub-array, use Mat::clone() .
- ranges: Array of selected ranges of m along each dimensionality.
Sourcepub fn from_gpumat(m: &impl GpuMatTraitConst) -> Result<Mat>
pub fn from_gpumat(m: &impl GpuMatTraitConst) -> Result<Mat>
download data from GpuMat
Sourcepub fn diag_mat(d: &impl MatTraitConst) -> Result<Mat>
pub fn diag_mat(d: &impl MatTraitConst) -> Result<Mat>
creates a diagonal matrix
The method creates a square diagonal matrix from specified main diagonal.
§Parameters
- d: One-dimensional matrix that represents the main diagonal.
Sourcepub fn zeros(rows: i32, cols: i32, typ: i32) -> Result<MatExpr>
pub fn zeros(rows: i32, cols: i32, typ: i32) -> Result<MatExpr>
Returns a zero array of the specified size and type.
The method returns a Matlab-style zero array initializer. It can be used to quickly form a constant array as a function parameter, part of a matrix expression, or as a matrix initializer:
Mat A;
A = Mat::zeros(3, 3, CV_32F);
In the example above, a new matrix is allocated only if A is not a 3x3 floating-point matrix. Otherwise, the existing matrix A is filled with zeros.
§Parameters
- rows: Number of rows.
- cols: Number of columns.
- type: Created matrix type.
Sourcepub fn zeros_size(size: Size, typ: i32) -> Result<MatExpr>
pub fn zeros_size(size: Size, typ: i32) -> Result<MatExpr>
Returns a zero array of the specified size and type.
The method returns a Matlab-style zero array initializer. It can be used to quickly form a constant array as a function parameter, part of a matrix expression, or as a matrix initializer:
Mat A;
A = Mat::zeros(3, 3, CV_32F);
In the example above, a new matrix is allocated only if A is not a 3x3 floating-point matrix. Otherwise, the existing matrix A is filled with zeros.
§Parameters
- rows: Number of rows.
- cols: Number of columns.
- type: Created matrix type.
§Overloaded parameters
- size: Alternative to the matrix size specification Size(cols, rows) .
- type: Created matrix type.
Sourcepub fn zeros_nd(sz: &[i32], typ: i32) -> Result<MatExpr>
pub fn zeros_nd(sz: &[i32], typ: i32) -> Result<MatExpr>
Returns a zero array of the specified size and type.
The method returns a Matlab-style zero array initializer. It can be used to quickly form a constant array as a function parameter, part of a matrix expression, or as a matrix initializer:
Mat A;
A = Mat::zeros(3, 3, CV_32F);
In the example above, a new matrix is allocated only if A is not a 3x3 floating-point matrix. Otherwise, the existing matrix A is filled with zeros.
§Parameters
- rows: Number of rows.
- cols: Number of columns.
- type: Created matrix type.
§Overloaded parameters
- ndims: Array dimensionality.
- sz: Array of integers specifying the array shape.
- type: Created matrix type.
Sourcepub fn ones(rows: i32, cols: i32, typ: i32) -> Result<MatExpr>
pub fn ones(rows: i32, cols: i32, typ: i32) -> Result<MatExpr>
Returns an array of all 1’s of the specified size and type.
The method returns a Matlab-style 1’s array initializer, similarly to Mat::zeros. Note that using this method you can initialize an array with an arbitrary value, using the following Matlab idiom:
Mat A = Mat::ones(100, 100, CV_8U)*3; // make 100x100 matrix filled with 3.
The above operation does not form a 100x100 matrix of 1’s and then multiply it by 3. Instead, it just remembers the scale factor (3 in this case) and use it when actually invoking the matrix initializer.
Note: In case of multi-channels type, only the first channel will be initialized with 1’s, the others will be set to 0’s.
§Parameters
- rows: Number of rows.
- cols: Number of columns.
- type: Created matrix type.
Sourcepub fn ones_size(size: Size, typ: i32) -> Result<MatExpr>
pub fn ones_size(size: Size, typ: i32) -> Result<MatExpr>
Returns an array of all 1’s of the specified size and type.
The method returns a Matlab-style 1’s array initializer, similarly to Mat::zeros. Note that using this method you can initialize an array with an arbitrary value, using the following Matlab idiom:
Mat A = Mat::ones(100, 100, CV_8U)*3; // make 100x100 matrix filled with 3.
The above operation does not form a 100x100 matrix of 1’s and then multiply it by 3. Instead, it just remembers the scale factor (3 in this case) and use it when actually invoking the matrix initializer.
Note: In case of multi-channels type, only the first channel will be initialized with 1’s, the others will be set to 0’s.
§Parameters
- rows: Number of rows.
- cols: Number of columns.
- type: Created matrix type.
§Overloaded parameters
- size: Alternative to the matrix size specification Size(cols, rows) .
- type: Created matrix type.
Sourcepub fn ones_nd(sz: &[i32], typ: i32) -> Result<MatExpr>
pub fn ones_nd(sz: &[i32], typ: i32) -> Result<MatExpr>
Returns an array of all 1’s of the specified size and type.
The method returns a Matlab-style 1’s array initializer, similarly to Mat::zeros. Note that using this method you can initialize an array with an arbitrary value, using the following Matlab idiom:
Mat A = Mat::ones(100, 100, CV_8U)*3; // make 100x100 matrix filled with 3.
The above operation does not form a 100x100 matrix of 1’s and then multiply it by 3. Instead, it just remembers the scale factor (3 in this case) and use it when actually invoking the matrix initializer.
Note: In case of multi-channels type, only the first channel will be initialized with 1’s, the others will be set to 0’s.
§Parameters
- rows: Number of rows.
- cols: Number of columns.
- type: Created matrix type.
§Overloaded parameters
- ndims: Array dimensionality.
- sz: Array of integers specifying the array shape.
- type: Created matrix type.
Sourcepub fn eye(rows: i32, cols: i32, typ: i32) -> Result<MatExpr>
pub fn eye(rows: i32, cols: i32, typ: i32) -> Result<MatExpr>
Returns an identity matrix of the specified size and type.
The method returns a Matlab-style identity matrix initializer, similarly to Mat::zeros. Similarly to Mat::ones, you can use a scale operation to create a scaled identity matrix efficiently:
// make a 4x4 diagonal matrix with 0.1's on the diagonal.
Mat A = Mat::eye(4, 4, CV_32F)*0.1;
Note: In case of multi-channels type, identity matrix will be initialized only for the first channel, the others will be set to 0’s
§Parameters
- rows: Number of rows.
- cols: Number of columns.
- type: Created matrix type.
Sourcepub fn eye_size(size: Size, typ: i32) -> Result<MatExpr>
pub fn eye_size(size: Size, typ: i32) -> Result<MatExpr>
Returns an identity matrix of the specified size and type.
The method returns a Matlab-style identity matrix initializer, similarly to Mat::zeros. Similarly to Mat::ones, you can use a scale operation to create a scaled identity matrix efficiently:
// make a 4x4 diagonal matrix with 0.1's on the diagonal.
Mat A = Mat::eye(4, 4, CV_32F)*0.1;
Note: In case of multi-channels type, identity matrix will be initialized only for the first channel, the others will be set to 0’s
§Parameters
- rows: Number of rows.
- cols: Number of columns.
- type: Created matrix type.
§Overloaded parameters
- size: Alternative matrix size specification as Size(cols, rows) .
- type: Created matrix type.
Trait Implementations§
Source§impl Boxed for Mat
impl Boxed for Mat
Source§unsafe fn from_raw(ptr: <Mat as OpenCVFromExtern>::ExternReceive) -> Self
unsafe fn from_raw(ptr: <Mat as OpenCVFromExtern>::ExternReceive) -> Self
Source§fn into_raw(self) -> <Mat as OpenCVTypeExternContainer>::ExternSendMut
fn into_raw(self) -> <Mat as OpenCVTypeExternContainer>::ExternSendMut
Source§fn as_raw(&self) -> <Mat as OpenCVTypeExternContainer>::ExternSend
fn as_raw(&self) -> <Mat as OpenCVTypeExternContainer>::ExternSend
Source§fn as_raw_mut(&mut self) -> <Mat as OpenCVTypeExternContainer>::ExternSendMut
fn as_raw_mut(&mut self) -> <Mat as OpenCVTypeExternContainer>::ExternSendMut
Source§impl MatTrait for Mat
impl MatTrait for Mat
fn as_raw_mut_Mat(&mut self) -> *mut c_void
Source§fn set_rows(&mut self, val: i32)
fn set_rows(&mut self, val: i32)
Source§fn set_cols(&mut self, val: i32)
fn set_cols(&mut self, val: i32)
Source§fn set_u(&mut self, val: &impl UMatDataTraitConst)
fn set_u(&mut self, val: &impl UMatDataTraitConst)
fn set_mat_size(&mut self, val: MatSize)
Source§fn set_matexpr(&mut self, expr: &impl MatExprTraitConst) -> Result<()>
fn set_matexpr(&mut self, expr: &impl MatExprTraitConst) -> Result<()>
Source§fn row_mut(&mut self, y: i32) -> Result<BoxedRefMut<'_, Mat>>
fn row_mut(&mut self, y: i32) -> Result<BoxedRefMut<'_, Mat>>
Source§fn col_mut(&mut self, x: i32) -> Result<BoxedRefMut<'_, Mat>>
fn col_mut(&mut self, x: i32) -> Result<BoxedRefMut<'_, Mat>>
Source§fn row_bounds_mut(
&mut self,
startrow: i32,
endrow: i32,
) -> Result<BoxedRefMut<'_, Mat>>
fn row_bounds_mut( &mut self, startrow: i32, endrow: i32, ) -> Result<BoxedRefMut<'_, Mat>>
Source§fn row_range_mut(
&mut self,
r: &impl RangeTraitConst,
) -> Result<BoxedRefMut<'_, Mat>>
fn row_range_mut( &mut self, r: &impl RangeTraitConst, ) -> Result<BoxedRefMut<'_, Mat>>
Source§fn col_bounds_mut(
&mut self,
startcol: i32,
endcol: i32,
) -> Result<BoxedRefMut<'_, Mat>>
fn col_bounds_mut( &mut self, startcol: i32, endcol: i32, ) -> Result<BoxedRefMut<'_, Mat>>
Source§fn col_range_mut(
&mut self,
r: &impl RangeTraitConst,
) -> Result<BoxedRefMut<'_, Mat>>
fn col_range_mut( &mut self, r: &impl RangeTraitConst, ) -> Result<BoxedRefMut<'_, Mat>>
Source§fn diag_def_mut(&mut self) -> Result<BoxedRefMut<'_, Mat>>
fn diag_def_mut(&mut self) -> Result<BoxedRefMut<'_, Mat>>
Source§fn diag_mut(&mut self, d: i32) -> Result<BoxedRefMut<'_, Mat>>
fn diag_mut(&mut self, d: i32) -> Result<BoxedRefMut<'_, Mat>>
Source§fn set_scalar(&mut self, s: Scalar) -> Result<()>
fn set_scalar(&mut self, s: Scalar) -> Result<()>
Source§fn set_to(
&mut self,
value: &impl ToInputArray,
mask: &impl ToInputArray,
) -> Result<Mat>
fn set_to( &mut self, value: &impl ToInputArray, mask: &impl ToInputArray, ) -> Result<Mat>
Source§fn set_to_def(&mut self, value: &impl ToInputArray) -> Result<Mat>
fn set_to_def(&mut self, value: &impl ToInputArray) -> Result<Mat>
Source§fn reshape_def_mut(&mut self, cn: i32) -> Result<BoxedRefMut<'_, Mat>>
fn reshape_def_mut(&mut self, cn: i32) -> Result<BoxedRefMut<'_, Mat>>
Source§fn reshape_mut(&mut self, cn: i32, rows: i32) -> Result<BoxedRefMut<'_, Mat>>
fn reshape_mut(&mut self, cn: i32, rows: i32) -> Result<BoxedRefMut<'_, Mat>>
Source§fn reshape_nd_mut(
&mut self,
cn: i32,
newsz: &[i32],
) -> Result<BoxedRefMut<'_, Mat>>
fn reshape_nd_mut( &mut self, cn: i32, newsz: &[i32], ) -> Result<BoxedRefMut<'_, Mat>>
Source§fn reshape_nd_vec_mut(
&mut self,
cn: i32,
newshape: &Vector<i32>,
) -> Result<BoxedRefMut<'_, Mat>>
fn reshape_nd_vec_mut( &mut self, cn: i32, newshape: &Vector<i32>, ) -> Result<BoxedRefMut<'_, Mat>>
Source§unsafe fn create_rows_cols(
&mut self,
rows: i32,
cols: i32,
typ: i32,
) -> Result<()>
unsafe fn create_rows_cols( &mut self, rows: i32, cols: i32, typ: i32, ) -> Result<()>
Source§unsafe fn create_size(&mut self, size: Size, typ: i32) -> Result<()>
unsafe fn create_size(&mut self, size: Size, typ: i32) -> Result<()>
Source§unsafe fn create_nd(&mut self, sizes: &[i32], typ: i32) -> Result<()>
unsafe fn create_nd(&mut self, sizes: &[i32], typ: i32) -> Result<()>
Source§unsafe fn create_nd_vec(&mut self, sizes: &Vector<i32>, typ: i32) -> Result<()>
unsafe fn create_nd_vec(&mut self, sizes: &Vector<i32>, typ: i32) -> Result<()>
Source§unsafe fn release(&mut self) -> Result<()>
unsafe fn release(&mut self) -> Result<()>
Source§fn deallocate(&mut self) -> Result<()>
fn deallocate(&mut self) -> Result<()>
Source§fn reserve(&mut self, sz: size_t) -> Result<()>
fn reserve(&mut self, sz: size_t) -> Result<()>
Source§fn reserve_buffer(&mut self, sz: size_t) -> Result<()>
fn reserve_buffer(&mut self, sz: size_t) -> Result<()>
Source§fn resize_with_default(&mut self, sz: size_t, s: Scalar) -> Result<()>
fn resize_with_default(&mut self, sz: size_t, s: Scalar) -> Result<()>
Source§fn push_back(&mut self, m: &impl MatTraitConst) -> Result<()>
fn push_back(&mut self, m: &impl MatTraitConst) -> Result<()>
Source§fn pop_back(&mut self, nelems: size_t) -> Result<()>
fn pop_back(&mut self, nelems: size_t) -> Result<()>
Source§fn pop_back_def(&mut self) -> Result<()>
fn pop_back_def(&mut self) -> Result<()>
Source§fn adjust_roi(
&mut self,
dtop: i32,
dbottom: i32,
dleft: i32,
dright: i32,
) -> Result<Mat>
fn adjust_roi( &mut self, dtop: i32, dbottom: i32, dleft: i32, dright: i32, ) -> Result<Mat>
Source§fn rowscols_mut(
&mut self,
row_range: impl RangeTrait,
col_range: impl RangeTrait,
) -> Result<BoxedRefMut<'_, Mat>>
fn rowscols_mut( &mut self, row_range: impl RangeTrait, col_range: impl RangeTrait, ) -> Result<BoxedRefMut<'_, Mat>>
Source§fn ranges_mut(&mut self, ranges: &Vector<Range>) -> Result<BoxedRefMut<'_, Mat>>
fn ranges_mut(&mut self, ranges: &Vector<Range>) -> Result<BoxedRefMut<'_, Mat>>
Source§fn ptr_mut(&mut self, i0: i32) -> Result<*mut u8>
fn ptr_mut(&mut self, i0: i32) -> Result<*mut u8>
Source§fn ptr_mut_def(&mut self) -> Result<*mut u8>
fn ptr_mut_def(&mut self) -> Result<*mut u8>
Source§fn ptr_2d_mut(&mut self, row: i32, col: i32) -> Result<*mut u8>
fn ptr_2d_mut(&mut self, row: i32, col: i32) -> Result<*mut u8>
Source§fn ptr_3d_mut(&mut self, i0: i32, i1: i32, i2: i32) -> Result<*mut u8>
fn ptr_3d_mut(&mut self, i0: i32, i1: i32, i2: i32) -> Result<*mut u8>
Source§fn ptr_nd_mut(&mut self, idx: &[i32]) -> Result<*mut u8>
fn ptr_nd_mut(&mut self, idx: &[i32]) -> Result<*mut u8>
Source§fn at_mut<T: DataType>(&mut self, i0: i32) -> Result<&mut T>
fn at_mut<T: DataType>(&mut self, i0: i32) -> Result<&mut T>
Source§fn at_mut_def<T: DataType>(&mut self) -> Result<&mut T>
fn at_mut_def<T: DataType>(&mut self) -> Result<&mut T>
Source§fn at_2d_mut<T: DataType>(&mut self, row: i32, col: i32) -> Result<&mut T>
fn at_2d_mut<T: DataType>(&mut self, row: i32, col: i32) -> Result<&mut T>
Source§fn at_3d_mut<T: DataType>(
&mut self,
i0: i32,
i1: i32,
i2: i32,
) -> Result<&mut T>
fn at_3d_mut<T: DataType>( &mut self, i0: i32, i1: i32, i2: i32, ) -> Result<&mut T>
Source§fn at_nd_mut<T: DataType>(&mut self, idx: &[i32]) -> Result<&mut T>
fn at_nd_mut<T: DataType>(&mut self, idx: &[i32]) -> Result<&mut T>
Source§fn at_pt_mut<T: DataType>(&mut self, pt: Point) -> Result<&mut T>
fn at_pt_mut<T: DataType>(&mut self, pt: Point) -> Result<&mut T>
fn set(&mut self, m: Mat) -> Result<()>
Source§fn update_continuity_flag(&mut self) -> Result<()>
fn update_continuity_flag(&mut self) -> Result<()>
Source§impl MatTraitConst for Mat
impl MatTraitConst for Mat
fn as_raw_Mat(&self) -> *const c_void
Source§fn rows(&self) -> i32
fn rows(&self) -> i32
Source§fn cols(&self) -> i32
fn cols(&self) -> i32
fn dataend(&self) -> *const u8
fn datalimit(&self) -> *const u8
fn mat_size(&self) -> MatSize
fn mat_step(&self) -> MatStep
Source§fn get_umat(
&self,
access_flags: AccessFlag,
usage_flags: UMatUsageFlags,
) -> Result<UMat>
fn get_umat( &self, access_flags: AccessFlag, usage_flags: UMatUsageFlags, ) -> Result<UMat>
Source§fn get_umat_def(&self, access_flags: AccessFlag) -> Result<UMat>
fn get_umat_def(&self, access_flags: AccessFlag) -> Result<UMat>
Source§fn row(&self, y: i32) -> Result<BoxedRef<'_, Mat>>
fn row(&self, y: i32) -> Result<BoxedRef<'_, Mat>>
Source§fn col(&self, x: i32) -> Result<BoxedRef<'_, Mat>>
fn col(&self, x: i32) -> Result<BoxedRef<'_, Mat>>
Source§fn row_bounds(&self, startrow: i32, endrow: i32) -> Result<BoxedRef<'_, Mat>>
fn row_bounds(&self, startrow: i32, endrow: i32) -> Result<BoxedRef<'_, Mat>>
Source§fn row_range(&self, r: &impl RangeTraitConst) -> Result<BoxedRef<'_, Mat>>
fn row_range(&self, r: &impl RangeTraitConst) -> Result<BoxedRef<'_, Mat>>
Source§fn col_bounds(&self, startcol: i32, endcol: i32) -> Result<BoxedRef<'_, Mat>>
fn col_bounds(&self, startcol: i32, endcol: i32) -> Result<BoxedRef<'_, Mat>>
Source§fn col_range(&self, r: &impl RangeTraitConst) -> Result<BoxedRef<'_, Mat>>
fn col_range(&self, r: &impl RangeTraitConst) -> Result<BoxedRef<'_, Mat>>
Source§fn diag(&self, d: i32) -> Result<BoxedRef<'_, Mat>>
fn diag(&self, d: i32) -> Result<BoxedRef<'_, Mat>>
Source§fn try_clone(&self) -> Result<Mat>
fn try_clone(&self) -> Result<Mat>
Source§fn copy_to(&self, m: &mut impl ToOutputArray) -> Result<()>
fn copy_to(&self, m: &mut impl ToOutputArray) -> Result<()>
Source§fn copy_to_masked(
&self,
m: &mut impl ToOutputArray,
mask: &impl ToInputArray,
) -> Result<()>
fn copy_to_masked( &self, m: &mut impl ToOutputArray, mask: &impl ToInputArray, ) -> Result<()>
Source§fn convert_to(
&self,
m: &mut impl ToOutputArray,
rtype: i32,
alpha: f64,
beta: f64,
) -> Result<()>
fn convert_to( &self, m: &mut impl ToOutputArray, rtype: i32, alpha: f64, beta: f64, ) -> Result<()>
Source§fn convert_to_def(&self, m: &mut impl ToOutputArray, rtype: i32) -> Result<()>
fn convert_to_def(&self, m: &mut impl ToOutputArray, rtype: i32) -> Result<()>
Source§fn assign_to(&self, m: &mut impl MatTrait, typ: i32) -> Result<()>
fn assign_to(&self, m: &mut impl MatTrait, typ: i32) -> Result<()>
Source§fn assign_to_def(&self, m: &mut impl MatTrait) -> Result<()>
fn assign_to_def(&self, m: &mut impl MatTrait) -> Result<()>
Source§fn reshape(&self, cn: i32, rows: i32) -> Result<BoxedRef<'_, Mat>>
fn reshape(&self, cn: i32, rows: i32) -> Result<BoxedRef<'_, Mat>>
Source§fn reshape_def(&self, cn: i32) -> Result<BoxedRef<'_, Mat>>
fn reshape_def(&self, cn: i32) -> Result<BoxedRef<'_, Mat>>
Source§fn reshape_nd(&self, cn: i32, newsz: &[i32]) -> Result<BoxedRef<'_, Mat>>
fn reshape_nd(&self, cn: i32, newsz: &[i32]) -> Result<BoxedRef<'_, Mat>>
Source§fn reshape_nd_vec(
&self,
cn: i32,
newshape: &Vector<i32>,
) -> Result<BoxedRef<'_, Mat>>
fn reshape_nd_vec( &self, cn: i32, newshape: &Vector<i32>, ) -> Result<BoxedRef<'_, Mat>>
Source§fn mul(&self, m: &impl ToInputArray, scale: f64) -> Result<MatExpr>
fn mul(&self, m: &impl ToInputArray, scale: f64) -> Result<MatExpr>
Source§fn mul_def(&self, m: &impl ToInputArray) -> Result<MatExpr>
fn mul_def(&self, m: &impl ToInputArray) -> Result<MatExpr>
Source§fn cross(&self, m: &impl ToInputArray) -> Result<Mat>
fn cross(&self, m: &impl ToInputArray) -> Result<Mat>
Source§fn dot(&self, m: &impl ToInputArray) -> Result<f64>
fn dot(&self, m: &impl ToInputArray) -> Result<f64>
Source§fn locate_roi(&self, whole_size: &mut Size, ofs: &mut Point) -> Result<()>
fn locate_roi(&self, whole_size: &mut Size, ofs: &mut Point) -> Result<()>
Source§fn rowscols(
&self,
row_range: impl RangeTrait,
col_range: impl RangeTrait,
) -> Result<BoxedRef<'_, Mat>>
fn rowscols( &self, row_range: impl RangeTrait, col_range: impl RangeTrait, ) -> Result<BoxedRef<'_, Mat>>
Source§fn roi(&self, roi: Rect) -> Result<BoxedRef<'_, Mat>>
fn roi(&self, roi: Rect) -> Result<BoxedRef<'_, Mat>>
Source§fn ranges(&self, ranges: &Vector<Range>) -> Result<BoxedRef<'_, Mat>>
fn ranges(&self, ranges: &Vector<Range>) -> Result<BoxedRef<'_, Mat>>
Source§fn is_continuous(&self) -> bool
fn is_continuous(&self) -> bool
Source§fn is_submatrix(&self) -> bool
fn is_submatrix(&self) -> bool
Source§fn elem_size1(&self) -> size_t
fn elem_size1(&self) -> size_t
Source§fn total_slice(&self, start_dim: i32, end_dim: i32) -> Result<size_t>
fn total_slice(&self, start_dim: i32, end_dim: i32) -> Result<size_t>
Source§fn total_slice_def(&self, start_dim: i32) -> Result<size_t>
fn total_slice_def(&self, start_dim: i32) -> Result<size_t>
Source§fn check_vector(
&self,
elem_channels: i32,
depth: i32,
require_continuous: bool,
) -> Result<i32>
fn check_vector( &self, elem_channels: i32, depth: i32, require_continuous: bool, ) -> Result<i32>
Source§fn ptr(&self, i0: i32) -> Result<*const u8>
fn ptr(&self, i0: i32) -> Result<*const u8>
Source§fn ptr_2d(&self, row: i32, col: i32) -> Result<*const u8>
fn ptr_2d(&self, row: i32, col: i32) -> Result<*const u8>
Source§fn ptr_3d(&self, i0: i32, i1: i32, i2: i32) -> Result<*const u8>
fn ptr_3d(&self, i0: i32, i1: i32, i2: i32) -> Result<*const u8>
Source§fn ptr_nd(&self, idx: &[i32]) -> Result<*const u8>
fn ptr_nd(&self, idx: &[i32]) -> Result<*const u8>
Source§fn at<T: DataType>(&self, i0: i32) -> Result<&T>
fn at<T: DataType>(&self, i0: i32) -> Result<&T>
Source§fn at_def<T: DataType>(&self) -> Result<&T>
fn at_def<T: DataType>(&self) -> Result<&T>
Source§fn at_2d<T: DataType>(&self, row: i32, col: i32) -> Result<&T>
fn at_2d<T: DataType>(&self, row: i32, col: i32) -> Result<&T>
Source§fn at_3d<T: DataType>(&self, i0: i32, i1: i32, i2: i32) -> Result<&T>
fn at_3d<T: DataType>(&self, i0: i32, i1: i32, i2: i32) -> Result<&T>
Source§fn at_nd<T: DataType>(&self, idx: &[i32]) -> Result<&T>
fn at_nd<T: DataType>(&self, idx: &[i32]) -> Result<&T>
Source§fn at_pt<T: DataType>(&self, pt: Point) -> Result<&T>
fn at_pt<T: DataType>(&self, pt: Point) -> Result<&T>
fn size(&self) -> Result<Size>
Source§fn get_data_dump(&self) -> Result<String>
fn get_data_dump(&self) -> Result<String>
Source§impl ToInputArray for &Mat
impl ToInputArray for &Mat
fn input_array(&self) -> Result<BoxedRef<'_, _InputArray>>
Source§impl ToInputArray for Mat
impl ToInputArray for Mat
fn input_array(&self) -> Result<BoxedRef<'_, _InputArray>>
Source§impl ToInputOutputArray for &mut Mat
impl ToInputOutputArray for &mut Mat
fn input_output_array(&mut self) -> Result<BoxedRefMut<'_, _InputOutputArray>>
Source§impl ToInputOutputArray for Mat
impl ToInputOutputArray for Mat
fn input_output_array(&mut self) -> Result<BoxedRefMut<'_, _InputOutputArray>>
Source§impl ToOutputArray for &mut Mat
impl ToOutputArray for &mut Mat
fn output_array(&mut self) -> Result<BoxedRefMut<'_, _OutputArray>>
Source§impl ToOutputArray for Mat
impl ToOutputArray for Mat
fn output_array(&mut self) -> Result<BoxedRefMut<'_, _OutputArray>>
impl Send for Mat
impl Sync for Mat
Auto Trait Implementations§
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> MatTraitConstManual for Twhere
T: MatTraitConst + ?Sized,
impl<T> MatTraitConstManual for Twhere
T: MatTraitConst + ?Sized,
Source§unsafe fn at_unchecked<T: DataType>(&self, i0: i32) -> Result<&T>
unsafe fn at_unchecked<T: DataType>(&self, i0: i32) -> Result<&T>
Mat::at()
but performs no bounds or type checks Read moreSource§unsafe fn at_2d_unchecked<T: DataType>(&self, row: i32, col: i32) -> Result<&T>
unsafe fn at_2d_unchecked<T: DataType>(&self, row: i32, col: i32) -> Result<&T>
Mat::at_2d()
but performs no bounds or type checks Read moreSource§unsafe fn at_pt_unchecked<T: DataType>(&self, pt: Point) -> Result<&T>
unsafe fn at_pt_unchecked<T: DataType>(&self, pt: Point) -> Result<&T>
Mat::at_pt()
but performs no bounds or type checks Read moreSource§unsafe fn at_3d_unchecked<T: DataType>(
&self,
i0: i32,
i1: i32,
i2: i32,
) -> Result<&T>
unsafe fn at_3d_unchecked<T: DataType>( &self, i0: i32, i1: i32, i2: i32, ) -> Result<&T>
Mat::at_3d()
but performs no bounds or type checks Read moreSource§unsafe fn at_nd_unchecked<T: DataType>(&self, idx: &[i32]) -> Result<&T>
unsafe fn at_nd_unchecked<T: DataType>(&self, idx: &[i32]) -> Result<&T>
Mat::at_nd()
but performs no bounds or type checks Read moreSource§unsafe fn at_row_unchecked<T: DataType>(&self, row: i32) -> Result<&[T]>
unsafe fn at_row_unchecked<T: DataType>(&self, row: i32) -> Result<&[T]>
Mat::at_row()
but performs no bounds or type checks Read morefn is_allocated(&self) -> bool
Source§fn data_bytes(&self) -> Result<&[u8]>
fn data_bytes(&self) -> Result<&[u8]>
Mat
must be continuousfn data_typed<T: DataType>(&self) -> Result<&[T]>
fn to_vec_2d<T: DataType>(&self) -> Result<Vec<Vec<T>>>
Source§fn iter<T: DataType>(&self) -> Result<MatIter<'_, T>>where
Self: Sized,
fn iter<T: DataType>(&self) -> Result<MatIter<'_, T>>where
Self: Sized,
Mat
elements and their positionsfn try_into_typed<T: DataType>(self) -> Result<Mat_<T>>
Source§impl<T> MatTraitManual for T
impl<T> MatTraitManual for T
Source§unsafe fn at_unchecked_mut<T: DataType>(&mut self, i0: i32) -> Result<&mut T>
unsafe fn at_unchecked_mut<T: DataType>(&mut self, i0: i32) -> Result<&mut T>
Mat::at_mut()
but performs no bounds or type checks Read moreSource§unsafe fn at_2d_unchecked_mut<T: DataType>(
&mut self,
row: i32,
col: i32,
) -> Result<&mut T>
unsafe fn at_2d_unchecked_mut<T: DataType>( &mut self, row: i32, col: i32, ) -> Result<&mut T>
Mat::at_2d_mut()
but performs no bounds or type checks Read moreSource§unsafe fn at_pt_unchecked_mut<T: DataType>(
&mut self,
pt: Point,
) -> Result<&mut T>
unsafe fn at_pt_unchecked_mut<T: DataType>( &mut self, pt: Point, ) -> Result<&mut T>
Mat::at_pt_mut()
but performs no bounds or type checks Read moreSource§unsafe fn at_3d_unchecked_mut<T: DataType>(
&mut self,
i0: i32,
i1: i32,
i2: i32,
) -> Result<&mut T>
unsafe fn at_3d_unchecked_mut<T: DataType>( &mut self, i0: i32, i1: i32, i2: i32, ) -> Result<&mut T>
Mat::at_3d_mut()
but performs no bounds or type checks Read moreSource§unsafe fn at_nd_unchecked_mut<T: DataType>(
&mut self,
idx: &[i32],
) -> Result<&mut T>
unsafe fn at_nd_unchecked_mut<T: DataType>( &mut self, idx: &[i32], ) -> Result<&mut T>
Mat::at_nd_mut()
but performs no bounds or type checks Read moreSource§fn at_row_mut<T: DataType>(&mut self, row: i32) -> Result<&mut [T]>
fn at_row_mut<T: DataType>(&mut self, row: i32) -> Result<&mut [T]>
Source§unsafe fn at_row_unchecked_mut<T: DataType>(
&mut self,
row: i32,
) -> Result<&mut [T]>
unsafe fn at_row_unchecked_mut<T: DataType>( &mut self, row: i32, ) -> Result<&mut [T]>
Mat::at_row_mut()
but performs no bounds or type checks Read moreSource§fn data_bytes_mut(&mut self) -> Result<&mut [u8]>
fn data_bytes_mut(&mut self) -> Result<&mut [u8]>
fn data_typed_mut<T: DataType>(&mut self) -> Result<&mut [T]>
Source§impl<Mat> ModifyInplace for Matwhere
Mat: Boxed,
impl<Mat> ModifyInplace for Matwhere
Mat: Boxed,
Source§unsafe fn modify_inplace<Res>(
&mut self,
f: impl FnOnce(&Mat, &mut Mat) -> Res,
) -> Res
unsafe fn modify_inplace<Res>( &mut self, f: impl FnOnce(&Mat, &mut Mat) -> Res, ) -> Res
Mat
or another similar object. By passing
a mutable reference to the Mat
to this function your closure will get called with the read reference and a write references
to the same Mat
. This is unsafe in a general case as it leads to having non-exclusive mutable access to the internal data,
but it can be useful for some performance sensitive operations. One example of an OpenCV function that allows such in-place
modification is imgproc::threshold
. Read more