探讨opencv函数中的mask的作用.docx_第1页
探讨opencv函数中的mask的作用.docx_第2页
探讨opencv函数中的mask的作用.docx_第3页
探讨opencv函数中的mask的作用.docx_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

其实opencv 里面很多函数都是会带有一个mask 参数的,很多同学都不知道它到底有什么用,好像在实际运用中忽略它也没有什么问题 我在这里就抛砖引玉,详细分析一个常用函数cvcopy里面的mask ,希望可以给大家一点点指引。 以下内容来子opencv安装文件夹中自带的pdf文档。 Copies one array to another. /复制一个数组到另外一个数组 void cvCopy(const CvArr* src, CvArr* dst, const CvArr* mask=NULL); src The source array /源数组,要复制谁? / opencv里面提到的数组不是通常意义上的数组,它是矩阵、图像等结构体dst The destination array /目标数组,复制以后的内容给谁? mask 下面这就是重点。鄙人认为很多人都没有深刻理解这个mask的作用 Operation mask, 8-bit single channel array; specifies elements of the destination array tobe changed /掩码操作,mask是一个8位单通道的数组;mask指定了目标数组(dst)中那些元素是可以改变的上面这句话还不是非常重点,重点是以下的那个公式,这个公式有多少人理解哈,就网上的资料来看很少有人理解,又或者高手都不屑于网上写东西,所以我们只能做等真相孩子,你被mask mask住了吗 (第一个mask是opencv里面的mask数组,第二个mask是这个英文词本身的意思,不懂就google去)?真相来了! The function copies selected elements from an input array to an output array:dst(I) = src(I) if mask(I) = 0. /该函数把输入数组(src数组)中选中的元素(可以认为是做了标记的,不过这些标志是谁来做的呢?对,就是mask)拷贝到dst数组dst(I) = src(I) if mask(I) != 0. 就是说,如果mask不是NULL,也就是说mask是一个数组,并且是一个和dst or src大小完全一致的数组。 这时遍历src的每一个元素, (1)在位置i时候如果mask对应的值为不为0,那么把src (i) 的值复制给dst (i) 。 (2)如果mask(i) 为0,那么不管src(i)是什么,dst(i)都设置为0. 举例说明,这里不举太复杂的就来一个一维的就够啦。If any of the passed arrays is of IplImage type, then its ROI and COI fields are used. Botharrays must have the same type, the same number of dimensions, and the same size. The functioncan also copy sparse arrays (mask is not supported in this case). /如果传递给src的数组是图像类型的,那么将使用ROI或者COI。src数组和dst数组必须具有相同的数据类型、一致的数组维数、一样的大小。该函数也可以用于拷贝稀疏矩阵(但是此种情况下,mask不起作用)。 好吧,到这里了终于写完了。你现在是不是明白为什么要起mask这个名字了吧,掩码就是:不为0的时候就可一操作(具体是什么操作就看具体的函数了)、为0就掩盖住了无法操作。 补充一点 :mask = NULL 意思就是没有模板、不使用掩码操作,函数该干啥就干啥来吧,再来一个例子 : 1. #includecv.h2. #includecxcore.h3. #includehighgui.h4. #include5. intmain()6. 7. floatarr1=1,2,3,4,5,6,;8. floatarr2=-4,78,12,154,786,-0.154;9. floatarr36=119;10. intmask_arr6=1;11. CvMatsrc1;12. cvInitMatHeader(&src1,2,3,CV_32FC1,arr1,CV_AUTOSTEP);13. CvMatsrc2;14. cvInitMatHeader(&src2,2,3,CV_32FC1,arr2,CV_AUTOSTEP);15. CvMatdst;16. cvInitMatHeader(&dst,2,3,CV_32FC1,arr3,CV_AUTOSTEP);17. CvMat*mask=cvCreateMat(2,3,CV_32FC1);18. cvInitMatHeader(mask,2,3,CV_8UC1,mask_arr,CV_AUTOSTEP);19. cvAdd(&src1,&src2,&dst,mask);20. intx;21. inty;22. for(y=0;y2;+y)23. 24. float*ptr=(float*)(dst.data.ptr+y*dst.step);25. for(x=0;x3;x+)26. 27. printf(/t%f,

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论