⑴ 如何獲取人臉 68個關鍵點 python代碼

可以使用OpenCV,OpenCV的人臉檢測功能在一般場合還是不錯的。而ubuntu正好提供了python-opencv這個包,用它可以方便地實現人臉檢測的代碼。 寫代碼之前應該先安裝python-opencv: #!/usr/bin/python# -*- coding: UTF-8 -*- # face_detect.py #...

⑵ 如何線上部署用python基於dlib寫的人臉識別演算法

python使用dlib進行人臉檢測與人臉關鍵點標記

Dlib簡介:

首先給大家介紹一下Dlib

我使用的版本是dlib-18.17,大家也可以在我這里下載:

之後進入python_examples下使用bat文件進行編譯,編譯需要先安裝libboost-python-dev和cmake

cd to dlib-18.17/python_examples

./compile_dlib_python_mole.bat 123

之後會得到一個dlib.so,復制到dist-packages目錄下即可使用

這里大家也可以直接用我編譯好的.so庫,但是也必須安裝libboost才可以,不然python是不能調用so庫的,下載地址:

將.so復制到dist-packages目錄下

sudo cp dlib.so /usr/local/lib/python2.7/dist-packages/1

最新的dlib18.18好像就沒有這個bat文件了,取而代之的是一個setup文件,那麼安裝起來應該就沒有這么麻煩了,大家可以去直接安裝18.18,也可以直接下載復制我的.so庫,這兩種方法應該都不麻煩~

有時候還會需要下面這兩個庫,建議大家一並安裝一下

9.安裝skimage

sudo apt-get install python-skimage1

10.安裝imtools

sudo easy_install imtools1

Dlib face landmarks Demo

環境配置結束之後,我們首先看一下dlib提供的示常式序

1.人臉檢測

dlib-18.17/python_examples/face_detector.py 源程序:

#!/usr/bin/python# The contents of this file are in the public domain. See LICENSE_FOR_EXAMPLE_PROGRAMS.txt## This example program shows how to find frontal human faces in an image. In# particular, it shows how you can take a list of images from the command# line and display each on the screen with red boxes overlaid on each human# face.## The examples/faces folder contains some jpg images of people. You can run# this program on them and see the detections by executing the# following command:# ./face_detector.py ../examples/faces/*.jpg## This face detector is made using the now classic Histogram of Oriented# Gradients (HOG) feature combined with a linear classifier, an image# pyramid, and sliding window detection scheme. This type of object detector# is fairly general and capable of detecting many types of semi-rigid objects# in addition to human faces. Therefore, if you are interested in making# your own object detectors then read the train_object_detector.py example# program. ### COMPILING THE DLIB PYTHON INTERFACE# Dlib comes with a compiled python interface for python 2.7 on MS Windows. If# you are using another python version or operating system then you need to# compile the dlib python interface before you can use this file. To do this,# run compile_dlib_python_mole.bat. This should work on any operating# system so long as you have CMake and boost-python installed.# On Ubuntu, this can be done easily by running the command:# sudo apt-get install libboost-python-dev cmake## Also note that this example requires scikit-image which can be installed# via the command:# pip install -U scikit-image# Or downloaded from . import sys

import dlib

from skimage import io

detector = dlib.get_frontal_face_detector()

win = dlib.image_window()

print("a");for f in sys.argv[1:]:

print("a");

print("Processing file: {}".format(f))
img = io.imread(f)
# The 1 in the second argument indicates that we should upsample the image
# 1 time. This will make everything bigger and allow us to detect more
# faces.
dets = detector(img, 1)
print("Number of faces detected: {}".format(len(dets))) for i, d in enumerate(dets):
print("Detection {}: Left: {} Top: {} Right: {} Bottom: {}".format(
i, d.left(), d.top(), d.right(), d.bottom()))

win.clear_overlay()
win.set_image(img)
win.add_overlay(dets)
dlib.hit_enter_to_continue()# Finally, if you really want to you can ask the detector to tell you the score# for each detection. The score is bigger for more confident detections.# Also, the idx tells you which of the face sub-detectors matched. This can be# used to broadly identify faces in different orientations.if (len(sys.argv[1:]) > 0):
img = io.imread(sys.argv[1])
dets, scores, idx = detector.run(img, 1) for i, d in enumerate(dets):
print("Detection {}, score: {}, face_type:{}".format(
d, scores[i], idx[i]))5767778798081

