Pytorch0.4.1 codes for InsightFace
- This repo is a reimplementation of Arcface(paper), or Insightface(github)
- For models, including the pytorch implementation of the backbone modules of Arcface and MobileFacenet
- Codes for transform MXNET data records in Insightface(github) to Image Datafolders are provided
- Pretrained models are posted, include the MobileFacenet and IR-SE50 in the original paper
IR-SE50 @ BaiduNetdisk, IR-SE50 @ Onedrive
LFW(%) | CFP-FF(%) | CFP-FP(%) | AgeDB-30(%) | calfw(%) | cplfw(%) | vgg2_fp(%) |
---|---|---|---|---|---|---|
0.9952 | 0.9962 | 0.9504 | 0.9622 | 0.9557 | 0.9107 | 0.9386 |
Mobilefacenet @ BaiduNetDisk, Mobilefacenet @ OneDrive
LFW(%) | CFP-FF(%) | CFP-FP(%) | AgeDB-30(%) | calfw(%) | cplfw(%) | vgg2_fp(%) |
---|---|---|---|---|---|---|
0.9918 | 0.9891 | 0.8986 | 0.9347 | 0.9402 | 0.866 | 0.9100 |
-
clone
git clone https://github.com/TropComplique/mtcnn-pytorch.git
Provide the face images your want to detect in the data/face_bank folder, and guarantee it have a structure like following:
data/facebank/
---> id1/
---> id1_1.jpg
---> id2/
---> id2_1.jpg
---> id3/
---> id3_1.jpg
---> id3_2.jpg
If more than 1 image appears in one folder, an average embedding will be calculated
download the refined dataset: (emore recommended)
- emore dataset @ BaiduDrive, emore dataset @ Dropbox
- More Dataset please refer to the original post
Note: If you use the refined MS1M dataset and the cropped VGG2 dataset, please cite the original papers.
-
after unzip the files to 'data' path, run :
python prepare_data.py
after the execution, you should find following structure:
faces_emore/
---> agedb_30
---> calfw
---> cfp_ff
---> cfp_fp
---> cfp_fp
---> cplfw
--->imgs
---> lfw
---> vgg2_fp
-
- download the desired weights to model folder:
-
2 to take a picture, run
python take_pic.py -n name
press q to take a picture, it will only capture 1 highest possibility face if more than 1 person appear in the camera
-
3 or you can put any preexisting photo into the facebank directory, the file structure is as following:
- facebank/
name1/
photo1.jpg
photo2.jpg
...
name2/
photo1.jpg
photo2.jpg
...
.....
if more than 1 image appears in the directory, average embedding will be calculated
-
4 to start
python face_verify.py
```
python infer_on_video.py -f [video file name] -s [save file name]
```
the video file should be inside the data/face_bank folder
- Video Detection Demo @Youtube
```
python train.py -b [batch_size] -lr [learning rate] -e [epochs]
# python train.py -net mobilefacenet -b 200 -w 4
```
- This repo is mainly inspired by deepinsight/insightface and InsightFace_TF
Packaging this project to insight-face-pytorch, so that you can import insight-face-pytorch to do inference in other projects, e.g. https://github.com/livingbio/face_model
python setup.py sdist bdist_wheel
ls dist/
insight_face_pytorch-0.1.dev52+g07dc082.d20190213-py3-none-any.whl insight-face-pytorch-0.1.dev52+g07dc082.d20190213.tar.gz
twine upload --repository-url https://pypi-dot-living-bio.appspot.com dist/*
export PIP_EXTRA_INDEX_URL=https://gliacloud:[email protected]/pypi
pip install insight-face-pytorch
- Face detection: https://github.com/livingbio/face_model/blob/master/face_detection.py
- Face recognition: https://github.com/livingbio/face_model/blob/master/face_recognition.py
- PRs are welcome, in case that I don't have the resource to train some large models like the 100 and 151 layers model
- Email : [email protected]