手把手教你如何用 OpenCV + Python 实现人脸检测

配好了OpenCV的Python环境,OpenCV的Python环境搭建。于是迫不及待的想体验一下opencv的人脸识别,如下文。

必备知识

Haar-like

Haar-like百科释义。通俗的来讲,就是作为人脸特征即可。

Haar特征值反映了图像的灰度变化情况。例如:脸部的一些特征能由矩形特征简单的描述,如:眼睛要比脸颊颜色要深,鼻梁两侧比鼻梁颜色要深,嘴巴比周围颜色要深等。

opencv api

要想使用opencv,就必须先知道其能干什么,怎么做。于是API的重要性便体现出来了。就本例而言,使用到的函数很少,也就普通的读取图片,灰度转换,显示图像,简单的编辑图像罢了。

读取图片

只需要给出待操作的图片的路径即可。

import cv2
image = cv2.imread(imagepath)

灰度转换

灰度转换的作用就是:转换成灰度的图片的计算强度得以降低。

import cv2
gray = cv2.cvtColor(image,cv2.COLOR_BGR2GRAY)

画图

opencv 的强大之处的一个体现就是其可以对图片进行任意编辑,处理。
下面的这个函数最后一个参数指定的就是画笔的大小。

import cv2
cv2.rectangle(image,(x,y),(x+w,y+w),(0,255,0),2)

显示图像

编辑完的图像要么直接的被显示出来,要么就保存到物理的存储介质。

import cv2
cv2.imshow("Image Title",image)

获取人脸识别训练数据看似复杂,其实就是对于人脸特征的一些描述,这样opencv在读取完数据后很据训练中的样品数据,就可以感知读取到的图片上的特征,进而对图片进行人脸识别。

import cv2
face_cascade = cv2.CascadeClassifier(r'./haarcascade_frontalface_default.xml')

里卖弄的这个xml文件,就是opencv在GitHub上共享出来的具有普适的训练好的数据。我们可以直接的拿来使用。

训练数据参考地址:https://github.com/opencv/opencv/tree/master/data/haarcascades

探测人脸

说白了,就是根据训练的数据来对新图片进行识别的过程。

import cv2

# 探测图片中的人脸

faces = face_cascade.detectMultiScale(
   gray,
   scaleFactor = 1.15,
   minNeighbors = 5,
   minSize = (5,5),
   flags = cv2.cv.CV_HAAR_SCALE_IMAGE
)

我们可以随意的指定里面参数的值,来达到不同精度下的识别。返回值就是opencv对图片的探测结果的体现。

处理人脸探测的结果

结束了刚才的人脸探测,我们就可以拿到返回值来做进一步的处理了。但这也不是说会多么的复杂,无非添加点特征值罢了。

import cv2

print "发现{0}个人脸!".format(len(faces))

for(x,y,w,h) in faces:
   cv2.rectangle(image,(x,y),(x+w,y+w),(0,255,0),2)

实例

有了刚才的基础,我们就可以完成一个简单的人脸识别的小例子了。

下面的这张图片将作为我们的检测依据。

人脸检测代码

# coding:utf-8
import sys


reload(sys)
sys.setdefaultencoding('utf8')
#    __author__ = '郭 璞'
#    __date__ = '2016/9/5'
#    __Desc__ = 人脸检测小例子,以圆圈圈出人脸
import cv2
# 待检测的图片路径
imagepath = r'./heat.jpg'


# 获取训练好的人脸的参数数据,这里直接从GitHub上使用默认值
face_cascade = cv2.CascadeClassifier(r'./haarcascade_frontalface_default.xml')


# 读取图片
image = cv2.imread(imagepath)
gray = cv2.cvtColor(image,cv2.COLOR_BGR2GRAY)


# 探测图片中的人脸
faces = face_cascade.detectMultiScale(
    gray,
    scaleFactor = 1.15,
    minNeighbors = 5,
    minSize = (5,5),
    flags = cv2.cv.CV_HAAR_SCALE_IMAGE
)


print "发现{0}个人脸!".format(len(faces))


for(x,y,w,h) in faces:
    # cv2.rectangle(image,(x,y),(x+w,y+w),(0,255,0),2)
    cv2.circle(image,((x+x+w)/2,(y+y+h)/2),w/2,(0,255,0),2)


cv2.imshow("Find Faces!",image)
cv2.waitKey(0)

输出图片:

