Python黑科技:50行代碼運用Python+OpenCV實現人臉追蹤
嗨,我最親愛的夥計們,很高興我們又見面了。
首先先感謝朋友們的關注。當然我更希望認識與計算機相關的領域的朋友咱們一起探討交流。重點說一下,我是真人,不是那些扒文章的自媒體組織,大家可以相互交流的!
本篇文章我們來講一下關於AI相關的人臉追蹤,人臉識別相關的一些知識。當然本篇教程為(上)部分,講一下利用python+opencv來實現人臉識別與追蹤,明後天出(下)部分,用python來通過指紋對比實現人臉驗證、人臉解鎖(大家感興趣的可以提前關注哦)。
這兩節課呢,代碼量都不是很多,鄙人盡量多注釋點,便於大家理解。那我們就不多啰嗦廢話了,直接上乾貨!
OpenCV:
opencv目前來講是十分流行的視覺庫,而且可以支持多語言。說到opencv就不得不說它的cascades分類器。
如果我們要判斷一張圖片是不是有一張臉,早期方式是通過成千上萬的分類器去從頭匹配到尾,這樣看並沒有什麼什麼毛病,但判斷的圖片多了呢?那可能需要猴年馬月。opencv的cascades呢,就把這些用來判斷人臉特徵的容器劃分成多塊層層匹配,到一層不匹配就被丟棄。
這好比一群人去公司面試,公司第一個要求是只要男人,那一批女人就走了,公司說只要本科,一批專科走了,公司說要兩年工作經驗的,又會走一批,直到最後。這樣的工作量比每個人面試不管男女都過一遍流程輕鬆的多。
環境拓撲:
操作系統:windows7
python版本:2.7.14
opencv版本:3.x
環境配置:
1.安裝python(額...這個當我沒說)
2.安裝Opencv
這個從官網下載就OK啦
下載完之後直接解壓就行,推薦解壓到跟你的python安裝的父路徑。
3.使用pip安裝numpy
打開cmd輸入:
pip install numpy
進行安裝,安裝完畢後會給提示。
4.找到你的opencv安裝路徑(比如我的是D盤)
複製D:opencvopencv3.xuildpython.7x64路徑下的cv2.py
注意:我的windows版本為64位所以我選擇的是X64,如果你的是32位的話你需要選擇X86文件夾下的cv2.pyd
複製完之後,粘貼到你的python安裝路徑下的Lib/site-packages這個文件夾下。
完成上面這些就基本OK啦,我們在寫代碼之前先來測試一下,環境是否配置成功。
在CMD命令行下運行python:
import numpy
import cv2
如果沒有報錯,說明安裝完成。
實現原理:
1.調用計算機攝像頭
cv2.Videocamture(0)
2.將攝像頭數據按幀來取(相當於給每一幀圖片的人臉加框框)
cam.red()
3.將每一幀攝像頭記錄的數據帶入opencv讓classifier去判斷人臉
detectMultiScale()
4.如果存在人臉給人臉標記畫框
cv2.rectangle()
5.輸出畫框後的幀動畫
cv2.imshow(My Camera,frame)
代碼實現:
第一步定義一個識別函數:
先放圖片,這個地方比較重要,我在下面會詳細的說一下。
6-7行代碼說明:
首先創建classifier,為什麼要弄這個呢?
引用的haarcascade開頭的文件是opencv裡面關於人臉級聯分類器,你在opencv文件夾下的sourcesdatahaarcascades可以看到:
說明功能:
人臉檢測器(默認):haarcascade_frontalface_default.xml
人臉檢測器(快速Harr):haarcascade_frontalface_alt2.xml
人臉檢測器(側視):haarcascade_profileface.xml
眼部檢測器(左眼):haarcascade_lefteye_2splits.xml
眼部檢測器(右眼):haarcascade_righteye_2splits.xml
嘴部檢測器:haarcascade_mcs_mouth.xml
鼻子檢測器:haarcascade_mcs_nose.xml
身體檢測器:haarcascade_fullbody.xml
人臉檢測器(快速LBP):lbpcascade_frontalface.xml
1:haarcascade_frontalface_alt.xml
Stump-based 20x20 gentle adaboost frontal face detector.
2:haarcascade_frontalface_alt2.xml
Tree-based 20x20 gentle adaboost frontal face detector.
3:haarcascade_frontalface_alt_tree.xml
Stump-based 20x20 gentle adaboost frontal face detector.This detector uses tree of stage classifiers instead of a cascade
4:haarcascade_frontalface_default.xml
Stump-based 24x24 discrete(?) adaboost frontal face detector.
以上這四個鄙人都測試過,haarcascade_frontalface_alt.xml這個效果是最好的,其它的大家可以單個測試。
設定灰度:
灰度的設定是為了增強面部輪廓的對比度,這是增加精度必不可少的。
核心代碼解剖:
DetectMultiScale 函數是一個檢測物體的通用函數,我們介紹一下:
gray:這是轉換成灰度後的圖片
scaleFactor:補償參數,一般設置值為1.1-1.5比較好,效果大家自己改著看
minNeighbors:對當前其周圍有多少物體進行定義
minSize:設定窗口大小
flags:略抽象,選擇默認或者上圖即可
畫方框:
定義xywh利用for循環讀取faces變數裡面的坐標,然後通過rectangle()函數進行畫方框。
代碼下部分:
OK,寫完代碼之後,我們把上部分代碼跟下部分代碼拼湊起來,運行下試一下:
大家湊合看吧,我筆記本cam有點渣,不過隨著人的晃動,都可以完美的識別出來,由於沒法上視頻,大家就自行測試吧。
最後再強調一點:明後天出(下)部分,用python來通過指紋對比實現人臉驗證、人臉解鎖(大家感興趣的可以提前關注哦)。
大家如果想要學習Python可以加我的群:719+139+688,小編整理了2018最新的學習資料和大神分享直播。歡迎還沒有找到方向的小夥伴來學習。
推薦閱讀:
※一步一步教你認識Python閉包
※隨機數生成
※此庫在手,好片無憂!Python爬片,小手不抖
※dlib人臉識別 模塊 如何 在Python 中安裝?
※Hello World!