This is a pre-production deployment of Warehouse. Changes made here affect the production instance of PyPI (pypi.python.org).
Help us improve Python packaging - Donate today!

Fusion of spoofing counter measures for the REPLAY-ATTACK database (competition entry for 2nd competition on counter measures to 2D facial spoofing attacks, ICB 2013)

Project Description
===============================================================
Fusing counter-measures for detecting attacks in Replay-Attack
===============================================================

This package implements:
- cropping face bounding boxes from Replay-Attack database
- extracting GLCM features for spoofing detection
- generating classification scores for the features using SVM and LDA
- extracting other types of features using other satellite packages it depends on
- calculating Q-statistics and fusing classification scores at score-level using other satellite package it depends on.

This satellite package depends on the following satellite packages: antispoofing.lbp <https://pypi.python.org/pypi/antispoofing.lbp>_ , antispoofing.lbptop <https://pypi.python.org/pypi/antispoofing.lbptop>_ , antispoofing.motion <https://pypi.python.org/pypi/antispoofing.motion>_ , antispoofing.fusion <https://pypi.python.org/pypi/antispoofing.fusion>_ , antispoofing.utils <https://pypi.python.org/pypi/antispoofing.utils/>_ . This dependence enables an interface for the scripts in these satellite packages through antispoofing.competition_icb2013, which means easy spoofing score generation using different types of features, as well as analysis of the common errors and fusion of the methods at score-level.

The fused system consisting of several of these counter-measures is submitted to the The 2nd competition on counter measures to 2D facial spoofing attacks, in conjuction with ICB 2013.

If you use this package and/or its results, please cite the following
publications:

1. Bob as the core framework used to run the experiments::

