Face Detection in just 5 lines of code

栏目: IT技术 · 发布时间: 4年前

Face Detection in just 5 lines of code

Recognize and Manipulate faces with the world’s simplest face recognition python library.

Face Detection in just 5 lines of code

Detected faces from an image of a group of kids in Indonesia. Image by Pixabay.

F ace detection is a computer technology part of deep learning. It identifies human faces in digital images or video scenes. It is used in a variety of applications such as Facial Recognition, Unlock smartphones, Smart advertising, Emotional inference , and many more.

Deep learningis a subset of machine learning in artificial intelligence (AI) that has networks capable of learning unsupervised from data that is unstructured or unlabeled.

“COMPUTERS ARE NOW ABLE TO SEE, HEAR AND LEARN. WELCOME TO THE FUTURE!“ — Dave Waters

In this beginner’s tutorial, we are going to learn how to install and configure python environment, use Integrated Development Environments (IDEs) to debug and run our python code. Then we will use widely popular face detection and manipulation library face-recognition by Adam Geitgey . We will customize the images with different colors and border shapes around the detected faces . It is built using dlib ’s state-of-the-art face recognition with deep learning. The model has an accuracy of 99.38% on the Labeled Faces in the Wild benchmark.

TL;DRThis tutorial is for absolute beginners , even if you are a fresh graduate or someone looking forward to starting machine learning using python. Developers across the technology stack like Web and Mobile developers or Backend developers can also follow this article with ease. So, Let’s begin our new brief code journey.

Environment Configuration and Installation

At first, we need to download the latest stable version of Python .

There are usually 2 famous ways to configure python environments and install packages in our computers — pip or condo.

A python package contains all the files you need for a module. Modules are Python code libraries you can include in your project.

  1. PIP - a package manager for Python packages.
  2. Anaconda - a complete python environment solution to run different versions and manage all python packages. Using Anaconda Navigator, you can install and manage all packages in your computers.

You can follow anyone or both among these.

Code Editor and IDE

Apart from basic python REPL (command-line interface), we can run our python program in any of these two professional editors-

  1. PyCharm - Download popular Python IDE for Professional Developers and start. It’s like other famous IDE out there and simple to start and use.
  2. Jupyter Notebooks - Widely used web-based code editor by programmers and professional trainers.

To install Jupyter Notebook using conda-

conda install -c conda-forge notebook

or install using pip and then run Jupiter notebook to run it-

pip install notebook
jupyter notebook

That's enough for us to start writing our first Python program and run it. You can use any one of the above editors. We are going to use PyCharm to write code with the pip package manager to install packages in our tutorial.

So, let’s commence detecting faces in any given images and photos. Ain't you excited?:grinning:

Gif by giphy.com

Firstly, let’s install the required libraries for our code to work. We will install and import only 2 libraries.

  1. Pillow - The friendly PIL fork (Python Imaging Library).
  2. Face_recognition - To detect faces in the image.
pip install Pillowpip install face-recognition

You can create a new file of type python (with the extension .py ) or a new notebook in Jupyter Notebooks to start coding — face_detection.py . In case, it requires other dependent libraries, you can simply install them too using pip or conda.

Let’s import above libraries in our code -

import PIL.Image
import PIL.ImageDraw
import face_recognition

Line 1

Let’s pick one image name GroupYoga.jpg (you can pick any image) in the same folder as our code file or else give the proper path of the image. We should load our image to the load_image_file() method from the face_recognition library which will convert it into a NumPy array of that image. Let’s assign it to the variable name given_image .

given_image = face_recognition.load_image_file('GroupYoga.jpg')

Line 2

Using face_locations() method from the same library, we will count the number of faces in the given_image and will print the length of total faces found in the image.

face_locations = face_recognition.face_locations(given_image)

number_of_faces = len(face_locations)
print("We found {} face(s) in this image.".format(number_of_faces))

Line 3

Now, to draw any shape on the image, we will convert the image to the Pillow library object using fromarray() method from PIL.Image.

pil_image = PIL.Image.fromarray(given_image)

Line 4

Now, we will run a for-in loop to print four pixel locations such as top, left, bottom & right of the detected faces.

for face_location in face_locations:
top, left, bottom, right = face_location
print("A face is detected at pixel location Top: {}, Left: {}, Bottom: {}, Right: {}".format(top, left, bottom, right))

Line 5

We will draw a green color rectangle box with width 10 around the faces. You can change the shape to polygon or ellipse also. So, in the same above loop write below 2 draw methods.

draw = PIL.ImageDraw.Draw(pil_image)
draw.rectangle([left, top, right, bottom], outline="green", width=10)

Now, just use the variable pil_image to display our new image with detected faces using a rectangular border around them.

pil_image.show()

The new temporary image will be open automatically on your computer (if everything is set up correctly). It should be something like below image -

Face Detection in just 5 lines of code

Detected faces of Women doing yoga. Image by Pexels.

Bingo! :tada:

In case, you get stuck with any compile time or run time issues and environment configuration issues, you can write in the response section below or connect with me.

Now, let’s recollect all the above small code snippets into one file conjointly which is ready to run in any python environment. Let’s use the school kids image(as featured in the cover of the article)-

Complete Code in face_detection.py

If you run the above file(run button in PyCharm or Notebook), if everything goes fine (I mean compile or runtime errors), you are going to get the below output at the console of your editor -

Console Output in PyCharm

That’s it. Our simplest face detection :performing_arts: code is ready to recognize faces from any given photos. You can customize the above code by changing colors, border types, and width. I recommend to try customization and explore other methods and options.

Face_recognitionlibrary can also be used to put digital makeup on the faces, check the similar faces among a group of people and develop some games around these detected faces.

I am sure you will find it as one of the simplest face detection tutorial among all the tech posts available on the internet. you can go through the below resources for more details of this library. For other applications of this library, I shall write some other articles next time.

Resources:

Follow me on Medium and let’s be connected on LinkedIn ( @kapilraghuwansh i) and Twitter ( @techygeeek y) for more such interesting tech articles.


以上所述就是小编给大家介绍的《Face Detection in just 5 lines of code》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

参数化建筑设计

参数化建筑设计

高云河、白云生 / 华中科技大学出版社 / 2016-8-1 / 69.80

《参数化建筑设计》以案例的形式讲解参数化建筑设计的具体方法,其中包含犀牛(Rhino)和Grasshopper的应用。本书不单单是一本计算机软件教材,书中教会读者的是参数化建筑设计的思路,希望通过完成一个个案例使读者融会贯通,在今后的设计工作中能够熟练使用,辅助自身完成建筑设计。全书共有10个案例,循序渐进,由浅入深,几乎涵盖了参数化建筑设计所要使用的所有功能和方法。一起来看看 《参数化建筑设计》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

SHA 加密
SHA 加密

SHA 加密工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具