Template class for small matrices whose type and size are known at compilation time. More...
#include <opencv2/core/matx.hpp>
Public Types | |
enum | { rows = m , cols = n , channels = rows*cols , shortdim = (m < n ? m : n) } |
typedef Matx< _Tp, shortdim, 1 > | diag_type |
typedef Matx< _Tp, m, n > | mat_type |
typedef _Tp | value_type |
Public Member Functions | |
Matx () | |
default constructor | |
Matx (_Tp v0) | |
1x1 matrix | |
Matx (_Tp v0, _Tp v1) | |
1x2 or 2x1 matrix | |
Matx (_Tp v0, _Tp v1, _Tp v2) | |
1x3 or 3x1 matrix | |
Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3) | |
1x4, 2x2 or 4x1 matrix | |
Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4) | |
1x5 or 5x1 matrix | |
Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5) | |
1x6, 2x3, 3x2 or 6x1 matrix | |
Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6) | |
1x7 or 7x1 matrix | |
Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6, _Tp v7) | |
1x8, 2x4, 4x2 or 8x1 matrix | |
Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6, _Tp v7, _Tp v8) | |
1x9, 3x3 or 9x1 matrix | |
Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6, _Tp v7, _Tp v8, _Tp v9) | |
1x10, 2x5 or 5x2 or 10x1 matrix | |
Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6, _Tp v7, _Tp v8, _Tp v9, _Tp v10, _Tp v11) | |
1x12, 2x6, 3x4, 4x3, 6x2 or 12x1 matrix | |
Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6, _Tp v7, _Tp v8, _Tp v9, _Tp v10, _Tp v11, _Tp v12, _Tp v13) | |
1x14, 2x7, 7x2 or 14x1 matrix | |
Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6, _Tp v7, _Tp v8, _Tp v9, _Tp v10, _Tp v11, _Tp v12, _Tp v13, _Tp v14, _Tp v15) | |
1x16, 4x4 or 16x1 matrix | |
Matx (const _Tp *vals) | |
initialize from a plain array | |
template<int l> | |
Matx (const Matx< _Tp, m, l > &a, const Matx< _Tp, l, n > &b, Matx_MatMulOp) | |
template<typename _T2 > | |
Matx (const Matx< _Tp, m, n > &a, _T2 alpha, Matx_ScaleOp) | |
Matx (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b, Matx_AddOp) | |
Matx (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b, Matx_DivOp) | |
Matx (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b, Matx_MulOp) | |
Matx (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b, Matx_SubOp) | |
Matx (const Matx< _Tp, n, m > &a, Matx_TOp) | |
Matx (std::initializer_list< _Tp >) | |
initialize from an initializer list | |
Matx< _Tp, m, 1 > | col (int i) const |
extract the matrix column | |
double | ddot (const Matx< _Tp, m, n > &v) const |
dot product computed in double-precision arithmetics | |
diag_type | diag () const |
extract the matrix diagonal | |
Matx< _Tp, m, n > | div (const Matx< _Tp, m, n > &a) const |
divide two matrices element-wise | |
_Tp | dot (const Matx< _Tp, m, n > &v) const |
dot product computed with the default precision | |
template<int m1, int n1> | |
Matx< _Tp, m1, n1 > | get_minor (int base_row, int base_col) const |
extract part of the matrix | |
Matx< _Tp, n, m > | inv (int method=DECOMP_LU, bool *p_is_ok=NULL) const |
invert the matrix | |
Matx< _Tp, m, n > | mul (const Matx< _Tp, m, n > &a) const |
multiply two matrices element-wise | |
template<typename T2 > | |
operator Matx< T2, m, n > () const | |
conversion to another data type | |
_Tp & | operator() (int i) |
const _Tp & | operator() (int i) const |
1D element access | |
_Tp & | operator() (int row, int col) |
const _Tp & | operator() (int row, int col) const |
element access | |
template<int m1, int n1> | |
Matx< _Tp, m1, n1 > | reshape () const |
change the matrix shape | |
Matx< _Tp, 1, n > | row (int i) const |
extract the matrix row | |
template<int l> | |
Matx< _Tp, n, l > | solve (const Matx< _Tp, m, l > &rhs, int flags=DECOMP_LU) const |
solve linear system | |
Vec< _Tp, n > | solve (const Vec< _Tp, m > &rhs, int method) const |
Matx< _Tp, n, m > | t () const |
transpose the matrix | |
Static Public Member Functions | |
static CV_NODISCARD_STD Matx | all (_Tp alpha) |
static CV_NODISCARD_STD Matx | diag (const diag_type &d) |
static CV_NODISCARD_STD Matx | eye () |
static CV_NODISCARD_STD Matx | ones () |
static CV_NODISCARD_STD Matx | randn (_Tp a, _Tp b) |
Generates normally distributed random numbers. | |
static CV_NODISCARD_STD Matx | randu (_Tp a, _Tp b) |
Generates uniformly distributed random numbers. | |
static CV_NODISCARD_STD Matx | zeros () |
Public Attributes | |
_Tp | val [m *n] |
Related Functions | |
(Note that these are not member functions.) | |
template<typename _Tp1 , typename _Tp2 , int m, int n> | |
static Matx< _Tp1, m, n > & | operator+= (Matx< _Tp1, m, n > &a, const Matx< _Tp2, m, n > &b) |
template<typename _Tp1 , typename _Tp2 , int m, int n> | |
static Matx< _Tp1, m, n > & | operator-= (Matx< _Tp1, m, n > &a, const Matx< _Tp2, m, n > &b) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > | operator+ (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > | operator- (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > & | operator*= (Matx< _Tp, m, n > &a, int alpha) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > & | operator*= (Matx< _Tp, m, n > &a, float alpha) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > & | operator*= (Matx< _Tp, m, n > &a, double alpha) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > | operator* (const Matx< _Tp, m, n > &a, int alpha) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > | operator* (const Matx< _Tp, m, n > &a, float alpha) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > | operator* (const Matx< _Tp, m, n > &a, double alpha) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > | operator* (int alpha, const Matx< _Tp, m, n > &a) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > | operator* (float alpha, const Matx< _Tp, m, n > &a) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > | operator* (double alpha, const Matx< _Tp, m, n > &a) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > & | operator/= (Matx< _Tp, m, n > &a, float alpha) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > & | operator/= (Matx< _Tp, m, n > &a, double alpha) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > | operator/ (const Matx< _Tp, m, n > &a, float alpha) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > | operator/ (const Matx< _Tp, m, n > &a, double alpha) |
template<typename _Tp , int m, int n> | |
static Matx< _Tp, m, n > | operator- (const Matx< _Tp, m, n > &a) |
template<typename _Tp , int m, int n, int l> | |
static Matx< _Tp, m, n > | operator* (const Matx< _Tp, m, l > &a, const Matx< _Tp, l, n > &b) |
template<typename _Tp , int m, int n> | |
static Vec< _Tp, m > | operator* (const Matx< _Tp, m, n > &a, const Vec< _Tp, n > &b) |
template<typename _Tp , int m, int n> | |
static bool | operator== (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b) |
template<typename _Tp , int m, int n> | |
static bool | operator!= (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b) |
Detailed Description
class cv::Matx< _Tp, m, n >
Template class for small matrices whose type and size are known at compilation time.
If you need a more flexible type, use Mat . The elements of the matrix M are accessible using the M(i,j) notation. Most of the common matrix operations (see also MatrixExpressions ) are available. To do an operation on Matx that is not implemented, you can easily convert the matrix to Mat and backwards:
Except of the plain constructor which takes a list of elements, Matx can be initialized from a C-array:
In case if C++11 features are available, std::initializer_list can be also used to initialize Matx:
Member Typedef Documentation
◆ diag_type
typedef Matx<_Tp, shortdim, 1> cv::Matx< _Tp, m, n >::diag_type |
◆ mat_type
◆ value_type
Member Enumeration Documentation
◆ anonymous enum
anonymous enum |
Constructor & Destructor Documentation
◆ Matx() [1/23]
◆ Matx() [2/23]
◆ Matx() [3/23]
1x2 or 2x1 matrix
◆ Matx() [4/23]
1x3 or 3x1 matrix
◆ Matx() [5/23]
cv::Matx< _Tp, m, n >::Matx | ( | _Tp | v0, |
_Tp | v1, | ||
_Tp | v2, | ||
_Tp | v3 | ||
) |
1x4, 2x2 or 4x1 matrix
◆ Matx() [6/23]
cv::Matx< _Tp, m, n >::Matx | ( | _Tp | v0, |
_Tp | v1, | ||
_Tp | v2, | ||
_Tp | v3, | ||
_Tp | v4 | ||
) |
1x5 or 5x1 matrix
◆ Matx() [7/23]
cv::Matx< _Tp, m, n >::Matx | ( | _Tp | v0, |
_Tp | v1, | ||
_Tp | v2, | ||
_Tp | v3, | ||
_Tp | v4, | ||
_Tp | v5 | ||
) |
1x6, 2x3, 3x2 or 6x1 matrix
◆ Matx() [8/23]
cv::Matx< _Tp, m, n >::Matx | ( | _Tp | v0, |
_Tp | v1, | ||
_Tp | v2, | ||
_Tp | v3, | ||
_Tp | v4, | ||
_Tp | v5, | ||
_Tp | v6 | ||
) |
1x7 or 7x1 matrix
◆ Matx() [9/23]
cv::Matx< _Tp, m, n >::Matx | ( | _Tp | v0, |
_Tp | v1, | ||
_Tp | v2, | ||
_Tp | v3, | ||
_Tp | v4, | ||
_Tp | v5, | ||
_Tp | v6, | ||
_Tp | v7 | ||
) |
1x8, 2x4, 4x2 or 8x1 matrix
◆ Matx() [10/23]
cv::Matx< _Tp, m, n >::Matx | ( | _Tp | v0, |
_Tp | v1, | ||
_Tp | v2, | ||
_Tp | v3, | ||
_Tp | v4, | ||
_Tp | v5, | ||
_Tp | v6, | ||
_Tp | v7, | ||
_Tp | v8 | ||
) |
1x9, 3x3 or 9x1 matrix
◆ Matx() [11/23]
cv::Matx< _Tp, m, n >::Matx | ( | _Tp | v0, |
_Tp | v1, | ||
_Tp | v2, | ||
_Tp | v3, | ||
_Tp | v4, | ||
_Tp | v5, | ||
_Tp | v6, | ||
_Tp | v7, | ||
_Tp | v8, | ||
_Tp | v9 | ||
) |
1x10, 2x5 or 5x2 or 10x1 matrix
◆ Matx() [12/23]
cv::Matx< _Tp, m, n >::Matx | ( | _Tp | v0, |
_Tp | v1, | ||
_Tp | v2, | ||
_Tp | v3, | ||
_Tp | v4, | ||
_Tp | v5, | ||
_Tp | v6, | ||
_Tp | v7, | ||
_Tp | v8, | ||
_Tp | v9, | ||
_Tp | v10, | ||
_Tp | v11 | ||
) |
1x12, 2x6, 3x4, 4x3, 6x2 or 12x1 matrix
◆ Matx() [13/23]
cv::Matx< _Tp, m, n >::Matx | ( | _Tp | v0, |
_Tp | v1, | ||
_Tp | v2, | ||
_Tp | v3, | ||
_Tp | v4, | ||
_Tp | v5, | ||
_Tp | v6, | ||
_Tp | v7, | ||
_Tp | v8, | ||
_Tp | v9, | ||
_Tp | v10, | ||
_Tp | v11, | ||
_Tp | v12, | ||
_Tp | v13 | ||
) |
1x14, 2x7, 7x2 or 14x1 matrix
◆ Matx() [14/23]
cv::Matx< _Tp, m, n >::Matx | ( | _Tp | v0, |
_Tp | v1, | ||
_Tp | v2, | ||
_Tp | v3, | ||
_Tp | v4, | ||
_Tp | v5, | ||
_Tp | v6, | ||
_Tp | v7, | ||
_Tp | v8, | ||
_Tp | v9, | ||
_Tp | v10, | ||
_Tp | v11, | ||
_Tp | v12, | ||
_Tp | v13, | ||
_Tp | v14, | ||
_Tp | v15 | ||
) |
1x16, 4x4 or 16x1 matrix
◆ Matx() [15/23]
initialize from a plain array
◆ Matx() [16/23]
initialize from an initializer list
◆ Matx() [17/23]
cv::Matx< _Tp, m, n >::Matx | ( | const Matx< _Tp, m, n > & | a, |
const Matx< _Tp, m, n > & | b, | ||
Matx_AddOp | |||
) |
◆ Matx() [18/23]
cv::Matx< _Tp, m, n >::Matx | ( | const Matx< _Tp, m, n > & | a, |
const Matx< _Tp, m, n > & | b, | ||
Matx_SubOp | |||
) |
◆ Matx() [19/23]
cv::Matx< _Tp, m, n >::Matx | ( | const Matx< _Tp, m, n > & | a, |
_T2 | alpha, | ||
Matx_ScaleOp | |||
) |
◆ Matx() [20/23]
cv::Matx< _Tp, m, n >::Matx | ( | const Matx< _Tp, m, n > & | a, |
const Matx< _Tp, m, n > & | b, | ||
Matx_MulOp | |||
) |
◆ Matx() [21/23]
cv::Matx< _Tp, m, n >::Matx | ( | const Matx< _Tp, m, n > & | a, |
const Matx< _Tp, m, n > & | b, | ||
Matx_DivOp | |||
) |
◆ Matx() [22/23]
cv::Matx< _Tp, m, n >::Matx | ( | const Matx< _Tp, m, l > & | a, |
const Matx< _Tp, l, n > & | b, | ||
Matx_MatMulOp | |||
) |
◆ Matx() [23/23]
cv::Matx< _Tp, m, n >::Matx | ( | const Matx< _Tp, n, m > & | a, |
Matx_TOp | |||
) |
Member Function Documentation
◆ all()
|
static |
◆ col()
extract the matrix column
◆ ddot()
double cv::Matx< _Tp, m, n >::ddot | ( | const Matx< _Tp, m, n > & | v | ) | const |
dot product computed in double-precision arithmetics
◆ diag() [1/2]
extract the matrix diagonal
◆ diag() [2/2]
|
static |
◆ div()
Matx< _Tp, m, n > cv::Matx< _Tp, m, n >::div | ( | const Matx< _Tp, m, n > & | a | ) | const |
divide two matrices element-wise
◆ dot()
_Tp cv::Matx< _Tp, m, n >::dot | ( | const Matx< _Tp, m, n > & | v | ) | const |
dot product computed with the default precision
◆ eye()
|
static |
◆ get_minor()
Matx< _Tp, m1, n1 > cv::Matx< _Tp, m, n >::get_minor | ( | int | base_row, |
int | base_col | ||
) | const |
extract part of the matrix
◆ inv()
Matx< _Tp, n, m > cv::Matx< _Tp, m, n >::inv | ( | int | method = DECOMP_LU , |
bool * | p_is_ok = NULL |
||
) | const |
invert the matrix
◆ mul()
Matx< _Tp, m, n > cv::Matx< _Tp, m, n >::mul | ( | const Matx< _Tp, m, n > & | a | ) | const |
multiply two matrices element-wise
◆ ones()
|
static |
◆ operator Matx< T2, m, n >()
cv::Matx< _Tp, m, n >::operator Matx< T2, m, n > | ( | ) | const |
conversion to another data type
◆ operator()() [1/4]
◆ operator()() [2/4]
1D element access
◆ operator()() [3/4]
◆ operator()() [4/4]
const _Tp & cv::Matx< _Tp, m, n >::operator() | ( | int | row, |
int | col | ||
) | const |
element access
◆ randn()
|
static |
Generates normally distributed random numbers.
- Parameters
-
a Mean value. b Standard deviation.
◆ randu()
|
static |
Generates uniformly distributed random numbers.
- Parameters
-
a Range boundary. b The other range boundary (boundaries don't have to be ordered, the lower boundary is inclusive, the upper one is exclusive).
◆ reshape()
Matx< _Tp, m1, n1 > cv::Matx< _Tp, m, n >::reshape | ( | ) | const |
change the matrix shape
◆ row()
extract the matrix row
◆ solve() [1/2]
Matx< _Tp, n, l > cv::Matx< _Tp, m, n >::solve | ( | const Matx< _Tp, m, l > & | rhs, |
int | flags = DECOMP_LU |
||
) | const |
solve linear system
◆ solve() [2/2]
Vec< _Tp, n > cv::Matx< _Tp, m, n >::solve | ( | const Vec< _Tp, m > & | rhs, |
int | method | ||
) | const |
◆ t()
transpose the matrix
◆ zeros()
|
static |
Friends And Related Function Documentation
◆ operator!=()
|
related |
◆ operator*() [1/8]
|
related |
◆ operator*() [2/8]
|
related |
◆ operator*() [3/8]
|
related |
◆ operator*() [4/8]
|
related |
◆ operator*() [5/8]
|
related |
◆ operator*() [6/8]
|
related |
◆ operator*() [7/8]
|
related |
◆ operator*() [8/8]
|
related |
◆ operator*=() [1/3]
|
related |
◆ operator*=() [2/3]
|
related |
◆ operator*=() [3/3]
|
related |
◆ operator+()
|
related |
◆ operator+=()
|
related |
◆ operator-() [1/2]
|
related |
◆ operator-() [2/2]
|
related |
◆ operator-=()
|
related |
◆ operator/() [1/2]
|
related |
◆ operator/() [2/2]
|
related |
◆ operator/=() [1/2]
|
related |
◆ operator/=() [2/2]
|
related |
◆ operator==()
|
related |
Member Data Documentation
◆ val
The documentation for this class was generated from the following file:
- opencv2/core/matx.hpp