只用opencv-python進(jìn)行人臉識(shí)別脖卖,比f(wàn)ace_recognition識(shí)別正確率高乒省!完整代碼!F枘尽袖扛!

這篇文章的話題依然是人臉識(shí)別,不過(guò)僅僅使用了opencv-python以及opencv-contrib-python這兩個(gè)包馋劈,而且就我做的測(cè)試用例來(lái)看識(shí)別的正確率比f(wàn)ace_recognition還要更高攻锰,話不多說(shuō),咱們這就開(kāi)始妓雾。

人臉檢測(cè)

要想做人臉識(shí)別娶吞,人臉檢測(cè)必須是要做的,畢竟識(shí)別也得你檢測(cè)到人臉之后才能辨別械姻。那么如何檢測(cè)到人臉呢妒蛇?提取出圖像的細(xì)節(jié)對(duì)產(chǎn)生穩(wěn)定分類結(jié)果很重要,這些提取的結(jié)果被稱為特征楷拳,專業(yè)的表述為:從圖像數(shù)據(jù)中提取特征绣夺。雖然任意像素都可以能影響多個(gè)特征,但特征應(yīng)該比像素少得多欢揖。兩個(gè)圖像的相似程度可以通過(guò)它們對(duì)應(yīng)特征的歐氏距離來(lái)度量陶耍。 Haar 特征是一種用于實(shí)現(xiàn)實(shí)時(shí)人臉跟蹤的征。每一個(gè) Haar 特征都描述了相鄰圖像區(qū)域的對(duì)比模式她混。例如烈钞,邊、頂點(diǎn)和細(xì)線都能生成具有判別性的特征坤按。獲取 Haar 特征的方法有很多種毯欣,這里我用的是安裝opencv以后opencv安裝目錄里的部分xml文件獲取的,如果你不想安裝opencv的話臭脓,也可以到文末直接下載我打包好的文件酗钞。如果你已經(jīng)安裝了opencv,找到你的安裝目錄来累,一般如下圖:


接著打開(kāi)sources/data/haarcascades文件夾砚作,你會(huì)看到下圖:

我提供的資源就是上圖所示的所有xml文件,不用再在電腦上安裝opencv了佃扼。默認(rèn)的人臉檢測(cè)器是haarcascade_frontalface_default.xml偎巢。當(dāng)然這個(gè)是可以更改的,使用的方法如下:

face_detector = cv2.CascadeClassifier('D:/OPENCV/sources/data/haarcascades/haarcascade_frontalface_default.xml')

for i in range(len(person_list)):

? ? person_name = os.listdir("faces/" + "person_" + str(i + 1))

? ? img_path = "faces/" + "person_" + str(i + 1) + "/" + person_name[0]

? ? # opencv人臉檢測(cè)

? ? PIL_img = Image.open(img_path).convert('L')

? ? img_numpy = np.array(PIL_img, 'uint8')

? ? faces = face_detector.detectMultiScale(img_numpy)

? ? #print(len(faces))

? ? for x,y,w,h in faces:

? ? ? ? face_sampes.append(img_numpy[y:y+h, x:x+w])

? ? ? ? ids.append(i + 1)

face_sampes兼耀,ids是訓(xùn)練數(shù)據(jù)用到的兩個(gè)參數(shù),face_sampes是人臉特征矩陣,ids是每個(gè)人臉對(duì)應(yīng)的id瘤运。

訓(xùn)練數(shù)據(jù)

這部分比較簡(jiǎn)單窍霞,如果有異常應(yīng)該是未安裝opencv-contrib-python導(dǎo)致的,直接上代碼了拯坟。

opencv_recognizer = cv2.face.LBPHFaceRecognizer_create()

opencv_recognizer.train(face_sampes, np.array(ids))

opencv_recognizer.write('train/train.yml')

執(zhí)行完代碼之后會(huì)在當(dāng)前目錄生成train.yml文件但金,人臉識(shí)別的時(shí)候會(huì)用到。

人臉識(shí)別

相信大家都已經(jīng)看到了我在訓(xùn)練數(shù)據(jù)時(shí)使用的代碼郁季,其中opencv_recognizer是比較重要的冷溃,當(dāng)然其實(shí)是cv2.face.LBPHFaceRecognizer_create()比較重要。這個(gè)人臉識(shí)別主要用的是LBPH算法**梦裂。它將檢測(cè)到的人臉?lè)譃樾卧普恚⑵渑c模型中的對(duì)應(yīng)單元進(jìn)行比較,對(duì)每個(gè)區(qū)域的匹配值產(chǎn)生一個(gè)直方圖年柠。由于這種方法的靈活性凿歼,LBPH是唯一允許模型樣本人臉和檢測(cè)到的人臉在形狀、大小上可以不同的人臉識(shí)別算法冗恨。具體的用法見(jiàn)以下代碼答憔。

opencv_recognizer.read('train/train.yml')

gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)

new_faces = face_detector.detectMultiScale(gray)

for x, y, w, h in new_faces:

? ? ? ? cv2.rectangle(img, (x,y), (x+w, y+h), (0, 255, 0), 2)

