角检测

来自testwiki
跳转到导航 跳转到搜索

Template:Expand English Template:FeatureDetectionCompVisNavbox 角检测Template:Lang-en)或兴趣点检测Template:Lang),是计算机视觉系统中用来提取特征以及推测图像内容的一种方法。角检测的应用很广,经常用在运动检测跟踪馬賽克(image mosaicing)、全景图缝合(panorama stiching)、三维建模以及物体识别中。

问题定义

两条边的交点形成一个角(点)。而图像的要点(也称为受关注点)是指图像中具有代表性以及稳健性(即指该点能够在有噪声干扰的情况下也能稳定的被定位,在大陆亦被称为:鲁棒性)的点。也就是说,要点可以是(点),也可以不是,例如局部亮点或暗点,线段终点,或者曲线上的曲率最大值点。在实际应用中,很多所谓的(角)点检测算法其实是检测要点,而不仅仅是角(点)。所以,如果我们只想检测角的话,还需要对检测出的要点进一步分析。

例如也可以先經過邊檢測,之後在做一些後處理來檢測角,像是Kirsch operatorFrei-Chen masking set兩種方法。為了分辨區辨識時圖像含有一部分目標圖像的資訊是否正確,角檢測通常不是一個非常確定且同時需要很多額外的確認才可以確定,角檢測在圖像上最簡單的做法是利用相關性,但這樣的作法需要耗費大量的運算資源以及得到的結果可能只是局部最大值,因此有另一個常見的作法是使用Harris和Stephens所提出的經由改善Moravec方法的結果。

Moravec 角檢測演算法

這是最早使用來做角檢測的做法,他首先定義所謂的「角」就是那些自我相似程度低的點。這個演算法檢查所有圖像中的像素,並考慮以該像素為中心點的一片範圍,該範圍與他周圍覆蓋最大的另一個範圍的相似度做為參考,而相似度通常是將兩個範圍的對應點計算誤差的平方和(SSD: Sum of Squared differences) ,越小代表相似度越高。

舉例來說,如果一個像素是位於一片均勻強度的區塊時,這時每個像素周圍與其附近的像素的周圍都是相當類似的,因此相似度也高,不會被認為是角。而在圖形的邊界處的像素,若是與邊垂直方向處附近的像素,兩者的周圍圖像相似度就會比較低,然而若是與邊平行附近的像素,兩者的周圍圖像相似度就會比較高(看到的都是一條在同樣位置的邊),因此也不會被認為是角。只有在那些與附近像素的周圍圖像都很不相似的像素,才會被認為是「角」。

如果我們將這種與周圍的相似程度量化(使用誤差平方和),並且找出整個圖像的局部最大值(局部最不相似的點),這些局部最大值就很有可能是我們想要偵測到的「角」。

Harris & Stephens / Plessey / Shi–Tomasi 角檢測演算法

Template:Main Harris & Stephens改善了Moravec的方法,他們直接考慮每個像素沿著特定方向處的像素的SSD,而不是使用與周圍像素範圍的SSD。

不失一般性,我們假設現在是對一個灰階的2維圖像來做偵測。令這個圖為 I ,考慮 (u,v) 位置的像素與周圍的區塊,並選取一個固定向量 (x,y) 作為該像素的參考像素,因此固定的這個向量 (x,y) 所算出的所有差平方和的總和記做為 S(x,y) ,而對於每個 (u,v) 做不同加權,就可以得到

S(x,y)=uvw(u,v)(I(u+x,v+y)I(u,v))2

如果使用泰勒展開式I(u+x,v+y) 展開,假設IxIyI 的偏微分,可以得到

I(u+x,v+y)I(u,v)+Ix(u,v)x+Iy(u,v)y

並將原式改寫成

S(x,y)uvw(u,v)(Ix(u,v)x+Iy(u,v)y)2,

或是使用矩陣來簡化算式

S(x,y)(xy)A(xy),

其中矩陣 A

