前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SSD-pytorch踩坑及修正(StopIteration)

SSD-pytorch踩坑及修正(StopIteration)

作者头像
狼啸风云
修改2022-09-02 19:48:04
1.8K0
修改2022-09-02 19:48:04
举报

SSD-pytorch踩坑(StopIteration)

ssd-pytorch代码链接

github上的:https://github.com/amdegroot/ssd.pytorch

bug

这篇博客写的基本上没什么问题,但是其实也有坑。

https://blog.csdn.net/sinat_39307513/article/details/84646177

在这篇博客的评论区里面出现了

“博主您好,我训练时候损失降得又快又低,但是运行eval.py时的精度又很低,博主有遇到过这个问题吗?是什么原因大概”

“博主你好,请问我用自己的数据集训练过后,用eval.py计算AP,mAP结果全是零,这是怎么回事呢?谢谢”

我在运行

代码语言:javascript
复制
python train.py

的时候,发现确实loss降的异常的快。

运行

代码语言:javascript
复制
python eval.py

的时候mAP是一个很接近0的数。

经过思考,发现问题出在原来博客的第4个点:

(下面这段是从原文中复制来的)

代码语言:javascript
复制
4.train.py代码中,在迭代过程中,每次执行batch张图片,通过images, targets = next(batch_iterator)读取图片时,如果next()中没有数据后会触发Stoplteration异常,使用下面语句替换 images, targets = next(batch_iterator)将解决这种异常问题。


while True:
    try:
        # 获得下一个值:
        images, targets = next(batch_iterator)
 
    except StopIteration:
        # 遇到StopIteration就退出循环
        break
————————————————
【版权声明:本文为CSDN博主「花花花哇_」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:[https://blog.csdn.net/sinat_39307513/article/details/84646177](https://blog.csdn.net/sinat_39307513/article/details/84646177)】
————————————————

但是其实是不能够这样改的,这么改的思路是遇到了问题就跳过去,这样很明显是不可以的,会导致不断的跳出循环,没有在进行有效的train,所以loss会降得很快,最后的结果也不好。

解决方案

这个问题出现的原因是dataloader导入数据之后经过了一轮的迭代,再次导入的时候发现没有数据了,也就是iterable完成之后,触发了StopIteration,然后跳出了循环。

既然再次导入的时候没有数据了,那我们就再用一个dataloader就行了。

将train.py(165行)的

代码语言:javascript
复制
images, targets = next(batch_iterator)

更改成:

代码语言:javascript
复制
try:
	images, targets = next(batch_iterator)
except StopIteration:
	batch_iterator = iter(data_loader)
	images, targets = next(batch_iterator)

问题解决。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-12-31 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • ssd-pytorch代码链接
  • bug
  • 解决方案
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档