环境配置
pycharm
YOLOv5
pytorch
labelling
收集样本,贴标签
收集样本用爬虫收集,下面是我用的爬虫代码:
爬取百度图库图片
1 | # -*- coding:utf8 -*- |
贴标签
在Pycharm下训练
相关目录形式如上图所示
其中关于coco128文件夹以及在YOLO中需要修改.yaml文件根据这个教程进行对应的设置
在准备好coco128文件和对应的.yaml文件的设置后点开train.py文件找到下图所示代码:
主要关注红圈或者红线的参数
对应参数的解释大致如下:
Epoch
一个epoch , 表示: 所有的数据送入网络中, 完成了一次前向计算 + 反向传播的过程。
由于一个epoch 常常太大, 分成 几个小的 baches .
将所有数据迭代训练一次是不够的, 需要反复多次才能拟合、收敛。
在实际训练时、 将所有数据分成多个batch , 每次送入一部分数据。
使用单个epoch 更新权重 不够。
随着epoch 数量的增加, 权重更新迭代的次数增多, 曲线从最开始的不拟合状态, 进入优化拟合状态, 最终进入过拟合。
epoch 如何设置: 大小与数据集的多样化程度有关, 多样化程度越强, epoch 越大。
batchsize
每个batch 中: 训练样本的数量。
batch size 大小的选择也很重要, 最优化网络模型的性能+速度。
当数据量较小, 计算机可以承载只有1个batch 的训练方式时, 收敛效果会好。
mini-batch : 将所有数据分为若干个batch , 每个batch 包含一部分训练样本。。
iterations
完成一次epoch 需要的batch 个数
batch numbers 就是 iterations .
分为了多少个batch? : 数据总数/ batch_size
参数解释链接
以上这些参数根据自己需要修改
红下划线参数,workers,需要将default=0
这些设置完后就可以开始训练了,右键运行train.py文件,运行过程如下图:
在训练完后你会在run文件夹中看到你本次训练的结果,如下图: