Facer
Face detection, alignment, and averaging using OpenCV and dlib
.
Facer draws heavily on this tutorial from Satya Mallick. I had to update the code pretty heavily to get the project to work, so I thought I'd share my modifications.
Example
The image below is an example of Facer's output for one of my posts on r/dataisbeautiful
.
Installation
You have my 100% money-back guarantee that the most difficult part of using this package is installing its requirements. Once you've got OpenCV installed, the rest will should be smooth sailing. I've had the best luck with the OpenCV using the opencv-python
package from PyPI.
Install facer
using pip
:
pip install -U average-facer
Pre-trained detection model
The face landmark detection relies on a pre-trained model that must be downloaded separately from the dlib
package itself.
wget http://dlib.net/files/shape_predictor_68_face_landmarks.dat.bz2
Unzip the compressed file after it finishes downloading and move it into a ./model
directory.
If you store the downloaded file somewhere other than ./model
(or if you use an entirely different model name), you can set a custom model path as an environment variable:
export FACER_PREDICTOR_PATH="./custom/path/to/your/model.dat"
Usage
from facer import facer
import matplotlib.pyplot as plt
path_to_images = "./face_images"
images = facer.load_images(path_to_images)
landmarks, faces = facer.detect_face_landmarks(images)
average_face = facer.create_average_face(faces, landmarks, save_image=True)
plt.imshow(average_face)
plt.show()
Facer also supports creating animated GIFs of the averaging process:
from facer import facer
path_to_images = "./face_images"
gif, average_face = facer.create_animated_gif(path_to_images)