最近创造实在有很多故意思的小项目,代码少,但是却可以非常大略高效的完成一些独立的功能。

实战小项目:运用 OpenCV 快速完成人脸检测_图像_代码 智能助手

这种小项目,对付新手朋友们练手或者理解一个业务很有帮助,所往后面我会搜集或者编写一些大略有用的实战小项目代码,陆续发一下,感兴趣的小伙伴欢迎体验。

本日就从一个利用 OpenCV 快速完成人脸的检测开始。

相信大家对人脸识别早已不陌生了,比如去公司时会刷脸进门,支付宝有刷脸支付等等。

大部分情形下,人脸识别可以通过剖析人脸的特色点,比如眼睛、鼻子、嘴巴的位置和大小,以及这些特色之间的相对关系,来完成一个人脸和对应个人身份的验证。

当然这种验证过程涉及很多技能和知识点,比如特色点提取、模式识别、机器学习等等,真正做起来也很繁芜。

本日,我们不做这么繁芜的东西,仅仅几行用大略的代码,带大家体验一下人脸检测的过程。

1. 准备

须要解释的是,接下来并不是做人脸的身份验证,而是做一个人脸的画框检测。

代码开拓环境为 python。

纵然你是个小白,按照下面的方法,也可以很大略的复现出来,感兴趣的话试着玩一玩吧。

准备一张你想要识别的人脸的图片,比如我从网高***的一张图片。

免费分享一些我整理的人工智能学习资料给大家,须要的可以直接扫码进群领资料

2. 代码实战

利用 OpenCV 库实现一个人脸识别很大略,由于 OpenCV 供应了干系的接口,我们直接调用即可。

在调用之前,须要***一个人脸检测分类器的文件(haarcascade_frontalface_default.xml)。

全体实战的详细代码如下,我对每一步都添加了注释,可以详细阅读一下。

import cv2 # 导入 OpenCV 库#人脸检测分类器确当地文件路径local_file_path = "./haarcascade_frontalface_default.xml"#加载人脸检测分类器#CascadeClassifier 是用于加载演习好的 Haar 特色分类器的类face_cascade = cv2.CascadeClassifier(local_file_path)#读取图像#'face.jpeg' 是须要进行人脸检测的图像文件的路径img = cv2.imread("./face.jpeg")#将彩色图像转换为灰度图像#灰度图像减少打算繁芜性,提高检测效率gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)#利用分类器进行人脸检测#detectMultiScale 函数可以检测图像中的多个人脸#参数 scaleFactor、minNeighbors、minSize 用于掌握检测的精度和结果faces = face_cascade.detectMultiScale( gray, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30))#在原图像上绘制人脸框for x, y, w, h in faces: #利用矩形框标记检测到的人脸 #cv2.rectangle 用于在图像上绘制矩形框 #(255, 0, 0) 是框的颜色(蓝色),2 是框的厚度 cv2.rectangle(img, (x, y), (x + w, y + h), (255, 0, 0), 2)#处理后的图像保存路径processed_img = "./processed_image.jpg"#保存处理后的图像cv2.imwrite(processed_img, img)print("succ dump processed img to:", processed_img)

上述代码运行之后,会将图片中的人脸部分检测出来,并且用矩形框框出来。

同时将处理的图片保存到本地,命名为 processed_image.jpg,识别出来的图片如下:

详细的代码和人脸分类器文件,扫码进群领资料即可获取。

这个小项目很大略,感兴趣的小伙伴可以试着玩一下。

免费分享一些我整理的人工智能学习资料给大家,整理了良久,非常全面。
包括人工智能根本入门***+AI常用框架实战***、机器学习、深度学习与神经网络等***、课件源码、毕设项目、AI热门论文等。

下面是截图,扫码进群免费领取:扫码进群领资料

我会在群里与朋友们定期分享人工智能的发展就业情形与干系资料。

末了祝大家每天进步!