当前位置: 首页 > news >正文

摄像头对人脸进行性别和年龄的判断

摄像头对人脸性别和年龄判断

    • 导入必要的库
    • 加载预训练的人脸检测模型
    • 加载预训练的性别和年龄识别模型
    • 定义性别和年龄的标签列表
    • 打开摄像头
    • 从摄像头读取一帧
    • 转换为灰度图像
    • 检测人脸
    • 遍历检测到的人脸
    • 显示视频流
    • 按 ‘q’ 或点击窗口的“×”退出循环
    • 释放摄像头和销毁所有窗口
    • 全部代码

导入必要的库

cv2:OpenCV库,用于图像处理和摄像头操作。
numpy:用于数值计算。

import cv2
import numpy as np

加载预训练的人脸检测模型

使用cv2.CascadeClassifier加载Haar级联分类器,用于检测图像中的人脸。

face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')

加载预训练的性别和年龄识别模型

使用cv2.dnn.readNetFromCaffe加载Caffe模型,用于预测人脸的性别和年龄。

gender_net = cv2.dnn.readNetFromCaffe('deploy_gender.prototxt', 'gender_net.caffemodel')
age_net = cv2.dnn.readNetFromCaffe('deploy_age.prototxt', 'age_net.caffemodel')

定义性别和年龄的标签列表

创建两个列表,分别用于存储性别和年龄的标签。

gender_list = ['man', 'woman']
age_list = ['(0-10)', '(10-15)', '(15-20)', '(20-30)', '(45-55)', '(55-65)', '(65-80)', '(80-100)']

打开摄像头

使用cv2.VideoCapture(0)打开默认的摄像头。

cap = cv2.VideoCapture(0)

从摄像头读取一帧

使用cap.read()从摄像头捕获一帧视频。

while True:# 从摄像头读取一帧ret, frame = cap.read()if not ret:print("无法捕获视频流,请检查摄像头是否正常工作。")break

转换为灰度图像

使用cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)将捕获的帧从BGR格式转换为灰度格式。

gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)

检测人脸

使用face_cascade.detectMultiScale(gray, 1.1, 4)在灰度图像中检测人脸。

faces = face_cascade.detectMultiScale(gray, 1.1, 4)

遍历检测到的人脸

对于检测到的人脸,执行以下操作:
裁剪出人脸区域。
将裁剪出的人脸区域转换为Caffe模型所需的格式。
使用Caffe模型预测性别和年龄。
在原图上画出人脸框,并在框内显示性别和年龄。

for (x, y, w, h) in faces:# 从原始图像中裁剪人脸区域face_img = frame[y:y + h, x:x + w].copy()# 预处理人脸图像以适应神经网络输入blob = cv2.dnn.blobFromImage(face_img, 1, (227, 227), (78.4263377603, 87.7689143744, 114.895847746), swapRB=False)# 预测性别gender_net.setInput(blob)gender_preds = gender_net.forward()gender = gender_list[gender_preds[0].argmax()]# 预测年龄age_net.setInput(blob)age_preds = age_net.forward()age = age_list[age_preds[0].argmax()]# 在人脸周围画框并显示性别和年龄cv2.rectangle(frame, (x, y), (x + w, y + h), (255, 255, 0), 2)cv2.putText(frame, f'{gender}, {age}', (x, y - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.8, (0, 255, 0), 2, cv2.LINE_AA)

显示视频流

使用cv2.imshow(‘Gender and Age Recognition’, frame)在窗口中显示视频流。

cv2.imshow('Gender and Age Recognition', frame)

按 ‘q’ 或点击窗口的“×”退出循环

使用cv2.waitKey(1)等待用户按键。
如果用户按了’q’键或者关闭了窗口,则退出循环。

if cv2.waitKey(1) == 27 or cv2.getWindowProperty('Gender and Age Recognition', cv2.WND_PROP_VISIBLE) < 1:break

释放摄像头和销毁所有窗口

使用cap.release()释放摄像头。
使用cv2.destroyAllWindows()销毁所有OpenCV创建的窗口。

cap.release()
cv2.destroyAllWindows()

全部代码

