2014-02-10 02:23:44 +08:00
|
|
|
#!/usr/bin/python
|
|
|
|
# The contents of this file are in the public domain. See LICENSE_FOR_EXAMPLE_PROGRAMS.txt
|
|
|
|
#
|
2014-02-24 05:56:14 +08:00
|
|
|
# This example program shows how to find frontal human faces in an image. In
|
2014-03-09 00:32:12 +08:00
|
|
|
# particular, it shows how you can take a list of images from the command
|
|
|
|
# line and display each on the screen with red boxes overlaid on each human
|
|
|
|
# face.
|
2014-02-24 05:56:14 +08:00
|
|
|
#
|
|
|
|
# The examples/faces folder contains some jpg images of people. You can run
|
2014-12-11 17:44:50 +08:00
|
|
|
# this program on them and see the detections by executing the
|
|
|
|
# following command:
|
2014-02-24 05:56:14 +08:00
|
|
|
# ./face_detector.py ../examples/faces/*.jpg
|
|
|
|
#
|
|
|
|
# This face detector is made using the now classic Histogram of Oriented
|
|
|
|
# Gradients (HOG) feature combined with a linear classifier, an image
|
|
|
|
# pyramid, and sliding window detection scheme. This type of object detector
|
|
|
|
# is fairly general and capable of detecting many types of semi-rigid objects
|
|
|
|
# in addition to human faces. Therefore, if you are interested in making
|
|
|
|
# your own object detectors then read the train_object_detector.py example
|
|
|
|
# program.
|
|
|
|
#
|
|
|
|
#
|
2015-10-27 20:25:43 +08:00
|
|
|
# COMPILING/INSTALLING THE DLIB PYTHON INTERFACE
|
|
|
|
# You can install dlib using the command:
|
|
|
|
# pip install dlib
|
|
|
|
#
|
|
|
|
# Alternatively, if you want to compile dlib yourself then go into the dlib
|
|
|
|
# root folder and run:
|
|
|
|
# python setup.py install
|
|
|
|
# or
|
|
|
|
# python setup.py install --yes USE_AVX_INSTRUCTIONS
|
|
|
|
# if you have a CPU that supports AVX instructions, since this makes some
|
|
|
|
# things run faster.
|
|
|
|
#
|
|
|
|
# Compiling dlib should work on any operating system so long as you have
|
|
|
|
# CMake and boost-python installed. On Ubuntu, this can be done easily by
|
|
|
|
# running the command:
|
2014-12-11 17:44:50 +08:00
|
|
|
# sudo apt-get install libboost-python-dev cmake
|
2015-03-08 03:14:47 +08:00
|
|
|
#
|
|
|
|
# Also note that this example requires scikit-image which can be installed
|
|
|
|
# via the command:
|
2015-10-27 20:50:44 +08:00
|
|
|
# pip install scikit-image
|
2015-03-08 03:14:47 +08:00
|
|
|
# Or downloaded from http://scikit-image.org/download.html.
|
2014-02-10 02:23:44 +08:00
|
|
|
|
2014-12-11 17:44:50 +08:00
|
|
|
import sys
|
|
|
|
|
|
|
|
import dlib
|
2014-02-10 02:23:44 +08:00
|
|
|
from skimage import io
|
|
|
|
|
|
|
|
|
|
|
|
detector = dlib.get_frontal_face_detector()
|
|
|
|
win = dlib.image_window()
|
|
|
|
|
|
|
|
for f in sys.argv[1:]:
|
2014-12-11 17:44:50 +08:00
|
|
|
print("Processing file: {}".format(f))
|
2014-02-10 02:23:44 +08:00
|
|
|
img = io.imread(f)
|
2014-02-24 05:56:14 +08:00
|
|
|
# The 1 in the second argument indicates that we should upsample the image
|
|
|
|
# 1 time. This will make everything bigger and allow us to detect more
|
|
|
|
# faces.
|
2014-12-11 17:44:50 +08:00
|
|
|
dets = detector(img, 1)
|
|
|
|
print("Number of faces detected: {}".format(len(dets)))
|
2015-03-29 11:16:54 +08:00
|
|
|
for i, d in enumerate(dets):
|
2014-12-11 17:44:50 +08:00
|
|
|
print("Detection {}: Left: {} Top: {} Right: {} Bottom: {}".format(
|
2015-03-29 11:16:54 +08:00
|
|
|
i, d.left(), d.top(), d.right(), d.bottom()))
|
2014-02-10 02:23:44 +08:00
|
|
|
|
|
|
|
win.clear_overlay()
|
|
|
|
win.set_image(img)
|
|
|
|
win.add_overlay(dets)
|
2015-03-23 06:45:08 +08:00
|
|
|
dlib.hit_enter_to_continue()
|
2015-03-29 11:16:54 +08:00
|
|
|
|
|
|
|
|
|
|
|
# Finally, if you really want to you can ask the detector to tell you the score
|
|
|
|
# for each detection. The score is bigger for more confident detections.
|
|
|
|
# Also, the idx tells you which of the face sub-detectors matched. This can be
|
|
|
|
# used to broadly identify faces in different orientations.
|
|
|
|
if (len(sys.argv[1:]) > 0):
|
|
|
|
img = io.imread(sys.argv[1])
|
|
|
|
dets, scores, idx = detector.run(img, 1)
|
|
|
|
for i, d in enumerate(dets):
|
|
|
|
print("Detection {}, score: {}, face_type:{}".format(
|
|
|
|
d, scores[i], idx[i]))
|
|
|
|
|