0130相机标定的原理与意义及opencvmatlab实现差异小结

上传人:cn****1 文档编号:512471431 上传时间:2023-09-27 格式:DOC 页数:13 大小:367KB
返回 下载 相关 举报
0130相机标定的原理与意义及opencvmatlab实现差异小结_第1页
第1页 / 共13页
0130相机标定的原理与意义及opencvmatlab实现差异小结_第2页
第2页 / 共13页
0130相机标定的原理与意义及opencvmatlab实现差异小结_第3页
第3页 / 共13页
0130相机标定的原理与意义及opencvmatlab实现差异小结_第4页
第4页 / 共13页
0130相机标定的原理与意义及opencvmatlab实现差异小结_第5页
第5页 / 共13页
点击查看更多>>
资源描述

《0130相机标定的原理与意义及opencvmatlab实现差异小结》由会员分享,可在线阅读,更多相关《0130相机标定的原理与意义及opencvmatlab实现差异小结(13页珍藏版)》请在金锄头文库上搜索。

1、2021-01-30 相机标定的原理与意义及OpenCV、Matlab实现差异小结分类:OpenCV点滴2021-01-30 20:352292人阅读评论(3)收藏举报 本文是一篇关于相机标定意义和原理的个人总结,包含了OpenCV和Matlab中常用的相机标定函数的注解。 相机标定是机器视觉的根底,标定结果的好坏直接决定了机器视觉的系统精度,作用可见一斑。在这一年半的时间里,我个人也是随着实验和程序的进一步理解,对标定的原理和意义有了更多的想法。同样,由于博文的关系,仍有一些朋友会常常询问标定的程序问题。本人的2021-05-17OpenCV标定程序的问题也屡次被朋友询问,由于当时对标定的认

2、识还不够系统,因此现在认为该文对标定的意义和原理有很多误解,并在此推荐一些较好的博文拱大家学习:双目测距与三维重建的OpenCV实现问题集锦一图像获取与单目标定;双目测距与三维重建的OpenCV实现问题集锦二双目标定与双目校正;双摄像头测距的OpenCV实现;分享一些OpenCV实现立体视觉的经验; 下面结合本人的毕业论文及一年半来对机器视觉的学习,对相机标定的意义和原理进行表达。 单目相机模型中的三种坐标系关系如图1所示,相机坐标系即是以光轴中心O为原点的坐标系,其z轴满足右手法那么,成像原点所代表平面即为像平面坐标系实际应用中,均以图像左上角为坐标系原点,实际物体坐标系即为世界坐标系。图1

3、 单目相机模型的三坐标系统关系 其中,在世界坐标系的值为,是在像平面坐标系的投影点,其相机坐标系的值为。是相机坐标系轴与像平面夹角,一般情况下轴与像平面垂直,值为。且相机坐标系与像平面平行,为相机的焦距。 对于从相机坐标系到像平面坐标系的变换,像平面坐标系是用像素单位来表示的,而相机坐标系那么是以毫米为单位来表示,因此,要完成改变换过程就需要先得到像平面的像素单位与毫米单位之间的线性关系。在图1中,相机光轴中心z轴方向上与像平面的交点称为投影中心,坐标为,是像素单位,而每个像素在和的物理尺寸为和,单位是像素/毫米,那么像平面的像素与毫米间的线性关系如式1:1 根据小孔模型下投影变换原理,像平面

4、的物理坐标对应的相机坐标系满足式2:2 其对应的矩阵形式为式3:3 联立式1和式3,得到式4即为相机坐标系与像平面坐标系变换的矩阵。4 其中,即为相机的6个内参数,其组成的矩阵即为内参数矩阵。 对于从相机坐标系到世界坐标系的变换,是通过旋转矩阵R和平移矩阵T完成的,如图2所示。图2 相机坐标系与世界坐标系的变换关系 其中,平移矩阵T是三维列向量,旋转矩阵R是坐标轴依次绕和轴旋转角度和所形成的三个矩阵的总乘积。它们的定义如式5:5 那么矩阵R的计算公式如式6:6 因此,从相机坐标系到世界坐标系的变换如式7,其中,表示,为旋转矩阵,为平移矩阵,该变换矩阵称为外参数矩阵。7 最后,联立式4和式7求得

5、像平面坐标系与世界坐标系之间的变换关系,如式8:8 其中,即为透视投影矩阵,表示空间中三维点坐标与图像平面二维坐标之间的线性关系,表示的像平面齐次坐标值,表示的世界坐标系齐次坐标值。基于以上几何原理和相机模型得到的图像信息和三维信息之间的关系,存在不可逆性,即可以通过世界坐标系的坐标值求得二维坐标值,如果要进行二维坐标到三维坐标的反求还需要其他的数学模型辅助求解。1) 制作标定板,标定板尺寸为324(mm)X252(mm),即7行9列63个36mm的正方形方格组成,如图3所示。图3 标定方格板2) 将水平平行的左右相机同时采集标定板的不同位姿图像,共计12组位姿对于采集的图像,位姿越多,标定结

6、果也会越精确,建议在10组到20组之间如图4,5所示。图4 左相机的标定图像图5 右相机的标定图像3) 在工具箱中通过Extract grid corners提取每幅标定图像的特征点即黑方格与白方格的交点。4) 进行单目标定,得到左右相机的内外参数以及畸变系数,并将参数保存到Calib_Results_left和Calib_Results_right两个mat格式的文件中。Matlab标定结果: 通过上节的步骤1-4,可以得到如图6和7所示的左右相机的内参数、畸变系数结果。图6 左相机的内参数和畸变系数图7 右相机的内参数和畸变系数 对于左右相机由于透镜畸变造成的误差使用工具箱中的visual