import cv2
import numpy as np# 加载预训练的人脸检测模型
face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')# 加载预训练的性别和年龄识别模型
gender_net = cv2.dnn.readNetFromCaffe('deploy_gender.prototxt', 'gender_net.caffemodel')
age_net = cv2.dnn.readNetFromCaffe('deploy_age.prototxt', 'age_net.caffemodel')# 定义性别和年龄的标签列表
gender_list = ['man', 'woman']
age_list = ['(0-10)', '(10-15)', '(15-20)', '(20-30)', '(45-55)', '(55-65)', '(65-80)', '(80-100)']# 打开摄像头
cap = cv2.VideoCapture(0)while True:# 从摄像头读取一帧ret, frame = cap.read()if not ret:print("无法捕获视频流,请检查摄像头是否正常工作。")break# 转换为灰度图像gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)# 检测人脸faces = face_cascade.detectMultiScale(gray, 1.1, 4)# 遍历检测到的人脸for (x, y, w, h) in faces:# 从原始图像中裁剪人脸区域face_img = frame[y:y + h, x:x + w].copy()# 预处理人脸图像以适应神经网络输入blob = cv2.dnn.blobFromImage(face_img, 1, (227, 227), (78.4263377603, 87.7689143744, 114.895847746), swapRB=False)# 预测性别gender_net.setInput(blob)gender_preds = gender_net.forward()gender = gender_list[gender_preds[0].argmax()]# 预测年龄age_net.setInput(blob)age_preds = age_net.forward()age = age_list[age_preds[0].argmax()]# 在人脸周围画框并显示性别和年龄cv2.rectangle(frame, (x, y), (x + w, y + h), (255, 255, 0), 2)cv2.putText(frame, f'{gender}, {age}', (x, y - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.8, (0, 255, 0), 2, cv2.LINE_AA)# 显示视频流cv2.imshow('Gender and Age Recognition', frame)# 按 'q' 或点击窗口的“×”退出循环if cv2.waitKey(1) == 27 or cv2.getWindowProperty('Gender and Age Recognition', cv2.WND_PROP_VISIBLE) < 1:break# 释放摄像头和销毁所有窗口
cap.release()
cv2.destroyAllWindows()

相关文章:

  • MT8781安卓核心板_MTK联发科Helio G99核心板规格参数
  • 开发语言Java+前端框架Vue+后端框架SpringBoot开发的ADR药物不良反应监测系统源码 系统有哪些优势?
  • Ubuntu24.04记录网易邮箱大师的安装
  • Bev 车道标注方案及复杂车道线解决
  • 七大战略性新兴产业崭露头角:新能源电燃灶或将成为未来厨房新宠
  • oracle with 递归查询
  • 2024HW|常见红队使用工具
  • nginx搭建简单负载均衡demo(springboot)
  • 基于聚类和回归分析方法探究蓝莓产量影响因素与预测模型研究附录
  • MySQL详细安装教程
  • C语言王国——字符函数和字符串函数(2)
  • Flutter 中的 ToggleButtonsTheme 小部件:全面指南
  • vue3的Element plus (一)
  • 2024 cicsn Ezheap
  • 使用import语句导入模块
  • 《Javascript高级程序设计 (第三版)》第五章 引用类型
  • 《Javascript数据结构和算法》笔记-「字典和散列表」
  • 【跃迁之路】【444天】程序员高效学习方法论探索系列(实验阶段201-2018.04.25)...
  • CEF与代理
  • flask接收请求并推入栈
  • java 多线程基础, 我觉得还是有必要看看的
  • Js实现点击查看全文(类似今日头条、知乎日报效果)
  • Python_网络编程
  • SQLServer之创建数据库快照
  • Vue 动态创建 component
  • Vue2 SSR 的优化之旅
  • 阿里云应用高可用服务公测发布
  • 高度不固定时垂直居中
  • 关于使用markdown的方法(引自CSDN教程)
  • 后端_MYSQL
  • 基于HAProxy的高性能缓存服务器nuster
  • 记录:CentOS7.2配置LNMP环境记录
  • 前端路由实现-history
  • 实现简单的正则表达式引擎
  • 使用Envoy 作Sidecar Proxy的微服务模式-4.Prometheus的指标收集
  • 微信如何实现自动跳转到用其他浏览器打开指定页面下载APP
  • 学习Vue.js的五个小例子
  • 一些关于Rust在2019年的思考
  • Java数据解析之JSON
  • 通过调用文摘列表API获取文摘
  • 我们雇佣了一只大猴子...
  • ​LeetCode解法汇总307. 区域和检索 - 数组可修改
  • #我与虚拟机的故事#连载20:周志明虚拟机第 3 版:到底值不值得买?
  • (1)bark-ml
  • (arch)linux 转换文件编码格式
  • (C语言)输入自定义个数的整数,打印出最大值和最小值
  • (echarts)echarts使用时重新加载数据之前的数据存留在图上的问题
  • (env: Windows,mp,1.06.2308310; lib: 3.2.4) uniapp微信小程序
  • (MonoGame从入门到放弃-1) MonoGame环境搭建
  • (附源码)spring boot智能服药提醒app 毕业设计 102151
  • (原创)boost.property_tree解析xml的帮助类以及中文解析问题的解决
  • (自用)learnOpenGL学习总结-高级OpenGL-抗锯齿
  • .htaccess配置重写url引擎
  • .NET : 在VS2008中计算代码度量值
  • .NET Core 实现 Redis 批量查询指定格式的Key