opencv中cvCalibrateCamera2()的函数细解

本文介绍了opencv中用于摄像机标定的cvCalibrateCamera2()函数,该函数能够计算出摄像机内参矩阵、畸变系数、旋转向量和平移矩阵。内容涉及张正友的标定算法简化版,通过建立单应性矩阵的等式,利用旋转向量的正交性和长度约束,解决多幅棋盘图像的方程组来求解内参数矩阵。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  在标定摄像机的过程中,我们通常是要计算出摄像机的内参数矩阵和畸变系数,以便后来对图像进行校正和重构出图像的三维场景。

     在opencv中提供了一个cvCalibrateCamera2()函数,使用该函数,我们可以一次性得到摄像机内参数矩阵,畸变系数,旋转向量和平移矩阵。

    在这个函数中,计算内参数矩阵的原理其实是用了张正友的标定算法(如果想了解算法的详细情况,请参考他的《A Flexible New Technique for Camera Calibration》论文)在这里我只做简单的原理介绍。

   在前文中我曾经推导过单应性矩阵H=sM[r1 r2 r3 t],注意,我们此时的z平面为0,所以旋转向量第三个没有用,所以H=sM[r1 r2 t],我们设H=[h1 h2 h3],则可列出三个等式,h1=sMr1,h2=sMr2,h3=sMt,而我们在构造旋的旋转向量是相互正交的,即我们可以得到两个性质:一r1的转置矩阵乘以r2是等于0,二旋转向量的单位长度也相等,||r1||=||r2||,那么由此我们可以导出两个约束:

1
2
,利用这两个约束,我们同时得到k个棋盘图像,堆叠方程,便可解出内参数矩阵。

void cvCalibrateCamera2(
//输入参数
cons
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值