7、ize_distortions功能进行分析,可以得到左相机的畸变图,如8、9、10所示,相应的右相机畸变图,如11、12、13所示。图8 左相机镜头畸变图图9 左相机径向畸变图图10 左相机切向畸变图 对于图8到10,图中的0点即为左相机光学中心,图中的箭头显示相机图像的畸变方向。图8左相机整体畸变模型中,该相机的左侧畸变不明显,假设物体的图像在此那么不易受畸变因素影响造成线条的弯曲;图9左相机径向畸变模型中,该相机的畸变系数由中心向外增大,即物体的图像越靠近图像边缘,其线条的弯曲程度就越大;图10左相机切向畸变模型中,箭头方向显示该相机切向畸变的增大方向,在相机的左侧其切向畸变与径向畸变的方

8、向相反,使得整体畸变模型中,相机左侧的畸变较小。图11 右相机镜头畸变图图12 右相机径向畸变图图13 右相机切向畸变图 对于图11到13,图中的0点与左相机相同,即为右相机光学中心,图中的箭头显示相机图像的畸变方向。图11右相机整体畸变模型中,该相机的中间及偏左侧畸变不明显,假设物体的图像在此那么不易受畸变因素影响造成线条的弯曲;图12右相机径向畸变模型中,该相机的畸变系数由中心向外增大,但右相机比左相机在光轴中心附近有更大的区域畸变很小,因此位于右侧相机光学中心的图像,其线条因受畸变造成的弯曲很小;图13右相机切向畸变模型中,箭头方向显示该相机切向畸变的增大方向,在相机的左侧其切向畸变与径

9、向畸变的方向相反,使得整体畸变模型中,位于右相机图像左侧的线条受畸变影响较小。OpenCV标定结果: 在此列举的OpenCV标定结果是我双目视觉标定且优化后的结果,与Matlab的会有差异。左侧相机的内参数矩阵:9右侧相机的内参数矩阵:10 该式9-10与式1相对应。而Matlab中的cc对应于式1中的相机光轴中心在图像平面的投影坐标,fc即为式1中的和。 至此,讲解完了OpenCV与Matlab所对应的相机标定内参数矩阵的含义。OpenCV与Matlab标定中的差异: OpenCV的标定参数中,对于镜头畸变采用的方法是Brown博士在71年发表的文章中提到的;而Matlab中的镜头畸变参数采

10、用基于Heikkil博士提出的方法,将非线性干扰因素引入到内外参数的求解过程。 Heikkil采用的矩阵来表示以上的两种畸变系数。根据Brown的非线性模型,和表示镜头的径向畸变系数,通常只使用两项,只是针对即便较大的镜头例如鱼眼镜头,其余情况下该系数值为0,而和表示切向畸变系数,由式11和式12求解该矩阵,本文的畸变系数求解伴随在相机标定过程中。11 其中,是像平面上的任一点坐标值,是进行径向畸变矫正后的坐标值,是作为光学中心畸变为0的点进行泰勒级数展开后得到的。12 其中,是像平面上的任一点坐标值,是进行切向畸变矫正后的坐标值,如式11的定义相同。 外参数定义了如图2所示的图像平面到世界坐

11、标系的变换关系。而标定就是通过相机寻找图像平面中如图3所示的标定板的特征点位置,所以得到的外参数是图像平面与标定板所处平面的线性变换关系。在我的2021-06-14基于Matlab的双目视觉定位问题研究中,通过Matlab标定工具箱产生的图4与图5就可以表达上述含义。 因此,对于不同的棋盘格标定板空间位置,必然对应于不同的外参数矩阵。同样的,在视觉伺服中,雅可比矩阵也有同样的数学意义。对于视觉伺服,个人认为可以看些徐德的论文入门。用于寻找图像中的棋盘格标定板的特征点:CvSize board_sz = cvSize( board_w, board_h );IplImage* imgLeft=c

12、vCreateImage(cvSize(imgL-width,imgL-height),imgL-depth,imgL-nChannels);IplImage* imgRight=cvCreateImage(cvSize(imgR-width,imgR-height),imgR-depth,imgR-nChannels);CvPoint2D32f* cornersLeft = new CvPoint2D32f board_n ;CvPoint2D32f* cornersRight = new CvPoint2D32f board_n ;int corner_countLeft, corner_

13、countRight;cvResize(imgL,imgLeft,CV_INTER_LINEAR);cvResize(imgR,imgRight,CV_INTER_LINEAR);if(frame+ % board_dt = 0) /Find chessboard corners: int foundLeft = cvFindChessboardCorners( imgLeft, board_sz, cornersLeft, &corner_countLeft, CV_CALIB_CB_ADAPTIVE_THRESH | CV_CALIB_CB_FILTER_QUADS ); int foun

14、dRight = cvFindChessboardCorners( imgRight, board_sz, cornersRight, &corner_countRight, CV_CALIB_CB_ADAPTIVE_THRESH | CV_CALIB_CB_FILTER_QUADS );/Get Subpixel accuracy on those corners cvCvtColor(imgLeft, grayLeft, CV_BGR2GRAY);/if input is colorful then use this cvCvtColor(imgRight, grayRight, CV_B

15、GR2GRAY); cvFindCornerSubPix(grayLeft, cornersLeft, corner_countLeft, cvSize(11,11),cvSize(-1,-1), cvTermCriteria(CV_TERMCRIT_EPS+CV_TERMCRIT_ITER, 30, 0.1 );/寻找棋盘格标定板的特征点 cvFindCornerSubPix(grayRight, cornersRight, corner_countRight, cvSize(11,11),cvSize(-1,-1), cvTermCriteria(CV_TERMCRIT_EPS+CV_TERMCRIT_I

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 资格认证/考试 > 自考

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号