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=(3, 3))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 - INFO: Reading image...
2018-09-18 10:35:31,261 - INFO: Detect faces...
2018-09-18 10:35:32,122 - INFO: Find 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=(3, 3))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 - INFO: Reading image...
2018-09-18 10:43:00,585 - INFO: Detect faces...
2018-09-18 10:43:01,741 - INFO: Find 1 face.
猫脸检测后的效果如下:
怎么样,是不是感觉萌萌的?
总结
本文主要介绍了OpenCV在人脸检测和猫脸检测方面的应用,并且给出了具体的Python代码。
那么,能检测人脸和猫脸,我们又能做些什么呢?其实,我们如果继续探究下去,可以做不少的事情,比如结合深度学习的模型,比如CNN等,可以实现人脸识别啊,物体检测,自动给图像打标签等。后续,笔者将会给出这些具体应用的一些实例,欢迎大家交流~
注意:本人现已开通微信公众号: 轻松学会Python爬虫(微信号为:easy_web_scrape), 欢迎大家关注哦~~
OpenCV神技——人脸检测,猫脸检测相关推荐
- OpenCV检测篇——猫脸检测
OpenCV检测篇(一)--猫脸检测 OpenCV检测篇一猫脸检测 OpenCV OpenCV的Python环境配置 猫脸检测 代码 效果 举一反三 下期预告 OpenCV OpenCV是时下最流行的 ...
- 运用特征脸方法的基于Opencv的猫脸检测实现
本文禁止转载.抄袭,请尊重作者权利. 使用特征脸方法的基于Opencv的猫脸检测实现 摘要 目前,在计算机视觉和模式识别领域,脸识别技术是一个很活跃的课题,人脸识别的方法已经十分丰富,而对于日常生活中 ...
- 【python】15行代码实现猫脸检测(opencv)
文章目录 1. 项目简介 2. 项目地址 3. 依赖模块 4. 完整代码 5. 必要组件 5.1. haar级联特征分类器(精度高) 5.2. lbp级联特征分类器(速度快) 6. 成果展示 6.1. ...
- 用 OpenCV 检测猫脸
Python中的OpenCV猫脸检测代码 使用 OpenCV 的预训练级联分类器可以轻松检测照片或视频中的猫脸.完成所有工作的代码: import cv2cascade = cv2.CascadeCl ...
- Python实战案例,图像识别技术OpenCV,Python实现猫脸检测
开发工具 Python版本:3.6.4 相关模块: cv2模块: 以及一些Python自带的模块. 环境搭建 安装Python并添加到环境变量,pip安装需要的相关模块即可. 原理简介 简单地讲一讲H ...
- OpenCV-Python实战(番外篇)——想要识别猫咪的情绪?从猫脸检测开始
OpenCV-Python实战(番外篇)--想要识别猫咪的情绪?从猫脸检测开始 前言 猫脸检测 使用级联检测器检测猫脸 使用深度学习模型检测图片中的猫 将 OpenCV 猫脸检测程序部署在 Web 端 ...
- CV:利用cv2自带两步法haarcascade_frontalcatface.xml实现对猫脸检测
CV:利用cv2自带两步法haarcascade_frontalcatface.xml实现对猫脸检测 目录 输出结果 实现代码 输出结果 实现代码 @author: niu ''' import cv ...
- 又发现一条喵星人将要统治地球的新线索(OpenCV猫脸检测)
都说喵星人快要统治地球了,各种证据正在被发现-- OpenCV的开发人员似乎也发现了些什么,在其发布版本里悄悄留下了些线索: 在OpenCV-Python安装包目录的data文件夹下,有2个" ...
- python检测猫脸
本人喜欢猫,今天用python完成了对猫的检测 代码: # -*- coding: utf-8 -*- """ Created on Wed Oct 16 09:23:3 ...
最新文章
- 某银行信用卡中心——大数据反欺诈应用案例 2017-06-23 10:54 本篇案例为数据猿推出的大型“金融大数据主题策划”活动(查看详情)第一部分的系列案例/征文;感谢 百融金服 的投递 作为整体
- 第二章 数组名是一个指针常量吗?
- python计算某年某月多少天_Python编程实现输入某年某月某日计算出这一天是该年第几天的方法...
- JPA在MySQL中自动建表
- 云付认证已通过可以支付吗_海科融通丨刷新支付日常问题【附交易操作步奏】...
- linux下yum安装pgsql,CentOS7使用yum安装PostgreSQL和PostGIS的方法
- python中运算符号怎样表示_Python中的运算符与表达式
- [spring-framework]Spring定时器的配置和使用
- 20分钟快速了解Redis
- web前端-浏览器兼容性处理大全
- java 实现根据ip重定向_从0到1用java再造tcpip协议栈:代码实现ping应用功能1
- 5000并发_彻底理解 jmeter 的线程数与并发数之间的关系
- macOS 升级12.0.1后,virtualBox 又不能用了
- c++_String一些使用记录
- assert函数_类成员函数指针在成员函数内部的调用
- 用u盘刻录装服务器系统盘,光盘系统刻录到U盘上教程
- 因子分析以及SPSS实现
- 力扣-剑指offer所有题
- 微信小程序-image(图片)
- video视频播放中trank标签字幕显示问题
热门文章
- java spring socket_详解java WebSocket的实现以及Spring WebSocket
- 无人驾驶笔记系列(四):Fast-RTPS初体验
- 微信 9 年:张小龙指路,微信 AI 全面开放 NLP 能力
- 移动app开发的几种方式
- 怎么将闲鱼当副业?闲鱼副业怎么运营?闲鱼如何弄副业?
- Low-light Enhancement暗光图像增强论文整理2019-2021
- 操作系统概念 CPU调度(进程调度)
- 美国防承包商邮件系统遭攻击,军事机密或泄露
- Windows java,jdk安装与环境变量配置 详细教程(图)
- 好书推荐 |《6G需求与愿景》(文末赠书福利)