数据集有三大功能: 训练、验证和测试
训练最好理解,是拟合模型的过程,模型会通过分析数据、调节内部参数从而得到最优的模型效果。
验证即验证模型效果,效果可以指导我们调整模型中的超参数(在开始训练之前设置参数,而不是通过训练得到参数),通常会使用少量未参与训练的数据对模型进行验证,在训练的间隙中进行。
测试的作用是检查模型是否具有泛化能力(泛化能力是指模型对训练集之外的数据集是否也有很好的拟合能力)。通常会在模型训练完毕之后,选用较多训练集以外的数据进行测试。
先说一下这个文件主要是用来干什么的,我们在训练结束后会打印出每个类别的一些评价指标,但是如果当时忘记记录,很多人就不知道怎么再次看到这些评价指标,那么我们就可以通过这个文件再次打印这些评价指标
还有就是我们在train的时候每轮打印出来的那些评价指标是验证集的评价指标,并不是测试集的评价指标,我们最终要放到论文里面的应该是测试集的评价指标
测试集的图片只在模型训练完成以后跑一轮,并且测试集的图片也是需要标注的!
数据集配置文件的路径,默认是coco128数据集,yaml文件里面包含数据集的路径、类别等信息
模型的权重文件地址 ,这里要改成你想参与验证的模型的路径
前向传播的批大小
输入网络的图片分辨率 默认640
置信度阈值
NMS时IOU的阈值
这个参数比较重要,这个文件最核心的部分就是这个参数,我们想得到各个数据集的评价指标都是通过这个参数,如果想得到验证集的参数可以使用如下指令,(speed和study似乎还没实现,用了会报错)
python val.py --task test
这样就会打印测试集的评价指标
指定测试的设备
线程数,和你训练时一样不报错就好
数据集是否只用一个类别 默认False
这也是一个比较重要的参数,即测试是否使用TTA Test Time Augment,指定这个参数后各项指标会明显提升几个点,但是如果要用这个参数,你的基线也要记得使用
是否打印出每个类别的mAP 默认False
是否保存txt格式文件,默认关闭
打开了就多了这个
里面就是这样的,包含了类别信息和中心点坐标和宽高
将标签+预测混合结果保存到 .txt
开启是这样的
这个参数的意思就是是否以.txt的格式保存目标的置信度
如果单独指定这个命令是没有效果的;
python detect.py --save-conf #不报错,但没效果
必须和–save-txt配合使用,即:
python detect.py --save-txt --save-conf
如果指定了这个参数就可以发现,同样是保存txt格式的文件,这次多了红色框里面的置信度值。原来每行只有5个数字,现在有6个了。
是否按照coco的json格式保存预测框,并且使用cocoapi做评估(需要同样coco的json格式的标签) 默认False
开启后就多了这个json文件
打开就这这样子的
保存的源文件地址
测试保存的文件地址名字 默认exp
是否存在当前文件 默认False
是否使用半精度推理 默认False
这个参数的意思就是是否使用 OpenCV DNN 进行 ONNX 推理
1.手把手带你调参Yolo v5 (v6.2)(一)强烈推荐
2.手把手带你调参Yolo v5 (v6.2)(二)
3.如何快速使用自己的数据集训练Yolov5模型
4.手把手带你Yolov5 (v6.2)添加注意力机制(一)(并附上30多种顶会Attention原理图)
5.手把手带你Yolov5 (v6.2)添加注意力机制(二)(在C3模块中加入注意力机制)
6.Yolov5如何更换激活函数?
7.Yolov5 (v6.2)数据增强方式解析
8.Yolov5更换上采样方式( 最近邻 / 双线性 / 双立方 / 三线性 / 转置卷积)
9.Yolov5如何更换EIOU / alpha IOU / SIoU?
10.Yolov5更换主干网络之《旷视轻量化卷积神经网络ShuffleNetv2》
11.YOLOv5应用轻量级通用上采样算子CARAFE
12.空间金字塔池化改进 SPP / SPPF / ASPP / SimSPPF / RFB / SPPCSPC
13.用于低分辨率图像和小物体的模块SPD-Conv
14.持续更新中
有问题欢迎大家指正,如果感觉有帮助的话请点赞支持下