使用Python+OpenCV進(jìn)行圖像處理(三)
角點(diǎn)檢測(cè)(Corner Detection)
角點(diǎn)檢測(cè)是另一種廣泛應(yīng)用于目標(biāo)檢測(cè)、運(yùn)動(dòng)檢測(cè)、視頻目標(biāo)追蹤等領(lǐng)域的檢測(cè)算法。圖像處理中的角是什么?應(yīng)該如何定義?在這里,我們把角看作是邊相交的連接點(diǎn)。那我們?cè)趺床拍苷业剿麄兡兀?你可能會(huì)想到一個(gè)最基礎(chǔ)的方式是先找到所有的邊,然后找到它們相交的點(diǎn)。但實(shí)際上,還有另一種更高效的方法確認(rèn)角點(diǎn)提高效率的方法,即Harris角點(diǎn)檢測(cè)和Shi&Tomasi角點(diǎn)檢測(cè)。接下來(lái)讓我們來(lái)詳細(xì)了解這兩種算法。
這兩種算法的工作原理如下。首先,檢測(cè)出各個(gè)方向上像素強(qiáng)度值有很大變化的點(diǎn)。然后構(gòu)造一個(gè)矩陣,從中提取特征值。通過(guò)這些特征值進(jìn)行評(píng)分從而決定它是否是一個(gè)角。數(shù)學(xué)表達(dá)式如下所示。
現(xiàn)在讓我們看看它們的代碼實(shí)現(xiàn)。首先,需要把圖片轉(zhuǎn)換為灰度圖。Harris角點(diǎn)檢測(cè)可以通過(guò)OpenCV中的cv2.cornerHarris()函數(shù)實(shí)現(xiàn)。
img = cv2.imread('images/desk.jpg')
img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
img_gray = cv2.cvtColor(img, cv2.COLOR_RGB2GRAY)
# Apply Harris corner detection
dst = cv2.cornerHarris(img_gray, blockSize = 2, ksize = 3, k = .04)
參數(shù)blocksize是指定領(lǐng)域窗口設(shè)定的大小,k是Harris檢測(cè)的自由參數(shù)對(duì)應(yīng)上方公式中的k值。輸出結(jié)構(gòu)為得分R,我們將使用R得分檢測(cè)角點(diǎn)。
# Spot the detected corners
img_2 = img.copy()
img_2[dst>0.01*dst.max()]=[255,0,0]
# Plot the image
plt.figure(figsize = (20, 20))
plt.subplot(1, 2, 1); plt.imshow(img)
plt.a(chǎn)xis('off')
plt.subplot(1, 2, 2); plt.imshow(img_2)
plt.a(chǎn)xis('off')
下方是Shi-Tomasi角點(diǎn)檢測(cè)的代碼實(shí)現(xiàn)。使用函數(shù)cv2.goodFeaturesToTrack()實(shí)現(xiàn)。通過(guò)maxCorners參數(shù)指定最大角點(diǎn)個(gè)數(shù)。相應(yīng)地,通過(guò)minDistance指定角點(diǎn)間的最小距離和角點(diǎn)評(píng)定的最小質(zhì)量級(jí)別。得到檢測(cè)到的角點(diǎn)后,使用圓圈標(biāo)記這些角點(diǎn),如下所示:
# Apply Shi-Tomasi corner detection
corners = cv2.goodFeaturesToTrack(img_gray, maxCorners = 50,
qualityLevel = 0.01,
minDistance = 10)
corners = np.int0(corners)
# Spot the detected corners
img_2 = img.copy(
for i in corners:
x,y = i.ravel()
cv2.circle(img_2, center = (x, y),
radius = 5, color = 255, thickness = -1)
# Plot the image
plt.figure(figsize = (20, 20))
plt.subplot(1, 2, 1); plt.imshow(img)
plt.a(chǎn)xis('off')
plt.subplot(1, 2, 2); plt.imshow(img_2)
plt.a(chǎn)xis('off')
001 (9)人臉檢測(cè)
人臉檢測(cè)是一種識(shí)別圖像中是否存在人臉以及人臉的位置的技術(shù)。人臉檢測(cè)不同于人臉識(shí)別,人臉識(shí)別是通過(guò)一個(gè)人的臉來(lái)識(shí)別這個(gè)人。 所以人臉檢測(cè)并不能告訴我們這個(gè)人臉是屬于誰(shuí)。
人臉檢測(cè)本質(zhì)上是一項(xiàng)分類(lèi)任務(wù),訓(xùn)練其分類(lèi)物體是否存在來(lái)從而實(shí)現(xiàn)檢測(cè);贖aar特征的級(jí)聯(lián)分類(lèi)器是OpenCV中常用的人臉檢測(cè)模型之一。它已經(jīng)在數(shù)千副圖像上進(jìn)行過(guò)預(yù)訓(xùn)練。理解該算法的四個(gè)關(guān)鍵點(diǎn)分別是:Haar特征提取、積分圖像、Adaboost和級(jí)聯(lián)分類(lèi)器。
類(lèi)haar特征(Haar-like features)是用于目標(biāo)檢測(cè)的數(shù)字圖像特征,示例如上圖。Haar特征這個(gè)名字來(lái)源于其與Harr小波的直觀相似性,且Haar小波最初是由Alfred Haar提出的。在檢測(cè)過(guò)程中,通過(guò)滑動(dòng)窗口和濾波器上的卷積操作來(lái)確認(rèn)這些特征是不是我們所需要的特征。如下方所示:
那么,我們具體如何來(lái)確定給定區(qū)域是否含有需要的特征呢? 如上方圖片中所示。使用一個(gè)特定卷積核(上半?yún)^(qū)域是暗的,下半?yún)^(qū)域是亮的)得到每個(gè)區(qū)域像素值的平均值,并減去兩者之間的差距。如果結(jié)果高于閾值(比如0.5),則可得出結(jié)果,其就是我們正在檢測(cè)的特征。對(duì)每個(gè)內(nèi)核重復(fù)這個(gè)過(guò)程,同時(shí)在圖像上滑動(dòng)窗口。
雖然這個(gè)計(jì)算過(guò)程并不復(fù)雜,但如果在正個(gè)圖像重復(fù)這個(gè)過(guò)程計(jì)算量還是很大的。這也是積分圖像要解決的主要問(wèn)題。積分圖像是一種圖像表示方式,它是為了提高特征估計(jì)的速度與效率而衍生出來(lái)的。
如下圖所示,左邊是原始圖像的像素值,右邊是積分圖像的像素值。從左上角開(kāi)始計(jì)算給定矩形區(qū)域下像素的累加值。在積分圖像上,將虛線(xiàn)框像素值的累加和填充在右邊框的右下角處。
使用上方這個(gè)“預(yù)計(jì)算表”,我們可以通過(guò)子矩形(上圖中紅色、橙色、藍(lán)色和紫色框)的值方便地得到某個(gè)區(qū)域的像素值總和。
所以積分圖像可以幫助我們?cè)谝欢ǔ潭壬辖鉀Q計(jì)算量過(guò)大的問(wèn)題。但還不夠,還存在著計(jì)算量?jī)?yōu)化的空間。當(dāng)檢測(cè)窗口位于沒(méi)有目標(biāo)或人臉的空白背景時(shí),執(zhí)行檢測(cè)則會(huì)耗費(fèi)不必要的計(jì)算量。這時(shí)就可以通過(guò)使用Adaboost和級(jí)聯(lián)分類(lèi)器,從而實(shí)現(xiàn)計(jì)算量進(jìn)一步優(yōu)化。
上圖展示了級(jí)聯(lián)分類(lèi)器逐步構(gòu)造的各個(gè)階段,并對(duì)類(lèi)haar特征進(jìn)行排序;咎卣鲿(huì)在早期階段被識(shí)別出來(lái),后期只識(shí)別有希望成為目標(biāo)特征的復(fù)雜特征。在每一個(gè)階段,Adaboost模型都將由集成弱分類(lèi)器進(jìn)行訓(xùn)練。如果子部件或子窗口在前一階段被分類(lèi)為“不像人臉的區(qū)域”,則將被拒絕進(jìn)入下一步。通過(guò)上述操作,只須考慮上一階段篩選出來(lái)的特征,從而實(shí)現(xiàn)更高的速度。