A=uvw(u,v)[Ix2IxIyIxIyIy2]=[Ix2IxIyIxIyIy2]

式子中的矩陣是Harris矩陣,而括號代表對所有的 (u,v) 取加權平均,

一個角(或者說是要點)可以被刻劃成該點 (u,v) 使得 S(u,v) 在不同的方向 (x,y) 之間有很大的變異數的點。 根據分析 A特徵值,以上的特性可以用下面的方式闡述:在角的點上,A應該要有兩個"大"的特徵值

根據特徵值的大小,我們會有以下的推論:

  1. 如果 λ10λ20 則這個像素 (u,v) 只是一個普通的點。
  2. 如果 λ10λ2 為一個大的正數,則這個像素 (u,v) 位在邊上面。
  3. 如果 λ1λ2 都是大的正數,則這個像素 (u,v) 就是一個角點。

Harris 和 Stephens 注意到計算特徵值在運算量上面相當大,計算中需要使用到取平方根的操作,因此給出了另一個近似值 Mc ,其中 κ 是需要調整的重要參數。

Mc=λ1λ2κ(λ1+λ2)2=det(A)κtrace2(A)

因此該演算法不需要真正的去做 A特徵分解,而只需要去估計 A行列式。 Shi–Tomasi[1] 角檢測在假設一般圖像每個像素所給出的函數值通常是光滑(smooth)且穩定的(stable),他直接去計算 min(λ1,λ2) ,有時又稱該方法為 Kanade-Tomasi 角檢測。

κ 的值通常是由經驗決定,而通常在 0.04–0.15 的範圍裡是可解的。 另一種方法可以避開選擇 κ 的困擾,這個方法是使用 Noble's[2] 角測度 Mc ,而角測度是計算所有特徵值調和平均數

Mc=2det(A)trace(A)+ϵ,

其中 ϵ 是一個小的正常數。

而角的位置的共變異數矩陣即為A1,可以寫成

1Ix2Iy2IxIy2[Iy2IxIyIxIyIx2].

Förstner 角檢測

使用 Förstner 演算法的例子

在某些情況,會希望更精確地去計算角的位置,為了得到近似值,Förstner[3] 演算法可以解出閉集上的角附近範圍中的所有切線與最接近這些切線的點,該演算法依賴於在一個理想的角附近。

一個像素 𝐱 的切線 T𝐱(𝐱) 可以由數學式給出

T𝐱(𝐱)=I(𝐱)(𝐱𝐱)=0

其中 I(𝐱)=[I𝐱,I𝐲] 是圖像 I𝐱 點的梯度向量。 而最靠近長方形範圍 N 中所有切線的點 𝐱0

𝐱0=argmin𝐱2×1𝐱NT𝐱(𝐱)2d𝐱

𝐱0 到切線 T𝐱 的距離依照梯度向量的大小來加權,因此若經過該點的切線有較大的梯度的話,在加權上就會占較高的比重。

嘗試著解 𝐱0

𝐱0=argmin𝐱2×1𝐱N(I(𝐱)(𝐱𝐱))2d𝐱=argmin𝐱2×1𝐱N(𝐱𝐱)I(𝐱)I(𝐱)(𝐱𝐱)d𝐱=argmin𝐱2×1(𝐱A𝐱2𝐱𝐛+c)

A2×2,b2×1,c 分別為

A=I(𝐱)I(𝐱)d𝐱𝐛=I(𝐱)I(𝐱)𝐱d𝐱c=𝐱I(𝐱)I(𝐱)𝐱d𝐱

要找出最小值可以經由計算式子對 x 的微分,並讓微分後的式子等於0來解x

2A𝐱2𝐛=0A𝐱=𝐛

注意到如果要能夠解上述等式, A2×2 必須要是可逆的,或是說 A2×2 必須要是滿的,而解可以寫成

x0=A1𝐛

只有在範圍 N 之中有角時才存在。

此外 Lindeberg[4][5] 給出一個方法去評估角的確定性,經由最小化誤差

