自识别标记(self-identifying marker) -(3) 用于相机标定的CALTag源码剖析(上)

CALTag的源代码(MATLAB)可以从如下网址下载:
https://github.com/brada/caltag
下面以一幅被遮挡的图I为例进行代码的详细分析:

1、 灰度图的二值化,计算连通区域

输入的灰度图为I,显示如下
这里写图片描述
二值化方法是基于Peter Kovesi在http://www.csse.uwa.edu.au/~pk/Research/MatlabFns/提供的adaptive thresholding方法。

T = adaptivethresh( I ); 

显示自适应二值化后的图像T:
这里写图片描述
用sobel算子检测边缘得到E,然后做了简单的形态学处理,去掉一些杂散的点,对应的代码如下

E = edge( I, 'sobel', 'nothinning' );
E = bwmorph( E, 'bridge' );
E = bwmorph( E, 'majority' );

显示E结果如下:
这里写图片描述
然后做了形态学里的细化,然后清理孤立的点

E  = bwmorph( E, 'thin', inf );
E  = bwmorph( E, 'clean' );

计算8邻域的连通区域,如果每个连通域内的像素点数小于阈值minDotEdgePixels(作者设为8),则删除掉该区域。

CC = bwconncomp( E, 8 );
nPixels = cellfun( @(x) numel(x), CC.PixelIdxList );
bad = find( nPixels < minDotEdgePixels );
CC = filtercc( CC, bad );
for i = 1:CC.NumObjects
    E(CC.PixelIdxList{i}) = 0;
end
E = bwmorph( E, 'close' );

这里写图片描述
将上述图反转~E的结果如下:
这里写图片描述
然后进行腐蚀得到如下结果
这里写图片描述
上述反转—腐蚀过程循环4次,然后寻找连通区域,上述过程下面一行代码搞定了:

CC = bwconncomp( bwmorph(~E,'erode'), 4 );

2、 过滤连通区域

上一步骤得到了不少连通区域(对应着自识别标记区域),这些连通区域的数目可能比实际的自识别标记数目多。这是因为一些随机的背景物体以及一些高纹理区域也会被检测为连通区域。下面的工作就是过滤连通区域,保留真正是自识别标记的那部分,过滤准则主要有两个:

1、 面积

假设code中的每个bit至少由一个2x2大小的像素组成,而一个自识别标记单元包括code和边界共有8x8个bit,那么每个标记包含的像素数目至少为16x16个像素,也是连通区域包含的最少像素数目。这个最小面积的限制会过滤掉很多细小区域,比如自然场景中的草、毛毯等高纹理区域。最大面积定义为输入图像尺寸的1/8,因为如果图片中的自识别标记少于8个的话无法完成标定。

2、 欧拉数

欧拉数描述的是区域的连通性。对一个给定平面区域来说,区域内的孔数H和区域内的连通组元(其中任2点可用完全在内部的曲线相连接的点集合)的个数C可被进一步用来定义欧拉数(Euler number)E=C-H。如下的几个字母从左到右欧拉数分别为:-1,2,1,0。
这里写图片描述
图像中欧拉数的定义是图像中的物体数目减去这些物体中孔洞的数目。计算连通区域的欧拉数就可以知道该区域内部有多少个孔洞。最大的孔洞数目就是当code黑白相间的情况,此时孔洞的数目是MN/2,对应的最小欧拉数就是1-(MN/2)。而自识别标记内部至少会有1个孔洞,所以最大的欧拉数为0。实际中,一般一个自识别标记内部的孔洞为1~3个。使用欧拉数来过滤连通区域的优势有两个:一是它的性能和图像分辨率无关,二是不需要参数调整。
代码中实现:

good = find( ([R.Area]>minRegionArea) & ([R.Area]<maxRegionArea) );
good = find( ([R.EulerNumber]>=minEulerNumber) & 
             ([R.EulerNumber]<=maxEulerNumber) );

经过过滤后的连通区域如下图。连通区域旁边的数字表示对应的欧拉数。
这里写图片描述

未完待续。。。

参考论文:

CALTag: High Precision Fiducial Markers for Camera Calibration
参考网站:
http://www.cs.ubc.ca/labs/imager/tr/2010/Atcheson_VMV2010_CALTag/
https://github.com/brada/caltag

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
CALTag是一种高精度的相机标定方法,其原理和应用领域已在参考文献中详细介绍。相机内参标定是指确定相机的内部参数,包括焦距、主点坐标和畸变系数等,以便在图像中进行准确的测量和重建。 如果您想在实际项目中应用CALTag进行自识别标记,您需要设计适合项目特点的图案。根据引用中的介绍,您可以根据项目的要求选择不同的尺寸、数目和排列方式来设计图案。在设计图案时,需要注意以下几点: 1. 尺寸:根据图案在场景中的大小和距离,选择适当的尺寸,以保证标记能够在图像中清晰可见。 2. 数目:根据需要检测和跟踪的目标数量,确定图案中标记的数目。更多的标记可以提供更好的定位精度和鲁棒性。 3. 排列:根据场景中的约束条件和标记的布置方式,确定标记的排列方式。可以考虑使用规则的网格布局或特定的形状布局。 CALTag提供了相关的代码和工具来辅助设计标记图案。引用中提供了关于CALTag的C代码实现和使用MATLAB进行图像处理的信息。您可以根据CALTag的要求和您的具体项目需求,使用MATLAB中的图像处理工具箱进行图案设计和标定操作。 综上所述,CALTag是一种用于相机内参标定的方法,您可以根据项目需求设计自己的标记图案,并利用CALTag提供的代码和工具进行标定操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [自识别标记(self-identifying marker) -(5) 用于相机标定CALTag图案设计](https://blog.csdn.net/electech6/article/details/52497679)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [matlabkmeansc代码-caltag:相机校准标签](https://download.csdn.net/download/weixin_38672812/18976773)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值