脊检测(英語:Ridge detection)為試圖尋找相片中的脊的位置之方法。在數學及電腦視覺等領域中,一個雙變數光滑函數的脊(或是稱作為脊集合)是所有至少在一個維度中是局部最大值的點所形成的曲線的集合,就如同地理上山脊的概念。而一個變數函數的脊,是所有在個維度中是局部最大值的點所形成的曲線的集合。脊可以看作是局部最大值的延伸。相對的,一個函數的谷可以以類似的方式定義,只要以局部最小值取代脊定義中的局部最大值的部份。
脊集合與谷集合表現了一個函數直覺上的幾何資訊,因此可以提供一種對於函數特徵的簡潔呈現。圖像分析及電腦視覺為了獲得相片中物件延伸特性的資訊,利用了脊集合與谷集合的特性而有脊检测及谷检测。相關的應用像是在分水嶺演算法中被使用以進行圖像分割,或是利用相片中的脊與谷去計算物件可能的形狀等等。此種幾何資訊的表示方式,若只有進行單一尺度的計算,容易會受到雜訊的干擾。根據尺度空間理論,多重尺度的脊與谷可以透過相片經過高斯金字塔的預先處理獲得,藉此應該可以產生對於物件更穩定的描述。
二維相片中單一尺度的脊與谷的微分幾何定義
令 為一個二維函數,而 為 的尺度空間表示,此種表示可以透過 與高斯函數的摺積獲得。
在單一尺度下,高斯函數中的 為一定值。
- .
透過旋轉的方式,可以找到一組直角座標 使得 ,其中的方向導數運算子,
-
進一步帶入海森矩陣中。
-
不難看出 即為海森矩陣的特徵值,而旋轉矩陣的旋轉角度可以由海森矩陣的特徵向量所決定。
- , .
有了恰當的旋轉後,便可以正式的定義函數 在單一尺度下的脊,脊包含所以符合以下條件的點。[1]
-
相對應的谷,谷包含所有符合以下條件的點。
-
相似的,也可以將座標旋轉,使得新座標 中, 的方向平行相片的梯度,而 的方向垂直相片的梯度。
-
此時的旋轉角度為,
-
以下的定義可以被證明與前述的是等價的[2]
-
其中
-
-
-
由 的正負號決定一個點是脊或是谷, 是脊而 是谷.
計算二維相片在變化尺度下的脊
單一尺度脊的主要問題是對於雜訊非常敏感,實驗證實尺度的選擇需要特別的調整才能得到一組能夠反應相片中結構的脊。為了在缺乏過往經驗時處理這個問題,而有了尺度空間脊的概念,此時尺度大小這個變數被當作是脊定義的固有特性,尺度可以在尺度空間中變化。此種概念使得尺度可以被自動的調整到反應相片結構的大小,以下有多種方法皆是基於此。
令 為一個描述脊強度的函數(底下有詳細定義)。則對於一個二維相片,尺度空間脊包含所有符合以下條件的點,
-
其中 為尺度空間表示中的尺度. 相似的,尺度空間谷包含所有符合以下條件的點,
-
如此定義下,可以想像尺度空簡脊為三維空間中一些一維曲線的集合(原本相片的二維加上尺度空間一維),而最後呈現的脊便是這些曲線在相片平面上的投影。
當初Lindeberg (1996, 1998)[3] 提出了尺度空間脊時,他考慮了三個描述脊強度的函數。
-
- 特徵值差的平方經 -標準化後的平方
-
- 特徵值差經 -標準化後的平方
-
是一個通用性的描述函數,常被用在血管偵測及道路提取等應用中,而 則被用在指紋的增強[4],即時手部追蹤及手勢辨識[5],以及利用局部影像統計偵測追蹤影像或影片中的人。[6]
歷史
脊與谷第一次被使用在數位影像的領域中是在由Haralick於1983[7]及Crowley於1984對於高斯金字塔的想法[8][9] ,脊在醫學影像中的應用則有Pizer及其同事的深入研究[10][11][12] 及他們所提出的M-reps。[13] 脊检测因Lindeberg加入了 -標準化導數及尺度空間脊等概念而有所提昇。這些概念之後由Steger等人使用在道路提取[14][15] ,由Frangi等人使用在血管的分割[16] 以及由Satos等人及Krissian等人使用在曲線及管狀結構的偵測中。[17][18]
N維空間中脊與谷的定義
脊的概念,推廣了實數函數的局部最大值。一個在 定義域中的點 ,若存在一個距離 使得所有在這個距離內的都符合 ,則點 是一個局部最大值。
稍微放寬一下這個條件,若所有在 的附近的點 中 維的子集合,皆符合 ,則 便是脊上的一個點。這樣的放寬,給予了脊一個維度的自由,也就是說脊會是一個一維的曲線。同樣的概念套用到局部最小值上,可以得到一維的谷曲線。
以下的定義是根據Eberly的著作[19],可以被當作是之前的脊的定義的推廣。令 為一個開放集合,且 是一個光滑函數。令 。令 為 在點 的梯度。令 為函數 在點 的 海森矩陣。令 為 個 的排序好的特徵值,並令 為對應到 的單位特徵向量。(在此,假設所有特徵值是相異的)
點 在一維的脊上若:
- 且
- for .
這精確地限制了 在特定的 維中在點 有局部最大值。
這樣的定義很自然的可以被推廣到成k維的脊,一個點 在k維脊上若
- 且
- for .
最大尺度脊
參見
參考資料