Home  >  Article  >  Backend Development  >  Methods and steps for implementing face recognition using Python

Methods and steps for implementing face recognition using Python

王林
王林forward
2023-05-07 20:43:111848browse

For the development environment, we will use Visual Studio Community Edition.

If it is not installed on your computer yet, you can download it from here. and install desktop development using C.

Methods and steps for implementing face recognition using Python

Now that we have Visual Studio for desktop development in C, we can start our project.

Use Visual Studio to open a new directory and create a new python environment. We will use venv. Open your integrated terminal and write python -m venv venv. Then activate the environment by typing venv/bin/Activate.ps1. This is for PowerShell.

If you are using any other terminal you can find the full list here

Methods and steps for implementing face recognition using Python

Now that we have finished creating the virtual environment, let’s start extracting Our dependencies. For this we will need opencv and face_recognition. Use pip within your terminal.

pip install opencv-python face_recognition

Face Recognition is a library that uses the state-of-the-art dlib library. We're ready to write some code and recognize some faces.

Create a new python file, we will call the file missingPerson.py, assuming we will use our application to match missing persons. Import our dependencies and write our first few lines.

import cv2
import numpy as np
import face_recognition
import os
 
from face_recognition.api import face_distance

Assuming all of our photos are stored in our server storage, we need to first pull the images of all the people into our application and read those images.

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)

In this section we will use opencv to read all images of missing persons and append them to our missingPerson list.

After we read all the missing face images from storage, we need to find the face encoding so that we can use the CNN face detector to create a 2D array of face bounding boxes in the image.

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')

We store the two-dimensional array into a list of known face codes. This will take several minutes.

Now that we have the facial codes for all the missing people, all we have to do now is match them to our reporter image. face_recognition is very convenient to use.

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

First we need to load the image file of the reporter and encode their face. All that remains is to compare the reported face encodings with what we already know about face encodings. Then a simple logic matches their index and returns if the person is found in our missingPersons list.

This kind of facial recognition is not only used to find missing people. It detects and recognizes faces and can operate as needed.

The above is the detailed content of Methods and steps for implementing face recognition using Python. For more information, please follow other related articles on the PHP Chinese website!

Statement:
This article is reproduced at:yisu.com. If there is any infringement, please contact admin@php.cn delete