输出结果:

D:\Software\Python2\python.exe E:/Code/Python/DataStructor/opencv/Demo.py
发现3个人脸!

如何学习大模型 AI ?

由于新岗位的生产效率,要优于被取代岗位的生产效率,所以实际上整个社会的生产效率是提升的。

但是具体到个人,只能说是:

“最先掌握AI的人,将会比较晚掌握AI的人有竞争优势”。

这句话,放在计算机、互联网、移动互联网的开局时期,都是一样的道理。

我在一线互联网企业工作十余年里,指导过不少同行后辈。帮助很多人得到了学习和成长。

我意识到有很多经验和知识值得分享给大家,也可以通过我们的能力和经验解答大家在人工智能学习中的很多困惑,所以在工作繁忙的情况下还是坚持各种整理和分享。但苦于知识传播途径有限,很多互联网行业朋友无法获得正确的资料得到学习提升,故此将并将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。

😝有需要的小伙伴,可以点击下方链接免费领取或者V扫描下方二维码免费领取🆓

在这里插入图片描述

在这里插入图片描述

第一阶段(10天):初阶应用

该阶段让大家对大模型 AI有一个最前沿的认识,对大模型 AI 的理解超过 95% 的人,可以在相关讨论时发表高级、不跟风、又接地气的见解,别人只会和 AI 聊天,而你能调教 AI,并能用代码将大模型和业务衔接。

  • 大模型 AI 能干什么?
  • 大模型是怎样获得「智能」的?
  • 用好 AI 的核心心法
  • 大模型应用业务架构
  • 大模型应用技术架构
  • 代码示例:向 GPT-3.5 灌入新知识
  • 提示工程的意义和核心思想
  • Prompt 典型构成
  • 指令调优方法论
  • 思维链和思维树
  • Prompt 攻击和防范

第二阶段(30天):高阶应用

该阶段我们正式进入大模型 AI 进阶实战学习,学会构造私有知识库,扩展 AI 的能力。快速开发一个完整的基于 agent 对话机器人。掌握功能最强的大模型开发框架,抓住最新的技术进展,适合 Python 和 JavaScript 程序员。

  • 为什么要做 RAG
  • 搭建一个简单的 ChatPDF
  • 检索的基础概念
  • 什么是向量表示(Embeddings)
  • 向量数据库与向量检索
  • 基于向量检索的 RAG
  • 搭建 RAG 系统的扩展知识
  • 混合检索与 RAG-Fusion 简介
  • 向量模型本地部署

第三阶段(30天):模型训练

恭喜你,如果学到这里,你基本可以找到一份大模型 AI相关的工作,自己也能训练 GPT 了!通过微调,训练自己的垂直大模型,能独立训练开源多模态大模型,掌握更多技术方案。

到此为止,大概2个月的时间。你已经成为了一名“AI小子”。那么你还想往下探索吗?

  • 为什么要做 RAG
  • 什么是模型
  • 什么是模型训练
  • 求解器 & 损失函数简介
  • 小实验2:手写一个简单的神经网络并训练它
  • 什么是训练/预训练/微调/轻量化微调
  • Transformer结构简介
  • 轻量化微调
  • 实验数据集的构建

第四阶段(20天):商业闭环

对全球大模型从性能、吞吐量、成本等方面有一定的认知,可以在云端和本地等多种环境下部署大模型,找到适合自己的项目/创业方向,做一名被 AI 武装的产品经理。

  • 硬件选型
  • 带你了解全球大模型
  • 使用国产大模型服务
  • 搭建 OpenAI 代理
  • 热身:基于阿里云 PAI 部署 Stable Diffusion
  • 在本地计算机运行大模型
  • 大模型的私有化部署
  • 基于 vLLM 部署大模型
  • 案例:如何优雅地在阿里云私有部署开源大模型
  • 部署一套开源 LLM 项目
  • 内容安全
  • 互联网信息服务算法备案

学习是一个过程,只要学习就会有挑战。天道酬勤,你越努力,就会成为越优秀的自己。

如果你能在15天内完成所有的任务,那你堪称天才。然而,如果你能完成 60-70% 的内容,你就已经开始具备成为一名大模型 AI 的正确特征了。

这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

😝有需要的小伙伴,可以Vx扫描下方二维码免费领取==🆓

