10 OpenCV图像识别之人脸追踪

news2024/9/23 13:16:25

文章目录

  • 1 级联分类器
  • 2 人脸跟踪
    • 2.1 相关方法
    • 2.2 代码示例

CV2中内置了人脸识别等常用的算法,这类算法是通过级联分类器实现的。

1 级联分类器

级联分类器的核心思想是使用多个分类器级联,每个分类器负责检测不同的特征,逐步排除不可能是目标的区域,从而减少计算量和误检率,提高检测效率。级联分类器通常由多个弱分类器组成,这些弱分类器的输出被级联在一起形成强分类器,因此级联分类器也被称为“弱分类器的级联”。

在OpenCV中,级联分类器使用的Haar特征是一种基于矩形区域的特征,用于描述物体的边缘、角、线等。Adaboost算法用于训练分类器,它是一种迭代算法,每一轮迭代都会选出最优的特征和阈值进行分类器训练。

级联分类器在人脸检测等领域有着广泛的应用,因为它能够快速准确地识别目标,并且可以通过调整参数来平衡检测速度和准确度。但是,级联分类器也存在一些局限性,比如对于光照、姿态、遮挡等变化较大的情况,检测效果可能不理想。

级联分类器存储在cv2包下的data中:
image.png
每个分类器都针对特定的物体或场景进行了优化。以下是一些常用的级联分类器及其作用:

  1. Haar人脸分类器(haarcascade_frontalface_default.xml):用于检测图像中的人脸,是OpenCV中最常用的级联分类器之一。
  2. Haar眼睛分类器(haarcascade_eye.xml):用于检测人脸中的眼睛。
  3. Haar上半身分类器(haarcascade_upperbody.xml):用于检测图像中的上半身,包括头、肩膀和胸部。
  4. Haar全身分类器(haarcascade_fullbody.xml):用于检测图像中的整个人体,包括头、肩膀、胸部、腰部、腿和脚。
  5. Haar汽车分类器(haarcascade_car.xml):用于检测图像中的汽车。
  6. Haar行人分类器(haarcascade_pedestrian.xml):用于检测图像中的行人,适用于行人检测和跟踪等场景。

除了以上列举的常用分类器,还有一些其他分类器,如针对摩托车、猫、狗、手部、火焰等物体或场景的分类器。值得注意的是,这些分类器都是基于Haar特征和Adaboost算法构建的,因此对于复杂场景或要检测的物体形态较为复杂的情况,可能需要使用其他类型的物体检测算法或自行训练分类器来获得更好的检测效果。

2 人脸跟踪

2.1 相关方法

在CV2中,涉及的操作分别为导入分类器(CascadeClassifier方法)与使用分类器(分类器下的detectMultiScale方法)。
其中导入方法比较简单:

cascade = cv2.CascadeClassifier("xml文件路径")

导入后使用分类器的detectMultiScale方法进行图像识别:

objects = cascade.detectMultiScale(image, scaleFactor=1.1, minNeighbors=3, flags=0, minSize=None, maxSize=None)

其中,cascadecv2.CascadeClassifier对象,image是要检测的图像。该方法返回一个由检测到的物体的矩形框组成的numpy数组。

其他可选参数解释如下:

  • scaleFactor:每次图像缩小的比例。默认为1.1,即每次图像缩小10%。
  • minNeighbors:控制误检测率的阈值。默认为3,表示每个候选矩形框周围至少需要有3个相邻的矩形框才能被认为是真正的矩形框。
  • flags:用于控制级联分类器的行为。可以是以下值之一:
    • cv2.CASCADE_SCALE_IMAGE:缩放图像以适应每个尺度。
    • cv2.CASCADE_DO_ROUGH_SEARCH:使用粗略的搜索模式。
    • cv2.CASCADE_FIND_BIGGEST_OBJECT:只返回最大的物体。
    • cv2.CASCADE_DO_CANNY_PRUNING:使用Canny边缘检测器进行物体检测。
    • cv2.CASCADE_DO_MEDIAN_BLUR:对图像进行中值模糊处理。
  • minSize:指定检测到的物体的最小尺寸,可以是元组或列表。默认为None,表示没有最小尺寸限制。
  • maxSize:指定检测到的物体的最大尺寸,可以是元组或列表。默认为None,表示没有最大尺寸限制。

detectMultiScale方法返回的矩形框是一个numpy数组,每行对应一个检测到的物体,四列分别表示矩形框的x坐标、y坐标、宽度和高度。可以使用循环遍历该数组,对图像中检测到的物体进行进一步处理,例如在物体周围画一个矩形框,或者将其提取出来用于后续处理。

2.2 代码示例

import cv2    
img = cv2.imread("zuiguifanju.jpg") 
# 加载识别人脸的级联分类器  
faceCascade = cv2.CascadeClassifier(r"D:\Python\Anaconda3\lib\site-packages\cv2\data\haarcascade_frontalface_default.xml")  
faces = faceCascade.detectMultiScale(img, maxSize=[100,100])  # 识别出所有人脸,最大不超过100*100(提升识别准确率)  
  
for (x, y, w, h) in faces:  # 遍历人脸区  
    cv2.rectangle(img, (x, y), (x + w, y + h), (0, 0, 255), 5)  
cv2.imshow("img", img)  
cv2.waitKey()  
cv2.destroyAllWindows()

image.png

同时,可以给大佬们带上个帅气的墨镜:

import cv2  
  
# 覆盖图像  
def overlay_img(img, img_over, img_over_x, img_over_y):  
    """  
    覆盖图像  
    :param img: 背景图像  
    :param img_over: 覆盖的图像  
    :param img_over_x: 覆盖图像在背景图像上的横坐标  
    :param img_over_y: 覆盖图像在背景图像上的纵坐标  
    :return: 两张图像合并之后的图像  
    """    img_h, img_w, img_p = img.shape  # 背景图像宽、高、通道数  
    img_over_h, img_over_w, img_over_c = img_over.shape  # 覆盖图像高、宽、通道数  
    if img_over_c == 3:  # 通道数小于等于3,则转换成4通道图像  
        img_over = cv2.cvtColor(img_over, cv2.COLOR_BGR2BGRA)  
    for w in range(0, img_over_w):  
        for h in range(0, img_over_h):  
            if img_over[h, w, 3] != 0:  # 如果不是透明的像素  
                print(img_over[h, w, 3])  
                for c in range(0, 3):  
                    x = img_over_x + w  
                    y = img_over_y + h  
                    if x >= img_w or y >= img_h:  # 如果坐标超出最大宽高则不画  
                        break  
                    alpha = img_over[h, w, 3] / 255.0  # 计算alpha通道值  
                    img[y, x, c] = alpha * img_over[h, w, c] /+ (1 - alpha) * img[y, x, c]  # 覆盖像素  
    return img  
  
face_img = cv2.imread("zuiguifanju.jpg")  
glass_img = cv2.imread("glass.png", cv2.IMREAD_UNCHANGED)  
height, width, channel = glass_img.shape  
# 加载级联分类器  
face_cascade = cv2.CascadeClassifier(r"D:\Python\Anaconda3\lib\site-packages\cv2\data\haarcascade_frontalface_default.xml")  
faces = face_cascade.detectMultiScale(face_img, maxSize=[100,100])  # 识别人脸  
for (x, y, w, h) in faces:  
    gw = w  # 眼镜缩放之后的宽度  
    gh = int(height * w / width)  # 眼镜缩放之后的高度度  
    glass_img = cv2.resize(glass_img, (gw, gh))  # 按照人脸大小缩放眼镜  
    overlay_img(face_img, glass_img, x, y + int(h * 1 / 3))  # 将眼镜绘制到人脸
cv2.imshow("screen", face_img)  
cv2.waitKey()  
cv2.destroyAllWindows()

