Skip to content

MaxKinny/kaggle_SMILE-Kinship-Recognizing

Repository files navigation

Deep Neural Networks for Kinship prediction using face photos

Code for : https://towardsdatascience.com/deep-neural-networks-for-kinship-prediction-using-face-photos-f2ad9ab53834

Requirements :

Keras 2

keras_vggface

to install keras_vggface => "pip install git+https://github.com/rcmalli/keras-vggface.git"

Data :

The data is available at : https://www.kaggle.com/c/recognizing-faces-in-the-wild/data

It needs to be dezipped into the folder input

Description

Can we predict if two people are blood related given just a photo of their face ?
This is what will try to do in this post by using the Families In the Wild: A Kinship Recognition Benchmark dataset in the format shared on Kaggle : https://www.kaggle.com/c/recognizing-faces-in-the-wild/data

We will explore the effectiveness deep neural networks and transfer learning techniques to train a neural network that will predict if two people are blood related or not given a picture of their face.

Dataset :

We will use the Families in the Wild dataset shared on kaggle. It is the biggest scale data set of its kind where face photos are grouped by person and then people are grouped by family.

Image organization in the FIW dataset

Other than the image folders we also have a file that lists all the cases where two people from a family are blood related, which is not the case for all members of the family. (Like the pair mother-father, unless we are talking about Lannisters 😄 )

Model :

In order to solve this task we will use a Siamese network that takes a pair of images and predict 1 if the people in the photos are related and 0 otherwise.

Siamese Network

The image encoder is applied to each input image and encodes each of them into a fixed length vector. The square of the difference between the two image vectors are fed into a fully connected layer which then predicts a binary label of kinship.

Example of input/output

Transfer Learning :

We will base our solution on pretrained image encoders using two different settings :

Pretraining on ImageNet : A data-set of 14 million manually labeled images used for classification into categories like dog, cat, airplane, strawberry …

Pretraining on VGGFACE2 : A data-set of 3.3 million face images and 9000+ identities in a a wide range of different ethnicities, accents, professions and ages.

Pretraining techniques are useful because they allow us to transfer representations learned on a source task ( here image classification or regression ) into a target task which is kinship prediction in this case.
This helps reduce over-fitting and achieve a much faster convergence rate, especially if the source task and target task are somewhat close.

Results :

We will use the accuracy and AUC Score to evaluate the results of each model.

Resnet50 Imagenet test ROC AUC : 0.70

Evaluation on the test set through kaggle submission

Resnet50 VGGFACE2 test ROC AUC : 0.81

Evaluation on the test set through kaggle submission

Validation Accuracy Comparison

We can see that even the architecture in the two different settings is the same the results are much better on the model pretrained on VGGFace2 since its a source task that is much closer to the target task of kinship prediction compared to Imagenet.

Conclusion :

We showed that we can train a Siamese network to predict if two people are blood related or not. By using transfer learning we were able to achieve encouraging results of 0.81 in AUC ROC, especially given that the task of kinship 👪 prediction is pretty hard even for humans.

vgg_face_splitmodel_kfold.py usage:

Firstly, use argument "CreateKF" to create the division:

python vgg_face_splitmodel_kfold.py --CreateKF True --<other arguments> <values>

Secondly, use argument "SelectedK" to select validation part to feed into different GPUs. Suppose you have 4 GPUs and K = 4(4-folds), then input these respectively:

CUDA_VISIABLE_DEVICES=0 python vgg_face_splitmodel_kfold.py --SelectedK 1 --CreateKF False --<other arguments> <values>
CUDA_VISIABLE_DEVICES=1 python vgg_face_splitmodel_kfold.py --SelectedK 2 --CreateKF False --<other arguments> <values>
CUDA_VISIABLE_DEVICES=2 python vgg_face_splitmodel_kfold.py --SelectedK 3 --CreateKF False --<other arguments> <values>
CUDA_VISIABLE_DEVICES=3 python vgg_face_splitmodel_kfold.py --SelectedK 4 --CreateKF False --<other arguments> <values>

After training, you will get 4 models with different validation part. Tip: The index of SelectedK starts from 1!

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •