|  | 
|  | Vec () | 
|  | default constructor  More... 
 | 
|  | 
|  | Vec (_Tp v0) | 
|  | 1-element vector constructor  More... 
 | 
|  | 
|  | Vec (_Tp v0, _Tp v1) | 
|  | 2-element vector constructor  More... 
 | 
|  | 
|  | Vec (_Tp v0, _Tp v1, _Tp v2) | 
|  | 3-element vector constructor  More... 
 | 
|  | 
|  | Vec (_Tp v0, _Tp v1, _Tp v2, _Tp v3) | 
|  | 4-element vector constructor  More... 
 | 
|  | 
|  | Vec (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4) | 
|  | 5-element vector constructor  More... 
 | 
|  | 
|  | Vec (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5) | 
|  | 6-element vector constructor  More... 
 | 
|  | 
|  | Vec (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6) | 
|  | 7-element vector constructor  More... 
 | 
|  | 
|  | Vec (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6, _Tp v7) | 
|  | 8-element vector constructor  More... 
 | 
|  | 
|  | Vec (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6, _Tp v7, _Tp v8) | 
|  | 9-element vector constructor  More... 
 | 
|  | 
|  | Vec (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6, _Tp v7, _Tp v8, _Tp v9) | 
|  | 10-element vector constructor  More... 
 | 
|  | 
|  | Vec (_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) | 
|  | 14-element vector constructor  More... 
 | 
|  | 
|  | Vec (const _Tp *values) | 
|  | 
|  | Vec (const Vec< _Tp, cn > &v) | 
|  | 
|  | Vec (const Matx< _Tp, cn, 1 > &a, const Matx< _Tp, cn, 1 > &b, Matx_AddOp) | 
|  | 
|  | Vec (const Matx< _Tp, cn, 1 > &a, const Matx< _Tp, cn, 1 > &b, Matx_SubOp) | 
|  | 
| template<typename _T2 > | 
|  | Vec (const Matx< _Tp, cn, 1 > &a, _T2 alpha, Matx_ScaleOp) | 
|  | 
| Vec | conj () const | 
|  | conjugation (makes sense for complex numbers and quaternions)  More... 
 | 
|  | 
| Vec | cross (const Vec &v) const | 
|  | 
| Vec | mul (const Vec< _Tp, cn > &v) const | 
|  | per-element multiplication  More... 
 | 
|  | 
| template<typename T2 > | 
|  | operator Vec< T2, cn > () const | 
|  | conversion to another data type  More... 
 | 
|  | 
| const _Tp & | operator() (int i) const | 
|  | 
| _Tp & | operator() (int i) | 
|  | 
| const _Tp & | operator[] (int i) const | 
|  | 
| _Tp & | operator[] (int i) | 
|  | 
|  | Matx () | 
|  | default constructor  More... 
 | 
|  | 
|  | Matx (_Tp v0) | 
|  | 1x1 matrix  More... 
 | 
|  | 
|  | Matx (_Tp v0, _Tp v1) | 
|  | 1x2 or 2x1 matrix  More... 
 | 
|  | 
|  | Matx (_Tp v0, _Tp v1, _Tp v2) | 
|  | 1x3 or 3x1 matrix  More... 
 | 
|  | 
|  | Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3) | 
|  | 1x4, 2x2 or 4x1 matrix  More... 
 | 
|  | 
|  | Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4) | 
|  | 1x5 or 5x1 matrix  More... 
 | 
|  | 
|  | Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5) | 
|  | 1x6, 2x3, 3x2 or 6x1 matrix  More... 
 | 
|  | 
|  | Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6) | 
|  | 1x7 or 7x1 matrix  More... 
 | 
|  | 
|  | Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6, _Tp v7) | 
|  | 1x8, 2x4, 4x2 or 8x1 matrix  More... 
 | 
|  | 
|  | Matx (_Tp v0, _Tp v1, _Tp v2, _Tp v3, _Tp v4, _Tp v5, _Tp v6, _Tp v7, _Tp v8) | 
|  | 1x9, 3x3 or 9x1 matrix  More... 
 | 
|  | 
|  | 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  More... 
 | 
|  | 
|  | 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  More... 
 | 
|  | 
|  | 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  More... 
 | 
|  | 
|  | 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  More... 
 | 
|  | 
|  | Matx (const _Tp *vals) | 
|  | initialize from a plain array  More... 
 | 