@inproceedings{Anjos_ACMMM_2012,
author = {A. Anjos AND L. El Shafey AND R. Wallace AND M. G\"unther AND C. McCool AND S. Marcel},
title = {Bob: a free signal processing and machine learning toolbox for researchers},
year = {2012},
month = oct,
booktitle = {20th ACM Conference on Multimedia Systems (ACMMM), Nara, Japan},
publisher = {ACM Press},
}

2. The 2nd competition on counter measures to 2D facial spoofing attacks::

@INPROCEEDINGS{Chingovska_ICB2013_2013,
author = {Chingovska, Ivana and others},
keywords = {Anti-spoofing, Competition, Counter-Measures, face spoofing, presentation attack},
title = {The 2nd competition on counter measures to 2D facial spoofing attacks},
booktitle = {International Conference of Biometrics 2013},
year = {2013}
}

If you wish to report problems or improvements concerning this code, please
contact the authors of the above mentioned papers.

Raw data
--------

The data used in the paper is publicly available and should be downloaded and
installed **prior** to try using the programs described in this package. Visit
the REPLAY-ATTACK database portal

Installation
------------

.. note::

note **the development tip of the package may not be stable** or become
unstable in a matter of moments.

Go to http://pypi.python.org/pypi/antispoofing.competition_icb2013
stable version of this package.

There are 2 options you can follow to get this package installed and
operational on your computer: you can use automatic installers like pip <http://pypi.python.org/pypi/pip/>_ (or easy_install
use zc.buildout <http://pypi.python.org/pypi/zc.buildout>_ to create a
virtual work environment just for this package.

Using an automatic installer
============================

Using pip is the easiest (shell commands are marked with a $ signal)::$ pip install antispoofing.competition_icb2013

You can also do the same with easy_install::

$easy_install antispoofing.competition_icb2013 This will download and install this package plus any other required dependencies. It will also verify if the version of Bob you have installed is compatible. This scheme works well with virtual environments by virtualenv <http://pypi.python.org/pypi/virtualenv>_ or if you have root access to your machine. Otherwise, we recommend you use the next option. Using zc.buildout ===================== Download the latest version of this package from PyPI <http://pypi.python.org/pypi/antispoofing.competition_icb2013>_ and unpack it in your working area. The installation of the toolkit itself uses buildout <http://www.buildout.org/>_. You don't need to understand its inner workings to use this package. Here is a recipe to get you started::$ python bootstrap.py
$./bin/buildout These 2 commands should download and install all non-installed dependencies and get you a fully operational test and development environment. .. note:: The python shell used in the first line of the previous command set determines the python interpreter that will be used for all scripts developed inside this package. Because this package makes use of Bob <http://idiap.github.com/bob>_, you must make sure that the bootstrap.py script is called with the **same** interpreter used to build Bob, or unexpected problems might occur. If Bob is installed by the administrator of your system, it is safe to consider it uses the default python interpreter. In this case, the above 3 command lines should work as expected. If you have Bob installed somewhere else on a private directory, edit the file buildout.cfg **before** running ./bin/buildout. Find the section named external and edit the line egg-directories to point to the lib directory of the Bob installation you want to use. For example:: [external] recipe = xbob.buildout:external egg-directories=/Users/crazyfox/work/bob/build/lib User Guide ---------- This section explains how to use the package in order to: a) crop face bounding boxes from Replay-Attack; b) calculate the GLCM features on Replay-Attack database; c) generate LBP, LBP-TOP and motion correlation features on Replay-Attack; d) generate classification scores using Linear Discriminant Analysis (LDA) and Support Vector Machines (SVM) and Multi-Layer perceptron (MLP); e) calculate common errors and Q-statistics for each of the features; f) perform fusion at score-level for the different classification scores. For generation of LBP, LBP-TOP and motion-correlation features, please refer to the corresponding satellite packages (antispoofing.lbp <https://pypi.python.org/pypi/antispoofing.lbp>_ , antispoofing.lbptop <https://pypi.python.org/pypi/antispoofing.lbptop>_ , antispoofing.motion <https://pypi.python.org/pypi/antispoofing.motion>_ respectively). For fusion at score-level, please refer to the corresponding satellite package (antispoofing.fusion <https://pypi.python.org/pypi/antispoofing.fusion>_). Crop face bounding boxes ======================== The features used in the paper are generated over the normalized face bounding boxes of the frames in the videos. The script to be used for face cropping and normalization is ./bin/crop_faces.py. It outputs .hdf5 files for each video, containing 3D numpy.array of pixel values of the normalized cropped frames. The first dimension of the array corresponds to the frames of the video files.::$ ./bin/crop_faces.py replay

To execute this script for the anonymized test-set, please call::

$./bin/crop_faces.py replay --ICB-2013 To see all the options for the scripts crop_faces.py. just type --help at the command line. If you want to see all the options for a specific database (e.g. protocols, lighting conditions etc.), type the following command (for Replay-Attack)::$ ./bin/calcglcm.py replay --help

This script uses the automatic face detections provided alongside Replay-Attack database. For frames with no detections, we copy the face detection from the previous frame (if there is one). In our work, we consider all the face bounding boxes smaller then 50x50 pixels as invalid detections (option --ff). Frames with no detected face or invalid detected face (<50x50 pixels) are set to Nan in our .hdf5 files. The face bounding boxes are normalized to 64x64 before storing (option -n).

Calculate the GLCM features
===========================

The first stage of the process is calculating the feature vectors on per-frame basis. The script operates on .hdf5 files as obtained using ./bin/crop_faces.py. The first dimension of the array corresponds to the frames of the video files.

The program to be used for calculating the GLCM features is ./bin/calcglcm.py::

$./bin/calcglcm.py replay To execute this script for the anonymized test-set, call::$ ./bin/calc_faces.py replay --ICB-2013

To see all the options for the scripts calcglcm.py just type --help at the command line. If you want to see all the options for a specific database (e.g. protocols, lighting conditions etc.), type the following command (for Replay-Attack)::

$./bin/calcglcm.py replay --help Classification with linear discriminant analysis (LDA) ====================================================== The classification with LDA is performed using the script ./bin/ldatrain.py. To execute the script with prior normalization and PCA dimensionality reduction as is done in the paper (for Replay-Attack), call::$ ./bin/ldatrain.py -r -n replay

If you want to normalize the output scores as well, just set the --ns option.

To execute this script for the anonymized test-set, call::

$./bin/ldatrain.py -r -n replay --ICB-2013 To reproduce our results, set the parameters cost=-1 (option -c -1) and gamma=3 (option -g 3) in the training of the SVM. This script can be used to calculate the LDA scores not only for GLCM, but also for any other features computed with any other of the satellite packages. To see all the options for this script, just type --help at the command line. Classification with support vector machine (SVM) ================================================ The classification with SVM is performed using the script ./bin/svmtrain.py. To execute the script with prior normalization of the data in the range [-1, 1] and PCA reduction as in the paper (for Replay-Attack), call::$ ./bin/svmtrain.py -n -r replay

If you want to normalize the output scores as well, just set the --ns option.

To call this script for the anonymized test-set, call::

$./bin/svmtrain.py -n -r replay --ICB-2013 To reproduce our results, set the parameters cost=-1 (option -c -1) and gamma=3 (option -g 3) in the training of the SVM. This script can be used to calculate the SVM scores not only for GLCM, but also for any other features computed with any other of the satellite packages. To see all the options for this script, just type --help at the command line. Bounding box countermeasure =========================== A fast countermeasure that takes account the area of the face bounding box as a feature.::$ ./bin/icb2013_facebb_countermeasure.py --input-dir [Database dir] -v [database]

Q-Statistic
===========

Fusion two or more countermeasures is one way to improve the classification performance. Kuncheva and Whitaker [1] shown the combination of statistically independent classifiers maximises the performance of a fusion and in order to measure this dependency, they proposed the Q-Statistic. For two countermeasures (A and B), the Q-Statistics can be defined.

.. math::

Q_{A,B} = \frac{N_{11}N_{00} - N_{01}N_{10}}{N_{11}N_{00} +N_{01}N_{10}}

where \mathcal{N} is the number of times that a countermeasure make a correct classification (\mathcal{N_1}) or make an incorrect classification (\mathcal{N_0}).

To run the Q-Statistic script call::

\$ ./bin/icb2013_qstatistic.py --input-dir [Set of scores of each countermeasure] -v [database]

Generating other types of features
==================================

This package depends on other satellite packages for calculating other types of features: LBP, LBP-TOP and motion correlation. To read more details and to generate these types of features, please refer to the corresponding satellite packages (antispoofing.lbp <https://pypi.python.org/pypi/antispoofing.lbp>_ , antispoofing.lbptop <https://pypi.python.org/pypi/antispoofing.lbptop>_ , antispoofing.motion <https://pypi.python.org/pypi/antispoofing.motion>_ respectively). Note that it is possoble to call the scripts belonging to these other satellite packages within antispoofing.competition_icb2013 satellite package.

To generate classificatio scores for the other types of features, you can use the methods provided by this or the other correponding satellite packages.

Fusion of counter-measures
==========================

The classification scores obtained using different features and classification techniques can be fused at score level. To read about the available fusion techniques as well as to perform the fusion, please refer to the corresponding satellite package antispoofing.fusion <https://pypi.python.org/pypi/antispoofing.fusion>_ . Note that you can call the scripts belonging to antispoofing.fusion satellite package within antispoofing.competition_icb2013 satellite package.

Generating error rates
======================

To calculate the threshold on the classification scores of a single or a fused counter-measure, use ./bin/eval_threshold.py. Note that as an input argument you need to give the file with the developments scores to evaluate the threshold. To calculate the error rates, use ./bin/apply_threshold.py. To see all the options for these two scripts,
just type --help at the command line.

References
----------

[1] L. I. Kuncheva and C. J. Whitaker, “Measures of diversity in classifier ensembles and their relationship with the ensemble accuracy,” Mach. Learn., vol. 51, pp. 181–207, May 2003.
Release History

This version

1.1.0

1.0.0