ultralytics yolo入门实践

一、配置本地Python环境

二、下载YOLO源码并解压

复制代码
https://github.com/ultralytics/ultralytics/releases

解压后的目录结构如下:

三、安装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目录下:

  1. 代码行执行预测
复制代码
from ultralytics import YOLO

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

参数说明:

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

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

... ...

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

五、训练自己的模型

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

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

第一步:准备数据集

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

第二步:数据集重命名

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

第三步:标注数据

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

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

数据集目录结构如下:

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

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

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

第六步:写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

第七步:训练

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

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

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

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

复制代码
from ultralytics import YOLO

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

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

相关推荐
云天AI实战派13 小时前
AI 智能体全流程实战:从 0 搭一个门店运营助手,用 API + 工具搜索 + 编码代理做出可复现闭环
人工智能·ai·智能体
哥不是小萝莉13 小时前
Agent 架构设计与能力构建
ai
十正13 小时前
Claude code源码精读之上下文压缩
ai·aigc·agent·claude code
太阳上的雨天13 小时前
任何格式的文件转Markdown
python·ai
提笔了无痕13 小时前
RAG存储策略中.md格式的切片与存储怎么处理
数据库·ai·rag
my烂笔头13 小时前
单阶段 双阶段 目标检测的区别
人工智能·ai
weixin_4684668514 小时前
纳米 AI 搜索新手极速上手指南
人工智能·python·深度学习·搜索引擎·ai·语言模型·自然语言处理
YueJoy.AI14 小时前
AI应用的API安全:从认证到授权的完整指南
人工智能·ai·语言模型
周易宅14 小时前
CLAUDE.md 与 MEMORY.md:AI 编程助手配置的两条平行铁轨
人工智能·ai·agent·claude
不懂的浪漫15 小时前
Role Agent 方法论:如何把一个标准工作流 Agent 化
人工智能·ai·agent