衡阳派盒市场营销有限公司

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何用40行代碼實(shí)現(xiàn)人臉識別?

悟空智能科技 ? 來源:未知 ? 作者:胡薇 ? 2018-07-15 09:16 ? 次閱讀

闖紅燈這件事情,一直是交通問題的一大頭疼病。自從交通法對機(jī)動車闖紅燈進(jìn)行扣 6 分的舉措后,很多司機(jī)朋友們紛紛表示不敢怠慢了。機(jī)動車好了,可是非機(jī)動車和行人闖紅燈的病咋治?當(dāng)中國式過馬路已經(jīng)深入人心的時候,這不,黑科技來了,乍一看還真的很像警方在搜捕嫌疑人。

近期山東、江蘇、深圳等一些城市開始在交通路口上啟用了人臉識別系統(tǒng),針對行人和非機(jī)動車闖紅燈等違規(guī)行為進(jìn)行抓拍,并現(xiàn)場進(jìn)行曝光。而對于行人和非機(jī)動車闖紅燈的行為,交管部門將會給予 20 元到 50 元的罰款。

雖然罰款錢數(shù)不多,但是最讓大家忌憚的就是,你不文明行為的視頻和你的個人信息,都會在大屏幕上全天輪次播放。交警叔叔說了,被拍的市民紛紛表示下次再也不敢闖紅燈了。

人臉抓拍系統(tǒng)的工作原理是:當(dāng)紅燈亮起后,如有行人和非機(jī)動車越過停止線,系統(tǒng)會自動抓拍四張照片,保留 15 秒視頻并截取違法者頭像,即便在晚上也能清晰成像。除了現(xiàn)場回放,交管部門還將連接的戶籍信息進(jìn)行曝光。

人臉識別技術(shù)到底是怎樣實(shí)現(xiàn)的呢?

很多人都認(rèn)為人臉識別是一項非常難以實(shí)現(xiàn)的工作,看到名字就害怕,然后心懷忐忑到網(wǎng)上一搜,看到網(wǎng)上 N 頁的教程立馬就放棄了。

這些人里包括曾經(jīng)的我自己。其實(shí)如果如果你不是非要深究其中的原理,只是要實(shí)現(xiàn)這一工作的話,人臉識別也沒那么難。

今天我們就來看看如何在 40 行代碼以內(nèi)簡單地實(shí)現(xiàn)人臉識別。

一點(diǎn)區(qū)分

對于大部分人來說,區(qū)分人臉檢測和人臉識別完全不是問題。但是網(wǎng)上有很多教程有意無意地把人臉檢測說成是人臉識別,誤導(dǎo)群眾,造成一些人認(rèn)為二者是相同的。

其實(shí),人臉檢測解決的問題是確定一張圖上有木有人臉,而人臉識別解決的問題是這個臉是誰的。可以說人臉檢測是是人識別的前期工作。

今天我們要做的是人臉識別。

所用工具

Anaconda 2 —— Python 2

Dlib

scikit-image

Dlib

對于今天要用到的主要工具,還是有必要多說幾句的。Dlib 是基于現(xiàn)代 C++ 的一個跨平臺通用的框架,作者非常勤奮,一直在保持更新。

Dlib 內(nèi)容涵蓋機(jī)器學(xué)習(xí)、圖像處理、數(shù)值算法、數(shù)據(jù)壓縮等等,涉獵甚廣。更重要的是,Dlib 的文檔非常完善,例子非常豐富。就像很多庫一樣,Dlib 也提供了 Python 的接口,安裝非常簡單,用 pip 只需要一句即可:

pipinstalldlib

上面需要用到的 scikit-image 同樣只是需要這么一句:

pipinstallscikit-image

注:如果用 pip install dlib 安裝失敗的話,那安裝起來就比較麻煩了。錯誤提示很詳細(xì),按照錯誤提示一步步走就行了。

人臉識別

之所以用 Dlib 來實(shí)現(xiàn)人臉識別,是因?yàn)樗呀?jīng)替我們做好了絕大部分的工作,我們只需要去調(diào)用就行了。Dlib 里面有人臉檢測器,有訓(xùn)練好的人臉關(guān)鍵點(diǎn)檢測器,也有訓(xùn)練好的人臉識別模型。

今天我們主要目的是實(shí)現(xiàn),而不是深究原理。例子既然代碼不超過 40 行,其實(shí)是沒啥難度的。

首先先通過文件樹看一下今天需要用到的代碼:

