- 相關推薦
基于最小二乘修正的隨機Hough變換直線檢測
摘要:利用Hough變換進行直線檢測時,由于直線在參數空間中的映射容易受到鄰近目標、噪聲以及本身非理想狀態的干擾,算法中的投票過程較易出現無效累積,進而導致虛檢、漏檢及端點定位不準等問題。針對傳統方法的上述缺陷,提出了一種基于ρθ域最小二乘擬合修正的隨機Hough變換的直線檢測方法。首先, 在隨機抽樣時利用像素-長度比值對抽樣的有效性進行判定,剔除不在直線上的抽樣點對;然后, 對鄰域相關點進行ρθ域的最小二乘擬合,得到修正后的直線參數用于累加投票,投票過程中設定累加閾值,通過檢測峰值點逐次檢出疑似長直線;最后, 通過設定斷裂閾值對每條長直線進行篩選和分段,定位出直線段的端點。仿真實驗表明,所提方法在投票時有效抑制了復雜環境對局部最大值的干擾,使直線檢測的準確率得到顯著提升。
關鍵詞:直線檢測;隨機Hough變換;最小二乘法;參數空間;投票有效性
引言
在圖像處理和計算機視覺領域,目標識別是一個重要的課題,而直線的檢測又是其中最為基本的內容之一。直線檢測之前通常需要對圖像進行預處理,如去噪、增強、分割、邊緣檢測等,將圖像轉換為只包含邊緣信息的二值圖像再進行直線檢測[1-2]。圖像直線檢測的難點在于,既要正確捕獲直線目標,又要保證一定的寬容度以適應非理想直線的情形。
Hough變換(Hough Transform, HT)是處理直線檢測問題的一種經典算法,在諸多領域得到了廣泛應用[3-5]。它的主要思想是,在參數空間的離散化網格中,利用“多對一”映射將各個像素點映射到參數空間,然后通過累加“投票”得到共線的像素點在參數空間的映射,進而得到圖像中直線的參數。這種方法為在參數域進行直線檢測提供了新的思路,但實際應用中由于非理想直線和復雜場景干擾,效果不佳。一方面圖像中的潛在直線往往因為噪聲的干擾而偏離理想狀態,出現諸如局部彎曲或斷裂的現象,參數空間峰值點不容易被檢測到,導致漏檢;另一方面,潛在直線周邊的其他非直線目標像素的存在,使參數空間相應位置出現偽峰,導致虛檢。
利用較小采樣集合代替全點集的改進方法取得了較好的效果,最早且有代表性的是Xu等[6]的隨機Hough變換(Randomized Hough Transform, RHT)和Kiryati等[7]的概率Hough變換(Probabilistic Hough Transform, PHT),但因全局采樣而引入大量無效累積,復雜場景效果不佳。毛俊勇等[8]在所建立的點屬于某直線上不確定性度量概率模型基礎上,根據隨機選擇的兩點間直線參數,按照Bayesian法則用基于不確定度量的參數空間軟投票,但檢測算法的分辨率受到度量模型和投票網格的限制。Ji等[9]引入局部增強算子,通過增加參數空間中直線峰值和噪聲之間的差異,得到更準確的局部最大值,但累加過程仍然基于標準Hough變換(Standard Hough Transform, SHT),需要全局計算,效率不高。王競雪等[10]在Hough變換前采用相位編組(Phase Grouping)方法進行邊緣跟蹤,降低了直線間干擾,但對多條直線相交的等復雜連通情形效果不理想。Lee等[11]和Chung等[12]采用多參數的離散Hough變換,在孤立直線檢測中比SHT具有更高檢測率,但多參數的引入導致了較大計算量。
RHT隨機選取點對,避免了傳統Hough變換“多對一”映射的缺陷,卻使得累積具有很大的盲目性,而且噪聲和互相干擾使得參數計算精度受到影響;诖,本文提出了一種在參數空間進行最小二乘修正的隨機Hough變換方法。首先進行邊緣點隨機抽樣,對抽樣兩點之間是否可能存在直線進行判斷并篩選; 然后對其所有鄰域相關點進行ρθ域的最小二乘擬合,根據修正后的直線參數在累加網格進行累加,通過搜索累加最大值計算得到檢測直線參數; 最后通過斷裂-尺度閾值定位出線段的端點,完成直線段的檢測。這種方法有效地減少了隨機Hough變換的無效累加,提高了累加效率,并避免了在參數空間累加網格中搜索局部最大值的過程,有效減少了直線檢測的誤檢和漏檢,得到定位準確的直線段。
一、基于最小二乘修正的RHT算法
1.1隨機Hough變換
Hough變換是一種經典的利用參數空間的累加統計來完成圖像空間檢測任務的方法。它將圖像xy空間的點映射為參數ρθ空間的一條曲線,而將圖像空間的一條給定形狀的曲線映射為參數空間的一個點,圖像空間曲線上的點在參數空間的像經過累加,就得到了一個累加權值較高的點,反向映射得到前面所述的圖像空間的曲線。
Hough變換的基本原理如圖1所示,設L是圖像空間的直線,在圖像空間直角坐標系下的方程為:
ρ=x cos θ+y sin θ(1)
式中:ρ為直角坐標系原點到直線L的距離,θ為直線L與y軸的夾角。點P(θ, ρ)就是直線L在參數ρθ空間的映射。標準的Hough變換針對每個前景像素進行映射,其計算復雜度比較高,不適合實時處理。因此,一種基于概率統計的隨機Hough變換開始應用于數字圖像處理領域。
圖片
圖1直線在參數空間的映射
隨機Hough變換(RHT)的基本思想是在圖像空間的前景像素(通常為邊緣點)中隨機選取兩個點,將通過這兩點的直線映射到參數空間。通過這種多到一的映射,RHT避免了標準Hough變換(SHT)中一到多映射所需的龐大計算量。
設邊緣像素點集Γ={P(x,y)},從中隨機選取兩個相異點P1(x1,y1)、P2(x2,y2),得到通過這兩點的唯一直線L12,且其參數可依次由式(2)、(3)計算得到。
θ12=tan-1y1-y2x2-x1(2
ρ12=y1+y22 sin θ12+x1+x22 cos θ12(3 將該組參數(θ12, ρ12)作為索引進行累加,即令該參數所屬的網格的累加值遞加一。經過一定數目的累加之后,在網格累加值中搜索局部最大值,這些網格的參數(θmax, ρmax)對應的直線就構成了一個直線集合,它包含但不限于實際圖像中的直線L,需要進行進一步篩選。
點集Γ中的邊緣點Pk到該直線L的距離為:
disk=ρ-xk cos θ-yk sin θ(4
通過判斷點到直線的距離是否小于某一閾值δ,距離小于該閾值的點就認為從屬于該直線L,構成集合ΓL,如圖2所示。另外,事先確定一個數目門限Nth,如果點集內的點的個數大于Nth,則直線L是實際直線;否則不為實際直線,將其排除。這樣就能判斷直線L在距離閾值δ下是否實際存在。排除后剩余的直線就是RHT檢測到的直線。
圖片
圖2通過δ閾值篩選直線示意圖
傳統的RHT有效降低了傳統HT的計算復雜度,但仍然存在無效累積的問題,給ρθ域的局部最大值搜索帶來較大噪聲,在復雜場景下易檢測出虛假直線目標,或漏檢實際直線目標。
1.2ρθ域的最小二乘擬合
傳統的RHT方法為克服虛檢、漏檢提供了思路,本文在RHT基礎上利用距離閾值中的點進行參數域的最小二乘修正。
最小二乘法(Least Square Method, LSM)是一種經典的優化手段。傳統的最小二乘直線擬合采用直線的斜率和截距兩個參數,優化的目標函數是觀測點到直線豎直距離的二次方,亦即y方向上坐標差值的二次方,這使得優化過程嚴重依賴坐標系。因此本文采用在參數域的直接最小二乘擬合。
圖像空間的直線L可由式(1)表示,對于空間一點Pk(xk,yk),Pi到直線L的距離可以由式(4)表示。于是,基于最小二乘準則的直線擬合也可描述為以下約束優化問題:
min f=∑nk=1(ρ-yk sin θ-xk cos θ)2(5)
s.t. -π/2 < θ ≤ π/2
或其等效約束優化問題:
min g(a,b,c)=∑nk=1(axk+byk+c)2(6)
s.t. a2+b2=1
式(5)所描述的優化問題,其優化函數是一個擬凸函數,在非邊界處有全局最小值,因此求偏導化簡可得:
tan (2θop)=2∑ni=1∑nj=1xiyj-n∑ni=1xiyi∑ni=1∑nj=1(xixj-yiyj)-n∑ni=1(x2i-y2i)
ρop=1nsin θop∑ni=1yi+cos θop∑ni=1xi
f(θop,ρop)≤f(θ,ρ)
-π/2< θop <π/2(7)
式中:θop、 ρop為最優解; n為參與擬合的樣本點個數。
實際求解過程中會遇到反正切函數值對應多解的問題。解決方法是先將可能的兩組最優θop求解出來,再代入優化函數通過判斷f是否達到最小來得到唯一的最優解。
這里對1.1節得到δ鄰域點集ΓL中所有點在參數域進行最小二乘擬合,通過求解降低偏差較大噪聲點的干擾,得到較為準確的直線參數參與投票。
1.3提出的直線檢測算法流程
正如第1.1節所述,標準RHT在參數累加時,不考慮參數的有效性,將通過兩個沒有關聯的點的直線參數作為一次累加,這樣既降低了累加的效率,同時也給ρθ域的局部最大值搜索引入噪聲。
本文在標準RHT的基礎上,在累加之前通過兩點連線的鄰域內點的密度判斷當前累加參數的有效性,并通過ρθ域的最小二乘擬合鄰域內點得到累加參數。當累加網格的最大值等于累加閾值時,記錄這個最大值并根據網格分辨率解算出一條直線,將這條直線從圖像中去除,然后重新進行累加。這個過程重復直到某次有效累加達到最大累加次數或者無效累加達到最大失敗次數為止。
將本文方法與標準Hough變換(SHT)在參數域的比較映射結果。圖3(a)是包含兩條非理想直線的二值圖像。圖3(b)、(c)分別是標準Hough變換及本文方法的參數域映射。圖3(d)~(f)是(a)中添加了短線噪聲之后的相應結果。標準Hough變換映射的峰有明顯的“拖尾”,且隨著短線噪聲的加入更加顯著,甚至出現了多個偽峰。而提出的方法映射的峰能量集中,即使增加短線噪聲干擾也沒有“拖尾”和偽峰出現。這與前面所作的理論分析結論相一致。可以看出,提出方法的累積修正對提高參數域的局部最大值搜索精度,進而降低直線檢測虛檢、漏檢率,有重大意義。
假設已給定累加閾值Amax、最大累加次數Nmax和最大失敗次數Fmax,以及直線寬容度閾值(距離閾值)δ和連線內點比例閾值Pth,則算法的詳細步驟為:
步驟1初始化累加網格,累加次數n和失敗次數f置零。
步驟2從二值圖像所有邊緣點中隨機抽取兩個。
步驟3考查選取的兩點間連線的δ鄰域內邊緣點個數與兩點之間距離的比值: 若比值大于Pth,則累加次數n加1并跳到步驟4; 否則失敗次數f加1,跳到步驟5。
步驟4對δ鄰域內所有點進行最小二乘擬合,計算直線參數 (ρ,θ),并將其對應的網格累加值加1。若累加網格的最大值等于Amax,則記錄直線參數,并直線δ鄰域內邊緣點從邊緣點集合去除,跳到步驟1;否則,繼續步驟5。
步驟5若累加次數n等于Nmax或失敗次數f等于Fmax,則算法結束。
二、斷裂尺度閾值定位線段
改進的RHT得到的是若干條長直線貫穿整幅圖像。實際應用中,定位出具體直線段的兩個端點才具有更大的實用價值。本文提出用斷裂尺度閾值來獲取直線端點的位置。
將檢測到的長直線δ鄰域內的邊緣點垂直投影到直線上,計算出投影點在直線上的相對位置,并按這個位置將邊緣點進行排序。根據設定的斷裂閾值Thgap和最短尺度閾值Thseg,先利用相對位置間隔大于Thgap的條件,將鄰域邊緣點劃分到幾條直線段中,然后將線段長度低于Thseg的線段作為短線噪聲剔除。
經過斷裂尺度閾值分段的直線段,既能避免因引入短線噪聲而出現虛假線段,也有較好的抗斷裂性能,防止出現過分割。
三、仿真實驗結果
3.1檢測結果評價指標
為了對實驗結果進行量化,需要確定具體評價指標。本文采用漏檢率和虛檢率表征檢測準確度。
假設實驗原圖中有Nr條直線段,經過檢測,得到的Nd條標注,漏檢記為Nm條,虛檢記為Ne條,規定如下:
1)對于一條標注,標注直線段與原直線段走向大于2°的,或夾角小于等于2°但標注線段被原直線段覆蓋長度小于50%,認為錯檢(虛檢),Ne加1;
2)對于一條原始直線段,原直線段與標注直線段走向大于2°的,或夾角小于等于2°但標注線段共同覆蓋原直線段長度小于80%,認為漏檢,Nm加1。
于是仿真實驗的漏檢率ηm和虛檢率ηe可以分別定義為:
ηm=Nm/Nr
ηe=Ne/Nd (8
直線檢測結果的精度可用上述指標進行衡量,漏檢率和虛檢率越低,直線檢測的精度越高。
3.2結果和評價
圖4(a)是一幅512×512像素的仿真圖像,其中有13條長短不同且部分存在相交、平行或共線的近似直線段,同時添加40條隨機短線噪聲。
圖片
圖4仿真實驗結果
對仿真圖像分別采用標準Hough變換、隨機Hough變換和本文方法進行直線提取,其中直線斷裂閾值設為20像素,最短檢測直線閾值設為30像素。圖中檢測到的直線段兩端分別用“×”符號表示。
對比采用同樣參數設置的三組結果,圖4 (b)標準Hough變換的檢測結果有顯著漏檢產生,主要集中于直線較短或彎折較為明顯的地方,即使檢測到的直線段,也存在端點定位不準的情況。SHT對于尺度較小的直線目標檢測性能較差,并且易受到直線彎折、短線噪聲等的影響。
圖4(c)隨機Hough變換的直線虛檢率略有上升,但漏檢率明顯低于標準Hough變換,原圖的每條線段目標都能被部分檢出;但線段的端點仍然不夠準確,而且存在同一線段目標被檢出為多條斷開短線目標,這些問題在右側平行線處尤其顯著。這組結果表明,RHT雖然在漏檢性能上優于SHT,但難以解決鄰近平行線目標和直線段目標過度分段問題。
圖4(d)本文方法精確檢出原圖存在的每條直線,沒有出現虛檢漏檢的情況,并且每條直線段的端點定位準確,尤其在面對右側兩組平行線交叉這種復雜的情況時,仍然沒有出現SHT、RHT存在的漏檢、虛檢、過度分段等問題,保持了優異的檢測性能。
檢測結果的漏檢虛檢指標如表1所示。
繼續探究三種方法在不同噪聲條件下的檢測性能。仍然采用上述直線,但隨機添加不同數目的短線噪聲,依次得到圖5中兩種指標的變化曲線。從圖中可以看出,三種方法的檢測準確度大體上隨著短線擾動數目的增加而下降;對比已有兩種算法,SHT的抗虛檢性能較好而RHT的抗漏檢性能較好,并且兩種方法都隨噪聲變化出現較大波動;本文方法在漏檢、虛檢性能方面都是要優于兩種已有算法的,并且其檢測性能并沒有隨噪聲的變化發生明顯波動,有著較好的穩定性和魯棒性。
圖片
圖5在不同短線噪聲影響下的檢測結果
四、結語
本文提出通過參數域的最小二乘修正來改進隨機Hough變換直線檢測:直接在參數空間引入最小二乘擬合方法,并對隨機Hough變換的投票步驟提出改進,最后在提取長直線的基礎上引入斷裂尺度閾值確定線段端點。
仿真圖像的直線提取實驗可以證明,本文提出的基于最小二乘估計修正改進的隨機Hough算法可以有效地改進標準Hough變換以及隨機Hough變換的固有缺陷。經過有效性篩選和最小二乘擬合之后的累加效率更高,噪聲像素和鄰近直線像素的干擾更小,虛檢率和漏檢率顯著降低;同時,對直線形變的寬容度更好,直線端點的定位性能更加優越。
參考文獻:
[1]DONG J, YANG X, YU Q. Fast line segment detection based on edge connection[J]. Acta Optica Sinica, 2013, 33(3):213-220. (董晶, 楊夏, 于起峰. 基于邊緣連接的快速直線段檢測算法[J]. 光學學報, 2013, 33(3):213-220.)
【基于最小二乘修正的隨機Hough變換直線檢測】相關文章:
基于HOUGH變換的雷達圖像圓檢測03-07
基于最小二乘模型的Bayes參數辨識方法03-07
基于小波變換的諧波檢測法03-28
基于FPGA的快速傅立葉變換03-19
基于自相關平方函數與小波變換結合的帶噪語音基音檢測03-07
基于最小因子定律的時間營銷法03-24
基于IHS變換的遙感影像融合方法研究11-22
一種基于小波變換的二級簽名認證方法03-07