代码改变世界

实战 | 相机标定

2019-02-28 09:06  计算机视觉life  阅读(3123)  评论(0编辑  收藏  举报

点击“计算机视觉life”关注,置顶更快接收消息!

什么是相机标定?我们为什么需要相机标定?

相机标定就是确定相机内参和外参的过程,其结果精度会直接影响视觉系统后续工作的准确性。

坐标系

相机标定涉及到了四大坐标系,分别为:

像素坐标系\((u,v)\)

图像物理坐标系\((x,y)\)

相机坐标系\(({x_c},{y_c},{z_c})\)

世界坐标系\(({x_w},{y_w},{z_w})\)

坐标系

为了进行相机标定,必须已知世界坐标系中足够多的三维空间点坐标,找到这些空间点在图像中投影点的二维图像坐标,并建立对应关系。世界坐标系中某个给定点投影到图像坐标系中被分为两个步骤:

坐标转换

机器视觉中常用的有两种不同类型的镜头:普通镜头和远心镜头。使用普通镜头时,世界坐标系到图像坐标系为透视投影;使用远心镜头时为平行投影。

相机标定方法分类

相机标定方法有:传统相机标定法、主动视觉相机标定法、相机自标定法。

标定方法 优点 缺点 常用方法
传统相机标定法 可使用于任意的相机模型、 精度高 需要标定物、算法复杂 Tsai两步法、张氏标定法
主动视觉相机标定法 不需要标定物、算法简单、鲁棒性高 成本高、设备昂贵 主动系统控制相机做特定运动
相机自标定法 灵活性强、可在线标定 精度低、鲁棒性差 分层逐步标定、基于Kruppa方程
  1. Tsai两步法是先线性求得相机参数,之后考虑畸变因素,得到初始的参数值,通过非线性优化得到最终的相机参数。Tsai两步法速度较快,但仅考虑径向畸变,当相机畸变严重时,该方法不适用。
  2. 张氏标定法使用二维方格组成的标定板进行标定,采集标定板不同位姿图片,提取图片中角点像素坐标,通过单应矩阵计算出相机的内外参数初始值,利用非线性最小二乘法估计畸变系数,最后使用极大似然估计法优化参数。该方法操作简单,而且精度较高,可以满足大部分场合。详细原理见[从零开始学习「张氏相机标定法」]: https://mp.weixin.qq.com/s/KuTRTPEgQ3oXBkQe11UgAA。
  3. 基于主动视觉的相机标定法是通过主动系统控制相机做特定运动,利用控制平台控制相机发生特定的移动拍摄多组图像,依据图像信息和已知位移变化来求解相机内外参数。这种标定方法需要配备精准的控制平台,因此成本较高。
  4. 分层逐步标定法是先对图像的序列做射影重建,在重建的基础上进行放射标定和欧式标定,通过非线性优化算法求得相机内外参数。由于初始参数是模糊值,优化算法收敛性不确定。
  5. 基于Kruppa的自标定法是通过二次曲线建立关于相机内参矩阵的约束方程,至少使用3对图像来标定相机。图像序列长度会影响标定算法的稳定性,无法保证射影空间中的无穷远平面。

MATLAB相机标定应用程序

MATLAB自带相机标定应用程序,有camera calibrator和stereo camera calibrator两类相机标定应用程序。其操作简单、直观,能够获得相机的内、外参数以及畸变参数等。

MATLAB相机标定应用程序

其中,camera calibrator用于单目相机标定;stereo camera calibrator用于双目相机标定。两者操作方式相同,唯一区别在于stereo camera calibrator添加图片时会弹出添加两个相机图片的操作框。

stereo camera calibrator图片添加界面

标定板准备(实验室经费有限,只能自己制作)

平面标定板具有以下几个优点:

  1. 易于操作;
  2. 尺寸可以制作的非常精确;
  3. 非常方便应用在背光照明应用中,只需要使用透明材料制作放置标志点的底盘即可。

使用MATLAB编程进行棋盘标定板的制作,将图片打印后固定在一块平板上。程序如下:

J = (checkerboard(300,3,4)>0.5);	%生成黑白棋盘图像
figure, imshow(J)	%显示黑白棋盘图像
imwrite(J,'plate.jpg');	%保存黑白棋盘图像

效果如图:(感觉有点寒酸呀,“但这不重要”,没条件自己创造)

标定板效果图

Camera Calibrator应用程序

camera calibrator操作界面如下:

camera calibrator操作界面

对于标定图像数量,位姿越多,标定结果也会越精确,建议在10到20幅之间。按照上图中的1、2、3进行相机标定操作。我们可以选择径向畸变系数以及是否计算切向畸变和倾斜,通过优化选项可以设置内参矩阵以及径向畸变参数的输出形式。

1.添加标定图像后显示界面如下图:

图片导入效果图

2.相机标定后显示界面会显示相机与标定板之间的位置关系。

相机与标定板位置关系

3.相机参数输出

camera calibrator应用程序相机标定参数输出如图所示:

标定参数

高亮:MATLAB相机标定结果中的内参矩阵默认格式为\(\left[ {\begin{array}{*{20}{c}}{{f_x}}&0&0\\ s&{{f_y}}&0\\ {{u_0}}&{{v_0}}&1 \end{array}} \right]\),其中,\({f_x}\)\({f_y}\)分别为\({u}\)轴和\({v}\)轴的有效焦距;\({s}\)\({u}\)轴和\({v}\)轴的不垂直因子,一般令\({s}=0\);\(({u_0},{v_0})\)是光学中心。

注意事项:

  1. 制作棋盘格标定板时,黑色方格与白色方格尺寸需要相同,所有方格尺寸一致;
  2. 采集标定板图像时,应采集多幅不同位姿的标定板图像,采集图像数量不应太少,建议10~20幅为宜;
  3. 采集图像时,相机的焦距不能调节,否则会改变相机的内参数,导致标定失败;
  4. MATLAB相机标定程序能够自动计算重投影误差,重投影误差越小表示相机标定的精度越高。

相机标定参数的准确度

相机标定过程中如果标定板放置不适当的话将会导致相机参数中某个参数或某些参数不能得到唯一值。为了得到高准确度的相机参数必须避免这种情况的发生。除了这个影响外,影响相机参数准确度的主要因素就是用于进行相机标定的图像数量。下面显示了用于相机标定的图像数量对参数的影响。

标准差

从图中可以看出相机参数的准确度随使用图像数量的增加而明显增加。为什么使用相当多的标定图像可以提高相机标定精度?这主要是因为相机参数之间存在不容忽视的相关性,这些参数只能通过多次无关测量进行求解。为了得到更准确的相机参数,我们需要这样做:

  1. 标定板在图像中最好能够覆盖整个视野(覆盖图像的每个角落可以使得径向畸变系数更准确);
  2. 标定板覆盖较大的深度范围(将标定板绕它的\(x\)轴和\(y\)轴旋转或者放置在不同距离的位置上)。