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

本文详细记录了在使用pytorch训练yolov3-spp网络时遇到的五个主要问题,包括'too many indices for tensor of dimension 1'的维度错误、多GPU训练时的'YOLOLayer'对象属性错误、处理空标签时的维度问题、Dataloader worker被信号杀死的运行时错误以及'tensor'对象没有argsort属性的问题。通过分析原因和提供解决方法,帮助读者避免和解决相似问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值