我把源代碼精簡了一下,加了一下注釋: face_detector0.1.py

# -*- coding: utf-8 -*-import sys

import dlib

from skimage import io#使用dlib自帶的frontal_face_detector作為我們的特徵提取器detector = dlib.get_frontal_face_detector()#使用dlib提供的圖片窗口win = dlib.image_window()#sys.argv[]是用來獲取命令行參數的,sys.argv[0]表示代碼本身文件路徑,所以參數從1開始向後依次獲取圖片路徑for f in sys.argv[1:]: #輸出目前處理的圖片地址
print("Processing file: {}".format(f)) #使用skimage的io讀取圖片
img = io.imread(f) #使用detector進行人臉檢測 dets為返回的結果
dets = detector(img, 1) #dets的元素個數即為臉的個數
print("Number of faces detected: {}".format(len(dets))) #使用enumerate 函數遍歷序列中的元素以及它們的下標
#下標i即為人臉序號
#left:人臉左邊距離圖片左邊界的距離 ;right:人臉右邊距離圖片左邊界的距離
#top:人臉上邊距離圖片上邊界的距離 ;bottom:人臉下邊距離圖片上邊界的距離
for i, d in enumerate(dets):
print("dets{}".format(d))
print("Detection {}: Left: {} Top: {} Right: {} Bottom: {}"
.format( i, d.left(), d.top(), d.right(), d.bottom())) #也可以獲取比較全面的信息,如獲取人臉與detector的匹配程度
dets, scores, idx = detector.run(img, 1)
for i, d in enumerate(dets):
print("Detection {}, dets{},score: {}, face_type:{}".format( i, d, scores[i], idx[i]))

#繪制圖片(dlib的ui庫可以直接繪制dets)
win.set_image(img)
win.add_overlay(dets) #等待點擊
dlib.hit_enter_to_continue()041424344454647484950

分別測試了一個人臉的和多個人臉的,以下是運行結果:

運行的時候把圖片文件路徑加到後面就好了

python face_detector0.1.py ./data/3.jpg12

一張臉的:

兩張臉的:

這里可以看出側臉與detector的匹配度要比正臉小的很多

2.人臉關鍵點提取

人臉檢測我們使用了dlib自帶的人臉檢測器(detector),關鍵點提取需要一個特徵提取器(predictor),為了構建特徵提取器,預訓練模型必不可少。

除了自行進行訓練外,還可以使用官方提供的一個模型。該模型可從dlib sourceforge庫下載:

arks.dat.bz2

也可以從我的連接下載:

這個庫支持68個關鍵點的提取,一般來說也夠用了,如果需要更多的特徵點就要自己去訓練了。

dlib-18.17/python_examples/face_landmark_detection.py 源程序:

#!/usr/bin/python# The contents of this file are in the public domain. See LICENSE_FOR_EXAMPLE_PROGRAMS.txt## This example program shows how to find frontal human faces in an image and# estimate their pose. The pose takes the form of 68 landmarks. These are# points on the face such as the corners of the mouth, along the eyebrows, on# the eyes, and so forth.## This face detector is made using the classic Histogram of Oriented# Gradients (HOG) feature combined with a linear

⑶ python人臉識別所用的優化演算法有什麼

python三步實現人臉識別

Face Recognition軟體

這是世界上最簡單的人臉識別庫了。你可以通過Python引用或者命令行的形式使用它,來管理和識別人臉。

該軟體包使用dlib中最先進的人臉識別深度學習演算法,使得識別准確率在《Labled Faces in the world》測試基準下達到了99.38%。

它同時提供了一個叫face_recognition的命令行工具,以便你可以用命令行對一個文件夾中的圖片進行識別操作。

特性

在圖片中識別人臉

找到圖片中所有的人臉

這里是一個例子:

