位置: IT常识 - 正文

yolov7模型训练结果分析以及如何评估yolov7模型训练的效果(yolov5模型训练)

编辑:rootadmin
yolov7模型训练结果分析以及如何评估yolov7模型训练的效果

推荐整理分享yolov7模型训练结果分析以及如何评估yolov7模型训练的效果(yolov5模型训练),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:yolov3训练模型时的loss图像,yolov3模型训练,yolov3训练模型时的loss图像,yolov1模型,yolov5模型训练,yolo 模型训练,yolov4训练模型,yolov4训练模型,内容如对您有帮助,希望把文章链接给更多的朋友!

最近是刚刚训练yolov7模型,但是只会一股脑的训练是不行的,要懂得训练多少epoch,以及通过哪些指标来查看训练的效果如何,现在这几天的经验总结一下。

本实验以person为例子,分别训练100epoch、60epoch、50epoch

训练经验:由于并不知道到底训练多少epoch效果比较好,所以现在先设置成100。(这几天查询资料得出来的结论一般50多就差不多了)

1、关于yolov7训练结果的文件解析

一、weights

也就是训练好的模型,一般使用best.pt去进行推理

 包括best.pt和last.pt,以及默认25epoch保存一次模型,以及保存最后5个epoch的模型

二、 confusion_matrix.png

混淆矩阵

混淆矩阵以矩阵形式将数据集中的记录按照真实的类别与分类模型预测的类别判断两个标准进行汇总。其中矩阵的行表示真实值,矩阵的列表示预测值。

TP(True Positive): 将正类预测为正类数 即正确预测,真实为0,预测也为0

FN (False Negative):将正类预测为负类 即错误预测,真实为0,预测为1

FP(False Positive):将负类预测为正类数 即错误预测, 真实为1,预测为0

TN (True Negative):将负类预测为负类数,即正确预测,真实为1,预测也为1

精确率和召回率的计算方法

精确率Precision=TP / (TP+FP), 在预测是Positive所有结果中,预测正确的比重

召回率recall=TP / (TP+FN), 在真实值为Positive的所有结果中,预测正确的比重

 三、F1_curve.png

F1分数,它被定义为查准率和召回率的调和平均数

一些多分类问题的机器学习竞赛,常常将F1-score作为最终测评的方法。它是精确率和召回率的调和平均数,最大为1,最小为0。

F1-Score的值是从0到1的,1是最好,0是最差。

 这是100epoch得到的F1_curve,说明在置信度为0.4-0.6区间内得到比较好的F1分数

四、hyp.yaml和opt.yaml

训练时的超参数以及train.py中间的参数

五、P_curve.png

准确率precision和置信度confidence的关系图

 六、PR_curve.png

PR曲线中的P代表的是precision(精准率),R代表的是recall(召回率),其代表的是精准率与召回率的关系,一般情况下,将recall设置为横坐标,precision设置为纵坐标。PR曲线下围成的面积即AP,所有类别AP平均值即Map.

如果PR图的其中的一个曲线A完全包住另一个学习器的曲线B,则可断言A的性能优于B,当A和B发生交叉时,可以根据曲线下方的面积大小来进行比较。一般训练结果主要观察精度和召回率波动情况(波动不是很大则训练效果较好)

Precision和Recall往往是一对矛盾的性能度量指标;及一个的值越高另一个就低一点; 提高Precision <==> 提高二分类器预测正例门槛 <==> 使得二分类器预测的正例尽可能是真实正例; 提高Recall <==> 降低二分类器预测正例门槛 <== >使得二分类器尽可能将真实的正例挑选

七、R_curve.png

召回率recall和置信度confidence之间的关系

 八、results.pngyolov7模型训练结果分析以及如何评估yolov7模型训练的效果(yolov5模型训练)

Box:Box推测为GIoU损失函数均值,越小方框越准; Objectness:推测为目标检测loss均值,越小目标检测越准; Classification:推测为分类loss均值,越小分类越准,本实验为一类所以为0; Precision:精度(找对的正类/所有找到的正类);

Recall:真实为positive的准确率,即正样本有多少被找出来了(召回了多少)。

Recall从真实结果角度出发,描述了测试集中的真实正例有多少被二分类器挑选了出来,即真实的正例有多少被该二分类器召回。

val BOX:  验证集bounding box损失

val Objectness:验证集目标检测loss均值

val classification:验证集分类loss均值,本实验为一类所以为0

