Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/foamliu/InsightFace-v2
PyTorch implementation of Additive Angular Margin Loss for Deep Face Recognition.
https://github.com/foamliu/InsightFace-v2
face-recognition
Last synced: 4 months ago
JSON representation
PyTorch implementation of Additive Angular Margin Loss for Deep Face Recognition.
- Host: GitHub
- URL: https://github.com/foamliu/InsightFace-v2
- Owner: foamliu
- License: apache-2.0
- Created: 2019-01-31T03:46:09.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2022-12-17T04:14:54.000Z (about 2 years ago)
- Last Synced: 2024-08-01T13:32:17.123Z (7 months ago)
- Topics: face-recognition
- Language: Python
- Homepage:
- Size: 7.93 MB
- Stars: 323
- Watchers: 14
- Forks: 76
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# InsightFace
data:image/s3,"s3://crabby-images/40b13/40b131827468351d8bfc350dd019ac04c5ed0237" alt="apm"
PyTorch implementation of Additive Angular Margin Loss for Deep Face Recognition.
[paper](https://arxiv.org/pdf/1801.07698.pdf).
```
@article{deng2018arcface,
title={ArcFace: Additive Angular Margin Loss for Deep Face Recognition},
author={Deng, Jiankang and Guo, Jia and Niannan, Xue and Zafeiriou, Stefanos},
journal={arXiv:1801.07698},
year={2018}
}
```
## DatasetFunction|Dataset|
|---|---|
|Train|MS-Celeb-1M|
|Test-1|LFW|
|Test-2|MegaFace|### Introduction
MS-Celeb-1M dataset for training, 3,804,846 faces over 85,164 identities.
## Dependencies
- Python 3.6.8
- PyTorch 1.3.0## Usage
### Data wrangling
Extract images, scan them, to get bounding boxes and landmarks:
```bash
$ python extract.py
$ python pre_process.py
```Image alignment:
1. Face detection(MTCNN).
2. Face alignment(similar transformation).
3. Central face selection.
4. Resize -> 112x112.Original | Aligned & Resized | Original | Aligned & Resized |
|---|---|---|---|
|data:image/s3,"s3://crabby-images/0ef0d/0ef0d4b3fd4e193f86a9b1dcb6c2ea193192441f" alt="image"|data:image/s3,"s3://crabby-images/0e473/0e4736080ff1dd0dd55f706157cd584fbb2dcfea" alt="image"|data:image/s3,"s3://crabby-images/35232/3523249b0a8e7596c6609341b1d4f904a47d12e3" alt="image"|data:image/s3,"s3://crabby-images/38f35/38f35a4bbda7f9d2632015fd8f133f1e5c4e2d01" alt="image"|
|data:image/s3,"s3://crabby-images/71dc9/71dc992916f61e6d1cba9b6becffe68aaa75faaa" alt="image"|data:image/s3,"s3://crabby-images/9421f/9421fed98d9d7ed2b63ebbda8b91ae64d29eaccc" alt="image"|data:image/s3,"s3://crabby-images/b4b2b/b4b2b78a167a743bdcfce0e06d520daf7e57e3e0" alt="image"|data:image/s3,"s3://crabby-images/2d33a/2d33a5a0c341aa313a51f963628ef9306008ab8b" alt="image"|
|data:image/s3,"s3://crabby-images/e1ee5/e1ee5c95074cd10c6eb318423b08f2a9a38c8f78" alt="image"|data:image/s3,"s3://crabby-images/c4cf4/c4cf4870801704697c1a584e83260a4f711835b4" alt="image"|data:image/s3,"s3://crabby-images/cbf7b/cbf7b6ac771339aa824111e0082e5e6f9240e49e" alt="image"|data:image/s3,"s3://crabby-images/b40f6/b40f63576a983ebcf25b96a3283837a5250f652a" alt="image"|
|data:image/s3,"s3://crabby-images/2267a/2267a5d127aa782969cee852961e171762a30dcf" alt="image"|data:image/s3,"s3://crabby-images/11972/119728e4a3ee620d6c815537ee7a04de28d8d5e6" alt="image"|data:image/s3,"s3://crabby-images/d5e51/d5e514437fa65a2f1d5a673f5029a6de6ff8b454" alt="image"|data:image/s3,"s3://crabby-images/0a5d0/0a5d0807d54967c7e5b4933be077d605ed5a08d6" alt="image"|
|data:image/s3,"s3://crabby-images/94d6a/94d6ad83c9577b3b0b527b200adfb1067b3ad293" alt="image"|data:image/s3,"s3://crabby-images/7359b/7359b872ebea4378fed08fc28cd47e961fd5aedb" alt="image"|data:image/s3,"s3://crabby-images/e66f9/e66f9b2fcbca3eb87ad2ab975a06c5995d940f4a" alt="image"|data:image/s3,"s3://crabby-images/02993/029937589451c0814ab4be4bc084e7b12887c29b" alt="image"|### Train
```bash
$ python train.py
```To visualize the training process:
```bash
$ tensorboard --logdir=runs
```## Performance evaluation
### LFW
#### Introduction
Use Labeled Faces in the Wild (LFW) dataset for performance evaluation:- 13233 faces
- 5749 identities
- 1680 identities with >=2 photo#### Download
Download LFW database put it under data folder:
```bash
$ wget http://vis-www.cs.umass.edu/lfw/lfw-funneled.tgz
$ wget http://vis-www.cs.umass.edu/lfw/pairs.txt
$ wget http://vis-www.cs.umass.edu/lfw/people.txt
```#### Start evaluation
```bash
$ python lfw_eval.py
```#### Results
Backbones|LFW(%)|Inference speed(*)|
|---|---|---|
|SE-LResNet101E-IR|99.83%|46.63 ms|
|SE-LResNet50E-IR|99.75%|27.30 ms|
|SE-LResNet18E-IR|99.65%|17.53 ms|Note(*): with 1 Nvidia Tesla P100.
#### theta j Distribution
data:image/s3,"s3://crabby-images/68f62/68f622eda12583a4d862c8232cc4b3550223429a" alt="image"
#### Error analysis
See also [LFW Face Database Errata](http://vis-www.cs.umass.edu/lfw/index.html#errata)##### False Positive
2 false positives:1|2|1|2|
|---|---|---|---|
|data:image/s3,"s3://crabby-images/6587b/6587bc88aa66bba79be2aeb929a7fde75f6773a7" alt="image"|data:image/s3,"s3://crabby-images/6b892/6b8928b65c4d5be769a05829ff5f8463ece8200f" alt="image"|data:image/s3,"s3://crabby-images/e43db/e43db6f52cb04bb3d7589204a19afa7ab71095cb" alt="image"|data:image/s3,"s3://crabby-images/be895/be8953aeb995349433e158da1232ffe90660e871" alt="image"|
|data:image/s3,"s3://crabby-images/8ed13/8ed135a1bea2fecb4e5f94ad1722ab54712cacb8" alt="image"|data:image/s3,"s3://crabby-images/9b7fe/9b7fec3b1930f5f17257134d1baaae105c5b0af0" alt="image"|data:image/s3,"s3://crabby-images/02de9/02de9f426909ad039fd99924c06c6784734d95aa" alt="image"|data:image/s3,"s3://crabby-images/4ae36/4ae36155aad078b4deecd3d0aeda46da79e427af" alt="image"|##### False Negative
8 false negative:1|2|1|2|
|---|---|---|---|
|data:image/s3,"s3://crabby-images/47452/474521b370e09123bd5a4709ff0b5637f225f4f5" alt="image"|data:image/s3,"s3://crabby-images/e5cdf/e5cdf864cddeff3e8d0b4b4d46ac70b5d11a0bc5" alt="image"|data:image/s3,"s3://crabby-images/9797f/9797fe1a6e972f4b447f037e134a26e620f9a3df" alt="image"|data:image/s3,"s3://crabby-images/90646/906464e3fff181bf76664878302c6fc50aea1475" alt="image"|
|data:image/s3,"s3://crabby-images/72deb/72deb02129e26c9ccc45aede45ce6ade92b5a23b" alt="image"|data:image/s3,"s3://crabby-images/e054e/e054e8ba56aa3469f66405013f9dac969d79a1ee" alt="image"|data:image/s3,"s3://crabby-images/60178/60178006ffed3e45d8d50e8eec93228ee9d07b06" alt="image"|data:image/s3,"s3://crabby-images/f6434/f6434c94a323a74603b570a428df051376a295d1" alt="image"|
|data:image/s3,"s3://crabby-images/89e53/89e5346ecf61304830d673aa3d4bcbd00f8d4f1b" alt="image"|data:image/s3,"s3://crabby-images/78dac/78dace0b7aa91bf54bb1d010d13a7df2f8f2abe3" alt="image"|data:image/s3,"s3://crabby-images/51aa0/51aa0b5051a8a2b1987d374df33fce176aafb20a" alt="image"|data:image/s3,"s3://crabby-images/18e76/18e76ea8a22e1d2c5b3736e986b906b465ebbe9d" alt="image"|
|data:image/s3,"s3://crabby-images/cab1b/cab1b79005e53c07152339d049bd84a862508e47" alt="image"|data:image/s3,"s3://crabby-images/f7bb9/f7bb9261f3a3ffd974f0994e654e45eedd6e1e88" alt="image"|data:image/s3,"s3://crabby-images/f0cfe/f0cfefe58e8398b1edf015069d07d2ac75358b84" alt="image"|data:image/s3,"s3://crabby-images/b0546/b05469f2439e618bddaec142795fba4042d5ff12" alt="image"|
|data:image/s3,"s3://crabby-images/e2749/e274914985f41aa55a74530fdfeb36aa96ef363d" alt="image"|data:image/s3,"s3://crabby-images/40c47/40c4763331d1c5a9e56cd3218f5965f03c7386ad" alt="image"|data:image/s3,"s3://crabby-images/0dd7c/0dd7ccfbe5279667bac41371bbd2eee88389a026" alt="image"|data:image/s3,"s3://crabby-images/42d53/42d53b421481a3c0878bb8b3aac2a292fa9ab4fd" alt="image"|
|data:image/s3,"s3://crabby-images/5466a/5466a4966a88b3901b533cd159e1aa6749df53e0" alt="image"|data:image/s3,"s3://crabby-images/aa104/aa104cd1108ae647cef5a00df66987f7f6e0e9d4" alt="image"|data:image/s3,"s3://crabby-images/b72b1/b72b1dbfe30202dd760cb2bf6a0cf6bdad08e155" alt="image"|data:image/s3,"s3://crabby-images/503c2/503c2996b47a4a6151e6db3f02e3ffe216916adc" alt="image"|
|data:image/s3,"s3://crabby-images/ba4d9/ba4d9470c8d7e8ff2399115ae20bd827cbb6a8d0" alt="image"|data:image/s3,"s3://crabby-images/7ad21/7ad212e617ed8daf4ade5673583730002c6c0146" alt="image"|data:image/s3,"s3://crabby-images/eda58/eda58b9a33c0e423bc6a8591519f0f28c1202dab" alt="image"|data:image/s3,"s3://crabby-images/6e511/6e511e1575df2d0f3a3d35659f99b2374ee253f9" alt="image"|
|data:image/s3,"s3://crabby-images/960b0/960b09256ebb444d649f87cdecbffabdac70b6b8" alt="image"|data:image/s3,"s3://crabby-images/9db72/9db72aa0dc4c8b7d23c5dd9d08b82df58262980a" alt="image"|data:image/s3,"s3://crabby-images/fe907/fe9075c875cf405f5f70b25afd9c2a14d24b121e" alt="image"|data:image/s3,"s3://crabby-images/d8978/d89786b009c562540d4d7958d0b43ef4b8bafe24" alt="image"|### MegaFace
#### Introduction
MegaFace dataset includes 1,027,060 faces, 690,572 identities. [Link](http://megaface.cs.washington.edu/)
Challenge 1 is taken to test our model with 1 million distractors.data:image/s3,"s3://crabby-images/d8311/d831106aa8dc8c1834405d5eb348c3e0e2061827" alt="image"
#### Download1. Download MegaFace and FaceScrub Images
2. Download Linux DevKit from [MagaFace WebSite](http://megaface.cs.washington.edu/) then extract to megaface folder:```bash
$ tar -vxf linux-devkit.tar.gz
```
#### Generate features1. Crop MegaFace.
2. Generate features for FaceScrub and MegaFace.
3. Remove noises.
Note: we used the noises list proposed by InsightFace, at https://github.com/deepinsight/insightface.```bash
$ python3 megaface.py --action crop_megaface$ find megaface/facescrub_images -name "*.bin" -type f -delete
$ find megaface/MegaFace_aligned/FlickrFinal2 -name "*.bin" -type f -delete$ python3 megaface.py --action gen_features
```#### Evaluation
Start MegaFace evaluation through devkit:
```bash
$ cd megaface/devkit/experiments
$ python run_experiment.py -p /dev/code/mnt/InsightFace-v2/megaface/devkit/templatelists/facescrub_uncropped_features_list.json /dev/code/mnt/InsightFace-v2/megaface/MegaFace_aligned/FlickrFinal2 /dev/code/mnt/InsightFace-v2/megaface/facescrub_images _0.bin results -s 1000000
```#### Results
##### Curves
Draw curves with matlab script @ megaface/draw_curve.m.
CMC|ROC|
|---|---|
|data:image/s3,"s3://crabby-images/337ba/337ba969e58f6ef60d9d8b7d5476e5e3249b09f8" alt="image"|data:image/s3,"s3://crabby-images/42d33/42d3319b0e0c988135495bad0d9f8292983fd21e" alt="image"|
|data:image/s3,"s3://crabby-images/f65b2/f65b27f62f759873366991ce484f1f00b6586c41" alt="image"|data:image/s3,"s3://crabby-images/8960c/8960c586015d287ba085ce7561b997ea212ba990" alt="image"|##### Textual results
Done matching! Score matrix size: 3379 972313
Saving to results/otherFiles/facescrub_megaface_0_1000000_1.bin
Computing test results with 1000000 images for set 1
Loaded 3379 probes spanning 80 classes
Loading from results/otherFiles/facescrub_facescrub_0.bin
Probe score matrix size: 3379 3379
distractor score matrix size: 3379 972313
Done loading. Time to compute some stats!
Finding top distractors!
Done sorting distractor scores
Making gallery!
Done Making Gallery!
Allocating ranks (972393)Rank 1: 0.964733