【yolov10】使用自己的数据集训练目标检测模型

一、anaconda安装

直接参考前一篇博客:
https://blog.csdn.net/m0_71523511/article/details/136546588

pycharm开发环境参考:
https://www.bilibili.com/video/BV1Cr4y1u76N/?p=3&spm_id_from=pageDriver&vd_source=2a10d30b8351190ea06d85c5d0bfcb2a

二、环境配置

官方给出的环境配置使用的torch版本是2.0.1,我电脑最高也就支持到1.11.0,所以就没法用gpu来训练了,当然也可以用自己的可以使用gpu训练的环境来训练yolov10,就是会有一些依赖报错,根据提示进行修改试试。
打开anaconda命令行:
在这里插入图片描述

conda create -n yolov10 python=3.9
conda activate yolov10
pip install -r requirements.txt
pip install -e .

三、数据集制作

1、labelimg的安装

首先打开cmd命令行(快捷键:win+R)。进入cmd命令行控制台。输入如下的命令:`

pip install labelimg -i https://pypi.tuna.tsinghua.edu.cn/simple

2、使用labelimg`

①搜索labelimg

在这里插入图片描述

②设置

在这里插入图片描述
格式选择yolo,然后点击open dir,选择存放待打标图片的文件夹,点击change save dir来更改保存标签的文件夹。

③打标

常用快捷键如下:

A:切换到上一张图片

D:切换到下一张图片

W:调出标注十字架

del :删除标注框框

Ctrl+u:选择标注的图片文件夹

Ctrl+r:选择标注好的label标签存在的文件夹

在这里插入图片描述
这样标注完之后可以在保存标签的目录看到yolo格式的标签,它会自己生成一个类别文件:
在这里插入图片描述

四、正片

1、下载yolov10源码

https://github.com/THU-MIG/yolov10
解压后目录如下:
在这里插入图片描述

2、数据集目录

将前面打标好的数据集以下面这种目录格式放置,并新建data.yaml文件:
在这里插入图片描述
data.yaml文件如下:
names根据自己数据集的标签来,train和val就是训练集和验证集的图片路径

train: C:/new_pycharm_project/yolov10-main/datasets/Data/train/images
val: C:/new_pycharm_project/yolov10-main/datasets/Data/val/images


# Classes
nc: 3  # number of classes
names: ['person', 'hat', 'one']  # class names

3、训练

在数据集的同级目录下新建一个train.py文件:

from ultralytics import YOLOv10

model_yaml_path = "ultralytics/cfg/models/v10/yolov10s.yaml"
#数据集配置文件
data_yaml_path = 'datasets/Data/data.yaml'
#预训练模型
pre_model_name = 'yolov10s.pt'

if __name__ == '__main__':
    #加载预训练模型
    model = YOLOv10(model_yaml_path).load(pre_model_name)
    #训练模型
    results = model.train(data=data_yaml_path,
                          epochs=150,
                          batch=4,
                          name='train_v10')

到以下网址下载s版本的预训练模型,并将此pt模型放置到与train.py的同级目录下:
https://github.com/jameslahm/yolov10/releases/download/v1.0/yolov10s.pt

右击开始训练:
在这里插入图片描述
等待训练结束之后可以在runs目录下找到权重文件:
在这里插入图片描述

4、推理

在数据集的同级目录下新建一个infer.py文件,并放置一张待检测的图片名字为infer.jpg:

from ultralytics import YOLOv10

model = YOLOv10("runs/detect/train_v10/weights/best.pt")

results = model.predict("infer.jpg")

results[0].show()

运行结果如下:
在这里插入图片描述
在这里插入图片描述
可以看出来推理时间很长,我这里只训练了一轮所以效果不好。

  • 4
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
YOLOv5 中使用自己的数据集进行训练需要进行以下步骤: 1. 数据准备:收集并标注你自己的数据集。确保每个图像都有对应的标签文件,标签文件应包含目标边界框的位置信息和类别信息。 2. 数据转换:将数据集转换为 YOLOv5 所需的格式。YOLOv5 支持多种数据格式,例如 COCO 格式、Pascal VOC 格式等。你可以使用工具如 LabelImg、VGG Image Annotator (VIA) 等进行数据标注,并将数据集转换为适当的格式。 3. 配置文件:创建一个 YOLOv5 的配置文件,用于定义模型的结构和训练的超参数。配置文件通常包括模型架构、学习率、批量大小、迭代次数等参数。你可以根据自己的需求进行调整。 4. 模型训练:通过运行训练脚本来训练模型。在 YOLOv5 中,你可以使用以下命令进行训练: ``` python train.py --data /path/to/data.yaml --cfg /path/to/model.yaml --weights yolov5s.pt ``` 其中,`data.yaml` 是数据集的配置文件,`model.yaml` 是模型的配置文件,`yolov5s.pt` 是预训练的权重文件。你可以根据自己的模型选择合适的权重文件。 5. 模型评估:在训练过程中,你可以使用验证集或测试集来评估模型的性能。可以使用以下命令来进行评估: ``` python val.py --data /path/to/data.yaml --weights /path/to/checkpoint.pt ``` 其中,`data.yaml` 是数据集的配置文件,`checkpoint.pt` 是训练过程中保存的模型权重文件。 6. 模型推理:训练完成后,你可以使用训练好的模型进行目标检测。可以使用以下命令进行推理: ``` python detect.py --source /path/to/image/or/video --weights /path/to/checkpoint.pt ``` 其中,`/path/to/image/or/video` 是待检测的图像或视频路径,`checkpoint.pt` 是训练完成后保存的模型权重文件。 记得根据自己的需求进行适当的调整和优化,以获得更好的检测结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值