OpenCV实现人脸检测(Haar特征)

学习目标

原理

实现

import cv2 as cv
print(cv.__file__)

路径:E:\Anaconda3\envs\test_py3.6\Lib\site-packages\cv2\data

代码实现

import cv2 as cv
import matplotlib.pyplot as plt
from pylab import mpl

mpl.rcParams['font.sans-serif'] = ['SimHei']
#1,以灰度图的形式读取图片
img = cv.imread("ll.jpg")
gray = cv.cvtColor(img , cv.COLOR_BGR2GRAY)

#2,实例化OpenCV人脸 和 眼睛识别的分类器
face_cas = cv.CascadeClassifier("haarcascade_frontalface_default.xml")
face_cas.load("haarcascade_frontalface_default.xml")  #加载已训练好的人脸识别模型


eyes_cas = cv.CascadeClassifier("haarcascade_eye.xml")
eyes_cas.load("haarcascade_eye.xml") #加载已训练好的眼睛识别模型

#3,调用识别人脸
'''gray: 输入灰度图像;
scaleFactor: 图像缩放比例,即在前一张图像的基础上,将图像缩小的比例,默认为 1.1;
minNeighbors: 每个矩形应该保留的邻居数,这个参数可以理解为减少误检的一个参数。默认为 3,可以根据实际情况调整;
minSize: 目标矩形的最小大小,小于这个尺寸的矩形会被忽略,默认为 (30, 30),这里设置为 (32, 32)。'''
faceRects = face_cas.detectMultiScale( gray,scaleFactor=1.2,minNeighbors=10,minSize=(32,32))
for faceRect in faceRects: #遍历所有检测到的人脸矩形框
    x,y,w,h = faceRect  #获取当前人脸矩形框的坐标和大小
    #框出人脸
    cv.rectangle(img,(x,y),(x+h,y+w),(0,255,0),3)
    #4,在识别出的人脸中进行眼睛检测
    roi_color = img[y:y+h,x:x+w]  #提取当前人脸区域的彩色图像
    roi_gray = gray[y:y+h,x:x+w]  #提取当前人脸区域的灰度图像
    eyes = eyes_cas.detectMultiScale(roi_gray)  #在当前人脸区域检测眼睛,并返回检测到的眼睛矩形框数组
    for (ex,ey,ew,eh) in eyes:  #遍历所有检测到的眼睛矩形框
        cv.rectangle(roi_color,(ex,ey),(ex+ew,ey+eh),(0,255,0),2)

#检测结果绘制
plt.figure(figsize=(8,6),dpi=100)
plt.imshow(img[:,:,::-1]),plt.title("检测结果")
plt.show()

结果展示

相关推荐
孤独且没人爱的纸鹤10 分钟前
【机器学习】深入无监督学习分裂型层次聚类的原理、算法结构与数学基础全方位解读,深度揭示其如何在数据空间中构建层次化聚类结构
人工智能·python·深度学习·机器学习·支持向量机·ai·聚类
后端研发Marion12 分钟前
【AI编辑器】字节跳动推出AI IDE——Trae,专为中文开发者深度定制
人工智能·ai编程·ai程序员·trae·ai编辑器
Tiger Z35 分钟前
R 语言科研绘图 --- 散点图-汇总
人工智能·程序人生·r语言·贴图
小深ai硬件分享2 小时前
Keras、TensorFlow、PyTorch框架对比及服务器配置揭秘
服务器·人工智能·深度学习
hunter2062063 小时前
用opencv生成视频流,然后用rtsp进行拉流显示
人工智能·python·opencv
Daphnis_z3 小时前
大模型应用编排工具Dify之常用编排组件
人工智能·chatgpt·prompt
yuanbenshidiaos4 小时前
【大数据】机器学习----------强化学习机器学习阶段尾声
人工智能·机器学习
好评笔记9 小时前
AIGC视频生成模型:Stability AI的SVD(Stable Video Diffusion)模型
论文阅读·人工智能·深度学习·机器学习·计算机视觉·面试·aigc
算家云9 小时前
TangoFlux 本地部署实用教程:开启无限音频创意脑洞
人工智能·aigc·模型搭建·算家云、·应用社区·tangoflux
叫我:松哥11 小时前
基于Python django的音乐用户偏好分析及可视化系统设计与实现
人工智能·后端·python·mysql·数据分析·django