【OpenCV学习】子矩阵操作

简介:
#include "highgui.h"
#include "cv.h"
#include <iostream>
#include <iomanip>


using namespace std;

void main()
{
int i=0;
int j=0;
CvRect mat_rect=cvRect(1,1,3,3);//指定取得数组子集的范围
CvMat *mat=cvCreateMat(6,6,CV_64FC1);//原数组
CvMat *submat=cvCreateMat(3,3,CV_64FC1);//按mat_rect指定取得的数组子集
CvMat *mat_rows=cvCreateMat(2,6,CV_64FC1);//按一定跨度内的行取得的数组子集
/*对这个6*6的矩阵初始化*/
for (i=0;i<6;i++)
{
for (j=0;j<6;j++)
{
CV_MAT_ELEM(*mat,double,i,j)=i*6+j;
}
}
/*打印源矩阵*/
for (i=0;i<6;i++)
{
for (j=0;j<6;j++)
{
cout<<setw(3)<<CV_MAT_ELEM(*mat,double,i,j);
}
cout<<endl;
}
cout<<endl;
/*取子数组,大小根据mat_rect来决定,然后打印*/
cvGetSubRect(mat,submat,mat_rect);
for (i=0;i<3;i++)
{
for (j=0;j<3;j++)
{
cout<<setw(3)<<CV_MAT_ELEM(*submat,double,i,j);
}
cout<<endl;
}
cout<<endl;
/*取第一行(从0开始)取到第(3-1=)2行,并打印*/
cvGetRows(mat,mat_rows,1,3,1);
for (i=0;i<2;i++)
{
for (j=0;j<6;j++)
{
cout<<setw(3)<<CV_MAT_ELEM(*mat_rows,double,i,j);
}
cout<<endl;
}
cvReleaseMat(&mat);
cvReleaseMat(&submat);
cvReleaseMat(&mat_rows);
}

在OpenCV中一般取元素都用定义好的宏:
取Mat结构的元素的宏为CV_MAT_ELEM,它取2D的矩阵最方便。
取IplImage元素的宏为CV_IMAGE_ELEM,如取一个图像(x,y)点的灰度值:
uchar *ptr=CV_IAMGE_ELEM(image,uchar,i,j*3);
ptr[0],ptr[1],ptr[2]就是对应的B/G/R三个分量了。



本文转自gnuhpc博客园博客,原文链接:http://www.cnblogs.com/gnuhpc/archive/2012/06/30/2571315.html,如需转载请自行联系原作者

相关文章
|
1月前
|
存储 资源调度 算法
Opencv(C++)系列学习---SIFT、SURF、ORB算子特征检测
Opencv(C++)系列学习---SIFT、SURF、ORB算子特征检测
|
2月前
|
机器学习/深度学习 算法 数据可视化
计算机视觉+深度学习+机器学习+opencv+目标检测跟踪+一站式学习(代码+视频+PPT)-2
计算机视觉+深度学习+机器学习+opencv+目标检测跟踪+一站式学习(代码+视频+PPT)
95 0
|
2月前
|
机器学习/深度学习 Ubuntu Linux
计算机视觉+深度学习+机器学习+opencv+目标检测跟踪+一站式学习(代码+视频+PPT)-1
计算机视觉+深度学习+机器学习+opencv+目标检测跟踪+一站式学习(代码+视频+PPT)
53 1
|
1月前
|
算法 C++ 计算机视觉
Opencv(C++)学习系列---Laplacian拉普拉斯边缘检测算法
Opencv(C++)学习系列---Laplacian拉普拉斯边缘检测算法
|
1月前
|
算法 计算机视觉 C++
Opencv(C++)学习系列---Sobel索贝尔算子边缘检测
Opencv(C++)学习系列---Sobel索贝尔算子边缘检测
|
1月前
|
算法 C++ 计算机视觉
Opencv(C++)学习系列---Canny边缘检测算法
Opencv(C++)学习系列---Canny边缘检测算法
|
1月前
|
存储 计算机视觉 C++
Opencv(C++)学习系列---特征点检测和匹配
Opencv(C++)学习系列---特征点检测和匹配
|
1月前
|
算法 测试技术 计算机视觉
Opencv(C++)系列学习---opencv_contrib安装
Opencv(C++)系列学习---opencv_contrib安装
|
1月前
|
C++ 计算机视觉
Opencv(C++)系列学习---读取视频文件和打开摄像头
Opencv(C++)系列学习---读取视频文件和打开摄像头
|
1月前
|
存储 计算机视觉 C++
Opencv (C++)系列学习---模板匹配
Opencv (C++)系列学习---模板匹配