準(zhǔn)備了六個候選人的圖片放在 candidate-faces 文件夾中,然后需要識別的人臉圖片 test.jpg 。我們的工作就是要檢測到 test.jpg 中的人臉,然后判斷她到底是候選人中的誰。

另外的 girl-face-rec.py 是我們的 python 腳本。

shape_predictor_68_face_landmarks.dat 是已經(jīng)訓(xùn)練好的人臉關(guān)鍵點(diǎn)檢測器。

dlib_face_recognition_resnet_model_v1.dat 是訓(xùn)練好的 ResNet 人臉識別模型。

ResNet 是何凱明在微軟的時候提出的深度殘差網(wǎng)絡(luò),獲得了 ImageNet 2015 冠軍,通過讓網(wǎng)絡(luò)對殘差進(jìn)行學(xué)習(xí),在深度和精度上做到了比 CNN 更加強(qiáng)大。

前期準(zhǔn)備

shape_predictor_68_face_landmarks.dat dlib_face_recognition_resnet_model_v1.dat 都可以在這里找到。

不能點(diǎn)擊超鏈接的可以直接輸入以下網(wǎng)址:http://dlib.net/files/。

然后準(zhǔn)備幾個人的人臉圖片作為候選人臉,最好是正臉。放到 candidate-faces 文件夾中。

本文這里準(zhǔn)備的是六張圖片,如下:

她們分別是:

然后準(zhǔn)備四張需要識別的人臉圖像,其實(shí)一張就夠了,這里只是要看看不同的情況:

可以看到前兩張和候選文件中的本人看起來還是差別不小的,第三張是候選人中的原圖,第四張圖片微微側(cè)臉,而且右側(cè)有陰影。

識別流程

數(shù)據(jù)準(zhǔn)備完畢,接下來就是代碼了。識別的大致流程是這樣的:

先對候選人進(jìn)行人臉檢測、關(guān)鍵點(diǎn)提取、描述子生成后,把候選人描述子保存起來。

然后對測試人臉進(jìn)行人臉檢測、關(guān)鍵點(diǎn)提取、描述子生成。

最后求測試圖像人臉描述子和候選人臉描述子之間的歐氏距離,距離最小者判定為同一個人。

代碼

代碼不做過多解釋,因?yàn)橐呀?jīng)注釋的非常完善了。以下是 girl-face-rec.py:

#-*-coding:UTF-8-*-

importsys,os,dlib,glob,numpy

fromskimageimportio

iflen(sys.argv)!=5:

print"請檢查參數(shù)是否正確"

exit()

#1.人臉關(guān)鍵點(diǎn)檢測器

predictor_path=sys.argv[1]

#2.人臉識別模型

face_rec_model_path=sys.argv[2]

#3.候選人臉文件夾

faces_folder_path=sys.argv[3]

#4.需識別的人臉

img_path=sys.argv[4]

#1.加載正臉檢測器

detector=dlib.get_frontal_face_detector()

#2.加載人臉關(guān)鍵點(diǎn)檢測器

sp=dlib.shape_predictor(predictor_path)

#3.加載人臉識別模型

facerec=dlib.face_recognition_model_v1(face_rec_model_path)

#win=dlib.image_window()

#候選人臉描述子list

descriptors=[]

#對文件夾下的每一個人臉進(jìn)行:

#1.人臉檢測

#2.關(guān)鍵點(diǎn)檢測

#3.描述子提取

forfinglob.glob(os.path.join(faces_folder_path,"*.jpg")):

print("Processingfile:{}".format(f))

img=io.imread(f)

#win.clear_overlay()

#win.set_image(img)

#1.人臉檢測

dets=detector(img,1)

print("Numberoffacesdetected:{}".format(len(dets)))

fork,dinenumerate(dets):

#2.關(guān)鍵點(diǎn)檢測

shape=sp(img,d)

#畫出人臉區(qū)域和和關(guān)鍵點(diǎn)

#win.clear_overlay()

#win.add_overlay(d)

#win.add_overlay(shape)

#3.描述子提取,128D向量

face_descriptor=facerec.compute_face_descriptor(img,shape)

#轉(zhuǎn)換為numpyarray

v=numpy.array(face_descriptor)

descriptors.append(v)

#對需識別人臉進(jìn)行同樣處理

#提取描述子,不再注釋

img=io.imread(img_path)

dets=detector(img,1)

dist=[]

fork,dinenumerate(dets):

shape=sp(img,d)

face_descriptor=facerec.compute_face_descriptor(img,shape)