|  | 
|  | 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_SubOp) | 
|  | 
|  | 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_MulOp) | 
|  | 
|  | Matx (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b, Matx_DivOp) | 
|  | 
|  | Matx (const Matx< _Tp, m, l > &a, const Matx< _Tp, l, n > &b, Matx_MatMulOp) | 
|  | 
|  | Matx (const Matx< _Tp, n, m > &a, Matx_TOp) | 
|  | 
| Matx< _Tp, m, 1 > | col (int i) const | 
|  | extract the matrix column  More... 
 | 
|  | 
| double | ddot (const Matx< _Tp, m, n > &v) const | 
|  | dot product computed in double-precision arithmetics  More... 
 | 
|  | 
| diag_type | diag () const | 
|  | extract the matrix diagonal  More... 
 | 
|  | 
| Matx< _Tp, m, n > | div (const Matx< _Tp, m, n > &a) const | 
|  | divide two matrices element-wise  More... 
 | 
|  | 
| _Tp | dot (const Matx< _Tp, m, n > &v) const | 
|  | dot product computed with the default precision  More... 
 | 
|  | 
| Matx< _Tp, m1, n1 > | get_minor (int base_row, int base_col) const | 
|  | extract part of the matrix  More... 
 | 
|  | 
| Matx< _Tp, n, m > | inv (int method=DECOMP_LU, bool *p_is_ok=NULL) const | 
|  | invert the matrix  More... 
 | 
|  | 
| Matx< _Tp, m, n > | mul (const Matx< _Tp, m, n > &a) const | 
|  | multiply two matrices element-wise  More... 
 | 
|  | 
|  | operator Matx< T2, m, n > () const | 
|  | conversion to another data type  More... 
 | 
|  | 
| const _Tp & | operator() (int row, int col) const | 
|  | element access  More... 
 | 
|  | 
| _Tp & | operator() (int row, int col) | 
|  | 
| const _Tp & | operator() (int i) const | 
|  | 1D element access  More... 
 | 
|  | 
| _Tp & | operator() (int i) | 
|  | 
| Matx< _Tp, m1, n1 > | reshape () const | 
|  | change the matrix shape  More... 
 | 
|  | 
| Matx< _Tp, 1, n > | row (int i) const | 
|  | extract the matrix row  More... 
 | 
|  | 
| Matx< _Tp, n, l > | solve (const Matx< _Tp, m, l > &rhs, int flags=DECOMP_LU) const | 
|  | solve linear system  More... 
 | 
|  | 
| Vec< _Tp, n > | solve (const Vec< _Tp, m > &rhs, int method) const | 
|  | 
| Matx< _Tp, n, m > | t () const | 
|  | transpose the matrix  More... 
 | 
