




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、OpenCV自学材料,田永鸿 北京大学数字媒体研究所,2,第一部分,OpenCV概述 基础结构与操作 基本OpenCV程序与示例 注:本讲义中部分代码来自OpenCV样例,部分代码来自OpenCV教程基础篇,部分代码则从网上收集。,3,OpenCV概述,OpenCV是Intel开源计算机视觉库。 它由一系列 C 函数和少量 C+ 类构成,实现了图像处理和计算机视觉方面的很多通用算法。 OpenCV 的特点 拥有包括 300 多个C函数的跨平台的中、高层 API 跨平台:Windows, Linux 免费(FREE):无论对非商业应用和商业应用 速度快 使用方便,4,OpenCV structu
2、re,CXCORE basic structures and algoritms, XML support, drawing functions,CV Image processing and vision,HighGUI GUI, Image and Video I/O,ML Machine Learning algorithms,CVCam video stream processing,The Functionality in Pictures,6,OpenCV的下载与安装,1、下载地址 2、VC6.0下的安装与配置 参见 3、.NET 2003下的安装与配置 参见 ,Configuri
3、ng MSVS .net 2k3,Create a Win32 Console Project,Make it an Empty Project by selecting the box under Application Settings,Configuring MSVS .net 2k3,Select C+ file and give it a name,Creating a file makes it possible to set Additional Include Directives in the C/C+ pane under the project properties.,C
4、onfiguring MSVS .net 2k3,In order to build projects using OpenCV the required libraries and directives must be included in the projects properties,Configuring MSVS .net 2k3,Select the Additional Include Directives,Configuring MSVS .net 2k3,Select the Additional Dependencies,Testing MSVS .net 2k3,Now
5、 that the environment is configured it would be a good idea to test it to make sure that a program will correctly build and run.,#include #include /*This will pop up a small box with Hello World as the text.*/ int main( int argc, char* argv ) /declare for the height and width of the image int height
6、 = 320; int width = 240; /specify the point to place the text CvPoint pt = cvPoint( height/4, width/2 ); /Create an 8 bit, 3 plane image IplImage* hw = cvCreateImage(cvSize(height, width), 8, 3); /initialize the font CvFont font; cvInitFont( ,Testing MSVS .net 2k3,Output of Program,14,OpenCV 编码样式指南,
7、1、文件命名:有cv和cvaux库文件的命名必须服从于以下规则: 所有的CV库文件名前缀为cv 混合的C/C+接口头文件扩展名为 .h 纯C+接口头文件扩展名为 .hpp 实现文件扩展名为 .cpp 为了与POSIX兼容,文件名都以小写字符组成,15,OpenCV 编码样式指南,2、文件结构 每个文件以BSD兼容的许可声明(模板在Contributors_BSD_Licsense.htm文件中可以找到)开头; 一行最多90个字符,不包括行结束符 不使用制表符 缩进为4个空格符,所以制表符应该用1-4个空格替换(依据开始列确定) 头文件必须使用保护宏,防止文件被重复包含。 混合C/C+接口头文件
8、用extern C 包含C语言定义。 为了使预编译头机制在Visual C+中工作正常,源文件必须在其它头文件前包含precomp.h头文件。,16,OpenCV 编码样式指南,3、命名约定 OpenCV中使用大小写混合样式来标识外部函数、数据类型和类方法。 宏全部使用大写字符,词间用下划线分隔。 所有的外部或内部名称,若在多个文件中可见,则必须含有前缀: 外部函数使用前缀cv 内部函数使用前缀Icv 数据结构(C结构体、枚举、联合体、类)使用前缀Cv 外部或某些内部宏使用前缀CV_ 内部宏使用前缀ICV_,17,OpenCV 编码样式指南,4、函数接口设计:为了保持库的一致性,以如下方式设计
9、接口非常重要。函数接口元素包括: 功能 名称 返回值 参数类型 参数顺序 参数默认值 函数功能必须定义良好并保持精简。函数应该容易镶入到使用其它OpenCV函数的不同处理过程。函数名称应该简单并能体现函数的功能。大多数函数名形式:cv,18,A Simple OpenCV Program,1. #include 2. #include 3. #include 4. int main( int argc, char* argv ) 5. CvPoint center; 6. double scale=-3; 7. IplImage* image = argc=2 ? cvLoadImage(ar
10、gv1) : 0; 8. if(!image) return -1; 9. center = cvPoint(image-width/2,image-height/2); 10. for(int i=0;iheight;i+) 11. for(int j=0;jwidth;j+) 12. double dx=(double)(j-center.x)/center.x; 13. double dy=(double)(i-center.y)/center.y; 14. double weight=exp(dx*dx+dy*dy)*scale); 15. uchar* ptr = ,19,基本数据结
11、构,点:CvPoint 、CvPoint2D32f、CvPoint3D32f 矩形框大小:CvSize 、CvSize2D32f 矩形框:CvRect 可以存放1-4个数值的数组:CvScalar 定义迭代算法的终止规则:CvTermCriteria 矩阵:CvMat 、CvMatND 、CvSparseMat IPL图像头部:IplImage 定义不确定的数组:CvArr (仅作函数参数),20,点数据结构,CvPoint 二维坐标系下的点,类型为整型 typedef struct CvPoint int x; /* X坐标, 通常以0为基点 */int y; /* y坐标, 通常以0为基点
12、 */CvPoint;/* 构造函数 */inline CvPoint cvPoint( int x, int y );/* 从 CvPoint2D32f类型转换得来 */inline CvPoint cvPointFrom32f( CvPoint2D32f point ) CvPoint2D32f :二维坐标下的点,类型为浮点 CvPoint3D32f :三维坐标下的点,类型为浮点,21,矩形框大小数据结构,CvSize 矩形框大小,以像素为精度 typedef struct CvSizeint width; /* 矩形宽 */int height; /* 矩形高 */CvSize;/* 构
13、造函数 */inline CvSize cvSize( int width, int height ); CvSize2D32f,22,矩形框数据结构,CvRect 矩形框的偏移和大小 typedef struct CvRectint x; /* 方形的最左角的x-坐标 */int y; /* 方形的最上或者最下角的y-坐标 */int width; /* 宽 */int height; /* 高 */CvRect;/* 构造函数*/inline CvRect cvRect(int x, int y, int width, int height);,23,矩阵数据结构,CvMat 二维矩阵 t
14、ypedef struct CvMat int type; /* CvMat 标识, 元素类型和标记 */int step; /* 以字节为单位的行数据长度*/int rows; /*行数*/int cols; /*列数*/ int* refcount; /* 数据引用计数 */unionuchar* ptr;short* s;int* i;float* fl;double* db; data; /* data 指针 */,24,矩阵数据结构,CvMatND:多维、多通道密集数组 CvSparseMat:多维、多通道稀疏数组 CvArr:不确定数组,25,图像头数据,IplImage:IPL
15、图像头,26,图像头数据,IplImage:IPL 图像头typedef struct _IplImage int nSize; /* IplImage大小 */int ID; /* 版本 (=0)*/int nChannels; /* 大多数OPENCV函数支持1,2,3 或4 个通道 */int alphaChannel; /* 被OpenCV忽略 */int depth; /* 像素的位深度: IPL_DEPTH_8U,IPL_DEPTH_8S, IPL_DEPTH_16U,IPL_DEPTH_16S, IPL_DEPTH_32S, IPL_DEPTH_32F and IPL_DEPTH
16、_64F 可支持 */char colorModel4; char channelSeq4; /* 被OpenCV忽略 */ int dataOrder; /* 0 - 交叉存取颜色通道, 1 - 分开的颜色通道.cvCreateImage只能创建交叉存取图像 */int origin; /* 0 - 顶左结构,1 - 底左结构 (BMP风格) */int align; /* 图像行排列 (4 or 8). OpenCV 用widthStep 代替 */,27,int width; /* 图像宽像素数 */int height; /* 图像高像素数*/struct _IplROI *roi;/
17、* 图像感兴趣区域. 当该值非空只对该区域进行处理 */struct _IplImage *maskROI; /* 在 OpenCV中必须置NULL */void *imageId; /* 同上*/struct _IplTileInfo *tileInfo; /*同上*/ int imageSize; /* 图像数据大小,单位字节*/ char *imageData; /* 指向排列的图像数据 */ int widthStep; /* 排列的图像行大小,以字节为单位 */ int BorderMode4; int BorderConst4; /* 边际结束模式, 被忽略*/ char *ima
18、geDataOrigin; /* 指针指向一个不同的图像数据结构,是为了纠正图像内存分配准备的 */ IplImage;,28,图像头数据,IplImage结构来自于 Intel Image Processing Library。OpenCV 只支持其中的一个子集: alphaChannel 在OpenCV中被忽略。 colorModel 和channelSeq 被OpenCV忽略。 dataOrder 必须是IPL_DATA_ORDER_PIXEL (颜色通道是交叉存取),然而平面图像的被选择通道可以被处理,就像COI(感兴趣的通道)被设置过一样。 align 是被OpenCV忽略的,而用
19、widthStep 去访问后继的图像行。 不支持maskROI 。处理MASK的函数把他当作一个分离的参数。MASK在 OpenCV 里是 8-bit,然而在 IPL他是 1-bit。 tileInfo 不支持。 BorderMode和BorderConst是不支持的。 OpenCV处理ROI有不同的要求。要求原图像和目标图像的尺寸或 ROI的尺寸必须精确匹配。,基本OpenCV操作,矩阵的使用与操作 GUI命令 图像的使用与操作 视频的使用与操作,30,矩阵的使用与操作(1),创建矩阵 CreateMatCvMat* cvCreateMat( int rows, int cols, int
20、type ); rows 矩阵行数。 cols 矩阵列数。 type 矩阵元素类型。 通常以 CV_(S|U|F)C型式描述, 例如: CV_8UC1 意思是一个8-bit 无符号单通道矩阵, CV_32SC2 意思是一个32-bit 有符号二个通道的矩阵。 函数 cvCreateMat 为新的矩阵分配头和下面的数据,并且返回一个指向新创建的矩阵的指针。矩阵按行存贮。所有的行以4个字节对齐。 删除矩阵 ReleaseMat void cvReleaseMat( CvMat* mat ); 例如:CvMat* M = cvCreateMat( 4, 4, CV_32FC1); cvRelease
21、Mat( ,31,矩阵的使用与操作(2),复制矩阵CloneMatCvMat* cvCloneMat( const CvMat* mat ); 例如: CvMat* M1 = cvCreateMat( 4, 4, CV_32FC1);CvMat* M2;M2 = cvCloneMat(M1); 初始化矩阵 方法1:用cvMat初始化 double a = 1, 2, 3, 4,5, 6, 7, 8,9, 10, 11, 12 ; CvMat Ma = cvMat( 3, 4, CV_64FC1, a); 方法2:用cvCreateMatHeader初始化 CvMat Ma; cvInitMat
22、Header( ,32,矩阵的使用与操作(3),访问矩阵元素 (1)直接访问cvmSet(M, i, j, 2, 0); /Set M(i,j)t = cvmGet(M, i, j); /Get M(i,j) (2)已知对齐方式的直接访问CvMat* M = cvCreateMat( 4, 4, CV_32FC1); int n = M-cols;float *data = M-data.fl;datai*n+j = 3.0; /假设32位对齐 (3)未知对齐方式的直接访问CvMat* M = cvCreateMat( 4, 4, CV_32FC1); int step = M-step/si
23、zeof(float);float *data = M-data.fl;(data + i*step)j = 3.0; (4)直接访问一个已初始化的矩阵Mai*4 + j = 2.0;,33,矩阵的使用与操作(4),矩阵间的操作CvMat *Ma, *Mb, *Mc; cvAdd(Ma, Mb, Mc); /Ma + Mb - Mc cvSub(Ma, Mb, Mc); /Ma - Mb - Mc cvMatMul(Ma, Mb, Mc); /Ma * Mb - Mc 矩阵元素间的操作 cvMul(Ma, Mb, Mc); /Ma. * Mb - Mc cvDiv(Ma, Mb, Mc); /
24、Ma. / Mb - Mc cvAddS(Ma, cvScalar(-10.0), Mc); /Ma. -10 - Mc 单个矩阵的操作 cvTranspose(Ma, Mb); /transpose(Ma) - Mb CvScalar t=cvTrace(Ma); /trace(Ma) -t.val0 double d = cvDet(Ma); /det(Ma) -d cvInvert(Ma, Mb); /inv(Ma) -Mb,34,矩阵的使用与操作(5),向量乘法假设Va, Vb, Vc均为n元素向量 double res = cvDotProduct( /A=UDVT标志使U和V以转置
25、方式返回 非齐次线性系统的求解假设A为n*n方阵,x,b均为n元素向量 cvSolve( / 显示矩阵 void Test_Multiply(); / 测试矩阵乘法 void Test_DCT(); / 计算DCT变换 int main() Test_Multiply(); Test_DCT(); return 0; ,36,矩阵的使用与操作:示例(2),void PrintMat(CvMat* A) / 显示矩阵 int i,j; for(i=0;irows;i+) printf(n); switch( CV_MAT_DEPTH(A-type) ) case CV_32F: case CV_
26、64F: for(j=0; jcols; j+) printf(%9.3f , (float) cvGetReal2D( A, i, j ); break; case CV_8U: case CV_16U: for(j=0;jcols;j+) printf(%6d,(int)cvGetReal2D( A, i, j ); break; default: break; printf(n); ,37,矩阵的使用与操作:示例(3),void Test_Multiply()/ Test matrix multiply double a = 1, 2, 3, 4,5, 6, 7, 8, 9, 10, 1
27、1, 12 ; double b = 1, 5, 9, 2, 6, 10, 3, 7, 11, 4, 8, 12 ; double c9; CvMat Ma, Mb, Mc; printf(n= Test multiply =); cvInitMatHeader( ,38,矩阵的使用与操作:示例(4),void Test_DCT()/ test 1-d and 2-d dct transform float data = 1, 2, 3, 4, 5, 6, 7, 8 ; CvMat a; a = cvMat(2,4,CV_32FC1,data); printf(n= Test DCT =);
28、printf(nOriginal matrix = ); PrintMat( ,39,Discrete Cosine Transform(DCT),Transform kernel of two-dimensional DCT is where Clearly, the kernel for the DCT is both separable and symmetric, and hence the DCT may be implemented as a series of one dimensional DCTs.,40,Discrete Cosine Transform(DCT),Forw
29、ard transform and Inverse transform where u, v, x, y = 0, 1, 2, , N-1,41,Transform Matrix of DCT,where:,42,Example of DCT,43,DCT的几点说明,DCT变换避免了复数运算。由于图像矩阵是实数矩阵,那么它的DCT也是实数 DCT是正交变换,其变换矩阵是正交阵,变换核是可分离的。 DCT有快速算法 DCT与IDCT具有相同的变换核,因此具有相同的变换矩阵,即正变换与逆变换公用同一个算法模块 DCT具有更强的信息集中能力,能将最多的信息放到最小的系数上去。,44,HighGUI操
30、作,Smart windows Image I/O, rendering Processing keyboard and other events, timeouts Trackbars Mouse callbacks Video I/O,45,Windows,cvNamedWindow(window_name, fixed_size_flag)cvNamedWindow(window_name, x, y)cvDestroyWindow(window_name) creates window accessed by its name. Window handles repaint, resi
31、ze events. Its position is remembered in registry. cvNamedWindow(ViewA,1); cvMoveWindow(ViewA,300,100); cvDestroyWindow(ViewA); cvShowImage(window_name, image); copies the image to window buffer, then repaints it when necessary. 8u|16s|32s|32fC1|3|4 are supported. only the whole window contents can
32、be modified. Dynamic updates of parts of the window are done using operations on images, drawing functions etc.,46,Windows,等待按键cvWaitKeyint cvWaitKey( int delay=0 ) 如果delay=0, 则无限等待,则等待delay毫秒则返回 在程序循环中,有时候由于程序一直处于计算中,窗口无法重新恢复(如读出视频中的所有帧并显示),可以加入cvWaitKey,使之等待几毫秒,让窗口完成重新绘制再执行其他操作,47,图像的使用与操作(1),创建头并
33、分配数据 CreateImageIplImage* cvCreateImage( CvSize size, int depth, int channels );size:图像宽、高. depth:图像元素的位深度,IPL_DEPTH_8U|8S|16U|16S|32S|32F|64F channels:每个元素(像素)的颜色通道数量.可以是 1, 2, 3 或 4. 释放头和图像数据 ReleaseImagevoid cvReleaseImage( IplImage* image ); 复制图像 CloneImageIplImage* cvCloneImage( const IplImage*
34、 image );,48,图像的使用与操作(2),头分配CreateImageHeaderIplImage* cvCreateImageHeader( CvSize size, int depth, int channels ) 初始化被用图分配的图像头 InitImageHeaderIplImage* cvInitImageHeader( IplImage* image, CvSize size, int depth,int channels, int origin=0, int align=4 );origin IPL_ORIGIN_TL 或 IPL_ORIGIN_BL. align 图像
35、行排列, 典型的 4 或 8 字节. 函数 cvInitImageHeader 初始化图像头结构, 指向用户指定的图像并且返回这个指针。 释放头 ReleaseImageHeadervoid cvReleaseImageHeader( IplImage* image );,程序示例:Create image,#include cv.h #include highgui.h #include int main() IplImage *cvImg; / image used for visualisation CvSize imgSize; / size of visualisation imag
36、e int i = 0, j = 0; imgSize.width = 640; imgSize.height = 480; cvImg = cvCreateImage( imgSize, 8, 1 ); / creation of a 8 bits depth gray image for ( i = 0; i imageData + cvImg-widthStep*j)i = ( char ) ( ( i * j ) % 256 ); cvNamedWindow( Testing OpenCV., 1 ); / creation of a visualisation window cvSh
37、owImage( Testing OpenCV., cvImg ); / image visualisation cvWaitKey( 0 ); / wait for key cvDestroyWindow( image ); / close window cvReleaseImage( / stopping the program ,50,程序示例:Create image,51,图像的使用与操作(3),从文件读图像cvLoadImageIplImage* cvLoadImage(char* fileName, int flag=1) OpenCV支持的图像格式:BMP、DIB、JPG、PN
38、G、PBM、PGM、PPM、SR、RAS和TIFF 写图像到文件cvSaveImageIplImage* cvSaveImage(char* fileName, IplImage* img) 图像转换cvConvertImage(IplImage* src, IplImage* dst, int flags=0); /灰度图彩色图cvCvtColor(IplImage* src, IplImage* dst, int code); /彩色图彩色图/灰度图 Code=CV_2:,=RGB,BGR,GRAY,HSV,YCrCb,XYZ,Luv,HLS,图像装载与显示示例,#include cv.h
39、 #include highgui.h #include / file example.bmp in the images directory char name0 = images/example.bmp; / file example.jpg in the images directory char name1 = images/example.jpg;,图像装载与显示示例,int main() IplImage* img0 = NULL; IplImage* img1 = NULL; img0 = cvLoadImage( name0, -1 ); img1 = cvLoadImage(
40、 name1, -1 ); cvNamedWindow( image0, 1 ); cvNamedWindow( image1, 1 ); cvShowImage( image0, img0 ); cvShowImage( image1, img1 ); cvWaitKey(0); / wait for key to close the windows cvReleaseImage( ,图像处理函数,cvSub( img0, img1, res, 0 ) subtract img0 from img1 and store the result in res,55,休息,56,第二部分,基本视频
41、操作 OpenCV的动态结构及操作 基于OpenCV的图像/视频处理(6个示例) 基于OpenCV的研究与开发:DEMO,57,视频的使用和操作(1),打开摄像头CvCapture* cvCaptureFromCAM(camera_id=0); 打开文件CvCapture* cvCaptureFromFile(videofile_path);CvCapture* cvCaptureFromAVI(inflie.avi); 捕捉某一帧 cvGrabFrame(capture) /抓住一帧,为快速遍历视频帧 IplImage* img=cvRetrieveImage(capture);/把Grab
42、的帧取出,或 IplImage* cvQueryFrame(capture); 释放捕捉源cvReleaseCapture(,58,视频的使用和操作(2),保存视频文件 typedef struct CvVideoWriter; CvVideoWriter* cvCreateVideoWriter( const char* filename, int fourcc, double fps, CvSize frame_size, int is_color=1 ); int cvWriteFrame( CvVideoWriter* writer, const IplImage* image );
43、void cvReleaseVideoWriter( CvVideoWriter* writer ); 获取/设置视频帧信息cvGetCaptureProperty(capture, property_id);cvSetCaptureProperty(capture, property_id, value); CV_CAP_PROP_POS_MSEC - video capture timestampCV_CAP_PROP_POS_FRAMES - 0-based index of the frame CV_CAP_PROP_POS_AVI_RATIO - relative position
44、of video(0-start, 1-end)CV_CAP_PROP_FRAME_WIDTH - width of frames in the video streamCV_CAP_PROP_FRAME_HEIGHT - height of frames in the video streamCV_CAP_PROP_FPS - frame rateCV_CAP_PROP_FOURCC - 4-character code of codec CV_CAP_PROP_FRAME_COUNT - number of frames in video file,59,视频操作示例(1),功能:从摄像头
45、或者AVI文件中得到视频流,对视频流进行边缘检测,并输出结果。 主要思想: 获取视频( cvCaptureFromCAM 或cvCaptureFromAVI) 循环处理每帧( cvQueryFrame ) 将多通道数组分割为多个单通道数组(cvCvtPixToPlan) 在每个通道内进行Laplace变换( cvLaplace),计算图像的边缘信息 恢复多通道图像( cvCvtPlaneToPix )并显示,60,Laplace变换,Laplace变换:工程数学中常用的一种积分变换。 普拉斯变换的存在性:关于一个函数f(t)的拉普拉斯变换,只有在拉普拉斯积分是收敛的情况下才存在。也就是说, f
46、(t)必须是在对于t0的每一个有限区间内都是片断性连续的,且当t趋于无穷大的时候, f(t)是指数阶地变化。 拉普拉斯变换的重大意义在于:将一个信号从时域上,转换为复频域(s域)上来表示,61,Laplace变换,void cvLaplace(const CvArr *src, CvArr * dst, int aperture_size=0) 1、用Sobel算子计算图像二阶x和y的差分 src:输入图像;dst:输出图像;xorder:x方向的差分阶数;yorder:y方向的差分阶数 2、按如下公式求和 对aperture_size=1则给出最快计算结果,相当于对每个图像采用如下内核做卷积
47、,62,视频操作示例(1),#include cv.h #include highgui.h #include #include int main( int argc, char* argv ) IplImage* laplace = 0; IplImage* colorlaplace = 0; IplImage* planes3 = 0, 0, 0 ; / 多个图像面 CvCapture* capture = 0; If(argc=1|(argc=2 ,63,视频操作示例(2),cvNamedWindow( Laplacian, 0 ); for(;) / 循环捕捉,直到用户按键跳出循环体
48、IplImage* frame = 0; int I; frame = cvQueryFrame( capture ); if( !frame ) break; if( !laplace ) for( i = 0; i width,frame-height),8,1); laplace = cvCreateImage( cvSize(frame-width,frame-height), IPL_DEPTH_16S, 1 ); /存放单通道Laplace结果 colorlaplace = cvCreateImage( cvSize(frame-width,frame-height), 8, 3
49、); /存放多通道Laplace结果 cvCvtPixToPlane( frame, planes0, planes1, planes2, 0 );/将多通道/数组分割为多个单通道数组 for( i = 0; i 3; i+ ) cvLaplace( planesi, laplace, 3 ); /计算输入图像的Laplace变换 cvConvertScaleAbs( laplace, planesi, 1, 0 ); /用线性变换将输入数组/元素转化为8位无符号整数 ,64,视频操作示例(3),cvCvtPlaneToPix( planes0, planes1, planes2, 0, co
50、lorlaplace ); colorlaplace-origin = frame-origin; cvShowImage(Laplacian, colorlaplace ); if( cvWaitKey(10) = 0 ) break; cvReleaseCapture( ,OpenCV的动态结构及操作,动态结构 内存存储 序列 集合与稀疏矩阵 数据保存 配置文件,66,动态结构:when 2d array is not enough,The sample task: collect the locations of all non-zero pixels in the image. Whe
51、re to store the locations? Possible solutions: Allocate array of maximum size (sizeof(CvPoint)*width*height a huge value) Use two-pass algorithm Use list or similar data structure (Any other ideas?),/ construct sequence of non-zero pixel locations CvSeq* get_non_zeros( const IplImage* img, CvMemStor
52、age* storage ) CvSeq* seq = cvCreateSeq( CV_32SC2, sizeof(CvSeq), sizeof(CvPoint), storage ); for( int i = 0; i height; i+ ) for( int j = 0; j width; j+ ) if( CV_IMAGE_ELEM(img, uchar, i, j) ) CvPoint pt=j,i; cvSeqPush( seq, /CvSeq:定义非固定元素的序列,67,内存管理,Memory storage is a linked list of memory blocks.
53、 Functions to remember: cvCreateMemStorage(block_size), cvReleaseMemStorage(storage); cvClearMemStorage(storage); cvMemStorageAlloc(storage,size); All OpenCV dynamic structures reside in memory storages. The model is very efficient for repetitive processing, where cvClearMemStorage is called on top
54、level between iterations.,68,序列,Sequence is a linked list of memory blocks Large sequences may be split into multiple storage blocks, while several small sequences may fit into the single storage block. Sequence is deque: adding/removing elements to/from either end is O(1) operation, inserting/remov
55、ing elements from the middle is O(N). Accessing arbitrary element is also O(1) (when storage block size sequence block) Sequences can not be released, use cvClear|ReleaseMemStorage() Basic Functions: cvCreateSeq(flags,header_size,element_size,storage), cvSeqPushFront(seq,element), cvSeqPopFront(seq,
56、element), cvClearSeq(seq), cvGetSeqElem(seq,index), cvStartReadSeq(seq,reader), cvStartAppendToSeq(seq,writer).,69,集合与稀疏矩阵,Set is variant of sequence with free node list and its active elements do not follow each other that is, it is convenient way to organize a heap of same-size memory blocks. Spar
57、se matrix in OpenCV uses CvSet for storing elements.,/ Collecting the image colors CvSparseMat* get_color_map( const IplImage* img ) int dims = 256, 256, 256 ; CvSparseMat* cmap = cvCreateSparseMat(3, dims, CV_32SC1); for( int i = 0; i height; i+ ) for ( int j = 0; j width; j+ ) uchar* ptr= ,70,数据存储
58、,数据存储与装载,/ somewhere deep in your code you get 5x5 / matrix that youd want to save CvMat A = cvMat( 5, 5, CV_32F, the_matrix_data ); cvSave( my_matrix.xml, , 5 5 f 1. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 1. ,71,配置文件,CvFileStorage* fs = cvOpenFileStorage(cfg.xml, 0, CV
59、_STORAGE_WRITE); cvWriteInt( fs, frame_count, 10 ); cvWriteStartWriteStruct( fs, frame_size, CV_NODE_SEQ); cvWriteInt( fs, 0, 320 ); cvWriteint( fs, 0, 200 ); cvEndWriteStruct(fs); cvWrite( fs, color_cvt_matrix, cmatrix ); cvReleaseFileStorage( ,Writing config file,CvFileStorage* fs = cvOpenFileStorage(cfg.xml, 0,
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 深度解读双观点面试题库:职场的全方位指导
- 静脉输液技术试题及答案
- 建筑幕墙技术试题及答案
- 高级鸭子养殖岗位面试题库
- 家教面试必 备知识库:高中教育行业常见面试题目及答案
- 市场营销人员组词造句面试题目及答案分享
- 老干局面试实战技巧:面试题目及答案详解
- 招聘专家揭秘:安职招教面试题库实战研究
- 2025年智能交通信号优化系统在高速公路交通流量预测中的应用报告
- 能源与资源行业2025年水电发电站安全运行与管理研究报告
- 网站篡改演练方案
- 《2025年CSCO卵巢癌诊疗指南》更新要点解读
- 2025年-四川省安全员《A证》考试题库及答案
- 防治传染病知识培训课件
- DBT29-35-2017 天津市住宅装饰装修工程技术标准
- 放射治疗技术规范标准
- 【物理】第九章 压强 单元练习+2024-2025学年人教版物理八年级下册
- 《仓库消防安全》课件
- (2021)最高法民申5114号凯某建设工程合同纠纷案 指导
- 蜡疗课件教学课件
- 九下语文必背内容(古诗、文言文、课文)
评论
0/150
提交评论