上面的代码主要思路是利用一个自定义函数overlay_img来实现图像的覆盖,函数的输入参数是背景图像img,覆盖的图像img_over,以及img_over在img中的坐标img_over_x和img_over_y。函数的返回值是两张图像合并之后的图像。

在函数内部,首先获取背景图像和覆盖图像的宽、高、通道数。如果覆盖图像的通道数小于等于3,就将其转换成4通道图像。然后遍历覆盖图像的所有像素,如果当前像素不是透明像素(alpha通道不为0),就计算alpha通道值,然后根据该值对覆盖像素和背景像素进行加权求和,得到最终的像素值。

在主程序中,首先读取人脸图像和眼镜图像,并使用级联分类器检测人脸。然后遍历所有人脸的区域,按照人脸大小缩放眼镜图片,并调用overlay_img函数将眼镜图片覆盖在人脸图片上。最后显示最终处理的效果。

image.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/355575.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Prometheus离线tar.gz包安装

Prometheus离线tar.gz包安装实验环境一、部署前操作二、Master2.1下载2.2解压2.3更改服务目录名称2.4创建系统服务启动文件2.5配置修改2.6启动并设置开机自启2.7访问2.8添加node节点2.8.1 添加方法2.8.2修改Prometheus配置(Master)实验环境节点ipcpu内存…

数据结构:归并排序和堆排序

归并排序 归并排序(merge sort)是利用“归并”操作的一种排序方法。从有序表的讨论中得知,将两个有序表“归并”为一个有序表,无论是顺序表还是链表,归并操作都可以在线性时间复杂度内实现。归并排序的基本操作是将两个位置相邻的有序记录子序列R[i…m]R[m1…n]归并为一个有序…

已解决zipfile.BadZipFile: File is not a zip file

已解决Python openpyxl 读取Excel文件,抛出异常zipfile.BadZipFile: File is not a zip file的正确解决,亲测有效!!! 文章目录报错问题报错翻译报错原因解决方法联系博主免费帮忙解决报错报错问题 一个小伙伴遇到问题跑…

python基于django+vue微信小程序的校园二手闲置物品交易

在大学校园里,存在着很多的二手商品,但是由于信息资源的不流通以及传统二手商品信息交流方式的笨拙,导致了很多仍然具有一定价值或者具有非常价值的二手商品的囤积,乃至被当作废弃物处理。现在通过微信小程序的校园二手交易平台,可以方便快捷的发布和交流任何二手商品的信息,并…

【CS224W】(task2)传统图机器学习和特征工程

note 和CS224W课程对应,将图的基本表示写在task1笔记中了;传统图特征工程:将节点、边、图转为d维emb,将emb送入ML模型训练Traditional ML Pipeline Hand-crafted feature ML model Hand-crafted features for graph data Node-l…

被滥用的Slack服务:APT29针对意大利的攻击活动分析

背景 APT29,又名CozyBear, Nobelium, TheDukes,奇安信内部编号APT-Q-77,被认为是与东欧某国政府有关的APT组织。该组织攻击活动可追溯至2008年,主要攻击目标包括西方政府组织机构、智囊团。APT29曾多次实施大规模鱼叉攻击&#x…

linux高级命令之进程的注意点

进程的注意点学习目标能够说出进程的注意点1. 进程的注意点介绍进程之间不共享全局变量主进程会等待所有的子进程执行结束再结束2. 进程之间不共享全局变量import multiprocessing import time# 定义全局变量 g_list list()# 添加数据的任务defadd_data():for i in range(5):g…

snakeyaml自定义pojo写入yml文件时属性字段排序问题

snakeyaml采用LinkedHashMap保存对象,最后写入yml文件的时候,可以按照存入的顺序写入yml,如果采用自定义pojo,虽然可以写入yml,但是属性默认是按照字母顺序进行写入的。 如下所示,定义一个User实体&#xf…

kafka生产者事务踩坑记录