mAP是用Precision和Recall作为两轴作图后围成的面积,m表示平均,@后面的数表示判定iou为正负样本的阈值,@0.5:0.95表示阈值取0.5:0.05:0.95后取均值。

mAP@.5:.95(mAP@[.5:.95]) 表示在不同IoU阈值(从0.5到0.95,步长0.05)(0.5、0.55、0.6、0.65、0.7、0.75、0.8、0.85、0.9、0.95)上的平均mAP。

mAP@.5:表示阈值大于0.5的平均mAP

一般训练结果主要观察精度和召回率波动情况(波动不是很大则训练效果较好) 然后观察mAP@0.5 & mAP@0.5:0.95 评价训练结果。

九、results.txt

 分别的含义是训练次数、GPU消耗、训练集边界框损失、训练集目标检测损失、训练集分类损失、训练集总损失、targets目标、输入图片大小、Precision、Recall、mAP@.5、mAP@.5:.95、验证集边界框损失、验证集目标检测损失、验证机分类损失

十、train_batchx

我设置的batch_size为8所以一次读取8张图片

 十一、test_batchx_labels

验证集第一轮的实际标签

十二、运行tensorboard

activate yolov7(自己所配的环境名称)tensorboard --logdir=训练结果所在的文件夹二、分析模型的训练效果

接下来我将分别展示100epoch、60epoch和50epoch的tensorboard的可视化训练结果

100epoch

Loss

AP值

60epoch

Loss

AP值

50epoch

Loss

AP值

 分析:从100epoch的Loss来看从50-60epoch损失值就维持在一定的范围内,所以我们可以缩小训练epoch,然后设置epoch为60继续训练,发现相较于100epoch的AP值86.8,60epoch的AP值为87.7上升0.9,但是发现val的目标检测损失在50epoch之后有所上涨,所以我们再次设置epoch为50进行训练,发现AP值上升0.1。

总结:所以来说查看yolov7模型训练的效果要综合四个损失函数的值来看,先设置的epoch次数多一些,然后通过损失函数来看减少或增加训练轮数,然后查看AP值是否有所增加。

最后增加一下计算模型训练的FPS值,设置相应的参数并运行test.py

运行结果

 FPS=1000/(4.3+0.6+5.0)=101

本文链接地址:https://www.jiuchutong.com/zhishi/283822.html 转载请保留说明!

上一篇:vue3,使用watch监听props中的数据(vue watch监听vuex数据)

下一篇:intmon.exe进程信息查询 intmon是什么进程(进程com)

  • 手机qq为什么来消息没声音(手机QQ为什么来消息是两种声音)

  • 算法执行过程中所需要的存储空间称为算法的(算法执行过程中所需要的基本运算次数)

  • 苹果手机wifi第二天自动开启(苹果手机的wifi)

  • 闲鱼申请退款卖家不处理几天会退款(闲鱼申请退款卖家会收到短信吗)

  • 数据卡是什么意思(数据卡怎么办有什么办法解决)

  • 华为P40充电没有指示灯吗(华为p40pro充电不显示)

  • 电瓶车充电先插电池还是先插电源(电瓶车正确充电方法)

  • 蓝牙鼠标连上去动不了(蓝牙鼠标为什么连不上)

  • 红米k20pro充电突然变慢(红米k20pro充电一闪一闪的是什么原因)

  • 蓝屏代码0x000001e(蓝屏代码0X0000007B)

  • 小米盒子调声音没反应(小米盒子调节音量)

  • 拼多多不交保证金有什么影响吗(拼多多不交保证金可以卖几单)

  • 网络显示hd啥意思(网络出现hd是不是说明网络不好)

  • 网易云音乐访问别人主页有记录吗(网易云音乐访问记录从哪看)

  • 手机qq如何取消qq看点(手机qq如何取消气泡)

  • 手机拼多多怎么退货(手机拼多多怎么退店铺保证金)

  • 荣耀20怎么设置清理白名单(荣耀20怎么设置锁屏壁纸)

  • 悬浮球有什么作用(悬浮球有什么用处)

  • 魅族手机音乐视频没有声音(魅族音乐怎么调播放顺序)

  • 优酷青少年模式怎么取消(优酷青少年模式怎么设置)

  • 网件R6400路由器怎么样?网件R6400上网与传输评测的教程

  • 主板BIOS语言,中文解释(各种主板bios中文设置图解)

  • 关于vue2与vue3(vue2和vue3的兼容)

  • catman命令 创建参考手册的格式化文件(用cat命令创建f1和f2文件)

  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设 电脑维修 湖南楚通运网络