萬張PubFig人臉數據實現基於python+OpenCV的人臉特征定位程序(1)


        在最近刷今日頭條以及其他媒體軟件時,經常會發現一些AI換臉的視頻,於是我想,可不可以自己實現一個可以進行人臉識別的軟件程序。我的具體流程是先配合python網絡爬蟲先進行萬張PubFig人臉公共圖片的爬取,分析出圖片具體特征,然后再配合機器學習的OpenCV視覺庫進行軟件的構建。有一篇Github的文章講得很詳細,大家可以參考:https://github.com/Hironsan/BossSensor

 

         前幾篇博客先向大家講解如何爬取PubFig人臉數據,然后本片的話先用一些動漫人臉圖片,向大家展示基本的opencv庫的操作,以及用一些公共人臉數據進行簡單的人臉識別技術學習。

1.OpenCV簡介

  OpenCV是一個開源的跨平台計算機視覺庫,提供的有python接口,並實現了圖像處理和計算機視覺方面的很多通用算法。

 

2.需要安裝的包

  本篇先安裝Opencv和numpy,pandas等數據分析包即可,如果感覺麻煩的話,可以直接安裝Anaconda科學包(數據分析,挖掘,機器學習庫合集),安裝與不同編譯器配置環境過程這里就不講解了。

  下載地址(官網太慢了,推薦下面的地址):https://mirrors.tuna.tsinghua.edu.cn/pypi/web/simple/opencv-python/。python3.5以上的需要下載opencv_python-4.0之類的版本,這里用到的是opencv_python-4.0.0.21-cp37-cp37m-win_amd64.whl這個文件。

  安裝完后,我們先用下面的代碼輸出一個圖片:
  

import cv2


img = cv2.imread("1.jpg", 1)
cv2.imshow("1", img)
cv2.waitKey()

結果如下:

發現我們的環境已經成功安裝了。

 

3.初步人臉識別

由於本篇文章是第一篇,因此這里先簡單的展示一下opencv的一些機器視覺的基礎方法,下面就進行介紹。

(1)導入人臉圖片,這里用一張動漫圖

代碼和上面的類似,更改圖片即可:

import cv2


img = cv2.imread("firstPer.jpg", 1)
cv2.imshow("1", img)
cv2.waitKey()
cv2.destroyAllWindows()

這里我們把這段代碼封裝成一個函數:

def viewImage(image, name_of_window):
    '''
    image:圖像對象
    name_of_window:圖像窗口名稱
    '''
    cv2.namedWindow(name_of_window, cv2.WINDOW_NORMAL)
    cv2.imshow(name_of_window, image)
    cv2.waitKey()
    cv2.destroyAllWindows()

(2)一些基礎圖像處理的方法

cropped:cropped = image[y:y+h, x:x+w],就是以(y, x)為起點,裁剪大小為(h, w)的圖像,以左上角為起點,豎直向下的方向為y軸,橫向為x軸。

resized:dim = (width, height)

     resized = cv2.resize(img, dim, interpolation = cv2.INTER_AREA)

    調整圖像的大小。

用下面的代碼分別進行這兩種圖像的處理:

img = cv2.imread("firstPer.jpg", 1)
# 裁剪圖片大小,裁剪100范圍的圖片
cropped = img[0:100, 0:100]
viewImage(cropped,"firstPer")

img = cv2.imread("firstPer.jpg", 1)
scale_percent = 30    #調整30%的大小
width = int(img.shape[1] * scale_percent / 100)
height = int(img.shape[0] * scale_percent / 100)
dim = (width, height)
resized = cv2.resize(img, dim, interpolation = cv2.INTER_AREA)
viewImage(resized,"firstPer")

還有一一些用的操作方法,就是旋轉,調節亮度,變模糊/平滑,繪制邊框,繪制線段等,在這里並不是進行圖像處理,因此就先不先向大家講解。哈哈。

(3)圖像灰度處理

       在進行人臉識別時,好多地方都先進行圖像變灰度的操作,這里也給大家介紹一下:

這里有一個閾值函數,gray_image,將所有圖像變為比127更暗直至0或者增加亮度到255,將圖像的彩色邊框的內容略過。

灰度處理代碼:

gray_image = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
viewImage(gray_image,"gray Image")

結果:

亮度彩色閾值處理代碼:

one,threshold_image = cv2.threshold(img, 127, 255, 0)
viewImage(threshold_image,"firstPer")

結果:

主要是有后面的三個參數控制,大家有興趣可以自行學習。

(4)人臉識別初講

  如果我們需要進行人臉識別,需要下載一些opencv配置文件,地址為:https://github.com/opencv/opencv/tree/master/data/haarcascades,這里我們用到的是haarcascade_frontalface_default.xml文件。用下面的代碼進行檢測:

face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
img = cv2.imread("firstPer.jpg")
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
faces = face_cascade.detectMultiScale(
gray,                # 灰度圖
scaleFactor= 1.1,    # 縮放比例
minNeighbors= 2,    # 識別出一個人臉之前在當前物體周圍需要檢測的物體數目
minSize=(50, 50)    #窗口的大小
)

firstPer = format(len(faces)) + "faces detected!"
print(firstPer)# Draw a rectangle around the faces
for (x, y, w, h) in faces:
    cv2.rectangle(img, (x, y), (x+w, y+h), (255, 255, 0), 2)
viewImage(img,firstPer)

detectMultiScale函數是一個檢測物體的通用函數。當我們把它用於人臉檢測時,它就會從圖像中檢測出人臉。

但是我們卻發現,根本沒有檢測出我們可愛的小櫻的臉,這是為什么呢?不急,我們先用其他圖片檢測:

再來一張最美的圖片:

       這時我們發現,識別程序識別的時候會有兩個要注意的地方,第一個是動漫圖片線條簡單,有時候並不能識別出;而且識別的能力和圖片的清晰度也有關系。

       針對第一個問題,在接下來的教程中,我會使用哥倫比亞大學的公共PubFig人臉庫作為人臉識別數據集,進行機器視覺的訓練。向大家講解一下如何用機器學習訓練一個不僅僅能夠識別人臉,而且還能夠識別表情的軟件,歡迎大家繼續關注我的博客,如果有寶貴建議的話,請在下方評論。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM