mxnet-insightface-cpp
This project implement an easy deployable face recognition pipeline with mxnet c++ framework.There are some awesome projects aim to train and design face recognition pipeline with python(like insightface), this project show how to deploy the pre-trained model to real production environment with mxnet c++. Compare with original python version, our implement has some optimization and speed improvement around 1/3.
Dependency lib
MXNet and OpenCV library. In this project we use MXNet 1.3.0/1.4.0 and OpenCV 4. It will be also ok for other version, you can compiled with MKL-DNN, MKL or OpenBLAS to make MXNet calcuation faster.
How to run
Windows
Build with VS2015 or higher version, add compiled opencv and mxnet lib to dependency lib and add opencv and mxnet include files.
Linux
Build with cmake.
1.Create new directory with "mkdir build && cd build", also add your compiled mxnet and dependency lib under lib.
2.Build with "cmake -D LINUX=ON .."
3.Compile repo with make -j"$(nproc)"
4.Run ./mxnet-insightface-cpp.
Operation
Make labels
Extract features with images in "images" folder, and also will generate labels(in main function):
std::string path = "D:\\cpp\\mxnet_cpp\\mxnet_cpp\\image"; //according to your label images path;
test_make_label(path); //make labels with split image name(e.g. penny.jpg -> penny)
Face recognition with camera
Extract feature from camera image and compare distance with labeled features:
test_camera(); // do recognition task with usb camrea
You can see detail recognition pipeline in feature_extract.hpp recognition function
Framework
This project implement face recognition pipeline with mxnet c++, and currently mainly optimize on CPU. The whole framework contains:
1. Face detect with MTCNN
We use the original version mtcnn to detect face(there are many re-design mtcnn model to make it faster with litttle accuracy lost, will be not mentioned here). MTCNN is a cascade network with PNet, RNet and ONet. The first stage will sample with image pyramid.
1.Assume that most task get images from camera so the input size is fiexed, thus the number of scales and scale size for every image is also fixed, we can initiate number=scales predict handler to avoid frequently resize or reload operation which will cause much time overhead.
2.The created predict handler for different scales can be easily implement with multi-thread to make speed up.
2. Face alignment with similarity transformation
The alignment algorithm check out from:face alignment with similarity transformation. It will transform detect image to norm face based on 5 average points. Detail algorithm please see paper "Least-squares estimation of transformation parameters between two point patterns", Shinji Umeyama, PAMI 1991, DOI: 10.1109/34.88573.
3. Face feature extraction(insightface or other approach)
Feature extraction phase utilizes deep network to extract features from aligned image, and then calculate the euclidean distance or cosine distance with labeled features. You can set threshold to do face verify, recognition or other task. In this project we show the efficient mobileface network to do face recognition with camera(you can change the camera io base on your device, we just set "0" in codes).
To be done
Optimization for different batch to feed RNet, ONet and feature extract network. Batch of input number of images will save time than loop. For example the input number x channels x width x height will get speed up than 1 x channels x width x height with loop.
Reference
- Insightface
- Joint Face Detection and Alignment using Multi-task Cascaded Convolutional Neural Networks
- MXNET
- Least-squares estimation of transformation parameters between two point patterns