一、配置本地Python环境

二、下载YOLO源码并解压

https://github.com/ultralytics/ultralytics/releases

解压后的目录结构如下:

image

三、安装YOLO

1. 可以直接使用pip安装,但是这样安装无法对源码进行修改

2. 源码安装,源码安装后,可以直接修改源代码。

源码安装方式,进入项目目录后,执行:

pip  install  -e  .

四、体验一下使用已有的模型进行预测

 

1. 命令行执行预测

yolo task='detect' mode='predict' model='yolo26n.pt' source='bus.jpg'
yolo predict model='yolov8n.pt' source="bus.jpg"

 

参数说明:

model:指定用哪个模型进行预测(在执行时会自动下载这个模型,或者也可以提前下载好放在项目里)

source:指定想要预测的图片或视频

执行结果会保存在runs目录下:

image

2. 代码行执行预测

from ultralytics import YOLO

yolo = YOLO('yolov8n.pt', task='detect')
result = yolo(source='bus.jpg', save=True)

参数说明:

save:是否保存结果,存到run目录

conf:  表示置信度多少以下不显示

... ...

这些参数也可以直接在文件中指定:

image

 五、训练自己的模型

上面用到的是YOLO已经训练好的模型进行预测的,我们要在它的模型基础上,用我们自己的数据集来训练自己的模型。

 

我在这里用的是电脑桌面截图,通过训练想让模型识别微信和飞书两个应用的图标。

第一步:准备数据集

我这里使用截图工具Pixpin截图,很好用。

 

image

第二步:数据集重命名

 

截图后,将所有图片按顺序命名如:1.png, 2.png, 3.png ...,(这里用到批量重命名工具https://rename.jgrass.xyz/)

第三步:标注数据

标注数据用到标注工具:labelimg

image

第四步:整理数据的目录结构

数据集目录结构如下:

image

其中:images和labels中的train和val需要分别一一对应,

labels中还有一个classes.txt,保存类别:

image

第五步:将数据集放到项目中去

image

 第六步:写yaml配置文件

datasets目录下有很多模板,定义一个自己的即可:

path: icons # dataset root dir
train: images/train # train images (relative to 'path') 118287 images
val: images/val # val images (relative to 'path') 5000 images
test:    # 20288 of 40670 images, submit to https://competitions.codalab.org/competitions/20794

# Classes
names:
  0: feishu
  1: wechat

image

第七步:训练

from ultralytics import YOLO
# Load model
model = YOLO('yolo11n.pt')
# Train model
model.train(data='icons.yaml',workers=0, epochs=300, batch=16)

image

最后一步:用训练出来的模型预测

训练完成后,会在runs路径下生成train目录,找到最后一个train(我这里是train3),train3/weights/best.pt就是训练出来的做好的模型:

image

####  用 best.pt 模型进行预测看看效果:

 

from ultralytics import YOLO

yolo = YOLO('best.pt', task='detect')
result = yolo(source='test.png', save=True)

 

效果如下(效果可能不太好,重在学习过程):

image

 


原文地址: https://www.cveoy.top/t/topic/qGji 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录