【yolov3】【3】yolov3-spp网络训练踩坑纪实(pytorch0.4环境跑pytorch1.0代码)

yolov3-spp是yolov3的一个版本,在yolo官网中给出了cfg和weights。
本文调试源码为ultralytics/yolov3,源码的解析放在之前的一篇yolov3-spp结构详解与源码解析(pytorch),这篇博客只记录在训练过程中出现的一些问题。

bug1: ‘too many indices for tensor of dimension 1’

bug描述:
问题出在dataset.py文件中,collate_fn函数中有一句:

l[:, 0] = i

bug原因:
这一句为1个batch中的每张image的每一个label,赋值一个idx,即为对应的image,使得最后的label可以和image相对应。但是,有的image是没有对应的label的,而pytorch0.4会出现维度的问题,是因为会将这种空的tensor的维度挤压为1:
torch.Size([0])
解决:

    def collate_fn(batch):
        img, label, path, hw = list(zip(*batch))  # transposed
        for i, l in enumerate(label):
            try:
                l[:, 0] = i  # add target image index for build_targets()
            except:
                pass
        return torch.stack(img, 0), torch.cat(label, 0), path, hw

补充:
build_target.py中,出现了类似的问题,这里是因为t是空的,即targets中没有标签,个人分析,原因是整个batch中所有image都没有对应的label。依旧用try-except粗暴解决:

        # Indices
        try:
            b<
  • 1
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 10
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值