【YOLOv3】YOLO3训练自己的单类model

YOLOv3:https://pjreddie.com/darknet/yolo/

说明书:https://pjreddie.com/media/files/papers/YOLOv3.pdf


今天Yolo Object Detector的作者发布了YOLOv3,看起来性能更好但速度有所牺牲。

大致使用方法见其他人对YOLOv2的blog,这里说一下训练单一class时的区别。

一般我们训练的class都是1类,所以在cfg/yolov3.cfg里:

    把所有“classes=80”替换为1 (别忘了.data里也要改);

    把所有“filters=255”替换为18;

原因:
在YOLOv2的【Region】上面那层的filters=num*(cls+1+4),所以按原来的算法filters=5*(1+1+4)=30
但在YOLOv3里【region】替换成了3个【yolo】层,因其用了三个scale来预测bounding box,每个scale上预测三个box
尽管每个【yolo】里num=9,但它们上一层filters=num*(cls+1+4)里num实际是3,原因见上一行
例:默认yolov3.cfg里是Coco的80类,classes=80

所以每个【yolo】层上面的filter数=3*(80+1+4)=255

BTW,新yolo训练真慢...
  • 2
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要使用 YOLOv3 训练自己的数据集,需要进行以下步骤: 1. 准备数据集:将自己的数据集标注为 YOLOv3 所需的格式。YOLOv3 要求标注文件为 `.txt` 格式,每个文件对应一张图片,文件中每一行表示一次标注,格式为 `[物体别] [中心点 x 坐标] [中心点 y 坐标] [宽度] [高度]`,其中坐标和尺寸应该是相对于图片宽度和高度的比例。例如: ``` 0 0.43 0.56 0.27 0.48 ``` 表示图片中一个别为 0 的物体,中心点坐标为 (0.43, 0.56),宽度为图片宽度的 0.27 倍,高度为图片高度的 0.48 倍。 2. 下载预训练权重:从 YOLO 官方网站下载预训练权重文件,可以使用 `wget` 命令进行下载: ``` wget https://pjreddie.com/media/files/yolov3.weights ``` 3. 转换权重文件:使用 `convert.py` 脚本将下载的权重文件转换成 Keras 模型所需的格式: ``` python convert.py yolov3.cfg yolov3.weights model_data/yolo.h5 ``` 4. 修改配置文件:将 YOLOv3 的配置文件 `yolov3.cfg` 中的参数修改为符合自己数据集的要求,包括别数、输入图片大小等。 5. 训练模型:使用 `train.py` 脚本进行训练,例如: ``` python train.py --batch_size 16 --epochs 50 --annotation train.txt --classes_path classes.txt --anchors_path yolov3_anchors.txt --input_shape 416 ``` 其中 `--annotation` 参数指定训练集的标注文件,`--classes_path` 参数指定别名称文件,`--anchors_path` 参数指定先前下载的锚点文件路径,`--input_shape` 参数指定输入图片的大小。 6. 测试模型:使用 `yolo_video.py` 或 `yolo_image.py` 脚本进行测试,例如: ``` python yolo_video.py --input video.mp4 --output output.avi --classes_path classes.txt --anchors_path yolov3_anchors.txt --weights_path logs/000/trained_weights_final.h5 --score 0.5 --input_shape 416 ``` 其中 `--input` 参数指定输入视频文件路径,`--output` 参数指定输出视频文件路径,`--weights_path` 参数指定训练好的模型权重文件路径,`--score` 参数指定筛选框的置信度阈值,`--input_shape` 参数同样指定输入图片的大小。 这些步骤只是大致流程,具体实现过程中可能还需要进行一些参数调整和代码修改。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值