? ? ? ? id, confidence = opencv_recognizer.predict(gray[y:y+h, x:x+w])

? ? ? ? cv2.putText(img, face_names[id-1]+str(int(confidence)), (x + 6, y + h - 6), font, 1.0, (255, 255, 255), 1)

識(shí)別的主體在predict方法中,它的返回值一個(gè)是id掀抹,一個(gè)是置信度虐拓。id是與人臉一一對(duì)應(yīng)的,好的置信度要低于50傲武,越小越好蓉驹。高于80的置信度都是較差的。然后由于我可以根據(jù)id得到人的姓名谱轨,所以我可以直接把人名實(shí)時(shí)顯示在攝像頭視頻中戒幔,如何做到的歡迎移步這里看我的人臉照片目錄結(jié)構(gòu),謝謝大家土童。

完整代碼附上:

import cv2

import os

import numpy as np

from PIL import Image

face_detector = cv2.CascadeClassifier('D:/OPENCV/sources/data/haarcascades/haarcascade_frontalface_default.xml')

face_sampes = []

ids = []

font = cv2.FONT_HERSHEY_DUPLEX

face_names = []

person_list = os.listdir("faces/")

for i in range(len(person_list)):

? ? person_name = os.listdir("faces/" + "person_" + str(i + 1))

? ? img_path = "faces/" + "person_" + str(i + 1) + "/" + person_name[0]

? ? face_names.append(person_name[0][:person_name[0].index(".")])

? ? # opencv人臉檢測(cè)

? ? PIL_img = Image.open(img_path).convert('L')

? ? img_numpy = np.array(PIL_img, 'uint8')

? ? faces = face_detector.detectMultiScale(img_numpy)

? ? for x,y,w,h in faces:

? ? ? ? face_sampes.append(img_numpy[y:y+h, x:x+w])

? ? ? ? ids.append(i + 1)

opencv_recognizer = cv2.face.LBPHFaceRecognizer_create()

opencv_recognizer.train(face_sampes, np.array(ids))

opencv_recognizer.write('train/train.yml')

camera = cv2.VideoCapture(0)

while True:

? ? success, img = camera.read()

? ? opencv_recognizer.read('train/train.yml')

? ? gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

? ? new_faces = face_detector.detectMultiScale(gray)

? ? for x, y, w, h in new_faces:

? ? ? ? cv2.rectangle(img, (x, y), (x + w, y + h), (0, 255, 0), 2)

? ? ? ? id, confidence = opencv_recognizer.predict(gray[y:y + h, x:x + w])

? ? ? ? cv2.putText(img, face_names[id - 1] + str(int(confidence)), (x + 6, y + h - 6), font, 1.0, (255, 255, 255), 1)

? ? cv2.imshow('camera', img)

? ? cv2.waitKey(0)

? ? cv2.destroyAllWindows()


?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末诗茎,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子献汗,更是在濱河造成了極大的恐慌敢订,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,509評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件罢吃,死亡現(xiàn)場(chǎng)離奇詭異楚午,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)尿招,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)矾柜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)阱驾,“玉大人,你說(shuō)我怎么就攤上這事怪蔑±锔玻” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,875評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵缆瓣,是天一觀的道長(zhǎng)喧枷。 經(jīng)常有香客問(wèn)我,道長(zhǎng)弓坞,這世上最難降的妖魔是什么隧甚? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,441評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮渡冻,結(jié)果婚禮上戚扳,老公的妹妹穿的比我還像新娘。我一直安慰自己菩帝,他們只是感情好咖城,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著呼奢,像睡著了一般宜雀。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上握础,一...
    開(kāi)封第一講書(shū)人閱讀 51,365評(píng)論 1 302
  • 那天辐董,我揣著相機(jī)與錄音,去河邊找鬼禀综。 笑死简烘,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的定枷。 我是一名探鬼主播孤澎,決...
    沈念sama閱讀 40,190評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼欠窒!你這毒婦竟也來(lái)了覆旭?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,062評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤岖妄,失蹤者是張志新(化名)和其女友劉穎型将,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體荐虐,經(jīng)...
    沈念sama閱讀 45,500評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡七兜,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評(píng)論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了福扬。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片腕铸。...
    茶點(diǎn)故事閱讀 39,834評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡惜犀,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出恬惯,到底是詐尸還是另有隱情向拆,我是刑警寧澤亚茬,帶...
    沈念sama閱讀 35,559評(píng)論 5 345
  • 正文 年R本政府宣布酪耳,位于F島的核電站,受9級(jí)特大地震影響刹缝,放射性物質(zhì)發(fā)生泄漏碗暗。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評(píng)論 3 328
  • 文/蒙蒙 一梢夯、第九天 我趴在偏房一處隱蔽的房頂上張望言疗。 院中可真熱鬧,春花似錦颂砸、人聲如沸噪奄。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,779評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)勤篮。三九已至,卻和暖如春色罚,著一層夾襖步出監(jiān)牢的瞬間碰缔,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,912評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工戳护, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留金抡,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,958評(píng)論 2 370
  • 正文 我出身青樓腌且,卻偏偏與公主長(zhǎng)得像梗肝,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子铺董,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容