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!

TAG:編程 | Python | OpenCV |