1
  • https://github.com/ageitgey/face_recognition/blob/master/examples/recognize_faces_in_picture
  • ⑷ 如何使用Python,基於OpenCV與Face++實現人臉解鎖的功能

    近幾天微軟的發布會上講到了不少認臉解鎖的內容,經過探索,其實利用手頭的資源我們完全自己也可以完成這樣一個過程。

    本文講解了如何使用Python,基於OpenCV與Face++實現人臉解鎖的功能。

    本文基於Python 2.7.11,Windows 8.1 系統。

    主要內容

    • Windows 8.1上配置OpenCV

    • OpenCV的人臉檢測應用

    • 使用Face++完成人臉辨識(如果你想自己實現這部分的功能,可以借鑒例如這個項目)

    • Windows 8.1上配置OpenCV

      入門的時候配置環境總是一個非常麻煩的事情,在Windows上配置OpenCV更是如此。

      既然寫了這個推廣的科普教程,總不能讓讀者卡在環境配置上吧。

      下面用到的文件都可以在這里(提取碼:b6ec)下載,但是注意,目前OpenCV僅支持Python2.7。

      將cv2加入site-packages

      將下載下來的cv2.pyd文件放入Python安裝的文件夾下的Libsite-packages目錄。

      就我的電腦而言,這個目錄就是C:/Python27/Lib/site-packages/。

      記得不要直接使用pip安裝,將文件拖過去即可。

      安裝numpy組件

      在命令行下進入到下載下來的文件所在的目錄(按住Shift右鍵有在該目錄打開命令行的選項)

      鍵入命令:

      1

    • pip install numpy-1.11.0rc2-cp27-cp27m-win32.whl

    • 如果你的系統或者Python不適配,可以在這里下載別的輪子。

      測試OpenCV安裝

      在命令行鍵入命令:

      1

    • python -c "import cv2"

    • 如果沒有出現錯誤提示,那麼cv2就已經安裝好了。

      OpenCV的人臉檢測應用

      人臉檢測應用,簡而言之就是一個在照片里找到人臉,然後用方框框起來的過程(我們的相機經常做這件事情)

      那麼具體而言就是這樣一個過程:

    • 獲取攝像頭的圖片

    • 在圖片中檢測到人臉的區域

    • 在人臉的區域周圍繪制方框

    • 獲取攝像頭的圖片

      這里簡單的講解一下OpenCV的基本操作。

      以下操作是打開攝像頭的基本操作:

      1

      2

      3

      4

      5

      6

      7

    • #coding=utf8

      import cv2

      # 一般筆記本的默認攝像頭都是0

      capInput = cv2.VideoCapture(0)

      # 我們可以用這條命令檢測攝像頭是否可以讀取數據

      if not capInput.isOpened(): print('Capture failed because of camera')

    • 那麼怎麼從攝像頭讀取數據呢?

      1

      2

      3

      4

      5

      6

      7

      8

    • # 接上段程序

      # 現在攝像頭已經打開了,我們可以使用這條命令讀取圖像

      # img就是我們讀取到的圖像,就和我們使用open('pic.jpg', 'rb').read()讀取到的數據是一樣的

      ret, img = capInput.read()

      # 你可以使用open的方式存儲,也可以使用cv2提供的方式存儲

      cv2.imwrite('pic.jpg', img)

      # 同樣,你可以使用open的方式讀取,也可以使用cv2提供的方式讀取

      img = cv2.imread('pic.jpg')

    • 為了方便顯示圖片,cv2也提供了顯示圖片的方法:

      1

      2

      3

      4

      5

      6

    • # 接上段程序

      # 定義一個窗口,當然也可以不定義

      imgWindowName = 'ImageCaptured'

      imgWindow = cv2.namedWindow(imgWindowName, cv2.WINDOW_NORMAL)

      # 在窗口中顯示圖片

      cv2.imshow(imgWindowName, img)

    • 當然在完成所有操作以後需要把攝像頭和窗口都做一個釋放:

      1

      2

      3

      4

      5

    • # 接上段程序

      # 釋放攝像頭

      capInput.release()

      # 釋放所有窗口

      cv2.destroyAllWindows()

    • 在圖片中檢測到人臉的區域

      OpenCV給我們提供了已經訓練好的人臉的xml模板,我們只需要載入然後比對即可。

      1

      2

      3

      4

      5

      6

      7

      8

    • # 接上段程序

      # 載入xml模板

      faceCascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')

      # 將圖形存儲的方式進行轉換

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

      # 使用模板匹配圖形

      faces = faceCascade.detectMultiScale(gray, 1.3, 5)

      print(faces)

    • 在人臉的區域周圍繪制方框

      在上一個步驟中,faces中的四個量分別為左上角的橫坐標、縱坐標、寬度、長度。

      所以我們根據這四個量很容易的就可以繪制出方框。

      1

      2

      3

    • # 接上段程序

      # 函數的參數分別為:圖像,左上角坐標,右下角坐標,顏色,寬度

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

    • 成果

      根據上面講述的內容,我們現在已經可以完成一個簡單的人臉辨認了:

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      11

      12

      13

      14

      15

      16

      17

      18

      19

      20

      21

      22

      23

      24

      25

      26

      27

      28

      29

      30

    • #coding=utf8

      import cv2

      print('Press Esc to exit')

      faceCascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')

      imgWindow = cv2.namedWindow('FaceDetect', cv2.WINDOW_NORMAL)

      def detect_face():

      capInput = cv2.VideoCapture(0)

      # 避免處理時間過長造成畫面卡頓

      nextCaptureTime = time.time()

      faces = []

      if not capInput.isOpened(): print('Capture failed because of camera')

      while 1:

      ret, img = capInput.read()

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

      if nextCaptureTime < time.time():

      nextCaptureTime = time.time() + 0.1

      faces = faceCascade.detectMultiScale(gray, 1.3, 5)

      if faces:

      for x, y, w, h in faces:

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

      cv2.imshow('FaceDetect', img)

      # 這是簡單的讀取鍵盤輸入,27即Esc的acsii碼

      if cv2.waitKey(1) & 0xFF == 27: break

      capInput.release()

      cv2.destroyAllWindows()

      if __name__ == '__main__':

      detect_face()

    • 使用Face++完成人臉辨識

      第一次認識Face++還是因為支付寶的人臉支付,響應速度還是非常讓人滿意的。

      現在只需要免費注冊一個賬號然後新建一個應用就可以使用了,非常方便。

      他的官方網址是這個,注冊好之後在這里的我的應用中創建應用即可。

      創建好應用之後你會獲得API Key與API Secret。

      Face++的API調用邏輯簡單來說是這樣的:

    • 上傳圖片獲取讀取到的人的face_id

    • 創建Person,獲取person_id(Person中的圖片可以增加、刪除)

    • 比較兩個face_id,判斷是否是一個人

    • 比較face_id與person_id,判斷是否是一個人

    • 上傳圖片獲取face_id

      在將圖片通過post方法上傳到特定的地址後將返回一個json的值。

      如果api_key, api_secret沒有問題,且在上傳的圖片中有識別到人臉,那麼會存儲在json的face鍵值下。

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      11

      12

      13

      14

      15

      16

      17

      18

      19

      20

    • #coding=utf8

      import requests

      # 這里填寫你的應用的API Key與API Secret

      API_KEY = ''

      API_SECRET = ''

      # 目前的API網址是這個,你可以在API文檔里找到這些

      BASE_URL = 'httlus.com/v2'

      # 使用Requests上傳圖片

      url = '%s/detection/detect?api_key=%s&api_secret=%s&attribute=none'%(

      BASE_URL, API_KEY, API_SECRET)

      files = {'img': (os.path.basename(fileDir), open(fileDir, 'rb'),

      mimetypes.guess_type(fileDir)[0]), }

      r = requests.post(url, files = files)

      # 如果讀取到圖片中的頭像則輸出他們,其中的'face_id'就是我們所需要的值

      faces = r.json().get('face')

      print faces

    • 創建Person

      這個操作沒有什麼可以講的內容,可以對照這段程序和官方的API介紹。

      官方的API介紹可以見這里,相信看完這一段程序以後你就可以自己完成其餘的API了。

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      11

      12

      13

      14

    • # 上接上一段程序

      # 讀取face_id

      if not faces is None: faceIdList = [face['face_id'] for face in faces]

      # 使用Requests創建Person

      url = '%s/person/create'%BASE_URL

      params = {

      'api_key': API_KEY,

      'api_secret': API_SECRET,

      'person_name': 'LittleCoder',

      'face_id': ','.join(faceIdList), }

      r = requests.get(url, params = params)

      # 獲取person_id

      print r.json.()['person_id']

    • 進度確認

      到目前為止,你應該已經可以就給定的兩張圖片比對是否是同一個人了。

      那麼讓我們來試著寫一下這個程序吧,兩張圖片分別為』pic1.jpg』, 『pic2.jpg』好了。

      下面我給出了我的代碼:

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      11

      12

      13

      14

      15

      16

      17

      18

      19

      20

      21

      22

      23

      24

      25

      26

      27

    • def upload_img(fileDir, oneface = True):

      url = '%s/detection/detect?api_key=%s&api_secret=%s&attribute=none'%(

      BASE_URL, API_KEY, API_SECRET)

      if oneface: url += '&mode=oneface'

      files = {'img': (os.path.basename(fileDir), open(fileDir, 'rb'),

      mimetypes.guess_type(fileDir)[0]), }

      r = requests.post(url, files = files)

      faces = r.json().get('face')

      if faces is None:

      print('There is no face found in %s'%fileDir)

      else:

      return faces[0]['face_id']

      def compare(faceId1, faceId2):

      url = '%s/recognition/compare'%BASE_URL

      params = BASE_PARAMS

      params['face_id1'] = faceId1

      params['face_id2'] = faceId2

      r = requests.get(url, params)

      return r.json()

      faceId1 = upload_img('pic1.jpg')

      faceId2 = upload_img('pic2.jpg')

      if face_id1 and face_id2:

      print(compare(faceId1, faceId2))

      else:

      print('Please change two pictures')

    • 成品

      到此,所有的知識介紹都結束了,相比大致如何完成這個項目各位讀者也已經有想法了吧。

      下面我們需要構思一下人臉解鎖的思路,大致而言是這樣的:

    • 使用一個程序設置賬戶(包括向賬戶中存儲解鎖用的圖片)

    • 使用另一個程序登陸(根據輸入的用戶名測試解鎖)

    • 這里會有很多重復的代碼,就不再贅述了,你可以在這里或者這里(提取碼:c073)下載源代碼測試使用。

      這里是設置賬戶的截圖:

      登陸

      結束語

      希望讀完這篇文章能對你有幫助,有什麼不足之處萬望指正(鞠躬)。

    ⑸ 運行人臉識別Python程序時遇到以下問題,求大佬解決

    要把所有錯誤堆棧貼出來 上面的不夠

    ⑹ 如何用pca做人臉識別 python實現

    基於特徵臉(PCA)的人臉識別方法
    特徵臉方法是基於KL變換的人臉識別方法,KL變換是圖像壓縮的一種最優正交變換。高維的圖像空間經過KL變換後得到一組新的正交基,保留其中重要的正交基,由這些基可以張成低維線性空間。如果假設人臉在這些低維線性空間的投影具有可分性,就可以將這些投影用作識別的特徵矢量,這就是特徵臉方法的基本思想。這些方法需要較多的訓練樣本,而且完全是基於圖像灰度的統計特性的。目前有一些改進型的特徵臉方法。


    比如人臉灰度照片40x40=1600個像素點,用每個像素的灰度值組成的矩陣代表這個人的人臉。那麼這個人人臉就要1600 個特徵。拿一堆這樣的樣本過來做pca,抽取得到的只是在統計意義下能代表某個樣本的幾個特徵。


    人臉識別可以採用神經網 絡深度學習的思路,國內的ColorReco在這邊有比較多的案例。

    ⑺ 怎麼用python調取一個人臉識別 api

    必備知識
    Haar-like
    通俗的來講,就是作為人臉特徵即可。
    Haar特徵值反映了圖像的灰度變化情況。例如:臉部的一些特徵能由矩形特徵簡單的描述,如:眼睛要比臉頰顏色要深,鼻樑兩側比鼻樑顏色要深,嘴巴比周圍顏色要深等。
    opencv api
    要想使用opencv,就必須先知道其能幹什麼,怎麼做。於是API的重要性便體現出來了。就本例而言,使用到的函數很少,也就普通的讀取圖片,灰度轉換,顯示圖像,簡單的編輯圖像罷了。
    如下:
    讀取圖片
    只需要給出待操作的圖片的路徑即可。
    import cv2
    image = cv2.imread(imagepath)
    灰度轉換
    灰度轉換的作用就是:轉換成灰度的圖片的計算強度得以降低。
    import cv2
    gray = cv2.cvtColor(image,cv2.COLOR_BGR2GRAY)
    畫圖
    opencv 的強大之處的一個體現就是其可以對圖片進行任意編輯,處理。
    下面的這個函數最後一個參數指定的就是畫筆的大小。
    import cv2
    cv2.rectangle(image,(x,y),(x+w,y+w),(0,255,0),2)
    顯示圖像
    編輯完的圖像要麼直接的被顯示出來,要麼就保存到物理的存儲介質。
    import cv2
    cv2.imshow("Image Title",image)
    獲取人臉識別訓練數據
    看似復雜,其實就是對於人臉特徵的一些描述,這樣opencv在讀取完數據後很據訓練中的樣品數據,就可以感知讀取到的圖片上的特徵,進而對圖片進行人臉識別。
    import cv2
    face_cascade = cv2.CascadeClassifier(r'./haarcascade_frontalface_default.xml')
    里賣弄的這個xml文件,就是opencv在GitHub上共享出來的具有普適的訓練好的數據。我們可以直接的拿來使用。
    訓練數據參考地址:

    探測人臉
    說白了,就是根據訓練的數據來對新圖片進行識別的過程。
    import cv2
    # 探測圖片中的人臉
    faces = face_cascade.detectMultiScale(
    gray,
    scaleFactor = 1.15,
    minNeighbors = 5,
    minSize = (5,5),
    flags = cv2.cv.CV_HAAR_SCALE_IMAGE
    )
    我們可以隨意的指定裡面參數的值,來達到不同精度下的識別。返回值就是opencv對圖片的探測結果的體現。
    處理人臉探測的結果
    結束了剛才的人臉探測,我們就可以拿到返回值來做進一步的處理了。但這也不是說會多麼的復雜,無非添加點特徵值罷了。
    import cv2
    print "發現{0}個人臉!".format(len(faces))
    for(x,y,w,h) in faces:
    cv2.rectangle(image,(x,y),(x+w,y+w),(0,255,0),2)
    實例
    有了剛才的基礎,我們就可以完成一個簡單的人臉識別的小例子了。
    圖片素材
    下面的這張圖片將作為我們的檢測依據。

    人臉檢測代碼
    # coding:utf-8
    import sys

    reload(sys)
    sys.setdefaultencoding('utf8')
    # __author__ = '郭 璞'
    # __date__ = '2016/9/5'
    # __Desc__ = 人臉檢測小例子,以圓圈圈出人臉
    import cv2
    # 待檢測的圖片路徑
    imagepath = r'./heat.jpg'

    # 獲取訓練好的人臉的參數數據,這里直接從GitHub上使用默認值
    face_cascade = cv2.CascadeClassifier(r'./haarcascade_frontalface_default.xml')

    # 讀取圖片
    image = cv2.imread(imagepath)
    gray = cv2.cvtColor(image,cv2.COLOR_BGR2GRAY)

    # 探測圖片中的人臉
    faces = face_cascade.detectMultiScale(
    gray,
    scaleFactor = 1.15,
    minNeighbors = 5,
    minSize = (5,5),
    flags = cv2.cv.CV_HAAR_SCALE_IMAGE
    )

    print "發現{0}個人臉!".format(len(faces))

    for(x,y,w,h) in faces:
    # cv2.rectangle(image,(x,y),(x+w,y+w),(0,255,0),2)
    cv2.circle(image,((x+x+w)/2,(y+y+h)/2),w/2,(0,255,0),2)

    cv2.imshow("Find Faces!",image)
    cv2.waitKey(0)
    人臉檢測結果
    輸出圖片:

    輸出結果:
    D:\Software\Python2\python.exe E:/Code/Python/DataStructor/opencv/Demo.py
    發現3個人臉!

    ⑻ 有沒有Python的人臉識別的demo

    OpenCV是開源的跨平台來計算源機視覺庫,提供了Python等語言的介面,實現了圖像處理和計算機視覺方面的很多通用演算法。
    opencv中內置了基於Viola-Jones目標檢測框架的Harr分類器,只需要載入一個配置文件(haarcascade_frontalface_alt.xml)就能直接調用detectObject去完成檢測過程,同時也支持其他特徵的檢測(如鼻子、嘴巴等)。

    ⑼ 如何使用yale大學的人臉資料庫進行人臉識別的訓練,python語言

    基於特徵臉(PCA)的人臉識別方法
    特徵臉方法是基於KL變換的人臉識別方法,KL變換是圖像壓縮的一種最優正交變換。高維的圖像空間經過KL變換後得到一組新的正交基,保留其中重要的正交基,由這些基可以張成低維線性空間。如果假設人臉在這些低維線性空間的投影具有可分性,就可以將這些投影用作識別的特徵矢量,這就是特徵臉方法的基本思想。這些方法需要較多的訓練樣本,而且完全是基於圖像灰度的統計特性的。目前有一些改進型的特徵臉方法。

    比如人臉灰度照片40x40=1600個像素點,用每個像素的灰度值組成的矩陣代表這個人的人臉。那麼這個人人臉就要1600 個特徵。拿一堆這樣的樣本過來做pca,抽取得到的只是在統計意義下能代表某個樣本的幾個特徵。

    人臉識別可以採用神經網 絡深度學習的思路,國內的ColorReco在這邊有比較多的案例。