d_test=numpy.array(face_descriptor)

#計算歐式距離

foriindescriptors:

dist_=numpy.linalg.norm(i-d_test)

dist.append(dist_)

#候選人名單

candidate=['Unknown1','Unknown2','Shishi','Unknown4','Bingbing','Feifei']

#候選人和距離組成一個dict

c_d=dict(zip(candidate,dist))

cd_sorted=sorted(c_d.iteritems(),key=lambdad:d[1])

print" Thepersonis:",cd_sorted[0][0]

dlib.hit_enter_to_continue()

運(yùn)行結(jié)果

我們在 .py 所在的文件夾下打開命令行。運(yùn)行如下命令:

python girl-face-rec.py 1.dat 2.dat ./candidate-faecs test1.jpg

由于shape_predictor_68_face_landmarks.dat 和 dlib_face_recognition_resnet_model_v1.dat 名字實(shí)在太長,所以我把它們重命名為 1.dat 和 2.dat 。

運(yùn)行結(jié)果如下:

The person is Bingbing。

記憶力不好的同學(xué)可以翻上去看看 test1.jpg 是誰的圖片。有興趣的話可以把四張測試圖片都運(yùn)行下試試。

這里需要說明的是,前三張圖輸出結(jié)果都是非常理想的。但是第四張測試圖片的輸出結(jié)果是候選人 4。對比一下兩張圖片可以很容易發(fā)現(xiàn)混淆的原因。

機(jī)器畢竟不是人,機(jī)器的智能還需要人來提升。

有興趣的朋友可以繼續(xù)深入研究如何提升識別的準(zhǔn)確率。比如每個人的候選圖片用多張,然后對比和每個人距離的平均值之類的,全憑自己了。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 人臉識別
    +關(guān)注

    關(guān)注

    76

    文章

    4015

    瀏覽量

    82309

原文標(biāo)題:【干貨】40行代碼,揭秘人臉識別技術(shù)

