Face detection wrapper using hybrid margin-based region of interest (MROI) approach."
Project description
Automatic Installation
You can install the hybrid MROI face detection wrapper using pip
:
pip install mroi-fd
Manual Installation
This project is developed and tested on python version 3.7.4
. Please check
your python version using python --version
. If your system has a different
python version, you may want to consider using
pyenv (See Using pyenv)
First, clone and cd
into the repository:
git clone https://gitlab.com/ailabuser/bacha_hybrid_mroi_face_detection
cd bacha_hybrid_mroi_face_detection
On Windows:
Create a python virtual environment:
mkvirtualenv venv
Activate the virtual environment (deactivate
to deactivate the virtual
environment):
workon venv
Install all the required dependencies while still having the virtual environment active:
pip install -r requirements.txt
On Linux:
Create a python virtual environment:
virtualenv -p /usr/bin/python3 venv
Activate the virtual environment (deactivate
to deactivate the virtual
environment):
source venv/bin/activate
Install all the required dependencies while still having the virtual environment active:
pip install -r requirements.txt
Using pyenv (Linux, Windows, MacOS)
If your python version is not 3.7.4, you may want to use
pyenv. After you have installed pyenv
,
install the specific python version. On Linux, this can be done by running the
following command:
env PYTHON_CONFIGURE_OPTS="--enable-shared" pyenv install 3.7.4
Then, create a virtual environment:
pyenv virtualenv 3.7.4 bacha_mroi_face_detection
You can activate the virtual environment using pyenv
like so:
pyenv activate bacha_mroi_face_detection
Description
The face detection technique used hybrid margin-based region of interest (MROI) approach. It is hybrid in the sense that the implementation runs one main routine to detect a face, but switch to an escape routine when the main routine fails. Using MROI increase the face detection speed by having the selected face detection algorithm to only consider a sub-region (where a face was previously detected) instead of the full frame.
There are three pre-defined selection of main routines available for you to use:
- Haar cascade classifier
- Joint cascade
- Multi-task Convolutional Neural Network (MTCNN)
When the main routine failed to detect a face, the implementation switch to the escape routine which runs template matching algorithm.
Example
Using the hybrid MROI for your face detection implementation
In order to use your face detection algorithm with the hybrid MROI face
detector, you need to create a subclass which inherit the FaceDetector
class,
and override its detect
method. The implementation requires thedetect
method to return either a face ROI or None
; otherwise, the hybrid MROI face
detector may fail.
Here's an example, in which we use a python implementation of MTCNN:
import cv2
from mtcnn.mtcnn import MTCNN
from mroi_fd import FaceDetector
class MROI_MTCNN(FaceDetector):
def __init__(self):
# The main routine face detector object used to detect faces.
fd_obj = MTCNN()
# Initialize using base class constructor. We pass the face detector
# object (fd_obj) and use the MROI with fixed-margin approach with
# a template matching escape routine.
super().__init__(fd_obj, mode=FaceDetector.FMTM)
@staticmethod
def detect(fd_obj, image):
rgb_src = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
result = fd_obj.detect_faces(rgb_src)
if len(result) > 0:
return result[0]['box']
else:
return None
Internally, this was basically how the pre-defined hyrbid MROI face detectors
(i.e., MROI_HaarCascade
and MROI_MTCNN
) was defined. Simply import them with
from mroi_fd import MROI_HaarCascade, MROI_MTCNN
Running the face detector
To use the face detector, simply instantiate the hybrid MROI face detector and
run it by invoking its run
method. Below is a simple script that runs the
face detector and feed it images in a loop.
fd = MROI_MTCNN()
fd.run() # This runs the face detector in the background.
cap = cv2.VideoCapture("/path/to/video/file")
while True:
ret, frame = cap.read()
# No more images; exit.
if not ret:
break
# Feed the image into the face detector.
fd.input_image(frame)
# Get the ROI containing the face. This will be `None` if no face is
# detected.
ROI = fd.get_face_region()
if ROI is not None:
x, y, w, h = ROI
cv2.rectangle(frame, (x, y), (x+w, y+h), (0, 255, 0), 2)
cv2.imshow("MROI_MTCNN Face Detector", frame)
if cv2.waitKey(1) == ord('q'):
break
fd.clean()
cap.release()
cv2.destroyAllWindows()
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file mroi-fd-1.0.0.post3.tar.gz
.
File metadata
- Download URL: mroi-fd-1.0.0.post3.tar.gz
- Upload date:
- Size: 8.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2 requests-toolbelt/0.9.1 tqdm/4.39.0 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3f62508ea4290270aa2950f9068aae709514e05693cd3d2ce436e5fa7e77069a |
|
MD5 | bded07f35b0b51eea7ed17687c59088d |
|
BLAKE2b-256 | bb89817c6eea6fd364ae4cbba6eeee45efe9135f6dbe158fd1602c8378d1235e |
File details
Details for the file mroi_fd-1.0.0.post3-py3-none-any.whl
.
File metadata
- Download URL: mroi_fd-1.0.0.post3-py3-none-any.whl
- Upload date:
- Size: 12.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2 requests-toolbelt/0.9.1 tqdm/4.39.0 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ddd7744705f1a210d813b2c5e293c13ed8da9868ace0455867e083cb0da7fa67 |
|
MD5 | c139536a567b097e74909230773d0fbe |
|
BLAKE2b-256 | f5be9e386e0b6289a8895dde8598c65cae606840fc7f1e7f508196368cc3cee7 |