利用Python實現人臉辨識的方法及步驟
對於開發環境,我們將使用 Visual Studio Community Edition。
如果你的電腦上還沒有安裝它,你可以從這裡下載。並使用 C 安裝桌面開發。
現在我們有了使用 C 進行桌面開發的 Visual Studio,我們可以開始我們的專案了。
使用 Visual Studio 開啟新目錄並建立新的 python 環境。我們將使用venv. 打開你的整合終端並編寫python -m venv venv。然後透過鍵入venv/bin/Activate.ps1來啟動環境。這是針對 PowerShell 的。
如果你使用任何其他終端,你可以在此處找到完整列表
#現在我們已經完成了虛擬環境的創建,讓我們開始提取我們的依賴項。為此,我們將需要opencv和face_recognition。在你的終端機內使用pip.
pip install opencv-python face_recognition
Face Recognition是一個使用最先進的dlib函式庫的函式庫。我們準備好編寫一些程式碼並識別一些面孔。
建立一個新的 python 文件,我們將呼叫文件missingPerson.py,假設我們將使用我們的應用程式來匹配失蹤者。導入我們的依賴項並編寫我們的前幾行。
import cv2 import numpy as np import face_recognition import os from face_recognition.api import face_distance
假設我們所有的照片都儲存在我們的伺服器儲存中,我們需要先將所有人物的圖像拉入我們的應用程式並讀取這些圖像。
path = 'MissingPersons' images = [] missingPersons = [] missingPersonsList = os.listdir(path) for missingPerson in missingPersonsList : curImg = cv2.imread(f'{path}/{missingPerson}') images.append(curImg) missingPersons.append(os.path.splitext(missingPerson)[0]) print(missingPersons)
在本節中,我們將使用 opencv 讀取失踪人員的所有圖像並將它們附加到我們的missingPerson列表中。
在我們從儲存中讀取所有遺失的人臉影像後,我們需要找到人臉編碼,以便我們可以使用 CNN 人臉偵測器在影像中建立人臉邊界框的二維數組。
def findEncodings(images): encodeList = [] for img in images: img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) encode = face_recognition.face_encodings(img)[0] encodeList.append(encode) print(encodeList) return encodeList encodeListKnown = findEncodings(images) print('Encoding Complete')
我們將二維陣列儲存到已知人臉編碼清單中。這將需要幾分鐘。
現在我們有了所有失踪人員的臉部編碼,我們現在要做的就是將它們與我們的報告人圖像進行匹配。 face_recognition使用起來非常方便。
def findMissingPerson(encodeListKnown, reportedPerson='found1.jpg'): person = face_recognition.load_image_file(f'ReportedPersons/{reportedPerson}]') person = cv2.cvtColor(person,cv2.COLOR_BGR2RGB) try: encodePerson = face_recognition.face_encodings(person)[0] comparedFace = face_recognition.compare_faces(encodeListKnown,encodePerson) faceDis = face_recognition.face_distance(encodeListKnown,encodePerson) matchIndex = np.argmin(faceDis) if comparedFace[matchIndex]: name = missingPersons[matchIndex].upper() print(name) return name else: print('Not Found') return False except IndexError as e: print(e) return e
首先我們需要載入被報告人的圖像文件,對他們的臉進行編碼。剩下的就是將被報告人臉編碼與我們已知的人臉編碼進行比較。然後一個簡單的邏輯匹配他們的索引並返回是否在我們的 missingPersons 列表中找到該人。
這種人臉辨識不僅用來尋找失蹤者。它可以檢測和識別人臉,並且可以根據需要進行操作。
以上是利用Python實現人臉辨識的方法及步驟的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。

PHP適合網頁開發和快速原型開發,Python適用於數據科學和機器學習。 1.PHP用於動態網頁開發,語法簡單,適合快速開發。 2.Python語法簡潔,適用於多領域,庫生態系統強大。

在 Sublime Text 中運行 Python 代碼,需先安裝 Python 插件,再創建 .py 文件並編寫代碼,最後按 Ctrl B 運行代碼,輸出會在控制台中顯示。

PHP起源於1994年,由RasmusLerdorf開發,最初用於跟踪網站訪問者,逐漸演變為服務器端腳本語言,廣泛應用於網頁開發。 Python由GuidovanRossum於1980年代末開發,1991年首次發布,強調代碼可讀性和簡潔性,適用於科學計算、數據分析等領域。

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

Golang在性能和可擴展性方面優於Python。 1)Golang的編譯型特性和高效並發模型使其在高並發場景下表現出色。 2)Python作為解釋型語言,執行速度較慢,但通過工具如Cython可優化性能。

在 Visual Studio Code(VSCode)中編寫代碼簡單易行,只需安裝 VSCode、創建項目、選擇語言、創建文件、編寫代碼、保存並運行即可。 VSCode 的優點包括跨平台、免費開源、強大功能、擴展豐富,以及輕量快速。

在 Notepad 中運行 Python 代碼需要安裝 Python 可執行文件和 NppExec 插件。安裝 Python 並為其添加 PATH 後,在 NppExec 插件中配置命令為“python”、參數為“{CURRENT_DIRECTORY}{FILE_NAME}”,即可在 Notepad 中通過快捷鍵“F6”運行 Python 代碼。
