Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/seasonsh/docface
Face recognition system for ID photos
https://github.com/seasonsh/docface
biometrics face-recognition face-verification multi-gpu tensorflow
Last synced: 6 days ago
JSON representation
Face recognition system for ID photos
- Host: GitHub
- URL: https://github.com/seasonsh/docface
- Owner: seasonSH
- License: mit
- Created: 2018-05-14T17:15:47.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-10-17T17:45:22.000Z (over 6 years ago)
- Last Synced: 2025-01-14T09:08:53.751Z (13 days ago)
- Topics: biometrics, face-recognition, face-verification, multi-gpu, tensorflow
- Language: Python
- Homepage:
- Size: 650 KB
- Stars: 371
- Watchers: 20
- Forks: 125
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# *DocFace*: Matching ID Document Photos to Selfies
By Yichun Shi and Anil K. Jain
## Update Notes
+ 09/28/2018: Added a demo code for face alignment.
+ 09/20/2018: The content of DocFace+ is added, including DIAM-Softmax, partially shared sibling networks and support for multiple ID/selfie per class.## Contents
0. [Introduction](#introduction)
0. [Citation](#citation)
0. [Requirements](#requirements)
0. [Usage](#usage)
0. [Models](#models)
0. [Results](#results)## Introduction
This repository includes the TensorFlow implementation of [**DocFace**](https://arxiv.org/abs/1805.02283) and [**DocFace+**](https://arxiv.org/abs/1809.05620), which is a system proposed for matching ID photos and live face photos. DocFace is shown to significantly outperform general face matchers on the ID-Selfie matching problem. We here give the example training code and pre-trained models in the paper. For the preprocessing part, we follow the repository of [SphereFace](https://github.com/wy1iu/sphereface) to align the face images using [MTCNN](https://github.com/kpzhang93/MTCNN_face_detection_alignment). The user can also use other methods for face alignment. Because the dataset used in the paper is private, we cannot publish it here. One can test the system on their own dataset.
## Citation
@article{shi2018docface+,
title = {DocFace+: ID Document to Selfie Matching},
author = {Shi, Yichun and Jain, Anil K.},
booktitle = {arXiv:1809.05620},
year = {2018}
}
@article{shi2018docface,
title = {DocFace: Matching ID Document Photos to Selfies},
author = {Shi, Yichun and Jain, Anil K.},
booktitle = {arXiv:1805.02283},
year = {2018}
}## Requirements
1. Requirements for `Python3`
2. Requirements for `Tensorflow r1.2` or newer versions.
3. Run `pip install -r requirements.txt` for other dependencies.
4. Requirements for `Matlab 2014b` and `Caffe` for MTCNN face alignment.## Usage
### Part 1: Preprocessing
#### 1.1 Dataset Structure
Download the [Ms-Celeb-1M](https://www.msceleb.org/download/cropped) and [LFW](http://vis-www.cs.umass.edu/lfw/lfw.tgz) dataset for training and testing the base model. Other dataset such as CASIA-Webface can also be used for training. Because Ms-Celeb-1M is known to be a very noisy dataset, we use the [clean list](https://github.com/AlfredXiangWu/face_verification_experiment) provided by Wu et al. Arrange Ms-Celeb-1M dataset and LFW dataset as the following structure, where each subfolder represents a subject:Aaron_Eckhart
Aaron_Eckhart_0001.jpg
Aaron_Guiel
Aaron_Guiel_0001.jpg
Aaron_Patterson
Aaron_Patterson_0001.jpg
Aaron_Peirsol
Aaron_Peirsol_0001.jpg
Aaron_Peirsol_0002.jpg
Aaron_Peirsol_0003.jpg
Aaron_Peirsol_0004.jpg
...For the ID-Selfie dataset, make sure all the foldesr in such a structure, where ID images and selfies start with "A" and "B", respectively :
Subject1
A001.jpg
B001.jpg
B002.jpg
Subject2
A001.jpg
B001.jpg
...#### 1.2 Face Alignment
To ensure the peroformance, we align all the face images using the original MATLAB version of MTCNN following [SphereFace](http://openaccess.thecvf.com/content_cvpr_2017/papers/Liu_SphereFace_Deep_Hypersphere_CVPR_2017_paper.pdf). Here, we provide a simpler code to align a given dataset folder. To use the code, you need to install [Caffe](http://caffe.berkeleyvision.org/installation.html) for Matlab, and clone the repo of [MTCNN](https://github.com/kpzhang93/MTCNN_face_detection_alignment) and [Pdolloar](https://github.com/pdollar/toolbox). Then fill in their paths in the following lines in `align/face_detect_align.m`:```Matlab
imglist = importdata('/path/to/input/imagelist.txt');
output_dir = '/path/to/output/dataset';
...
matCaffe = '/path/to/caffe/matlab/';
pdollarToolbox = '/path/to/toolbox';
MTCNN = '/path/to/mtcnn/code/codes/MTCNNv1';
...
modelPath = '/path/to/mtcnn/code/codes/MTCNNv1/model';
```
Run the following command in Matlab for face alignement:
```
run align/face_detect_align.m
```### Part 2: Training
**Note:** In this part, we assume you are in the directory **`$DOCFACE_ROOT/`**#### 2.1 Training the base model
1. Set up the dataset paths in `config/basemodel.py`:
```Python
# Training dataset path
train_dataset_path = '/path/to/msceleb1m/dataset/folder'
# Testing dataset path
test_dataset_path = '/path/to/lfw/dataset/folder'
```2. Due to the memory cost, the user may need more than one GPUs to use a batch size of `256` on Ms-Celeb-1M. In particular, we used four GTX 1080 Ti GPUs. In such cases, change the following entry in `config/basemodel.py`:
```Python
# Number of GPUs
num_gpus = 1
```
3. Run the following command in the terminal:```Shell
python src/train_base.py config/basemodel.py
```
After training, a model folder will appear under`log/faceres_ms/`. We will use it for fine-tuning. If the training code is run more than once, multiple folders will appear with time stamps as their names. The user can also skip this part and use the pre-trained [base model](#models) we provide.
#### 2.2 Fine-tuning on the ID-Selfie datasets1. Set up the dataset paths and the pre-trained model path in `config/finetune.py`
```Python
# Training dataset path
train_dataset_path = '/path/to/training/dataset/folder'
# Testing dataset path
test_dataset_path = '/path/to/testing/dataset/folder'
...
# The model folder from which to retore the parameters
restore_model = '/path/to/the/pretrained/model/folder'
```2. Tune the parameters of loss functions according to your dataset in `config/finetune.py`, e.g.
```Python
# Loss functions and their parameters.
losses = {
'diam': {'scale': 'auto', 'm': 5.0, 'alpha':1.0}
}
```
In our experiments, we found that there is no necessity to manually choose "scale". But in some cases one may find it helpful to change the "scale" to a fixed value. A smaller "alpha" should be favored when the average number of samples per class is larger.
3. Run the following command in the terminal to start fine-tuning:```Shell
python src/train_sibling.py config/finetune.py
```### Part 3: Feature Extraction
**Note:** In this part, we assume you are in the directory **`$DOCFACE_ROOT/`**To extract features using a pre-trained model (either base network or sibling network), prepare a `.txt` file of image list. The images should be aligned in the same way as the training dataset. Then run the following command in terminal:
```Shell
python src/extract_features.py \
--model_dir /path/to/pretrained/model/dir \
--image_list /path/to/imagelist.txt \
--output /path/to/output.npy
```Notice that the images in the image list follow the same naming convention of the training dataset. That is, ID images should start with "A\*\*" and selfie images should start with "B\*\*".
## Models
- BaseModel (unconstraind face matching): [Google Drive](https://drive.google.com/open?id=1nBmggq4uixcI2AtucGu5nsa28dJRwkIz) | [Baidu Yun](https://pan.baidu.com/s/1RadsPNjcdzBDYcdoN5BAhQ)
- Fine-tuned DocFace model: (contact the author)
## Results
- Using our pre-trained base model, one should be able to achieve 99.67% on the standard LFW verification protocol and 99.60% on the [BLUFR](http://www.cbsr.ia.ac.cn/users/scliao/projects/blufr/) protocol. Similar results should be achieved by using our code to train the Face-ResNet on Ms-Celeb-1M.- Using the proposed Max-margin Pairwise Score loss and sibling network, DocFace acheives a significant improvement compared with Base Model on our private ID-Selfie dataset after transfer learning:
- Results of DIAM-Softmax and DocFace+ on a combination of ID-Selfie-A, ID-Selifie-B and another larger dataset, most of whose classes have only two images (a pair of ID and selfie):
## Contact
Yichun Shi: shiyichu **at** msu **dot** edu