溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Python中怎么利用OpenCV實(shí)現(xiàn)貓臉檢測(cè)

發(fā)布時(shí)間:2021-06-25 17:37:06 來(lái)源:億速云 閱讀:132 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

這篇文章給大家介紹Python中怎么利用OpenCV實(shí)現(xiàn)貓臉檢測(cè),內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

開(kāi)發(fā)工具

Python版本:3.6.4

相關(guān)模塊:

cv2模塊;

以及一些Python自帶的模塊。

環(huán)境搭建

安裝Python并添加到環(huán)境變量,pip安裝需要的相關(guān)模塊即可。

原理簡(jiǎn)介

簡(jiǎn)單地講一講Haar分類(lèi)器,也就是Viola-Jones識(shí)別器。

詳細(xì)的原理說(shuō)明可參考相關(guān)文件中的兩篇論文:

Rapid Object Detection using a Boosted Cascade of Simple Features;

Robust Real-Time Face Detection.

(1)Haar-like特征

Haar-like矩形特征是用于物體檢測(cè)的數(shù)字圖像特征,由兩個(gè)或者多個(gè)相鄰的黑白矩形組合而成,矩形的特征值是白色矩形的灰度值之和減去黑色矩形的灰度值之和。一般地,我們認(rèn)為矩形特征對(duì)一些簡(jiǎn)單的圖形結(jié)構(gòu)(線(xiàn)段、邊緣)等較為敏感:

Python中怎么利用OpenCV實(shí)現(xiàn)貓臉檢測(cè)

具體到貓臉檢測(cè)而言,我們認(rèn)為把這樣的矩形放到一個(gè)非貓臉區(qū)域后獲得的特征值與放到一個(gè)貓臉區(qū)域后獲得的特征值是不同的

利用上述基于特征的檢測(cè)算法,不僅能夠編碼特定區(qū)域的狀態(tài),而且效率高于基于像素的檢測(cè)算法。

(2)積分圖

下面我們來(lái)考慮一下如何計(jì)算矩形的特征值。對(duì)圖像中的任意一點(diǎn)A(x, y),定義該點(diǎn)的積分圖為其左上角的所有像素值之和,即:

Python中怎么利用OpenCV實(shí)現(xiàn)貓臉檢測(cè)

因此,要計(jì)算矩形模板的特征值,也就是計(jì)算兩個(gè)區(qū)域之間的像素和之差,只需要用特征區(qū)域端點(diǎn)的積分圖來(lái)進(jìn)行簡(jiǎn)單的加減運(yùn)算就可以了:

Python中怎么利用OpenCV實(shí)現(xiàn)貓臉檢測(cè)

(3)Haar分類(lèi)器

Haar分類(lèi)器是一個(gè)監(jiān)督學(xué)習(xí)分類(lèi)器,要進(jìn)行目標(biāo)檢測(cè),首先要對(duì)圖像進(jìn)行直方圖均衡化和歸一化處理,然后檢測(cè)里面是否包含要檢測(cè)的物體。

流程框架圖為(Haar分類(lèi)器本質(zhì)上由Haar特征提取器、離散強(qiáng)分類(lèi)器以及強(qiáng)分類(lèi)級(jí)聯(lián)器組成):

Python中怎么利用OpenCV實(shí)現(xiàn)貓臉檢測(cè)

Haar分類(lèi)器使用Adaboost算法,但是把它組織為了篩選式的級(jí)聯(lián)分類(lèi)器,在任意一級(jí)計(jì)算中,**一旦獲得輸入內(nèi)容不在檢測(cè)類(lèi)中的結(jié)論,便終止計(jì)算,只有通過(guò)所有級(jí)別的分類(lèi)器,才可認(rèn)為檢測(cè)到了目標(biāo)物體,**以此來(lái)提高檢測(cè)效率。

關(guān)于AdaBoost算法,我就不展開(kāi)介紹了,有興趣的同學(xué)可以自己查找相關(guān)資料進(jìn)行學(xué)習(xí)。以后有時(shí)間我再對(duì)其進(jìn)行詳細(xì)的介紹。

(4)適用范圍

適用于“基本剛性”的物體檢測(cè),如臉、汽車(chē)、人體和自行車(chē)等等。

(5)總結(jié)

Viola-Jones目標(biāo)檢測(cè)框架的核心思想是通過(guò)滑動(dòng)窗口掃描圖像(多尺度的掃描),然后將每個(gè)窗口的Haar特征值輸入到篩選式的級(jí)聯(lián)分類(lèi)器中來(lái)判斷該窗口內(nèi)是否含有目標(biāo)物體以實(shí)現(xiàn)目標(biāo)檢測(cè)。

具體實(shí)現(xiàn)

OpenCV中內(nèi)置了基于Viola-Jones目標(biāo)檢測(cè)框架的Haar分類(lèi)器,并提供了貓臉檢測(cè)預(yù)訓(xùn)練好的模型。因此實(shí)現(xiàn)起來(lái)十分簡(jiǎn)單。

具體實(shí)現(xiàn)過(guò)程詳見(jiàn)相關(guān)文件中的源代碼。

效果演示

使用方式:

修改源代碼中的圖片名為自己需要檢測(cè)的圖片:

Python中怎么利用OpenCV實(shí)現(xiàn)貓臉檢測(cè)

在cmd窗口運(yùn)行DetectCatFace.py文件即可。

效果:

原圖1:

Python中怎么利用OpenCV實(shí)現(xiàn)貓臉檢測(cè)

檢測(cè)結(jié)果1:

Python中怎么利用OpenCV實(shí)現(xiàn)貓臉檢測(cè)

原圖2:

Python中怎么利用OpenCV實(shí)現(xiàn)貓臉檢測(cè)

檢測(cè)結(jié)果2(并不能很好地區(qū)分狗狗和貓咪):

Python中怎么利用OpenCV實(shí)現(xiàn)貓臉檢測(cè)

關(guān)于Python中怎么利用OpenCV實(shí)現(xiàn)貓臉檢測(cè)就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI