zoukankan      html  css  js  c++  java
  • OpenCV神技——人脸检测,猫脸检测

    简介

      OpenCV是一个基于BSD许可(开源)发行的跨平台计算机视觉库,可以运行在Linux、Windows、Android和Mac OS操作系统上。它轻量级而且高效——由一系列 C 函数和少量 C++ 类构成,同时提供了Python、Ruby、MATLAB等语言的接口,实现了图像处理和计算机视觉方面的很多通用算法。
      OpenCV的官方网址为:https://opencv.org/, 其Github网址为:https://github.com/opencv 。
      本文将会介绍OpenCV在人脸检测等方面的应用,使用的语言为Python。
      本文介绍的人脸检测使用OpenCV自带的Haar特征检测,训练好的模型的存放网址为:https://github.com/opencv/opencv/tree/master/data/haarcascades ,如下图:


    笔者将会介绍其中的人脸检测(haarcascade_frontalface_default.xml)和猫脸检测(haarcascade_frontalface.xml)。

    人脸检测

      利用OpenCV的Python接口实现人脸检测的流程如下:

    • 读取图片
    • 将图片转换为灰度模式,便于人脸检测
    • 利用Haar特征检测图片中的人脸
    • 绘制人脸的矩形区域
    • 显示人脸检测后的图片

      示例的Python代码如下:

    # -*- coding: utf-8 -*-
    import cv2
    import logging

    # 设置日志
    logging.basicConfig(level = logging.INFO, format='%(asctime)s - %(levelname)s: %(message)s')
    logger = logging.getLogger(__name__)

    # 待检测的图片路径
    ImagePath = 'E://zhoujielun.jpg'

    # 读取图片
    logger.info('Reading image...')
    image = cv2.imread(ImagePath)
    # 把图片转换为灰度模式
    gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

    # 探测图片中的人脸
    logger.info('Detect faces...')
    # 获取训练好的人脸的参数数据,进行人脸检测
    face_cascade = cv2.CascadeClassifier(r'./haarcascade_frontalface_default.xml')
    faces = face_cascade.detectMultiScale(gray,scaleFactor=1.15,minNeighbors=5,minSize=(33))

    search_info = "Find %d face."%len(faces) if len(faces) <= 1 else "Find %d faces."%len(faces)
    logger.info(search_info)

    # 绘制人脸的矩形区域(红色边框)
    for (x, y, w, h) in faces:
        cv2.rectangle(image, (x,y), (x+w,y+h), (0,0,255), 2)

    # 显示图片
    cv2.imshow('Find faces!', image)
    cv2.waitKey(0)

    输出结果如下:

    2018-09-18 10:35:31,232 - INFOReading image...
    2018-09-18 10:35:31,261 - INFODetect faces...
    2018-09-18 10:35:32,122 - INFOFind 1 face.

    检测后的图片如下:


    可以看到人脸检测的效果还是不错的。
      把代码中的图片换成《碟中谍6》里面的图片(笔者最近刚看完《碟中谍6》,强烈推荐),人脸检测的效果如下:

    猫脸检测

      人脸检测、人脸识别是近来非常火的技术,那么,用来识别猫脸呢?只需要把之前代码中的模型文件换成haarcascade_frontalface.xml即可。完整的Python代码如下:

    # -*- coding: utf-8 -*-
    import cv2
    import logging

    # 设置日志
    logging.basicConfig(level = logging.INFO, format='%(asctime)s - %(levelname)s: %(message)s')
    logger = logging.getLogger(__name__)

    # 待检测的图片路径
    ImagePath = 'E://cat.jpg'

    # 读取图片
    logger.info('Reading image...')
    image = cv2.imread(ImagePath)
    # 把图片转换为灰度模式
    gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

    # 探测图片中的人脸
    logger.info('Detect faces...')
    # 获取训练好的人脸的参数数据,进行人脸检测
    face_cascade = cv2.CascadeClassifier(r'./haarcascade_frontalcatface.xml')
    faces = face_cascade.detectMultiScale(gray,scaleFactor=1.15,minNeighbors=5,minSize=(33))

    search_info = "Find %d face."%len(faces) if len(faces) <= 1 else "Find %d faces."%len(faces)
    logger.info(search_info)

    # 绘制人脸的矩形区域(红色边框)
    for (x, y, w, h) in faces:
        cv2.rectangle(image, (x,y), (x+w,y+h), (0,0,255), 2)

    # 显示图片
    cv2.imshow('Find faces!', image)
    cv2.waitKey(0)

    输出的结果如下:

    2018-09-18 10:43:00,564 - INFOReading image...
    2018-09-18 10:43:00,585 - INFODetect faces...
    2018-09-18 10:43:01,741 - INFOFind 1 face.

    猫脸检测后的效果如下:


    怎么样,是不是感觉萌萌的?

    总结

      本文主要介绍了OpenCV在人脸检测和猫脸检测方面的应用,并且给出了具体的Python代码。
      那么,能检测人脸和猫脸,我们又能做些什么呢?其实,我们如果继续探究下去,可以做不少的事情,比如结合深度学习的模型,比如CNN等,可以实现人脸识别啊,物体检测,自动给图像打标签等。后续,笔者将会给出这些具体应用的一些实例,欢迎大家交流~

    注意:本人现已开通微信公众号: 轻松学会Python爬虫(微信号为:easy_web_scrape), 欢迎大家关注哦~~

  • 相关阅读:
    hiho_1139_二分+bfs搜索
    hiho_1138_island_travel
    google_apactest_round_A_problem_D
    hiho1122_二分图匈牙利算法
    hiho1123_好配对
    hiho1096_divided_product
    hiho1099_constellation
    hiho1093_spfa
    hiho1092_have lunch together
    【ipad神坑】ipad麦克风听不到声音怎么回事 微信QQ语音视频对方都听不到
  • 原文地址:https://www.cnblogs.com/jclian91/p/9667669.html
Copyright © 2011-2022 走看看