在这里插入图片描述

  • 19
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Qt 是一种跨平台的应用程序开发框架,而 OpenCV 是一个开源的计算机视觉库,提供了丰富的图像处理和分析功能。在 PyQT 中结合 OpenCV 进行人脸识别有以下步骤: 首先,我们需要导入必要的库,包括 PyQt 和 OpenCV,确保我们能够在 Python 环境中使用它们。 然后,我们创建一个 Qt 的窗口应用程序,并添加用于显示图像的 QLabel 控件。 接下来,我们使用 OpenCV 加载图像并进行人脸检测OpenCV 提供了 Haar 级联分类器来实现人脸检测,我们可以使用这个分类器来识别图像中的人脸。 然后,我们将识别出的人脸标记出来,并在 Qt 的 QLabel 控件中显示出来。我们可以使用 OpenCV 的矩形函数来绘制人脸区域。 最后,我们将以上步骤结合起来,并添加其他功能,例如点击按钮加载图像、保存图像等。 总结起来,使用 Qt 和 OpenCV 进行人脸识别的 Python 程序可以通过导入必要的库、创建 Qt 窗口、加载图像并进行人脸检测、标记人脸区域并显示,从而实现人脸识别的功能。在这个过程中,我们可以使用 OpenCV 提供的图像处理和分析功能完成人脸检测,并结合 Qt 提供的界面设计和交互功能来实现用户友好的人脸识别程序。 ### 回答2: Qt OpenCV是一个用于图像处理和计算机视觉的开源库,结合了Qt和OpenCV的强大功能,使得人脸识别在Python中更加容易实现。 首先,你需要在Python中安装Qt和OpenCV库,并确保它们已经正确配置。然后,你可以使用OpenCV提供的人脸检测器通过加载已经训练好的分类器模型来检测图像中的人脸。在这里,你可以使用OpenCV的`cv2.CascadeClassifier()`函数并指定分类器的文件路径。 接下来,你可以使用Qt设计并实现一个用户界面,通过该界面你可以选择需要进行人脸识别的图像,并将其传递给OpenCV进行处理。你可以使用Qt提供的各种控件,如按钮、文本框等。 一旦图像被选择并传递给OpenCV,你可以使用OpenCV的`detectMultiScale()`函数来检测人脸。这个函数将返回一个矩形列表,表示图像中每个检测到的人脸的位置和大小。 最后,你可以使用Qt的绘图功能在原始图像上绘制矩形框来标记每个检测到的人脸。你可以使用Qt的`QPainter`类来进行绘图,并使用`drawRect()`函数来绘制矩形框。 总之,Qt OpenCV人脸识别py是一个结合了Qt和OpenCV的强大工具,它允许你在Python实现人脸识别功能。通过Qt的界面设计和OpenCV人脸检测算法,你可以轻松地加载图像并检测其中的人脸,并使用Qt的绘图功能在原始图像上绘制矩形框来标记每个检测到的人脸。 ### 回答3: Qt是一种用于创建图形用户界面的跨平台应用程序开发框架。而OpenCV是一个用于计算机视觉和机器学习的开源库,提供了许多图像和视频处理的功能。通过使用Qt和OpenCV,我们可以实现人脸识别的功能,并以Python语言进行开发。 使用Qt创建一个图形用户界面,可以方便用户输入图像或者视频文件,并调用OpenCV的人脸识别功能进行处理。首先,需要在界面中添加一个按钮,用于选择输入文件,然后将选中的文件传递给OpenCV进行处理。通过OpenCV的人脸识别功能,可以实现人脸检测、人脸特征提取、人脸识别等功能。 在代码中,需要导入Qt和OpenCV的相关模块,并编写相应的函数来处理人脸识别。通过OpenCV的人脸级联分类器(Haar级联分类器),可以进行人脸检测,找到图像中的人脸区域,并在图像中标记出来。此外,还可以使用OpenCV的人脸识别算法(如Eigenfaces、Fisherfaces、LBPH)来进行人脸识别,识别出人脸所属的身份。 最后,将处理后的图像或者视频展示在Qt界面中,可以使用Qt提供的图像显示组件进行显示。利用Qt的信号和槽机制,可以实现图像或者视频的实时处理和显示。 综上所述,通过使用Qt、OpenCVPython语言,我们可以实现一个人脸识别的应用程序,并在图形界面中展示处理结果。这样用户可以方便地进行人脸识别操作,实现对图像或者视频中人脸的检测和识别。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值