44
#ifndef OPENCV_CORE_MAT_HPP
45
#define OPENCV_CORE_MAT_HPP
48
# error mat.hpp header must be compiled as C++
51
#include "opencv2/core/matx.hpp"
52
#include "opencv2/core/types.hpp"
54
#include "opencv2/core/bufferpool.hpp"
56
#include <type_traits>
64
enum
AccessFlag { ACCESS_READ=1<<24, ACCESS_WRITE=1<<25,
65
ACCESS_RW=3<<24, ACCESS_MASK=ACCESS_RW, ACCESS_FAST=1<<26 };
66CV_ENUM_FLAGS(AccessFlag)
67__CV_ENUM_FLAGS_BITWISE_AND(AccessFlag,
int, AccessFlag)
71
class
CV_EXPORTS _OutputArray;
163
FIXED_TYPE = 0x8000 << KIND_SHIFT,
164
FIXED_SIZE = 0x4000 << KIND_SHIFT,
165
KIND_MASK = 31 << KIND_SHIFT,
167
NONE = 0 << KIND_SHIFT,
168
MAT = 1 << KIND_SHIFT,
169
MATX = 2 << KIND_SHIFT,
170
STD_VECTOR = 3 << KIND_SHIFT,
171
STD_VECTOR_VECTOR = 4 << KIND_SHIFT,
172
STD_VECTOR_MAT = 5 << KIND_SHIFT,
173
#if OPENCV_ABI_COMPATIBILITY < 500
174
EXPR = 6 << KIND_SHIFT,
176
OPENGL_BUFFER = 7 << KIND_SHIFT,
177
CUDA_HOST_MEM = 8 << KIND_SHIFT,
178
CUDA_GPU_MAT = 9 << KIND_SHIFT,
179
UMAT =10 << KIND_SHIFT,
180
STD_VECTOR_UMAT =11 << KIND_SHIFT,
181
STD_BOOL_VECTOR =12 << KIND_SHIFT,
182
STD_VECTOR_CUDA_GPU_MAT = 13 << KIND_SHIFT,
183
#if OPENCV_ABI_COMPATIBILITY < 500
184
STD_ARRAY =14 << KIND_SHIFT,
186
STD_ARRAY_MAT =15 << KIND_SHIFT
195
template<
typename
_Tp>
_InputArray(
const
std::vector<_Tp>& vec);
197
template<
typename
_Tp>
_InputArray(
const
std::vector<std::vector<_Tp> >& vec);
198
_InputArray(
const
std::vector<std::vector<bool> >&) =
delete;
200
template<
typename
_Tp>
_InputArray(
const
_Tp* vec,
int
n);
204
_InputArray(
const
std::vector<cuda::GpuMat>& d_mat_array);
207
template<
typename
_Tp>
_InputArray(
const
cudev::GpuMat_<_Tp>& m);
211
template<
typename
_Tp, std::
size_t
_Nm>
_InputArray(
const
std::array<_Tp, _Nm>& arr);
212
template<std::
size_t
_Nm>
_InputArray(
const
std::array<Mat, _Nm>& arr);
214
template<
typename
_Tp>
static
_InputArray
rawIn(
const
std::vector<_Tp>& vec);
215
template<
typename
_Tp, std::
size_t
_Nm>
static
_InputArray
rawIn(
const
std::array<_Tp, _Nm>& arr);
217
Mat
getMat(
int
idx=-1)
const;
218
Mat
getMat_(
int
idx=-1)
const;
219
UMat
getUMat(
int
idx=-1)
const;
220
void
getMatVector(std::vector<Mat>& mv)
const;
221
void
getUMatVector(std::vector<UMat>& umv)
const;
222
void
getGpuMatVector(std::vector<cuda::GpuMat>& gpumv)
const;
226
int
getFlags()
const;
227
void* getObj()
const;
231
int
dims(
int
i=-1)
const;
232
int
cols(
int
i=-1)
const;
233
int
rows(
int
i=-1)
const;
234
Size
size(
int
i=-1)
const;
235
int
sizend(
int* sz,
int
i=-1)
const;
237
size_t
total(
int
i=-1)
const;
238
int
type(
int
i=-1)
const;
239
int
depth(
int
i=-1)
const;
240
int
channels(
int
i=-1)
const;
241
bool
isContinuous(
int
i=-1)
const;
242
bool
isSubmatrix(
int
i=-1)
const;
246
size_t
offset(
int
i=-1)
const;
247
size_t
step(
int
i=-1)
const;
250
bool
isMatVector()
const;
251
bool
isUMatVector()
const;
253
bool
isVector()
const;
254
bool
isGpuMat()
const;
255
bool
isGpuMatVector()
const;
263
void
init(
int
_flags,
const
void* _obj);
264
void
init(
int
_flags,
const
void* _obj,
Size
_sz);
299
DEPTH_MASK_8U = 1 << CV_8U,
300
DEPTH_MASK_8S = 1 << CV_8S,
301
DEPTH_MASK_16U = 1 << CV_16U,
302
DEPTH_MASK_16S = 1 << CV_16S,
303
DEPTH_MASK_32S = 1 << CV_32S,
304
DEPTH_MASK_32F = 1 << CV_32F,
305
DEPTH_MASK_64F = 1 << CV_64F,
306
DEPTH_MASK_16F = 1 << CV_16F,
307
DEPTH_MASK_ALL = (DEPTH_MASK_64F<<1)-1,
308
DEPTH_MASK_ALL_BUT_8S = DEPTH_MASK_ALL & ~DEPTH_MASK_8S,
309
DEPTH_MASK_ALL_16F = (DEPTH_MASK_16F<<1)-1,
310
DEPTH_MASK_FLT = DEPTH_MASK_32F + DEPTH_MASK_64F
321
template<
typename
_Tp>
_OutputArray(cudev::GpuMat_<_Tp>& m);
322
template<
typename
_Tp>
_OutputArray(std::vector<_Tp>& vec);
324
template<
typename
_Tp>
_OutputArray(std::vector<std::vector<_Tp> >& vec);
325
_OutputArray(std::vector<std::vector<bool> >&) =
delete;
339
template<
typename
_Tp>
_OutputArray(
const
cudev::GpuMat_<_Tp>& m);
340
template<
typename
_Tp>
_OutputArray(
const
std::vector<_Tp>& vec);
341
template<
typename
_Tp>
_OutputArray(
const
std::vector<std::vector<_Tp> >& vec);
344
template<
typename
_Tp>
_OutputArray(
const
_Tp* vec,
int
n);
349
template<
typename
_Tp, std::
size_t
_Nm>
_OutputArray(std::array<_Tp, _Nm>& arr);
350
template<
typename
_Tp, std::
size_t
_Nm>
_OutputArray(
const
std::array<_Tp, _Nm>& arr);
351
template<std::
size_t
_Nm>
_OutputArray(std::array<Mat, _Nm>& arr);
352
template<std::
size_t
_Nm>
_OutputArray(
const
std::array<Mat, _Nm>& arr);
355
template<
typename
_Tp, std::
size_t
_Nm>
static
_OutputArray
rawOut(std::array<_Tp, _Nm>& arr);
357
bool
fixedSize()
const;
358
bool
fixedType()
const;
360
Mat& getMatRef(
int
i=-1)
const;
361
UMat& getUMatRef(
int
i=-1)
const;
363
std::vector<cuda::GpuMat>& getGpuMatVecRef()
const;
366
void
create(
Size
sz,
int
type,
int
i=-1,
bool
allowTransposed=
false, _OutputArray::DepthMask fixedDepthMask=
static_cast<_OutputArray::DepthMask
>(0))
const;
367
void
create(
int
rows,
int
cols,
int
type,
int
i=-1,
bool
allowTransposed=
false, _OutputArray::DepthMask fixedDepthMask=
static_cast<_OutputArray::DepthMask
>(0))
const;
368
void
create(
int
dims,
const
int* size,
int
type,
int
i=-1,
bool
allowTransposed=
false, _OutputArray::DepthMask fixedDepthMask=
static_cast<_OutputArray::DepthMask
>(0))
const;
369
void
createSameSize(
const
_InputArray& arr,
int
mtype)
const;
370
void
release()
const;
374
void
assign(
const
UMat& u)
const;
375
void
assign(
const
Mat& m)
const;
377
void
assign(
const
std::vector<UMat>& v)
const;
378
void
assign(
const
std::vector<Mat>& v)
const;
380
void
move(
UMat& u)
const;
381
void
move(
Mat& m)
const;
414
template<
typename
_Tp>
_InputOutputArray(
const
std::vector<std::vector<_Tp> >& vec);
422
template<
typename
_Tp, std::
size_t
_Nm>
_InputOutputArray(std::array<_Tp, _Nm>& arr);
423
template<
typename
_Tp, std::
size_t
_Nm>
_InputOutputArray(
const
std::array<_Tp, _Nm>& arr);
442
typedef
InputArray InputArrayOfArrays;
458
USAGE_ALLOCATE_HOST_MEMORY = 1 << 0,
459
USAGE_ALLOCATE_DEVICE_MEMORY = 1 << 1,
460
USAGE_ALLOCATE_SHARED_MEMORY = 1 << 2,
462
__UMAT_USAGE_FLAGS_32BIT = 0x7fffffff
465
struct
CV_EXPORTS UMatData;
479
virtual
UMatData* allocate(
int
dims,
const
int* sizes,
int
type,
480
void* data,
size_t* step, AccessFlag flags,
UMatUsageFlags
usageFlags)
const
= 0;
482
virtual
void
deallocate(
UMatData* data)
const
= 0;
483
virtual
void
map(
UMatData* data, AccessFlag accessflags)
const;
484
virtual
void
unmap(
UMatData* data)
const;
485
virtual
void
download(
UMatData* data,
void* dst,
int
dims,
const
size_t
sz[],
486
const
size_t
srcofs[],
const
size_t
srcstep[],
487
const
size_t
dststep[])
const;
488
virtual
void
upload(
UMatData* data,
const
void* src,
int
dims,
const
size_t
sz[],
489
const
size_t
dstofs[],
const
size_t
dststep[],
490
const
size_t
srcstep[])
const;
491
virtual
void
copy(
UMatData* srcdata,
UMatData* dstdata,
int
dims,
const
size_t
sz[],
492
const
size_t
srcofs[],
const
size_t
srcstep[],
493
const
size_t
dstofs[],
const
size_t
dststep[],
bool
sync)
const;
536
enum
MemoryFlag { COPY_ON_MAP=1, HOST_COPY_OBSOLETE=2,
537
DEVICE_COPY_OBSOLETE=4, TEMP_UMAT=8, TEMP_COPIED_UMAT=24,
538
USER_ALLOCATED=32, DEVICE_MEM_MAPPED=64,
548
bool
hostCopyObsolete()
const;
549
bool
deviceCopyObsolete()
const;
550
bool
deviceMemMapped()
const;
551
bool
copyOnMap()
const;
552
bool
tempUMat()
const;
553
bool
tempCopiedUMat()
const;
554
void
markHostCopyObsolete(
bool
flag);
555
void
markDeviceCopyObsolete(
bool
flag);
556
void
markDeviceMemMapped(
bool
flag);
566
UMatData::MemoryFlag flags;
572
std::shared_ptr<void> allocatorContext;
574CV_ENUM_FLAGS(UMatData::MemoryFlag)
579
explicit
MatSize(
int* _p) CV_NOEXCEPT;
580
int
dims()
const
CV_NOEXCEPT;
581
Size
operator()()
const;
582
const
int& operator[](
int
i)
const;
583
int& operator[](
int
i);
584
operator
const
int*()
const
CV_NOEXCEPT;
585
bool
operator == (
const
MatSize& sz)
const
CV_NOEXCEPT;
586
bool
operator != (
const
MatSize& sz)
const
CV_NOEXCEPT;
594
explicit
MatStep(
size_t
s) CV_NOEXCEPT;
595
const
size_t& operator[](
int
i)
const
CV_NOEXCEPT;
596
size_t& operator[](
int
i) CV_NOEXCEPT;
597
operator
size_t()
const;
598
MatStep& operator = (
size_t
s);
818
Mat(
int
rows,
int
cols,
int
type);
856
Mat(
int
ndims, const
int* sizes,
int
type);
863
Mat(const std::vector<
int>& sizes,
int
type);
874
Mat(
int
ndims, const
int* sizes,
int
type, const
Scalar& s);
884
Mat(const std::vector<
int>& sizes,
int
type, const
Scalar& s);
910
Mat(
int
rows,
int
cols,
int
type,
void* data,
size_t
step=AUTO_STEP);
926
Mat(
Size
size,
int
type,
void* data,
size_t
step=AUTO_STEP);
941
Mat(
int
ndims, const
int* sizes,
int
type,
void* data, const
size_t* steps=0);
955
Mat(const std::vector<
int>& sizes,
int
type,
void* data, const
size_t* steps=0);
1015
template<typename _Tp> explicit
Mat(const std::vector<_Tp>& vec,
bool
copyData=false);
1019
template<typename _Tp, typename = typename std::enable_if<std::is_arithmetic<_Tp>::value>::type>
1020
explicit
Mat(const std::initializer_list<_Tp> list);
1024
template<typename _Tp> explicit
Mat(const std::initializer_list<
int> sizes, const std::initializer_list<_Tp> list);
1028
template<typename _Tp,
size_t
_Nm> explicit
Mat(const std::array<_Tp, _Nm>& arr,
bool
copyData=false);
1032
template<typename _Tp,
int
n> explicit
Mat(const
Vec<_Tp, n>& vec,
bool
copyData=true);
1036
template<typename _Tp,
int
m,
int
n> explicit
Mat(const
Matx<_Tp, m, n>& mtx,
bool
copyData=true);
1040
template<typename _Tp> explicit
Mat(const
Point_<_Tp>& pt,
bool
copyData=true);
1044
template<typename _Tp> explicit
Mat(const
Point3_<_Tp>& pt,
bool
copyData=true);
1051
explicit
Mat(const cuda::GpuMat& m);
1129
Mat
rowRange(
int
startrow,
int
endrow) const;
1143
Mat
colRange(
int
startcol,
int
endcol) const;
1198
Mat
clone() const CV_NODISCARD;
1238
void
convertTo(
OutputArray
m,
int
rtype,
double
alpha=1,
double
beta=0 ) const;
1246
void
assignTo(
Mat& m,
int
type=-1 ) const;
1260
Mat& setTo(InputArray value, InputArray mask=noArray());
1286
Mat
reshape(
int
cn,
int
rows=0) const;
1289
Mat
reshape(
int
cn,
int
newndims, const
int* newsz) const;
1292
Mat
reshape(
int
cn, const std::vector<
int>& newshape) const;
1336
Mat
cross(InputArray m) const;
1346
double
dot(InputArray m) const;
1362
static
MatExpr
zeros(
int
rows,
int
cols,
int
type);
1375
static
MatExpr
zeros(
int
ndims, const
int* sz,
int
type);
1393
static
MatExpr
ones(
int
rows,
int
cols,
int
type);
1406
static
MatExpr
ones(
int
ndims, const
int* sz,
int
type);
1463
void
create(
int
rows,
int
cols,
int
type);
1476
void
create(
int
ndims, const
int* sizes,
int
type);
1482
void
create(const std::vector<
int>& sizes,
int
type);
1522
void
reserve(
size_t
sz);
1530
void
reserveBuffer(
size_t
sz);
1548
void
push_back_(const
void* elem);
1557
template<typename _Tp>
void
push_back(const _Tp& elem);
1562
template<typename _Tp>
void
push_back(const
Mat_<_Tp>& elem);
1567
template<typename _Tp>
void
push_back(const std::vector<_Tp>& elem);
1580
void
pop_back(
size_t
nelems=1);
1622
Mat& adjustROI(
int
dtop,
int
dbottom,
int
dleft,
int
dright );
1650
Mat
operator()(const std::vector<
Range>& ranges) const;
1652
template<typename _Tp> operator std::vector<_Tp>() const;
1653
template<typename _Tp,
int
n> operator
Vec<_Tp, n>() const;
1654
template<typename _Tp,
int
m,
int
n> operator
Matx<_Tp, m, n>() const;
1656
template<typename _Tp, std::
size_t
_Nm> operator std::array<_Tp, _Nm>() const;
1732
bool
isContinuous() const;
1735
bool
isSubmatrix() const;
1742
size_t
elemSize() const;
1749
size_t
elemSize1() const;
1777
int
channels() const;
1784
size_t
step1(
int
i=0) const;
1798
size_t
total() const;
1804
size_t
total(
int
startDim,
int
endDim=INT_MAX) const;
1827
int
checkVector(
int
elemChannels,
int
depth=-1,
bool
requireContinuous=true) const;
1835
uchar* ptr(
int
i0=0);
1837
const uchar* ptr(
int
i0=0) const;
1843
uchar* ptr(
int
row,
int
col);
1848
const uchar* ptr(
int
row,
int
col) const;
1851
uchar* ptr(
int
i0,
int
i1,
int
i2);
1853
const uchar* ptr(
int
i0,
int
i1,
int
i2) const;
1856
uchar* ptr(const
int* idx);
1858
const uchar* ptr(const
int* idx) const;
1860
template<
int
n> uchar* ptr(const
Vec<
int, n>& idx);
1862
template<
int
n> const uchar* ptr(const
Vec<
int, n>& idx) const;
1865
template<typename _Tp> _Tp* ptr(
int
i0=0);
1867
template<typename _Tp> const _Tp* ptr(
int
i0=0) const;
1872
template<typename _Tp> _Tp* ptr(
int
row,
int
col);
1877
template<typename _Tp> const _Tp* ptr(
int
row,
int
col) const;
1879
template<typename _Tp> _Tp* ptr(
int
i0,
int
i1,
int
i2);
1881
template<typename _Tp> const _Tp* ptr(
int
i0,
int
i1,
int
i2) const;
1883
template<typename _Tp> _Tp* ptr(const
int* idx);
1885
template<typename _Tp> const _Tp* ptr(const
int* idx) const;
1887
template<typename _Tp,
int
n> _Tp* ptr(const
Vec<
int, n>& idx);
1889
template<typename _Tp,
int
n> const _Tp* ptr(const
Vec<
int, n>& idx) const;
1921
template<typename _Tp> _Tp& at(
int
i0=0);
1925
template<typename _Tp> const _Tp& at(
int
i0=0) const;
1930
template<typename _Tp> _Tp& at(
int
row,
int
col);
1935
template<typename _Tp> const _Tp& at(
int
row,
int
col) const;
1942
template<typename _Tp> _Tp& at(
int
i0,
int
i1,
int
i2);
1948
template<typename _Tp> const _Tp& at(
int
i0,
int
i1,
int
i2) const;
1953
template<typename _Tp> _Tp& at(const
int* idx);
1957
template<typename _Tp> const _Tp& at(const
int* idx) const;
1960
template<typename _Tp,
int
n> _Tp& at(const
Vec<
int, n>& idx);
1962
template<typename _Tp,
int
n> const _Tp& at(const
Vec<
int, n>& idx) const;
1968
template<typename _Tp> _Tp& at(
Point
pt);
1973
template<typename _Tp> const _Tp& at(
Point
pt) const;
2017
template<typename _Tp> std::reverse_iterator<
MatConstIterator_<_Tp>> rbegin() const;
2030
template<typename _Tp> std::reverse_iterator<
MatConstIterator_<_Tp>> rend() const;
2087
template<typename _Tp, typename Functor>
void
forEach(const Functor& operation);
2089
template<typename _Tp, typename Functor>
void
forEach(const Functor& operation) const;
2092
Mat& operator = (
Mat&& m);
2094
enum { MAGIC_VAL = 0x42FF0000, AUTO_STEP = 0, CONTINUOUS_FLAG = CV_MAT_CONT_FLAG, SUBMATRIX_FLAG = CV_SUBMAT_FLAG };
2095
enum
{ MAGIC_MASK = 0xFFFF0000, TYPE_MASK = 0x00000FFF, DEPTH_MASK = 7 };
2113
const
uchar* dataend;
2114
const
uchar* datalimit;
2121
static
void
setDefaultAllocator(
MatAllocator* allocator);
2133
template<
typename
_Tp,
typename
Functor>
void
forEach_impl(
const
Functor& operation);
2201
typedef
_Tp value_type;
2211
Mat_(
int
_rows,
int
_cols, const _Tp& value);
2217
Mat_(
int
_ndims, const
int* _sizes);
2219
Mat_(
int
_ndims, const
int* _sizes, const _Tp& value);
2225
Mat_(
int
_rows,
int
_cols, _Tp* _data,
size_t
_step=AUTO_STEP);
2227
Mat_(
int
_ndims, const
int* _sizes, _Tp* _data, const
size_t* _steps=0);
2239
explicit
Mat_(const std::vector<_Tp>& vec,
bool
copyData=false);
2240
template<
int
n> explicit
Mat_(const
Vec<typename
DataType<_Tp>::channel_type, n>& vec,
bool
copyData=true);
2241
template<
int
m,
int
n> explicit
Mat_(const
Matx<typename
DataType<_Tp>::channel_type, m, n>& mtx,
bool
copyData=true);
2242
explicit
Mat_(const
Point_<typename
DataType<_Tp>::channel_type>& pt,
bool
copyData=true);
2243
explicit
Mat_(const
Point3_<typename
DataType<_Tp>::channel_type>& pt,
bool
copyData=true);
2246
Mat_(std::initializer_list<_Tp> values);
2247
explicit
Mat_(const std::initializer_list<
int> sizes, const std::initializer_list<_Tp> values);
2249
template <std::
size_t
_Nm> explicit
Mat_(const std::array<_Tp, _Nm>& arr,
bool
copyData=false);
2251
Mat_& operator = (const
Mat& m);
2265
std::reverse_iterator<
iterator> rbegin();
2266
std::reverse_iterator<
iterator> rend();
2272
template<typename Functor>
void
forEach(const Functor& operation);
2273
template<typename Functor>
void
forEach(const Functor& operation) const;
2286
template<typename T2> operator
Mat_<T2>() const;
2289
Mat_
col(
int
x) const;
2290
Mat_
diag(
int
d=0) const;
2291
Mat_
clone() const CV_NODISCARD;
2295
size_t
elemSize1() const;
2298
int
channels() const;
2299
size_t
step1(
int
i=0) const;
2309
static
MatExpr
ones(
int
_ndims, const
int* _sizes);
2316
Mat_
operator()( const
Rect& roi ) const;
2317
Mat_
operator()( const
Range* ranges ) const;
2318
Mat_
operator()(const std::vector<
Range>& ranges) const;
2321
_Tp* operator [](
int
y);
2322
const _Tp* operator [](
int
y) const;
2325
_Tp& operator ()(const
int* idx);
2327
const _Tp& operator ()(const
int* idx) const;
2330
template<
int
n> _Tp& operator ()(const
Vec<
int, n>& idx);
2332
template<
int
n> const _Tp& operator ()(const
Vec<
int, n>& idx) const;
2335
_Tp& operator ()(
int
idx0);
2337
const _Tp& operator ()(
int
idx0) const;
2339
_Tp& operator ()(
int
row,
int
col);
2341
const _Tp& operator ()(
int
row,
int
col) const;
2343
_Tp& operator ()(
int
idx0,
int
idx1,
int
idx2);
2345
const _Tp& operator ()(
int
idx0,
int
idx1,
int
idx2) const;
2347
_Tp& operator ()(
Point
pt);
2348
const _Tp& operator ()(
Point
pt) const;
2351
operator std::vector<_Tp>() const;
2354
template<std::
size_t
_Nm> operator std::array<_Tp, _Nm>() const;
2357
template<
int
n> operator
Vec<typename
DataType<_Tp>::channel_type, n>() const;
2359
template<
int
m,
int
n> operator
Matx<typename
DataType<_Tp>::channel_type, m, n>() const;
2425
UMat(
const
UMat& m,
const
std::vector<Range>& ranges);
2429
template<
typename
_Tp>
explicit
UMat(
const
std::vector<_Tp>& vec,
bool
copyData=
false);
2436
Mat
getMat(AccessFlag flags)
const;
2455
static
UMat
diag(
const
UMat& d) {
return
diag(d, USAGE_DEFAULT); }
2476
UMat
reshape(
int
cn,
int
newndims, const
int* newsz) const;
2486
double
dot(InputArray m) const;
2494
static
UMat
zeros(
int
ndims,
const
int* sz,
int
type) {
return
zeros(ndims, sz, type, USAGE_DEFAULT); }
2496
static
UMat ones(Size size,
int
type,
UMatUsageFlags
usageFlags
);
2497
static
UMat ones(
int
ndims,
const
int* sz,
int
type,
UMatUsageFlags
usageFlags
);
2498
static
UMat ones(
int
rows,
int
cols,
int
type) {
return
ones(
rows, cols, type, USAGE_DEFAULT); }
2499
static
UMat ones(Size size,
int
type) {
return
ones(size, type, USAGE_DEFAULT); }
2500
static
UMat ones(
int
ndims,
const
int* sz,
int
type) {
return
ones(ndims, sz, type, USAGE_DEFAULT); }
2502
static
UMat eye(Size size,
int
type,
UMatUsageFlags
usageFlags
);
2503
static
UMat eye(
int
rows,
int
cols,
int
type) {
return
eye(
rows, cols, type, USAGE_DEFAULT); }
2504
static
UMat eye(Size size,
int
type) {
return
eye(size, type, USAGE_DEFAULT); }
2511
void
create(
const
std::vector<int>& sizes,
int
type,
UMatUsageFlags
usageFlags = USAGE_DEFAULT);
2531
UMat
operator()(
const
Rect& roi )
const;
2532
UMat
operator()(
const
Range* ranges )
const;
2533
UMat
operator()(
const
std::vector<Range>& ranges)
const;
2562
int
checkVector(
int
elemChannels,
int
depth=-1,
bool
requireContinuous=
true)
const;
2572
void
ndoffset(
size_t* ofs)
const;
2574
enum
{ MAGIC_VAL = 0x42FF0000, AUTO_STEP = 0, CONTINUOUS_FLAG = CV_MAT_CONT_FLAG, SUBMATRIX_FLAG = CV_SUBMAT_FLAG };
2575
enum
{ MAGIC_MASK = 0xFFFF0000, TYPE_MASK = 0x00000FFF, DEPTH_MASK = 7 };
2709
enum
{ MAGIC_VAL=0x42FD0000, MAX_DIM=32, HASH_SCALE=0x5bd1e995, HASH_BIT=0x80000000 };
2714
Hdr(
int
_dims,
const
int* _sizes,
int
_type);
2722
std::vector<uchar> pool;
2723
std::vector<size_t> hashtab;
2812
size_t
elemSize1() const;
2819
int
channels() const;
2822
const
int* size() const;
2824
int
size(
int
i) const;
2828
size_t
nzcount() const;
2831
size_t
hash(
int
i0) const;
2833
size_t
hash(
int
i0,
int
i1) const;
2835
size_t
hash(
int
i0,
int
i1,
int
i2) const;
2837
size_t
hash(const
int* idx) const;
2851
uchar*
ptr(
int
i0,
bool
createMissing,
size_t* hashval=0);
2853
uchar*
ptr(
int
i0,
int
i1,
bool
createMissing,
size_t* hashval=0);
2855
uchar*
ptr(
int
i0,
int
i1,
int
i2,
bool
createMissing,
size_t* hashval=0);
2857
uchar*
ptr(const
int* idx,
bool
createMissing,
size_t* hashval=0);
2869
template<typename _Tp> _Tp& ref(
int
i0,
size_t* hashval=0);
2871
template<typename _Tp> _Tp& ref(
int
i0,
int
i1,
size_t* hashval=0);
2873
template<typename _Tp> _Tp& ref(
int
i0,
int
i1,
int
i2,
size_t* hashval=0);
2875
template<typename _Tp> _Tp& ref(const
int* idx,
size_t* hashval=0);
2890
template<typename _Tp> _Tp value(
int
i0,
size_t* hashval=0) const;
2892
template<typename _Tp> _Tp value(
int
i0,
int
i1,
size_t* hashval=0) const;
2894
template<typename _Tp> _Tp value(
int
i0,
int
i1,
int
i2,
size_t* hashval=0) const;
2896
template<typename _Tp> _Tp value(const
int* idx,
size_t* hashval=0) const;
2908
template<typename _Tp> const _Tp* find(
int
i0,
size_t* hashval=0) const;
2910
template<typename _Tp> const _Tp* find(
int
i0,
int
i1,
size_t* hashval=0) const;
2912
template<typename _Tp> const _Tp* find(
int
i0,
int
i1,
int
i2,
size_t* hashval=0) const;
2914
template<typename _Tp> const _Tp* find(const
int* idx,
size_t* hashval=0) const;
2918
void
erase(
int
i0,
int
i1,
size_t* hashval=0);
2920
void
erase(
int
i0,
int
i1,
int
i2,
size_t* hashval=0);
2922
void
erase(const
int* idx,
size_t* hashval=0);
2950
template<typename _Tp> _Tp& value(
Node* n);
2952
template<typename _Tp> const _Tp& value(const
Node* n) const;
2955
Node* node(
size_t
nidx);
2956
const
Node* node(
size_t
nidx) const;
2958
uchar* newNode(const
int* idx,
size_t
hashval);
2959
void
removeNode(
size_t
hidx,
size_t
nidx,
size_t
previdx);
2960
void
resizeHashTab(
size_t
newsize);
3018
int
channels() const;
3021
_Tp& ref(
int
i0,
size_t* hashval=0);
3023
_Tp& ref(
int
i0,
int
i1,
size_t* hashval=0);
3025
_Tp& ref(
int
i0,
int
i1,
int
i2,
size_t* hashval=0);
3027
_Tp& ref(const
int* idx,
size_t* hashval=0);
3030
_Tp operator()(
int
i0,
size_t* hashval=0) const;
3032
_Tp operator()(
int
i0,
int
i1,
size_t* hashval=0) const;
3034
_Tp operator()(
int
i0,
int
i1,
int
i2,
size_t* hashval=0) const;
3036
_Tp operator()(const
int* idx,
size_t* hashval=0) const;
3055
typedef
uchar* value_type;
3056
typedef
ptrdiff_t difference_type;
3057
typedef
const
uchar** pointer;
3058
typedef
uchar* reference;
3060
typedef
std::random_access_iterator_tag iterator_category;
3078
const
uchar* operator *()
const;
3099
ptrdiff_t lpos()
const;
3100
void
seek(ptrdiff_t ofs,
bool
relative =
false);
3101
void
seek(
const
int* _idx,
bool
relative =
false);
3106
const
uchar* sliceStart;
3107
const
uchar* sliceEnd;
3116
template<
typename
_Tp>
3120
typedef
_Tp value_type;
3121
typedef
ptrdiff_t difference_type;
3122
typedef
const
_Tp* pointer;
3123
typedef
const
_Tp& reference;
3125
typedef
std::random_access_iterator_tag iterator_category;
3143
const
_Tp& operator *()
const;
3169
template<
typename
_Tp>
3173
typedef
_Tp* pointer;
3174
typedef
_Tp& reference;
3176
typedef
std::random_access_iterator_tag iterator_category;
3194
_Tp& operator *()
const;
3242
template<
typename
_Tp>
const
_Tp&
value()
const;
3287
template<
typename
_Tp> _Tp&
value()
const;
3310
typedef
std::forward_iterator_tag iterator_category;
3323
const
_Tp& operator *()
const;
3344
typedef
std::forward_iterator_tag iterator_category;
3357
_Tp& operator *()
const;
3439
void
init(
const
Mat** arrays,
Mat* planes, uchar** ptrs,
int
narrays=-1);
3473
virtual
bool
elementWise(
const
MatExpr& expr)
const;
3474
virtual
void
assign(
const
MatExpr& expr,
Mat& m,
int
type=-1)
const
= 0;
3477
virtual
void
diag(
const
MatExpr& expr,
int
d,
MatExpr& res)
const;
3478
virtual
void
augAssignAdd(
const
MatExpr& expr,
Mat& m)
const;
3479
virtual
void
augAssignSubtract(
const
MatExpr& expr,
Mat& m)
const;
3480
virtual
void
augAssignMultiply(
const
MatExpr& expr,
Mat& m)
const;
3481
virtual
void
augAssignDivide(
const
MatExpr& expr,
Mat& m)
const;
3482
virtual
void
augAssignAnd(
const
MatExpr& expr,
Mat& m)
const;
3483
virtual
void
augAssignOr(
const
MatExpr& expr,
Mat& m)
const;
3484
virtual
void
augAssignXor(
const
MatExpr& expr,
Mat& m)
const;
3505
virtual
int
type(
const
MatExpr& expr)
const;
3561
const
Mat& _c =
Mat(),
double
_alpha = 1,
double
_beta = 1,
const
Scalar& _s =
Scalar());
3563
operator
Mat()
const;
3564
template<
typename
_Tp>
operator
Mat_<_Tp>()
const;
3571
MatExpr
diag(
int
d = 0)
const;
3581
double
dot(
const
Mat& m)
const;
3605
template<
typename
_Tp,
int
m,
int
n>
static
inline
3607
template<
typename
_Tp,
int
m,
int
n>
static
inline
3608MatExpr operator + (
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) + b; }
3610CV_EXPORTS MatExpr operator - (
const
Mat& a,
const
Mat& b);
3611CV_EXPORTS MatExpr operator - (
const
Mat& a,
const
Scalar& s);
3612CV_EXPORTS MatExpr operator - (
const
Scalar& s,
const
Mat& a);
3613CV_EXPORTS MatExpr operator - (
const
MatExpr& e,
const
Mat& m);
3614CV_EXPORTS MatExpr operator - (
const
Mat& m,
const
MatExpr& e);
3615CV_EXPORTS MatExpr operator - (
const
MatExpr& e,
const
Scalar& s);
3616CV_EXPORTS MatExpr operator - (
const
Scalar& s,
const
MatExpr& e);
3617CV_EXPORTS MatExpr operator - (
const
MatExpr& e1,
const
MatExpr& e2);
3618
template<
typename
_Tp,
int
m,
int
n>
static
inline
3619MatExpr operator - (
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
a -
Mat(b); }
3620
template<
typename
_Tp,
int
m,
int
n>
static
inline
3621MatExpr operator - (
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) - b; }
3623CV_EXPORTS MatExpr operator - (
const
Mat& m);
3624CV_EXPORTS MatExpr operator - (
const
MatExpr& e);
3626CV_EXPORTS MatExpr operator * (
const
Mat& a,
const
Mat& b);
3627CV_EXPORTS MatExpr operator * (
const
Mat& a,
double
s);
3628CV_EXPORTS MatExpr operator * (
double
s,
const
Mat& a);
3629CV_EXPORTS MatExpr operator * (
const
MatExpr& e,
const
Mat& m);
3630CV_EXPORTS MatExpr operator * (
const
Mat& m,
const
MatExpr& e);
3631CV_EXPORTS MatExpr operator * (
const
MatExpr& e,
double
s);
3632CV_EXPORTS MatExpr operator * (
double
s,
const
MatExpr& e);
3633CV_EXPORTS MatExpr operator * (
const
MatExpr& e1,
const
MatExpr& e2);
3634
template<
typename
_Tp,
int
m,
int
n>
static
inline
3635MatExpr operator * (
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
a *
Mat(b); }
3636
template<
typename
_Tp,
int
m,
int
n>
static
inline
3637MatExpr operator * (
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) * b; }
3642CV_EXPORTS MatExpr
operator /
(
const
MatExpr& e,
const
Mat& m);
3643CV_EXPORTS MatExpr
operator /
(
const
Mat& m,
const
MatExpr& e);
3644CV_EXPORTS MatExpr
operator /
(
const
MatExpr& e,
double
s);
3645CV_EXPORTS MatExpr
operator /
(
double
s,
const
MatExpr& e);
3646CV_EXPORTS MatExpr
operator /
(
const
MatExpr& e1,
const
MatExpr& e2);
3647
template<
typename
_Tp,
int
m,
int
n>
static
inline
3648MatExpr
operator /
(
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
a /
Mat(b); }
3649
template<
typename
_Tp,
int
m,
int
n>
static
inline
3650MatExpr
operator /
(
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) / b; }
3652CV_EXPORTS MatExpr operator < (
const
Mat& a,
const
Mat& b);
3653CV_EXPORTS MatExpr operator < (
const
Mat& a,
double
s);
3654CV_EXPORTS MatExpr operator < (
double
s,
const
Mat& a);
3655
template<
typename
_Tp,
int
m,
int
n>
static
inline
3656MatExpr operator < (
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
a <
Mat(b); }
3657
template<
typename
_Tp,
int
m,
int
n>
static
inline
3658MatExpr operator < (
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) < b; }
3660CV_EXPORTS MatExpr operator <= (
const
Mat& a,
const
Mat& b);
3661CV_EXPORTS MatExpr operator <= (
const
Mat& a,
double
s);
3662CV_EXPORTS MatExpr operator <= (
double
s,
const
Mat& a);
3663
template<
typename
_Tp,
int
m,
int
n>
static
inline
3664MatExpr operator <= (
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
a <=
Mat(b); }
3665
template<
typename
_Tp,
int
m,
int
n>
static
inline
3666MatExpr operator <= (
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) <= b; }
3668CV_EXPORTS MatExpr operator == (
const
Mat& a,
const
Mat& b);
3669CV_EXPORTS MatExpr operator == (
const
Mat& a,
double
s);
3670CV_EXPORTS MatExpr operator == (
double
s,
const
Mat& a);
3671
template<
typename
_Tp,
int
m,
int
n>
static
inline
3672MatExpr operator == (
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
a ==
Mat(b); }
3673
template<
typename
_Tp,
int
m,
int
n>
static
inline
3674MatExpr operator == (
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) == b; }
3676CV_EXPORTS MatExpr operator != (
const
Mat& a,
const
Mat& b);
3677CV_EXPORTS MatExpr operator != (
const
Mat& a,
double
s);
3678CV_EXPORTS MatExpr operator != (
double
s,
const
Mat& a);
3679
template<
typename
_Tp,
int
m,
int
n>
static
inline
3680MatExpr operator != (
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
a !=
Mat(b); }
3681
template<
typename
_Tp,
int
m,
int
n>
static
inline
3682MatExpr operator != (
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) != b; }
3684CV_EXPORTS MatExpr operator >= (
const
Mat& a,
const
Mat& b);
3685CV_EXPORTS MatExpr operator >= (
const
Mat& a,
double
s);
3686CV_EXPORTS MatExpr operator >= (
double
s,
const
Mat& a);
3687
template<
typename
_Tp,
int
m,
int
n>
static
inline
3688MatExpr operator >= (
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
a >=
Mat(b); }
3689
template<
typename
_Tp,
int
m,
int
n>
static
inline
3690MatExpr operator >= (
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) >= b; }
3692CV_EXPORTS MatExpr operator > (
const
Mat& a,
const
Mat& b);
3693CV_EXPORTS MatExpr operator > (
const
Mat& a,
double
s);
3694CV_EXPORTS MatExpr operator > (
double
s,
const
Mat& a);
3695
template<
typename
_Tp,
int
m,
int
n>
static
inline
3696MatExpr operator > (
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
a >
Mat(b); }
3697
template<
typename
_Tp,
int
m,
int
n>
static
inline
3698MatExpr operator > (
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) > b; }
3701CV_EXPORTS MatExpr
operator &
(
const
Mat& a,
const
Scalar& s);
3702CV_EXPORTS MatExpr
operator &
(
const
Scalar& s,
const
Mat& a);
3703
template<
typename
_Tp,
int
m,
int
n>
static
inline
3704MatExpr
operator &
(
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
a &
Mat(b); }
3705
template<
typename
_Tp,
int
m,
int
n>
static
inline
3706MatExpr
operator &
(
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) & b; }
3709CV_EXPORTS MatExpr
operator |
(
const
Mat& a,
const
Scalar& s);
3710CV_EXPORTS MatExpr
operator |
(
const
Scalar& s,
const
Mat& a);
3711
template<
typename
_Tp,
int
m,
int
n>
static
inline
3712MatExpr
operator |
(
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
a |
Mat(b); }
3713
template<
typename
_Tp,
int
m,
int
n>
static
inline
3714MatExpr
operator |
(
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) | b; }
3717CV_EXPORTS MatExpr
operator ^
(
const
Mat& a,
const
Scalar& s);
3718CV_EXPORTS MatExpr
operator ^
(
const
Scalar& s,
const
Mat& a);
3719
template<
typename
_Tp,
int
m,
int
n>
static
inline
3720MatExpr
operator ^
(
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
a ^
Mat(b); }
3721
template<
typename
_Tp,
int
m,
int
n>
static
inline
3722MatExpr
operator ^
(
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
Mat(a) ^ b; }
3726CV_EXPORTS MatExpr
min(
const
Mat& a,
const
Mat& b);
3727CV_EXPORTS MatExpr
min(
const
Mat& a,
double
s);
3728CV_EXPORTS MatExpr
min(
double
s,
const
Mat& a);
3729
template<
typename
_Tp,
int
m,
int
n>
static
inline
3730MatExpr
min
(
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
min(a,
Mat(b)); }
3731
template<
typename
_Tp,
int
m,
int
n>
static
inline
3732MatExpr
min
(
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
min(
Mat(a), b); }
3734CV_EXPORTS MatExpr
max(
const
Mat& a,
const
Mat& b);
3735CV_EXPORTS MatExpr
max(
const
Mat& a,
double
s);
3736CV_EXPORTS MatExpr
max(
double
s,
const
Mat& a);
3737
template<
typename
_Tp,
int
m,
int
n>
static
inline
3738MatExpr
max
(
const
Mat& a,
const
Matx<_Tp, m, n>& b) {
return
max(a,
Mat(b)); }
3739
template<
typename
_Tp,
int
m,
int
n>
static
inline
3740MatExpr
max
(
const
Matx<_Tp, m, n>& a,
const
Mat& b) {
return
max(
Mat(a), b); }
3764
#include "opencv2/core/mat.inl.hpp"
This type is very similar to InputArray except that it is used for input/output and output function p...
Definition:
mat.hpp:295
Definition:
bufferpool.hpp:22
Template "trait" class for OpenCV primitive data types.
Definition:
traits.hpp:113
Template matrix class derived from Mat
Definition:
mat.hpp:2199
void forEach(const Functor &operation)
template methods for for operation over all matrix elements.
Mat_() CV_NOEXCEPT
default constructor
Mat_ row(int y) const
overridden forms of Mat::row() etc.
_Tp * operator[](int y)
more convenient forms of row and element access operators
size_t elemSize() const
overridden forms of Mat::elemSize() etc.
iterator begin()
iterators; they are smart enough to skip gaps in the end of rows
static MatExpr zeros(int rows, int cols)
overridden forms of Mat::zeros() etc. Data type is omitted, of course
Mat_ cross(const Mat_ &m) const
cross-product
void release()
equivalent to Mat::release()
size_t stepT(int i=0) const
returns step()/sizeof(_Tp)
void create(int _rows, int _cols)
equivalent to Mat::create(_rows, _cols, DataType<_Tp>::type)
Mat_ & adjustROI(int dtop, int dbottom, int dleft, int dright)
some more overridden methods
Custom array allocator
Definition:
mat.hpp:470
Comma-separated Matrix Initializer
Definition:
mat.hpp:515
MatCommaInitializer_(Mat_< _Tp > *_m)
the constructor, created by "matrix << firstValue" operator, where matrix is cv::Mat
MatCommaInitializer_< _Tp > & operator,(T2 v)
the operator that takes the next value and put it to the matrix
Matrix read-only iterator
Definition:
mat.hpp:3118
MatConstIterator_()
default constructor
MatConstIterator_(const Mat_< _Tp > *_m, Point _pt)
constructor that sets the iterator to the specified element of the matrix
MatConstIterator_(const MatConstIterator_ &it)
copy constructor
MatConstIterator_(const Mat_< _Tp > *_m, int _row, int _col=0)
constructor that sets the iterator to the specified element of the matrix
MatConstIterator_(const Mat_< _Tp > *_m, const int *_idx)
constructor that sets the iterator to the specified element of the matrix
Point pos() const
returns the current iterator position
MatConstIterator_(const Mat_< _Tp > *_m)
constructor that sets the iterator to the beginning of the matrix
MatConstIterator(const Mat *_m, const int *_idx)
constructor that sets the iterator to the specified element of the matrix
MatConstIterator()
default constructor
Point pos() const
returns the current iterator position
MatConstIterator(const Mat *_m, Point _pt)
constructor that sets the iterator to the specified element of the matrix
MatConstIterator(const MatConstIterator &it)
copy constructor
void pos(int *_idx) const
returns the current iterator position
MatConstIterator(const Mat *_m, int _row, int _col=0)
constructor that sets the iterator to the specified element of the matrix
MatConstIterator(const Mat *_m)
constructor that sets the iterator to the beginning of the matrix
Matrix expression representation This is a list of implemented matrix operations that can be combined...
Definition:
mat.hpp:3555
n-dimensional dense array class
Definition:
mat.hpp:802
Mat & setTo(InputArray value, InputArray mask=noArray())
Sets all or some of the array elements to the specified value.
MatExpr inv(int method=DECOMP_LU) const
Inverses a matrix.
double dot(InputArray m) const
Computes a dot-product of two vectors.
UMatData * u
interaction with UMat
Definition:
mat.hpp:2127
void copyTo(OutputArray m) const
Copies the matrix to another one.
void updateContinuityFlag()
internal use method: updates the continuity flag
MatExpr mul(InputArray m, double scale=1) const
Performs an element-wise multiplication or division of the two matrices.
int dims
the matrix dimensionality, >= 2
Definition:
mat.hpp:2105
MatAllocator * allocator
custom allocator
Definition:
mat.hpp:2117
uchar * data
pointer to the data
Definition:
mat.hpp:2109
Mat reshape(int cn, int rows=0) const
Changes the shape and/or the number of channels of a 2D matrix without copying the data.
uchar * ptr(int i0=0)
Returns a pointer to the specified matrix row.
void addref()
Increments the reference counter.
Mat rowRange(int startrow, int endrow) const
Creates a matrix header for the specified row span.
void assignTo(Mat &m, int type=-1) const
Provides a functional form of convertTo.
MatExpr t() const
Transposes a matrix.
Mat colRange(int startcol, int endcol) const
Creates a matrix header for the specified column span.
int rows
the number of rows and columns or (-1, -1) when the matrix has more than 2 dimensions
Definition:
mat.hpp:2107
void convertTo(OutputArray m, int rtype, double alpha=1, double beta=0) const
Converts an array to another data type with optional scaling.
static MatAllocator * getStdAllocator()
and the standard allocator
const uchar * datastart
helper fields used in locateROI and adjustROI
Definition:
mat.hpp:2112
int flags
Definition:
mat.hpp:2103
Matrix read-write iterator
Definition:
mat.hpp:3171
MatIterator_(Mat_< _Tp > *_m, int _row, int _col=0)
constructor that sets the iterator to the specified element of the matrix
MatIterator_(Mat_< _Tp > *_m, Point _pt)
constructor that sets the iterator to the specified element of the matrix
MatIterator_()
the default constructor
MatIterator_(Mat_< _Tp > *_m, const int *_idx)
constructor that sets the iterator to the specified element of the matrix
MatIterator_(const MatIterator_ &it)
copy constructor
MatIterator_(Mat_< _Tp > *_m)
constructor that sets the iterator to the beginning of the matrix
Template class for small matrices whose type and size are known at compilation time
Definition:
matx.hpp:100
n-ary multi-dimensional array iterator.
Definition:
mat.hpp:3430
const Mat ** arrays
the iterated arrays
Definition:
mat.hpp:3447
size_t size
the size of each segment (in elements)
Definition:
mat.hpp:3457
size_t nplanes
the number of hyper-planes that the iterator steps through
Definition:
mat.hpp:3455
NAryMatIterator(const Mat **arrays, uchar **ptrs, int narrays=-1)
the full constructor taking arbitrary number of n-dim matrices
uchar ** ptrs
data pointers
Definition:
mat.hpp:3451
NAryMatIterator(const Mat **arrays, Mat *planes, int narrays=-1)
the full constructor taking arbitrary number of n-dim matrices
void init(const Mat **arrays, Mat *planes, uchar **ptrs, int narrays=-1)
the separate iterator initialization method
Mat * planes
the current planes
Definition:
mat.hpp:3449
NAryMatIterator()
the default constructor
int narrays
the number of arrays
Definition:
mat.hpp:3453
Template class for 3D points specified by its coordinates x, y and z.
Definition:
core/types.hpp:240
Template class for 2D points specified by its coordinates x and y.
Definition:
core/types.hpp:158
Template class specifying a continuous subsequence (slice) of a sequence.
Definition:
core/types.hpp:590
Template class for 2D rectangles
Definition:
core/types.hpp:421
Template class for specifying the size of an image or rectangle.
Definition:
core/types.hpp:316
Template sparse n-dimensional array class derived from SparseMat
Definition:
mat.hpp:2982
SparseMat_(const Mat &m)
converts dense matrix to the sparse form
SparseMat_()
the default constructor
SparseMat_(const SparseMat_ &m)
the copy constructor. This is O(1) operation - no data is copied
SparseMat_(const SparseMat &m)
the copy constructor. If DataType<_Tp>.type != m.type(), the m elements are converted
SparseMat_ clone() const CV_NODISCARD
makes full copy of the matrix. All the elements are duplicated
SparseMat_(int dims, const int *_sizes)
the full constructor equivalent to SparseMat(dims, _sizes, DataType<_Tp>::type)
Template Read-Only Sparse Matrix Iterator Class.
Definition:
mat.hpp:3307
SparseMatConstIterator_(const SparseMatConstIterator_ &it)
the copy constructor
SparseMatConstIterator_(const SparseMat_< _Tp > *_m)
the full constructor setting the iterator to the first sparse matrix element
SparseMatConstIterator_()
the default constructor
Read-Only Sparse Matrix Iterator.
Definition:
mat.hpp:3229
const _Tp & value() const
template method returning the current matrix element
SparseMatConstIterator(const SparseMat *_m)
the full constructor setting the iterator to the first sparse matrix element
SparseMatConstIterator(const SparseMatConstIterator &it)
the copy constructor
const SparseMat::Node * node() const
returns the current node of the sparse matrix. it.node->idx is the current element index
void seekEnd()
moves iterator to the element after the last element
SparseMatConstIterator()
the default constructor
The class SparseMat represents multi-dimensional sparse numerical arrays.
Definition:
mat.hpp:2704
~SparseMat()
the destructor
SparseMat clone() const CV_NODISCARD
creates full copy of the matrix
SparseMat(int dims, const int *_sizes, int _type)
SparseMat(const SparseMat &m)
SparseMat()
Various SparseMat constructors.
Template Read-Write Sparse Matrix Iterator Class.
Definition:
mat.hpp:3341
SparseMatIterator_()
the default constructor
SparseMatIterator_(const SparseMatIterator_ &it)
the copy constructor
SparseMatIterator_(SparseMat_< _Tp > *_m)
the full constructor setting the iterator to the first sparse matrix element
Read-write Sparse Matrix Iterator
Definition:
mat.hpp:3273
SparseMatIterator(SparseMat *_m, const int *idx)
the full constructor setting the iterator to the specified sparse matrix element
SparseMatIterator()
the default constructor
SparseMat::Node * node() const
returns pointer to the current sparse matrix node. it.node->idx is the index of the current element (...
SparseMatIterator(const SparseMatIterator &it)
the copy constructor
SparseMatIterator(SparseMat *_m)
the full constructor setting the iterator to the first sparse matrix element
_Tp & value() const
returns read-write reference to the current sparse matrix element
void updateContinuityFlag()
internal use method: updates the continuity flag
UMat(const std::vector< _Tp > &vec, bool copyData=false)
builds matrix from std::vector with or without copying the data
UMat(int rows, int cols, int type, const Scalar &s, UMatUsageFlags usageFlags=USAGE_DEFAULT)
constructs 2D matrix and fills it with the specified value _s.
int cols
number of columns in the matrix; -1 when the matrix has more than 2 dimensions
Definition:
mat.hpp:2592
MatAllocator * allocator
custom allocator
Definition:
mat.hpp:2595
static MatAllocator * getStdAllocator()
and the standard allocator
UMat & adjustROI(int dtop, int dbottom, int dleft, int dright)
moves/resizes the current matrix ROI inside the parent matrix.
void copySize(const UMat &m)
internal use function; properly re-allocates _size, _step arrays
size_t elemSize1() const
returns the size of element channel in bytes.
size_t elemSize() const
returns element size in bytes,
int checkVector(int elemChannels, int depth=-1, bool requireContinuous=true) const
returns N if the matrix is 1-channel (N x ptdim) or ptdim-channel (1 x N) or (N x 1); negative number...
UMat row(int y) const
returns a new matrix header for the specified row
UMat(UMatUsageFlags usageFlags=USAGE_DEFAULT) CV_NOEXCEPT
default constructor
int channels() const
returns element type, similar to CV_MAT_CN(cvmat->type)
size_t step1(int i=0) const
returns step/elemSize1()
int type() const
returns element type, similar to CV_MAT_TYPE(cvmat->type)
void locateROI(Size &wholeSize, Point &ofs) const
locates matrix header within a parent matrix. See below
UMat(const UMat &m)
copy constructor
MatSize size
dimensional size of the matrix; accessible in various formats
Definition:
mat.hpp:2613
int dims
the matrix dimensionality, >= 2
Definition:
mat.hpp:2586
int rows
number of rows in the matrix; -1 when the matrix has more than 2 dimensions
Definition:
mat.hpp:2589
UMat rowRange(int startrow, int endrow) const
... for the specified row span
UMat operator()(Range rowRange, Range colRange) const
extracts a rectangular sub-matrix
int depth() const
returns element type, similar to CV_MAT_DEPTH(cvmat->type)
void deallocate()
deallocates the matrix data
bool empty() const
returns true if matrix data is NULL
MatStep step
number of bytes each matrix element/row/plane/dimension occupies
Definition:
mat.hpp:2616
static UMat diag(const UMat &d, UMatUsageFlags usageFlags)
constructs a square diagonal matrix which main diagonal is vector "d"
void addref()
increases the reference counter; use with care to avoid memleaks
void * handle(AccessFlag accessFlags) const
UMatUsageFlags usageFlags
usage flags for allocator; recommend do not set directly, instead set during construct/create/getUMat
Definition:
mat.hpp:2598
void release()
decreases reference counter;
UMat col(int x) const
returns a new matrix header for the specified column
UMat clone() const CV_NODISCARD
returns deep copy of the matrix, i.e. the data is copied
size_t total() const
returns the total number of matrix elements
~UMat()
destructor - calls release()
bool isSubmatrix() const
returns true if the matrix is a submatrix of another matrix
UMatData * u
black-box container of UMat data
Definition:
mat.hpp:2607
int flags
Definition:
mat.hpp:2583
UMat colRange(int startcol, int endcol) const
... for the specified column span
UMat(int rows, int cols, int type, UMatUsageFlags usageFlags=USAGE_DEFAULT)
constructs 2D matrix of the specified size and type
size_t offset
offset of the submatrix (or 0)
Definition:
mat.hpp:2610
UMat(int ndims, const int *sizes, int type, UMatUsageFlags usageFlags=USAGE_DEFAULT)
constructs n-dimensional matrix
bool isContinuous() const
returns true iff the matrix data is continuous
void create(int rows, int cols, int type, UMatUsageFlags usageFlags=USAGE_DEFAULT)
allocates new matrix data unless the matrix already has specified size and type.
UMat(const UMat &m, const Range &rowRange, const Range &colRange=Range::all())
creates a matrix header for a part of the bigger matrix
Template class for short numerical vectors, a partial case of Matx
Definition:
matx.hpp:342
Base storage class for GPU memory with reference counting.
Definition:
core/cuda.hpp:106
Class with reference counting wrapping special memory type allocation functions from CUDA.
Definition:
core/cuda.hpp:731
Smart pointer for OpenGL buffer object with reference counting.
Definition:
opengl.hpp:80
void CV_EXPORTS_W copyTo(InputArray src, OutputArray dst, InputArray mask)
This is an overloaded member function, provided for convenience (python) Copies the matrix to another...
CV_EXPORTS_W void max(InputArray src1, InputArray src2, OutputArray dst)
Calculates per-element maximum of two arrays or an array and a scalar.
CV_EXPORTS_W double invert(InputArray src, OutputArray dst, int flags=DECOMP_LU)
Finds the inverse or pseudo-inverse of a matrix.
CV_EXPORTS_W void transpose(InputArray src, OutputArray dst)
Transposes a matrix.
CV_EXPORTS_W void min(InputArray src1, InputArray src2, OutputArray dst)
Calculates per-element minimum of two arrays or an array and a scalar.
CV_EXPORTS_W void add(InputArray src1, InputArray src2, OutputArray dst, InputArray mask=noArray(), int dtype=-1)
Calculates the per-element sum of two arrays or an array and a scalar.
CV_EXPORTS_W void divide(InputArray src1, InputArray src2, OutputArray dst, double scale=1, int dtype=-1)
Performs per-element division of two arrays or a scalar by an array.
CV_EXPORTS_W void multiply(InputArray src1, InputArray src2, OutputArray dst, double scale=1, int dtype=-1)
Calculates the per-element scaled product of two arrays.
CV_EXPORTS_W void subtract(InputArray src1, InputArray src2, OutputArray dst, InputArray mask=noArray(), int dtype=-1)
Calculates the per-element difference between two arrays or array and a scalar.
@ DECOMP_LU
Definition:
base.hpp:135
static _InputOutputArray rawInOut(_Tp &v)
static _InputArray rawIn(_Tp &v)
UMatUsageFlags
Usage flags for allocator
Definition:
mat.hpp:454
static _OutputArray rawOut(_Tp &v)
CV_INLINE v_reg< _Tp, n > operator|(const v_reg< _Tp, n > &a, const v_reg< _Tp, n > &b)
Bitwise OR
CV_INLINE v_reg< _Tp, n > operator&(const v_reg< _Tp, n > &a, const v_reg< _Tp, n > &b)
Bitwise AND
CV_INLINE v_reg< _Tp, n > operator/(const v_reg< _Tp, n > &a, const v_reg< _Tp, n > &b)
Divide values
CV_INLINE v_reg< _Tp, n > operator~(const v_reg< _Tp, n > &a)
Bitwise NOT
CV_INLINE v_reg< _Tp, n > operator^(const v_reg< _Tp, n > &a, const v_reg< _Tp, n > &b)
Bitwise XOR
softfloat abs(softfloat a)
Absolute value
Definition:
softfloat.hpp:444
CV_EXPORTS void swap(Mat &a, Mat &b)
Swaps two matrices
"black box" representation of the file storage associated with a file on disk.
Definition:
aruco.hpp:75
DualQuat< T > inv(const DualQuat< T > &dq, QuatAssumeType assumeUnit=QUAT_ASSUME_NOT_UNIT)
Definition:
dualquaternion.inl.hpp:187
the sparse matrix header
Definition:
mat.hpp:2713
sparse matrix node - element of a hash table
Definition:
mat.hpp:2729
size_t hashval
hash value
Definition:
mat.hpp:2731
size_t next
index of the next node in the same hash table entry
Definition:
mat.hpp:2733