d~min=cbTA1btraceA

而這對所有尺度都適用,因此這方法可以自動去適應圖片中不同梯度大小所造成的影響與誤差。

此外

  • c 可以被視為最小平方誤差計算中的誤差,因此當 c 為0時,將沒有誤差存在。
  • 這個演算法可以用來找出環狀特徵的中心,只需將上述演算法中的梯度向量改成法線向量即可。

多尺度 Harris 算子

Harris 算子中的微分矩陣 A 會牽涉到要計算圖像中的偏微分(Image derivatives) Ix,Iy,而這可以用附近點的線性組合來做逼近,而計算線性組合時通常也會需要根據附近圖像值的大小來做縮放,因此需要兩個額外的縮放參數:(i)一個局部縮放參數主要用來讓圖像平滑一點 (ii)一個積分參數用來累積在微分操作中的非線性算子,作為圖像的修正項。

若以 I 代表原本圖形中的亮度,L 為一個將圖像 I 通過一個高斯濾波器讓圖像變模糊的結果。

g(x,y,t)=12πte(x2+y2)/2t

而參數 t 用來控制高斯濾波器的變異數

L(x,y,t) =g(x,y,t)*I(x,y)

Lx=xLLy=yLL 的偏導數,此外用一個高斯濾波器作為縮放大小,參數 s 可供調整。 則multi-scale second-moment matrix [6][7] 可以被定義為

μ(x,y;t,s)=ξ=η=[Lx2(xξ,yη;t)Lx(xξ,yη;t)Ly(xξ,yη;t)Lx(xξ,yη;t)Ly(xξ,yη;t)Ly2(xξ,yη;t)]g(ξ,η;s)dξdη.

則我們也可以用前面類似的方法來計算 μ 的特徵值,並且定義多尺度 Harris corner 測度為

Mc(x,y;t,s)=det(μ(x,y;t,s))κtrace2(μ(x,y;t,s))

注意到局部尺度參數 t 和積分尺度參數 s ,這兩個參數通常會有相對關係 s=γ2t,其中 γ 為一個參數通常介於 [1,2] 之間。 因此我們可以計算多尺度 Harris corner 測度 Mc(x,y;t,γ2t) ,在給定的任何局部尺度 t 去做到多尺度角偵測。 一般實際應用上,多尺度角偵測通常會先做尺度選擇的步驟,可以參考正規化尺度拉普拉斯算子 [5][6]

norm2L(x,y;t) =t2L(x,y,t)=t(Lxx(x,y,t)+Lyy(x,y,t))

常常在尺度選擇的部分用到,並且用來同時調整尺度以適應該角點。[8]

  • 空間範圍內多尺度角測度 Mc(x,y;t,γ2t) 的最大值:
(x^,y^;t)=argmaxlocal(x,y)Mc(x,y;t,γ2t)
  • 將圖像通過一個高斯濾波器 norm2(x,y,t) (拉普拉斯算子[5])所得到的 L 的局部最大值或最小值:
t^=argmaxminlocaltnorm2L(x^,y^;t)

參考文獻

引用

Template:Reflist

来源

  1. 引用错误:<ref>标签无效;未给name(名称)为shitomasi的ref(参考)提供文本
  2. 引用错误:<ref>标签无效;未给name(名称)为noble的ref(参考)提供文本
  3. Template:Cite journalTemplate:Dead link
  4. 引用错误:<ref>标签无效;未给name(名称)为lindeberg94icip的ref(参考)提供文本
  5. 5.0 5.1 5.2 引用错误:<ref>标签无效;未给name(名称)为lindeberg98的ref(参考)提供文本
  6. 6.0 6.1 引用错误:<ref>标签无效;未给name(名称)为lindeberg94book的ref(参考)提供文本
  7. 引用错误:<ref>标签无效;未给name(名称)为lindeberg08enc的ref(参考)提供文本
  8. 引用错误:<ref>标签无效;未给name(名称)为schmid的ref(参考)提供文本