0

0

AI禁烟可还行!吸烟识别+人脸识别

WBOY

WBOY

发布时间:2023-04-14 12:49:02

|

2802人浏览过

|

来源于51CTO.COM

转载

哈喽,大家好。

今天给大家分享一个吸烟识别+人脸识别的项目。很多公共场所、生产场所和学校,都有禁烟的要求,做一个禁烟的监控,让AI自动识别吸烟行为,并识别是谁在吸烟,还是很有必要的。

用目标检测算法判断吸烟行为,提取吸烟者的人脸,用人脸识别算法判断谁在吸烟。思路比较简单,但细节处理起来还是稍微有些麻烦。

项目用到训练数据和源码,都已经打包好了。还是老样子,评论区获取。

1. 检测香烟

我用了 5k 张抽烟的标记数据,作为训练数据

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

图片

放在dataset目录下。

训练YOLOv5目标检测模型。

第一步,复制data/coco128.yaml为smoke.yaml,并修改数据集目录和类别配置信息

path: ../dataset/smoke # dataset root dir
train: images/train# train images (relative to 'path') 128 images
val: images/test# val images (relative to 'path') 128 images
test:# test images (optional)

# Classes
names:
0: smoke

第二步,复制./models/yolov5s.yaml为smoke.yaml​,修改nc

nc: 1# number of classes

第三步,下载yolov5s.pt​预训练模型,放在{yolov5目录}/weights目录中

执行下面命令,训练即可

python ./train.py --data ./data/smoke.yaml --cfg ./models/smoke.yaml --weights ./weights/yolov5s.pt --batch-size 30 --epochs 120 --workers 8 --name smoke --project smoke_s

图片

训练完成后可以看到如下输出:

图片

准召还凑合。

训练完成后,可以找到best.pt位置,后面用它来做香烟检测。

model = torch.hub.load('../28_people_counting/yolov5', 'custom', './weights/ciga.pt', source='local')

results = self.model(img[:, :, ::-1])
pd = results.pandas().xyxy[0]
ciga_pd = pd[pd['class'] == 0]

图片

能识别到烟后,我们还需要判断,当前是否正在吸烟。

可以用香烟检测框与嘴部检测框计算IOU来判断,说白了,就是判断这两框是否有交集,若有,则认为当前正在吸烟。

Groq
Groq

GroqChat是一个全新的AI聊天机器人平台,支持多种大模型语言,可以免费在线使用。

下载

图片

嘴部检测框,使用人脸关键点来识别。

2. 人脸识别

人脸识别算法有很多成熟的模型,我们不需要自己训练,直接调库即可。

我这里用的是dlib库,它可以识别人脸 68 个关键点,并根据这 68 个关键点,提取人脸特征。

图片

face_detector = dlib.get_frontal_face_detector()
face_sp = dlib.shape_predictor('./weights/shape_predictor_68_face_landmarks.dat')

dets = face_detector(img, 1)

face_list = []
for face in dets:
l, t, r, b = face.left(), face.top(), face.right(), face.bottom()

face_shape = face_sp(img, face)

face_detector​可以检测人脸,返回人脸检测框,face_sp基于人脸检测框,识别人脸 68 个关键点。

从这 68 个关键点中,我们便可以获取到嘴部检测框,用于判断是否正在吸烟。

最后,我们还是希望利用人脸识别算法,识别到谁在吸烟。

第一步,提取人脸特征

face_feature_model = dlib.face_recognition_model_v1('./weights/dlib_face_recognition_resnet_model_v1.dat')

face_descriptor = face_feature_model.compute_face_descriptor(img, face_shape)

face_descriptor​根据人脸 68 个关键点之间的位置、距离,维每张脸计算出一个特征向量。这个原理类似于我们之前分享的word2vec​或者将视频映射到N维向量。

第二步,将现有人脸录入人脸库。我准备了 3 个影视剧中的吸烟行为

图片

从视频中裁剪出人脸,向量化后,写入人脸数据库(用文件代替)

图片

第三步,发生吸烟行为后,我们可以裁剪出吸烟者的人脸,并计算人脸向量,与人脸数据库的特征进行比对,找到最相似的人脸,返回对应的名字

图片

def find_face_name(self, face_feat):
"""
人脸识别,计算吸烟者名称
:param face_feat:
:return:
"""
cur_face_feature = np.asarray(face_feat, dtype=np.float64).reshape((1, -1))

# 计算两个向量(两张脸)余弦相似度
distances = np.linalg.norm((cur_face_feature - self.face_feats), axis=1)
min_dist_index = np.argmin(distances)
min_dist = distances[min_dist_index]

if min_dist < 0.3:
return self.face_name_list[min_dist_index]
else:
return '未知'

这个项目还有很多可以扩展的地方,比如:我提供的视频只有单张脸,实际监控中肯定是多张脸。这时候可以用MOT算法进行行人跟踪,然后再对每个人单独做吸烟识别

还有,可以单独做一个统计区,把识别到的吸烟行为保存,用作警告、处罚的证据。

相关专题

更多
页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

389

2023.08.14

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

333

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2068

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

346

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

251

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

402

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

372

2023.10.16

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号