相机成像原理与数学模型

别说谁变了你拦得住时间么 提交于 2020-03-04 12:23:35

相机的成像结果可以抽象为一个小孔和一个平面,用小孔成像模型描述。
在这里插入图片描述
三维世界的光线经过小孔即光心到达成像平面,形成二维投影。以相机的光心O为原点,XcX_cYcY_cZcZ_c 为坐标轴组成相机坐标系;以成像平面的中心 OO'为原点,xx'yy' 为坐标轴组成图像坐标系。成像过程即为相机坐标系下的三维点变换为图像坐标系下的二维点的过程。

假设P为三维空间中一点。在相机坐标系下,其坐标为 P=[X,Y,Z]TP = [ X,Y,Z]^T;在图像坐标系下为点 pp,其坐标为p=[x,y]Tp = [x,y]^T

连接O 、O 与光轴重合,且与成像平面垂直,则p在相机坐标系下p=[x,y,z]Tp = [x,y,z]^T,其中 z=fz = fff表示相机的焦距。仅考虑水平和光轴方向,模型抽象为一组相似三角形。
在这里插入图片描述
由几何关系:
Zf=Xx=Yy \frac{Z}{f} = \frac{X}{x} = \frac{Y}{y}
整理得:
x=fXZy=fYZz=f(1) x = f \cdot \frac{X}{Z}\\ y = f \cdot \frac{Y}{Z}\\ z = f \\ \tag1
扩展坐标的维度,将ZZ线性化:
[x^y^z^]=[f0000f000010][XYZ1] \left[ \begin{matrix} \hat{x} \\ \hat{y} \\ \hat{z} \end{matrix} \right] = \left[ \begin{matrix} f&0&0&0 \\ 0&f&0&0 \\ 0&0&1&0 \end{matrix} \right] \left[ \begin{matrix} X \\ Y \\ Z \\ 1 \end{matrix} \right]
则坐标(x^,y^,z^)(\hat{x} ,\hat{y} ,\hat{z}) 就是 p=(x,y)p = (x,y)的齐次坐标。

相机的像素信息的计算机中占据一段连续的磁盘或内存空间,为了从存储信息的首地址开始读写,以成像平面的左上角为原点,水平向右作为uu轴正向,竖直向下作为vv轴正向,建立像素坐标系,其基本单位为像素。
两个坐标系的对应关系如下:
在这里插入图片描述
由此可知,图像坐标系和像素坐标系虽然在同一平面,但是相差了一个缩放和一个原点的平移。由于像素块是一个矩形,设其水平长度为α\alpha,竖直长度为β\beta。将图像坐标系下的点(x,y)(x,y)在水平方向上缩放 α\alpha倍、平移cxc_{x},竖直方向上缩放β\beta倍、平移cyc_{y},得到像素坐标系下坐标(u,v)(u,v)
u=αx+cxv=βy+cy u = \alpha \cdot x + c_{x} \\ v = \beta \cdot y + c_{y}
式(1)带入:
fx=αffy=βf f_{x} = \alpha \cdot f \\ f_{y} = \beta \cdot f
写成齐次坐标的形式:
[uv1]=1Z[fx0cx0fycy001] \left[ \begin{matrix} u \\ v \\ 1 \end{matrix} \right] = \frac{1}{Z} \left[ \begin{matrix} f_{x}&0&c_{x} \\ 0&f_{y}&c_{y} \\ 0&0&1 \end{matrix} \right]
得相机得内参数矩阵:
K=[fx0cx0fycy001] K = \left[ \begin{matrix} f_{x}&0&c_{x} \\ 0&f_{y}&c_{y} \\ 0&0&1 \end{matrix} \right]
其中KK称为相机的内参数矩阵,有四个未知数,这与相机的构造有关。根据以上推导可知,fxf_{x}fyf_{y} 与相机的焦距、像素的长宽有关; cxc_xcyc_y 与相机的成像平面大小有关。
综上所述,相机的成像过程为:
p=KPp = K \cdot P
当相机移动时,相机坐标系的原点和坐标轴的方向也会随之变化,所以需要将其变换到系统的绝对坐标系下,即世界坐标系。

相机的运动可以用一个旋转和一个平移描述。设某一点在相机坐标系下坐标为PcP_c,在世界坐标系下坐标为 PwP_w,旋转矩阵为RR,平移向量为tt,则其转换关系为:Pc=RPw+t P_c = R \cdot P_w +t
写成齐次坐标形式为
[XcYcZc1]=[R11R12R13t1R21R22R23t2R31R32R33t30001][XwYwZw1] \left[ \begin{matrix} X_c \\ Y_c \\ Z_c \\ 1 \end{matrix} \right] = \left[ \begin{matrix} R_{11} & R_{12} &R_{13}&t_1 \\ R_{21}&R_{22}&R_{23}&t_2 \\ R_{31}&R_{32}&R_{33}&t_3 \\ 0&0&0&1 \end{matrix} \right] \left[ \begin{matrix} X_w \\ Y_w \\ Z_w \\ 1 \end{matrix} \right]

[XcYcZc1]=[Rt01][XwYwZw1] \left[ \begin{matrix} X_c \\ Y_c \\ Z_c \\ 1 \end{matrix} \right] = \left[ \begin{matrix} R & t \\ 0&1 \end{matrix} \right] \left[ \begin{matrix} X_w \\ Y_w \\ Z_w \\ 1 \end{matrix} \right]
得到相机的外参数矩阵
T=[Rt01] T = \left[ \begin{matrix} R & t \\ 0&1 \end{matrix} \right]
综上所述,就得到了一个相机的矩阵:
[uv1]=[1dx0cx01dycy001][f0000f000010][Rt01][XwYwZw1] \left[ \begin{matrix} u \\ v \\ 1 \end{matrix} \right] = \left[ \begin{matrix} \frac{1}{dx} & 0 & c_x \\ 0& \frac{1}{dy} & c_y \\ 0 & 0 &1 \end{matrix} \right] \left[ \begin{matrix} f&0&0&0 \\ 0&f&0&0 \\ 0&0&1&0 \end{matrix} \right] \left[ \begin{matrix} R & t \\ 0&1 \end{matrix} \right] \left[ \begin{matrix} X_w \\ Y_w \\ Z_w \\ 1 \end{matrix} \right]
其中:

  • (u,v,1)(u,v,1)表示像素坐标系下点的齐次坐标形式;
  • dxdydx,dy表示相机像素的长和宽,承前,α=1dx,β=1dy\alpha = \frac{1}{dx},\beta = \frac{1}{dy};
  • cx,cyc_x , c_y表示图像坐标系原点和像素坐标系原点的偏移值;
  • ff表示相机的焦距;
  • RR表示相机的旋转矩阵
  • tt表示相机的平移矩阵
  • (Xw,Yw,Zw,1)(X_w , Y_w , Z_w , 1)表示点在世界坐标系下坐标的的齐次坐标形式

这就推得了相机矩阵。相机矩阵的参数由内参数和外参数组成。相机在制造的过程中,难免会出现偏差,仅仅使用出厂参数是不够的,另外还要考虑镜头畸变引起的误差。相机标定是一个获取相机内参数和外参数以及矫正镜头畸变的过程。相机标定的结果的精度将直接影响相机工作时所得结果的准确度。

标定方法使用张定友教授提出的张氏标定法。

参考:高翔《视觉SLAM十四讲》

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!