YOLOX训练自己的数据集(头铁出来的超详细教程)

2024-02-14 00:59

本文主要是介绍YOLOX训练自己的数据集(头铁出来的超详细教程),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这里写自定义目录标题

  • 1.YOLOX环境搭建
    • 1.1新建一个conda环境
    • 1.2安装代码依赖的库文件
    • 1.3通过setup.py安装一些库文件
    • 1.4下载apex文件
    • 1.4下载pycocotools
  • 2.创建自己的数据集
    • 2.1创建VOC格式数据集
  • 3.训练
    • 3.1修改文件代码
    • 3.2开始训练
  • 3.测试
    • 3.1测试自己的训练结果
  • 3.预测结果
      • 参考(侵删)

1.YOLOX环境搭建

首先,搭建YOLOX所需要的环境。这里我使用Anaconda来搭建的。在搭建环境之前,先附上YOLOX的官方代码: 官方代码链接.

1.1新建一个conda环境

conda create -n yolox python=3.8
conda activate yolox   //进入环境

如果你想用原有的环境来搭建,也ok,直接激活你的环境。

1.2安装代码依赖的库文件

用到你下载好的官方文件,在命令行中

cd your/yolox-main/path
pip install -r requirements.txt

1.3通过setup.py安装一些库文件

python3 setup.py develop

1.4下载apex文件

apex下载链接.
下载好后cd到文件夹中并安装

cd path/to/your/apex
python3 setup.py install

安装成功后会显示
在这里插入图片描述

1.4下载pycocotools

pip3 install cython
pip3 install 'git+https://github.com/cocodataset/cocoapi.git#subdirectory=PythonAPI'

2.创建自己的数据集

2.1创建VOC格式数据集

yolox可以跑两种格式的数据集voc和coco,这里我用voc举例。
yolox的预训练模型 下载地址.我用yolox-s.pth举例
在这里插入图片描述
这是目录格式要求,可以自己手动建立。

其中,annotation用于存放xml格式的标签文件,JPEGimage用于存放原始图片。ImageSets/Main下的两个文件可以根据代码建立。

# oding = utf-8
# -*- coding:utf-8 -*-
import os
import randomtrainval_percent = 0.1
train_percent = 0.9
xmlfilepath = r'E:\YOLOX-main\datasets\VOCdevkit\VOC2007\Annotations'
txtsavepath = r'E:\YOLOX-main\datasets\VOCdevkit\VOC2007\ImageSets'
total_xml = os.listdir(xmlfilepath)num = len(total_xml)
list = range(num)
tv = int(num * trainval_percent)
tr = int(tv * train_percent)
trainval = random.sample(list, tv)
train = random.sample(trainval, tr)ftest = open(r'E:\YOLOX-main\datasets\VOCdevkit\VOC2007\ImageSets\Main\test.txt', 'w')
ftrain = open(r'\YOLOX-main\datasets\VOCdevkit\VOC2007\ImageSets\Main\trainval.txt', 'w')for i in list:name = total_xml[i][:-4] + '\n'if i in trainval:ftest.write(name)else:ftrain.write(name)ftrain.close()
ftest.close()

运行此代码后会出现两个.txt文件。

3.训练

3.1修改文件代码

修改 yolox/data/dataloading.py

def get_yolox_datadir():"""get dataset dir of YOLOX. If environment variable named `YOLOX_DATADIR` is set,this function will return value of the environment variable. Otherwise, use data"""yolox_datadir = os.getenv("YOLOX_DATADIR", None)if yolox_datadir is None:import yoloxyolox_path = os.path.dirname(os.path.dirname(yolox.__file__))//修改这里yolox_datadir = os.path.join(yolox_path, "datasets")return yolox_datadir

其次,修改exps/example/yolox_voc/yolox_voc_s.py

class Exp(MyExp):def __init__(self):super(Exp, self).__init__()self.num_classes = 10 #修改类别数目self.depth = 0.33self.width = 0.50self.warmup_epochs = 1

然后,修改这里,这块复制就好了

        with wait_for_the_master(local_rank):dataset = VOCDetection(data_dir=os.path.join(get_yolox_datadir(), "VOCdevkit"),//修改这里image_sets=[('2007', 'trainval')],#, ('2012', 'trainval')img_size=self.input_size,preproc=TrainTransform(max_labels=50,flip_prob=self.flip_prob,hsv_prob=self.hsv_prob),cache=cache_img,)

修改yolox/data/datasets/voc_classes.py为自己的类别。

VOC_CLASSES = ('1','2','3','4','5','6','7','8','9','10',
)

最后,修改yolox/evaluators/voc_eval.py,添加root为annotation的绝对路径。

#修改yolox/evaluators/voc_eval.py,添加root为annotation的绝对路径。
root = r'E:\YOLOX-main\datasets\VOCdevkit\VOC2007\Annotations\\'
def parse_rec(filename):""" Parse a PASCAL VOC xml file """tree = ET.parse(root + filename)

3.2开始训练

超参数设置:

python tools/train.py -f exps/example/yolox_voc/yolox_voc_s.py -d 0 -b 4 --fp16  -c yolox_s.pth

在这里插入图片描述

在这里插入图片描述
如果训练中断,开启,resume

python3 tools/train.py -f exps/example/yolox_voc/yolox_voc_s.py -d 0 -b 64 -c <last_epoch_ckpt.pth的路径> --resume

3.测试

3.1测试自己的训练结果

修改yolox/data/datasets/下的init.py文件,添加:
from .voc_classes import VOC_CLASSES
在这里插入图片描述

之后在toos/demo.py文件中将COCO_CLASSES全部修改为VOC_CLASSES
直接在此文件find下COCO_CLASSES然后全部修改为VOC_CLASSES就好了。
在这里插入图片描述

python tools/demo.py image -f exps/example/yolox_voc/yolox_voc_s.py -c weights/best_ckpt.pth --path assets/class01.jpg --conf 0.25 --nms 0.45 --tsize 640 --save_result --device [cpu/gpu]

-c 代表训练好的权重,-path 代表你要预测的图片存放的文件夹,
若想进行视频预测,只需将下面的 image 更换为 video;
若想预测整个文件夹,将.jpg去掉,只留 --path assets/

3.预测结果

跑了300个epoch训练了两个类,一个是飞机一个是油罐,感觉精度在280个epoch的时候明显上升,但是最终的结果不如v5好,不知道是因为我将.txt转xml出错了还是果真效果就是不太行,这个我还没分析。上图:
在这里插入图片描述
上图是yolox-s的效果,我人麻了……
在这里插入图片描述
上图是yolov5-x的效果。。。

好了我继续trick了,感兴趣的小伙伴来一起交流
持续更新中……

参考(侵删)

文献1.
文献2.
文献3.
文献4.

这篇关于YOLOX训练自己的数据集(头铁出来的超详细教程)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/707103

相关文章

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

PyTorch使用教程之Tensor包详解

《PyTorch使用教程之Tensor包详解》这篇文章介绍了PyTorch中的张量(Tensor)数据结构,包括张量的数据类型、初始化、常用操作、属性等,张量是PyTorch框架中的核心数据结构,支持... 目录1、张量Tensor2、数据类型3、初始化(构造张量)4、常用操作5、常用属性5.1 存储(st

Python实现将实体类列表数据导出到Excel文件

《Python实现将实体类列表数据导出到Excel文件》在数据处理和报告生成中,将实体类的列表数据导出到Excel文件是一项常见任务,Python提供了多种库来实现这一目标,下面就来跟随小编一起学习一... 目录一、环境准备二、定义实体类三、创建实体类列表四、将实体类列表转换为DataFrame五、导出Da