1. 背景 公司需要迁移一个老 spark 项目,之前是消费阿里 LogStore 中的实时数据,处理之后将结果落库。使用的是 spark streaming,batch 时间为 2 分钟。迁移后,需要将 LogStore 切换为 kafka,涉及到了对代码的改动。公…

常见的数据结构

栈(stack) 栈( stack)是限制插入和删除只能在一个位置上进行的表,该位置是表的末端,叫做栈顶(top)。它是后进先出(LIFO)的。对栈的基本操作只有 push&#x…

linux高级命令之线程

线程学习目标能够知道线程的作用1. 线程的介绍在Python中,想要实现多任务除了使用进程,还可以使用线程来完成,线程是实现多任务的另外一种方式。2. 线程的概念线程是进程中执行代码的一个分支,每个执行分支(线程&#…

macos 下载 macOS 系统安装程序及安装U盘制作方法

01 下载 macOS 系统安装程序的方法 本文来自: https://discussionschinese.apple.com/docs/DOC-250004259 简介 Mac 用户时不时会需要下载 macOS 的安装程序,目的不同,或者升级或者降级,或者研究或者收藏。为了方便不同用户,除…

设计模式之委派模式与模板模式详解和应用

目录1 委派模式1.1 目标1.2 内容定位1.3 定义1.4 委派模式的应用场景1.5 委派模式在业务场景中的应用1.6 委派模式在源码中的体现1.6.1 双亲委派模型1.6.2 常用代理执行方法 invoke1.6.3 Spring loC中 在调用 doRegisterBeanDefinitions()1.6.4 SpringMVC 的DispatcherServlet1…

python基于vue微信小程序的校园闲置二手跳蚤商城的设计与实现

在当今社会的高速发展过程中,产生的劳动力越来越大,提高人们的生活水平和质量,尤其计算机科技的进步,数据和信息以人兴化为本的目的,给人们提供优质的服务,其中网上购买二手商品尤其突出,使我们的购物方式发生巨大的改变。而线上购物,不仅需要在硬件上为人们提供服务网上购物,而…

尚医通 (十七)手机登录

目录一、登录需求分析二、搭建service-user模块三、登录接口实现1、添加service接口与实现2、添加Mapper接口3、添加Controller方法四、手机验证码登录(生成token)1、使用JWT进行跨域身份验证1.1 传统用户身份验证1.2 解决方案2、JWT介绍3、整合JWT4、单…

Minecraft服务端配置

✨✨前言 ✨✨ 我的世界大家肯定都不陌生,在网易拿下中国区的代理后,很多小伙伴也是都转向了网易版我的世界,网易版我的世界可以说已经做是的十分全面了,使用起来也十分方便,一部分小伙伴也是看重了网易庞大的玩家数量…

使用uniapp创建小程序和H5界面

uniapp的介绍可以看官网,接下来我们使用uniapp创建小程序和H5界面,其他小程序也是可以的,只演示创建这2个,其实都是一套代码,只是生成的方式不一样而已。 uni-app官网 1.打开HBuilder X 选择如图所示,下…

1. Unity的下载与安装

1. 下载 Unity Hub: unity hub是unity编辑器的一个管理工具,负责平时的unity项目创建和管理,以及unity编辑器的安装等 首先在unity官网网址链接,点击左下角的DownLoad Unity图标,如下图: 进入下一个页面,…

LinkedHashMap实现LRU算法

目录LRU 简介LinkedHashMap的使用手写LRU缓存淘汰算法LRU 简介 LRU 是 Least Recently Used 的缩写,这种算法认为最近使用的数据是热门数据,下一次很大概率将会再次被使用。而最近很少被使用的数据,很大概率下一次不再用到。当缓存容量的满时…

show profile和trance分析SQL

目录 一.show profile分析SQL 二.trance分析优化器执行计划 一.show profile分析SQL Mysql从5.0.37版本开始增加了对show profiles和show profile语句的支持。show profiles能够在做SQL优化时帮助我们了解时间都耗费到哪里去了。。 通过have_profiling参数,能够…