文章出處:【微信號:WUKOOAI,微信公眾號:悟空智能科技】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    人臉識別

    注冊username和人臉圖片,您可以使用這個功能自己實(shí)現(xiàn)一個小規(guī)模的人臉識別系統(tǒng),比如明星臉識別、家庭成員
    發(fā)表于 02-22 12:09

    LabVIEW人臉識別設(shè)計

    系統(tǒng)與試卷,公布綜合成績3、挑戰(zhàn)成功學(xué)員在3-5個工作日之內(nèi)即可收到退款【課程介紹】本課程主要以LabVIEW視覺和第三方開源深度學(xué)習(xí)庫,實(shí)現(xiàn)人臉識別功能。人臉
    發(fā)表于 04-28 10:00

    Python的face_regcognition包做人臉識別

    代碼人臉識別:初學(xué)face_recognition
    發(fā)表于 03-11 07:50

    S32V視覺處理平臺怎么實(shí)現(xiàn)人臉識別的應(yīng)用?

    汽車行業(yè)ADAS功能需求日益增長,防疲勞駕駛是一個熱門方向,對于駕駛員狀態(tài)的檢測,人臉識別是基礎(chǔ),只有快速準(zhǔn)確地識別人臉,才能對人臉狀態(tài)進(jìn)
    發(fā)表于 11-26 06:36

    人臉識別的全部源代碼

    Google Glass-- 谷歌眼鏡核心源碼人臉識別的全部源代碼(在Visual C++6.0下可以運(yùn)行識別)l智能分析接口(支持車牌識別
    發(fā)表于 08-06 07:21

    在嵌入式開發(fā)板上如何用opencv調(diào)用caffe模型進(jìn)行人臉識別并截圖呢

    在嵌入式開發(fā)板上如何用opencv調(diào)用caffe模型進(jìn)行人臉識別并截圖呢?其代碼該如何去實(shí)現(xiàn)呢?
    發(fā)表于 12-27 06:56

    RV1126基于虹軟人臉識別算法實(shí)現(xiàn)指南

    1、RV1126基于虹軟人臉識別算法實(shí)現(xiàn)的示例使用教程示例(rkmedia_vi_arc_rtsp_test.cc) 使用 CORE-1126-JD4 配套的 os04a10 攝像頭進(jìn)行人臉
    發(fā)表于 06-08 15:51

    人臉識別C/C++源代碼

    人臉識別C/C++源代碼 將生物特征識別應(yīng)用于人臉,實(shí)際上是包含兩個方面:第一,從圖像或視頻幀中檢測
    發(fā)表于 02-09 16:05 ?184次下載

    基于matlab的簡單人臉識別程序代碼

    基于matlab的簡單人臉識別程序代碼,大家有需要的,選擇性下載~~
    發(fā)表于 11-13 14:13 ?0次下載

    人臉識別沒那么難,1命令就能實(shí)現(xiàn)

    現(xiàn)在人臉識別那么火,各大手機(jī)廠商也是爭先在自己的手機(jī)上加入這種技術(shù)。那么,人臉識別技術(shù)真的很難嗎,其實(shí)不是的。下面告訴你如何用1
    發(fā)表于 10-27 16:13 ?2719次閱讀
    <b class='flag-5'>人臉</b><b class='flag-5'>識別</b>沒那么難,1<b class='flag-5'>行</b>命令就能<b class='flag-5'>實(shí)現(xiàn)</b>

    用dlib實(shí)現(xiàn)人臉識別的技巧

    很多人都認(rèn)為人臉識別是一項非常難以實(shí)現(xiàn)的工作,看到名字就害怕,然后心懷忐忑到網(wǎng)上一搜,看到網(wǎng)上N頁的教程立馬就放棄了。這些人里包括曾經(jīng)的我自己。其實(shí)如果如果你不是非要深究其中的原理,只是要實(shí)現(xiàn)
    的頭像 發(fā)表于 11-01 16:45 ?2.7w次閱讀

    人臉識別技術(shù)原理與實(shí)現(xiàn)方式

    隨著大數(shù)據(jù)時代的到來,“人臉”也將成為數(shù)據(jù)的一部分,人臉識別如何實(shí)現(xiàn)?本文將為大家從人臉檢測、人臉
    發(fā)表于 02-05 11:16 ?2w次閱讀
    <b class='flag-5'>人臉</b><b class='flag-5'>識別</b>技術(shù)原理與<b class='flag-5'>實(shí)現(xiàn)</b>方式

    什么是人臉識別?如何使用10代碼實(shí)現(xiàn)人臉識別

    人臉識別,是基于人的臉部特征信息進(jìn)行身份識別的一種生物識別技術(shù)。用攝像機(jī)或攝像頭采集含有人臉的圖像或視頻流,并自動在圖像中檢測和跟蹤
    的頭像 發(fā)表于 04-06 12:17 ?5501次閱讀

    人臉識別是什么_人臉識別技術(shù)原理

    人臉識別是什么,人臉識別技術(shù)原理是如何的,它又是若何一步步實(shí)現(xiàn)的,人臉
    發(fā)表于 09-27 15:49 ?6084次閱讀
    <b class='flag-5'>人臉</b><b class='flag-5'>識別</b>是什么_<b class='flag-5'>人臉</b><b class='flag-5'>識別</b>技術(shù)原理

    基于python代碼人臉識別實(shí)例

    基于python代碼的一個人臉識別的實(shí)例,完整的實(shí)例,本人在pycharm中實(shí)測通過,是一個很基礎(chǔ)的入門級的人臉檢測和識別
    發(fā)表于 07-18 11:11 ?13次下載
    KK百家乐的玩法技巧和规则| 百家乐官网隔一数打法| 百家乐官网官网7scs| 包赢百家乐的玩法技巧和规则| 大发888移动版| 百家乐官网概率投注| 金字塔百家乐官网的玩法技巧和规则 | 百家乐官网家| 德州扑克发牌| 免费百家乐官网倍投软件| 大发888官网客服| 网上百家乐官网假| 大发888平台下载| 真人百家乐官网赌法| 罗马百家乐的玩法技巧和规则| 百家乐官网视频游365| 百家乐玩法开户彩公司| 甘肃省| 网上百家乐官网解密| 云鼎娱乐城优惠| 新时代百家乐官网的玩法技巧和规则 | 香港六合彩特码开奖结果| 2024年九运的房屋风水| 云顶国际平台| 新百家乐官网的玩法技巧和规则 | 百家乐筹码盒| 真人百家乐官网打法| 威尼斯人娱乐城网上赌博| 百家乐官网2号机器投注技巧| 威尼斯人娱乐城澳门威| 百家乐官网娱乐真人娱乐| 博彩e族777| 大发百家乐现金网| 百家乐官网平台开发| 泰山百家乐的玩法技巧和规则 | 新全讯网a3322.com| G3百家乐官网的玩法技巧和规则 | 百家乐注册赠金| 金道百家乐官网游戏| 澳门百家乐骗人| 皇冠百家乐官网在线游戏|