發(fā)表評(píng)論
登錄
手機(jī)
驗(yàn)證碼
立即登錄即可訪(fǎng)問(wèn)所有OFweek服務(wù)
還不是會(huì)員?免費(fèi)注冊(cè)
忘記密碼請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
圖片新聞
-
馬云重返一線(xiàn)督戰(zhàn),阿里重啟創(chuàng)始人模式
-
機(jī)器人奧運(yùn)會(huì)戰(zhàn)報(bào):宇樹(shù)機(jī)器人摘下首金,天工Ultra搶走首位“百米飛人”
-
存儲(chǔ)圈掐架!江波龍起訴佰維,索賠121萬(wàn)
-
長(zhǎng)安汽車(chē)母公司突然更名:從“中國(guó)長(zhǎng)安”到“辰致科技”
-
豆包前負(fù)責(zé)人喬木出軌BP后續(xù):均被辭退
-
字節(jié)AI Lab負(fù)責(zé)人李航卸任后返聘,Seed進(jìn)入調(diào)整期
-
員工持股爆雷?廣汽埃安緊急回應(yīng)
-
中國(guó)“智造”背后的「關(guān)鍵力量」
最新活動(dòng)更多
-
10月23日火熱報(bào)名中>> 2025是德科技創(chuàng)新技術(shù)峰會(huì)
-
10月23日立即報(bào)名>> Works With 開(kāi)發(fā)者大會(huì)深圳站
-
10月24日立即參評(píng)>> 【評(píng)選】維科杯·OFweek 2025(第十屆)物聯(lián)網(wǎng)行業(yè)年度評(píng)選
-
即日-11.25立即下載>>> 費(fèi)斯托白皮書(shū)《柔性:汽車(chē)生產(chǎn)未來(lái)的關(guān)鍵》
-
11月27日立即報(bào)名>> 【工程師系列】汽車(chē)電子技術(shù)在線(xiàn)大會(huì)
-
12月18日立即報(bào)名>> 【線(xiàn)下會(huì)議】OFweek 2025(第十屆)物聯(lián)網(wǎng)產(chǎn)業(yè)大會(huì)
推薦專(zhuān)題
- 1 特斯拉工人被故障機(jī)器人打成重傷,索賠3.6億
- 2 【行業(yè)深度研究】退居幕后四年后,張一鳴終于把算法公司變成AI公司?
- 3 AI 時(shí)代,阿里云想當(dāng)“安卓” ,那誰(shuí)是“蘋(píng)果”?
- 4 硬剛英偉達(dá)!華為發(fā)布全球最強(qiáng)算力超節(jié)點(diǎn)和集群
- 5 機(jī)器人9月大事件|3家國(guó)產(chǎn)機(jī)器人沖刺IPO,行業(yè)交付與融資再創(chuàng)新高!
- 6 谷歌“香蕉”爆火啟示:國(guó)產(chǎn)垂類(lèi)AI的危機(jī)還是轉(zhuǎn)機(jī)?
- 7 00后華裔女生靠?jī)刹緼I電影狂賺7.8億人民幣,AI正式進(jìn)軍好萊塢
- 8 美光:AI Capex瘋投不止,終于要拉起存儲(chǔ)超級(jí)周期了?
- 9 華為已殺入!AI領(lǐng)域最熱黃金賽道,大廠的數(shù)字人美女讓我一夜沒(méi)睡著覺(jué)
- 10 隱退4年后,張一鳴久違現(xiàn)身!互聯(lián)網(wǎng)大佬正集體殺回