OpenCV中Mat数据结构的用法
2014-10-10 22:39
369 查看
本文参考了博文/article/1568713.html和http://blog.sina.com.cn/s/blog_79bb01d00101ao58.html以及/article/1390614.html
1.介绍两种初始化的方法:
1)利用循环结构逐个赋值
首先分配内存:Mat m(a,b,CV_64F);//定义Mat型变量m, int型变量a表示行数, int型变量b表示列数, 64表示double型, 32表示float型
2.对于单个元素的操作,比如输出第i行第j列的元素,下面给出两种方式:
3.数据类型
CV_8U:8位无符号int
CV_8S:8位有符号int
CV_16U:16位无符号int
CV_16S:16位有符号int
CV_32S:32位有符号int
CV_32F:float
CV_64F:double
1.介绍两种初始化的方法:
1)利用循环结构逐个赋值
首先分配内存:Mat m(a,b,CV_64F);//定义Mat型变量m, int型变量a表示行数, int型变量b表示列数, 64表示double型, 32表示float型
for(int i=0;i<m.rows;i++) for(int j=0;j<m.cols;j++) m.at<double>(i,j)=1.0/(i+j+1);2)利用已知的一维数组赋值
double *data = new double[15]; for(int i=0;i<15;i++) data[i]=1.0/(i+1); Mat m(2,3,CV_64F, data);//64:double, 32:float
2.对于单个元素的操作,比如输出第i行第j列的元素,下面给出两种方式:
cout<<m.at<double>(i,j)<<endl; cout<<m.ptr<double>(i)[j]<<endl;
3.数据类型
CV_8U:8位无符号int
CV_8S:8位有符号int
CV_16U:16位无符号int
CV_16S:16位有符号int
CV_32S:32位有符号int
CV_32F:float
CV_64F:double
相关文章推荐
- OpenCV中贝叶斯分类器相关的API及其用法
- opencv Mat类用法
- openCV中 cvSeq的用法说明
- opencv中scr.copyTo()的用法介绍
- 【转】OpenCV Mat数据结构
- OpenCV基础篇之Mat数据结构
- opencv中CvSeq的用法
- OpenCV_CUDA 中GpuMat数据结构
- openCV中 cvSeq的用法说明
- OpenCV Machine Learning 之正态贝叶斯分类器(Normal Bayes Classifier)的用法实例
- opencv矩阵元素类型转换和cvConvertScale()函数用法
- opencv2 矩阵方式 resize图像缩放代码及cvresize函数用法
- OpenCV中Mat数据结构使用举例
- OpenCV boundingRect 与 boundingRect 用法
- OpenCv cv::Mat类用法1
- opencv文件读写(二)使用多种方式及用法
- OpenCV中Mat数据结构
- opencv中videocapture用法 打开视频和打开摄像头
- opencv查找轮廓---cvFindContours && cvDrawCountours 用法及例子
- OpenCV的Rect矩形类用法