网站首页 > 技术文章 正文
1 说明
=====
1.1 Dlib库,非常强大的一个库,有python接口。
1.2 多用于人工智能、机器人、物体检测和识别、自动驾驶等热门领域。
1.3 比如强大的人脸识别,当然训练自己的数据集和模型,可用于物体检测和识别,当然在各个领域都有广泛的使用空间,比如医学上,可以训练较大的数据集,用于肺炎或者癌症等疾病的检测。
1.4 今天从一个简单的例子,来说明如何训练自己的数据集,并检测和识别。
1.5 熟悉dlib+python+opencv等相关知识。
2 检测和识别猫脸(结果倒置)
=======================
2.1 效果图
2.2 部分失败原因:
图片数据集太少,本次训练用的图片,仅有10张猫脸正照,而且差异不大。
2.3 还可以训练一切自己感兴趣的东西,用于检测和识别。
【感兴趣的朋友可以继续,我手把手教你】
3 前期准备
========
3.1 《Dlib库教程(1):介绍、linux下的安装与避坑》
3.2 《Dlib库教程(2):联合python的人脸检测、标记、识别》,可以不看这篇。
3.3 准备
git clone https://github.com/davisking/dlib
#这个方法太慢了
3.4 我采用浏览器下载dlib-master包,解压在根目录下
https://github.com/davisking/dlib
本机解压:/home/xgj/dlib-master
#本机
cd dlib-master/tools/imglab
mkdir build
cd build
cmake .. #注意点点
cmake --build . --config Release
sudo make install
3.5 素材准备:图片来自网络,如有侵权请联系,定删。
#/home/xgj/Desktop/dlib-cat-detect #我在桌面新建一个文件夹dlib-cat-detect,下面再新建2个文件夹,cat_train文件夹和cat_test文件夹。
把所有要训练的猫图片保存到cat_train文件夹(10张图片jpg),要测试的图片放到cat_test文件夹(3张图片jpg),2个文件夹里的图片不要一样,以免影响测试效果。
4 图片标注:用imglab
=================
4.1 终端:
cd /home/xgj/Desktop/dlib-cat-detect
cd cat_train
imglab -c cat.xml . #注意点
imglab cat.xml #生成xml文件
4.2 图示:
打标签的方法很简单,在imglab窗口下,先按住shift键,然后在猫身的左上方按下鼠标左键,
拖动到猫身右下方再放开鼠标,这样就在猫身位置上画出了一个矩形框,如下图所示。
针对每一张图片进行上述操作,结束后保存。如果数据集够大的话,确实是个体力活。
下图只是方法演示,请注意与猫脸有区别。
5 训练数据集的代码
===============
5.1 cat_train_self.py,放在文件夹下dlib-cat-detect
#文件名:cat_train_self.py
#使用方法:在文件夹下,打开终端,输入
#python3.8 cat_train_self.py
# -*- coding: utf-8 -*-
#训练代码
import os
import dlib
# 训练的参数,可以根据实际情况进行修改
options = dlib.simple_object_detector_training_options()
options.add_left_right_image_flips = True
options.C = 5
options.num_threads = 4
options.be_verbose = True
current_path = os.getcwd()
train_folder = current_path + '/cat_train/'
train_xml_path = train_folder + 'cat.xml'
print("start training:")
# 最重要的一个函数
dlib.train_simple_object_detector(train_xml_path, 'detector.svm', options)
print("Training accuracy: {}".format(
dlib.test_simple_object_detector(train_xml_path, "detector.svm")))
5.2 效果和过程省略。
6 检测和识别代码
#检测代码
#cat_detect_self.py
# -*- coding: utf-8 -*-
#在文件夹下,打开终端,输入
#python3.8 cat_detect_self.py
#导入模块
import os
import glob
import dlib
import cv2
#路径管控
current_path = os.getcwd()
#加载测试文件夹
test_folder = current_path + '/cat_test/'
#加载已经训练好的数据集或模型文件
detector = dlib.simple_object_detector(current_path + "/"+"detector.svm")
#读取测试图片
for f in glob.glob(test_folder+'*.jpg'):
print("Processing file: {}".format(f))
#读取图片
img = cv2.imread(f, cv2.IMREAD_COLOR)
#颜色转换
b, g, r = cv2.split(img)
img2 = cv2.merge([r, g, b])
#检测
dets = detector(img2)
print("Number of cats detected: {}".format(len(dets)))
#获取侦测结果
for index, cat in enumerate(dets):
print('cat {}; left {}; top {}; right {}; bottom {}'.format(index, cat.left(), cat.top(), cat.right(), cat.bottom()))
left = cat.left()
top = cat.top()
right = cat.right()
bottom = cat.bottom()
#绿色检测和识别框
cv2.rectangle(img, (left, top), (right, bottom), (0, 255, 0), 3)
cv2.namedWindow(f, cv2.WINDOW_AUTOSIZE)
cv2.imshow(f, img)
k = cv2.waitKey(0)
cv2.destroyAllWindows()
小结
本次只是演示操作流程和效果,当然如果差异较大的猫脸可能检测不出来,这与训练用的猫脸图片差异不大和数据集较少有关,这个不重要,自己可以增加训练的图集和猫脸的差异图片。
完美分享,本人亲测,一秒入门,适合收藏,慢慢调用。
猜你喜欢
- 2024-12-16 人工智能应用的模型训练和评估 人工智能模型的主要技术指标
- 2024-12-16 二年级数学计算专项练习题,检测孩子计算能力
- 2024-12-16 DBnet检测加分类,提取身份证要素
- 2024-12-16 [图像处理] 基于CleanVision库清洗图像数据集
- 2024-12-16 python机器学习:如何储存训练好的模型并重新调用
- 2024-12-16 灵智互动|训练数据你不得不知道的问题
- 2024-12-16 机器学习基础:超参数和验证集 超参数是指
- 2024-12-16 中安表单识别AI训练平台的识别准确率是否可以通过测试来验证?
- 2024-12-16 天池伪造图像的篡改检测比赛TOP2/3方案分享
- 2024-12-16 【AI 和机器学习】PyTorch BASIC 基础知识(节2):数据集数据加载器
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- oraclesql优化 (66)
- 类的加载机制 (75)
- feignclient (62)
- 一致性hash算法 (71)
- dockfile (66)
- 锁机制 (57)
- javaresponse (60)
- 查看hive版本 (59)
- phpworkerman (57)
- spark算子 (58)
- vue双向绑定的原理 (68)
- springbootget请求 (58)
- docker网络三种模式 (67)
- spring控制反转 (71)
- data:image/jpeg (69)
- base64 (69)
- java分页 (64)
- kibanadocker (60)
- qabstracttablemodel (62)
- java生成pdf文件 (69)
- deletelater (62)
- com.aspose.words (58)
- android.mk (62)
- qopengl (73)
- epoch_millis (61)
本文暂时没有评论,来添加一个吧(●'◡'●)