|  | 
|  | 
| (Note that these are not member functions.)  | 
|  | 
| template<typename _Tp1 , typename _Tp2 , int cn> | 
| static Vec< _Tp1, cn > & | operator+= (Vec< _Tp1, cn > &a, const Vec< _Tp2, cn > &b) | 
|  | 
| template<typename _Tp1 , typename _Tp2 , int cn> | 
| static Vec< _Tp1, cn > & | operator-= (Vec< _Tp1, cn > &a, const Vec< _Tp2, cn > &b) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > | operator+ (const Vec< _Tp, cn > &a, const Vec< _Tp, cn > &b) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > | operator- (const Vec< _Tp, cn > &a, const Vec< _Tp, cn > &b) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > & | operator*= (Vec< _Tp, cn > &a, int alpha) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > & | operator*= (Vec< _Tp, cn > &a, float alpha) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > & | operator*= (Vec< _Tp, cn > &a, double alpha) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > & | operator/= (Vec< _Tp, cn > &a, int alpha) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > & | operator/= (Vec< _Tp, cn > &a, float alpha) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > & | operator/= (Vec< _Tp, cn > &a, double alpha) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > | operator* (const Vec< _Tp, cn > &a, int alpha) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > | operator* (int alpha, const Vec< _Tp, cn > &a) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > | operator* (const Vec< _Tp, cn > &a, float alpha) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > | operator* (float alpha, const Vec< _Tp, cn > &a) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > | operator* (const Vec< _Tp, cn > &a, double alpha) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > | operator* (double alpha, const Vec< _Tp, cn > &a) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > | operator/ (const Vec< _Tp, cn > &a, int alpha) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > | operator/ (const Vec< _Tp, cn > &a, float alpha) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > | operator/ (const Vec< _Tp, cn > &a, double alpha) | 
|  | 
| template<typename _Tp , int cn> | 
| static Vec< _Tp, cn > | operator- (const Vec< _Tp, cn > &a) | 
|  | 
| template<typename _Tp > | 
| Vec< _Tp, 4 > | operator* (const Vec< _Tp, 4 > &v1, const Vec< _Tp, 4 > &v2) | 
|  | 
| template<typename _Tp > | 
| Vec< _Tp, 4 > & | operator*= (Vec< _Tp, 4 > &v1, const Vec< _Tp, 4 > &v2) | 
|  | 
| static Matx< _Tp1, m, n > & | operator+= (Matx< _Tp1, m, n > &a, const Matx< _Tp2, m, n > &b) | 
|  | 
| static Matx< _Tp1, m, n > & | operator-= (Matx< _Tp1, m, n > &a, const Matx< _Tp2, m, n > &b) | 
|  | 
| static Matx< _Tp, m, n > | operator+ (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b) | 
|  | 
| static Matx< _Tp, m, n > | operator- (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b) | 
|  | 
| static Matx< _Tp, m, n > | operator- (const Matx< _Tp, m, n > &a) | 
|  | 
| static Matx< _Tp, m, n > & | operator*= (Matx< _Tp, m, n > &a, int alpha) | 
|  | 
| static Matx< _Tp, m, n > & | operator*= (Matx< _Tp, m, n > &a, float alpha) | 
|  | 
| static Matx< _Tp, m, n > & | operator*= (Matx< _Tp, m, n > &a, double alpha) | 
|  | 
| static Matx< _Tp, m, n > | operator* (const Matx< _Tp, m, n > &a, int alpha) | 
|  | 
| static Matx< _Tp, m, n > | operator* (const Matx< _Tp, m, n > &a, float alpha) | 
|  | 
| static Matx< _Tp, m, n > | operator* (const Matx< _Tp, m, n > &a, double alpha) | 
|  | 
| static Matx< _Tp, m, n > | operator* (int alpha, const Matx< _Tp, m, n > &a) | 
|  | 
| static Matx< _Tp, m, n > | operator* (float alpha, const Matx< _Tp, m, n > &a) | 
|  | 
| static Matx< _Tp, m, n > | operator* (double alpha, const Matx< _Tp, m, n > &a) | 
|  | 
| static Matx< _Tp, m, n > | operator* (const Matx< _Tp, m, l > &a, const Matx< _Tp, l, n > &b) | 
|  | 
| static Vec< _Tp, m > | operator* (const Matx< _Tp, m, n > &a, const Vec< _Tp, n > &b) | 
|  | 
| static bool | operator== (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b) | 
|  | 
| static bool | operator!= (const Matx< _Tp, m, n > &a, const Matx< _Tp, m, n > &b) | 
|  | 
template<typename _Tp, int cn>
class cv::Vec< _Tp, cn >
Template class for short numerical vectors, a partial case of Matx. 
This template class represents short numerical vectors (of 1, 2, 3, 4 ... elements) on which you can perform basic arithmetical operations, access individual elements using [] operator etc. The vectors are allocated on stack, as opposite to std::valarray, std::vector, cv::Mat etc., which elements are dynamically allocated in the heap.
The template takes 2 parameters: 
- Template Parameters
- 
  
    | _Tp | element type |  | cn | the number of elements |  
 
In addition to the universal notation like Vec<float, 3>, you can use shorter aliases for the most popular specialized variants of Vec, e.g. Vec3f ~ Vec<float, 3>.
It is possible to convert Vec<T,2> to/from Point_, Vec<T,3> to/from Point3_ , and Vec<T,4> to CvScalar or Scalar_. Use operator[] to access the elements of Vec.
All the expected vector operations are also implemented:
- v1 = v2 + v3
- v1 = v2 - v3
- v1 = v2 * scale
- v1 = scale * v2
- v1 = -v2
- v1 += v2 and other augmenting operations
- v1 == v2, v1 != v2
- norm(v1) (euclidean norm) The Vec class is commonly used to describe pixel types of multi-channel arrays. See Mat for details. 
- Examples: 
- samples/cpp/camshiftdemo.cpp, samples/cpp/connected_components.cpp, samples/cpp/fitellipse.cpp, samples/cpp/tutorial_code/ImgTrans/houghcircles.cpp, samples/cpp/tutorial_code/ImgTrans/houghlines.cpp, samples/cpp/watershed.cpp, and samples/dnn/segmentation.cpp.