相機標定技術原理(1):張氏標定算法詳解

相機標定方法綜述

相機標定技術繁多,總體上可以分爲三類:

  1. 基於標定板的輔助標定
  2. 基於世界屬性的半自動標定
  3. 相機的自標定(self-calibration)

1. 基於標定板的輔助標定

標定板標定方法的應用較爲常見,歷史早期得標定板爲立體標定板,一般爲兩到三個相互垂直的平面,每個平面上有一些標記點,通過3D-2D投影關係估計相機的內參,立體標定板成本高,不易得到,使用不方便;張正友博士提出利用一個平面標定板依靠單應模型實現求解相機內外參數(外參數指相機得位姿),精度穩定,易於實現,成爲最流行的相機標定技術,同時OpenCV採用該方法實現標定功能。1本文着重論述此方法。

2. 基於世界屬性的半自動標定

通過獲取場景屬性,如建築物、道路等邊緣平行線、垂直線段,也可實現標定內參數,具體原理詳見下一篇介紹。

3. 相機的自標定

通過先驗約束條件,如相機的skew因數爲零,實現相機的內參數估計,此類方法在多視圖幾何有詳細論述,另一篇會總結該思路。 2

張氏標定算法詳解

三維空間平面上的特徵點與其像點存在單應關係(homography), 利用該約束可以構造關於內參得方程組求解未知參數。

1. 約束方程推導

採用齊次座標表達,設世界座標系原點在(標定板)平面上,xOy平面與平面重合
x=K[Rt]X(1.1) x=K \left[ \begin{matrix} R & t \end{matrix} \right] X\tag{1.1}
其中,
K=[αγu0βv001](1.2) K=\left[\begin{matrix}\alpha&\gamma&u\\0&\beta&v\\0&0&1\end{matrix}\right]\tag{1.2}
R=[r1r2r3](1.3) R=\left[\begin{matrix}r_1&r_2&r_3\end{matrix}\right]\tag{1.3}
由於X的第三個元素爲0,
x=K[r1r2t][ab1](1.4) x=K\left[\begin{matrix}r_1&r_2&t\end{matrix}\right]\left[\begin{matrix}a\\b\\1\end{matrix}\right]\tag{1.4}
則存在,
x=HX(1.5) x=HX^{'}\tag{1.5}
其中,
X=[ab1](1.6) X^{'}=\left[\begin{matrix}a\\b\\1\end{matrix}\right]\tag{1.6}

由等式1.3與1.4
H=λK[r1r2t](1.7) H=\lambda K\left[\begin{matrix}r_1&r_2&t\end{matrix}\right]\tag{1.7}
λ\lambda爲比例因子,設
H=[h1h2h3](1.8) H=\left[\begin{matrix}h_1&h_2&h_3\end{matrix}\right]\tag{1.8}
r1r_1r2r_2爲正交單位向量,則有
h1TKTKTh2=0(1.9) h_1^TK^{-T}K^{-T}h_2=0\tag{1.9}
h1TKTK1h1=h2TKTK1h2(1.10) h_1^TK^{-T}K^{-1}h_1=h_2^TK^{-T}K^{-1}h_2\tag{1.10}

2. 方程求解

B=KTK1B=K^{-T}K^{-1}
B=[1α2γα2βvγuβα2βγα2βγ2α2β2+1β2γ(vγuβ)α2β2vβ2vγuβα2βγ(vγuβ)α2β2vβ2(vγuβ)2α2β2+v2β2+1](1.11) B=\left[\begin{matrix}\frac{1}{\alpha^2}&-\frac{\gamma}{\alpha^2\beta}&\frac{v\gamma-u\beta}{\alpha^2\beta}\\-\frac{\gamma}{\alpha^2\beta}&\frac{\gamma^2}{\alpha^2\beta^2}+\frac{1}{\beta^2}&-\frac{\gamma(v\gamma-u\beta)}{\alpha^2\beta^2}-\frac{v}{\beta^2}\\\frac{v\gamma-u\beta}{\alpha^2\beta}&-\frac{\gamma(v\gamma-u\beta)}{\alpha^2\beta^2}-\frac{v}{\beta^2}&\frac{(v\gamma-u\beta)^2}{\alpha^2\beta^2}+\frac{v^2}{\beta^2}+1\end{matrix}\right]\tag{1.11}
b=[B11B12B22B13B23B33]b=\left[\begin{matrix}B_{11}&B_{12}&B_{22}&B_{13}&B_{23}&B_{33}\end{matrix}\right],令式(1.5)中H的第i列爲hi=[hi1hi2hi3]Th_i=\left[\begin{matrix}h_{i1}&h_{i2}&h_{i3}\end{matrix}\right]^T,令vij=[hi1hj1hi1hj2+hi2hj1hi2hj2hi1hj3+hi3hj1hi2hj3+hi3hj2hi3hj3]Tv_{ij}=\left[\begin{matrix}h_{i1}h_{j1}&h_{i1}h_{j2}+h_{i2}h_{j1}&h_{i2}h_{j2}&h_{i1}h_{j3}+h_{i3}h_{j1}&h_{i2}h_{j3}+h_{i3}h_{j2}&h_{i3}h_{j3}\end{matrix}\right]^T

由式(1.9),(1.10),
[v12T(v11v22)T]b=0(1.12) \left[\begin{matrix}v_{12}^T\\(v_{11}-v_{22})^T\end{matrix}\right]b=0\tag{1.12}

從1幀圖像估計的單應矩陣H可以獲得2個標定方程,設有n張標定板圖像,則可構成
Vb=0(1.13) Vb=0\tag{1.13}
其中,V是2n x 6大小的矩陣

式(1.13)爲齊次方程,可採用SVD求得b,利用下式獲得內參:
在這裏插入圖片描述
進一步可以求得相機外參,即位姿參數:
在這裏插入圖片描述

3. 參數優化

上述推導過程假設相機是理想的針孔相機模型,沒有考慮鏡頭畸變問題,同時上述求解過程是一個代數解法,結果不是最優參數,可以相機內外參數、畸變係數爲待優化參數最小化重投影誤差,利用LM算法求得最優估計。


  1. Z. Zhang, “A flexible new technique for camera calibration,” in IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 22, no. 11, pp. 1330-1334, Nov. 2000.
    doi: 10.1109/34.888718 ↩︎

  2. Hartley R, Zisserman A. Multiple view geometry in computer vision[M]. Cambridge university press, 2003. ↩︎

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章