这些年炼丹时的低级失误,持续反省中

23 篇文章 0 订阅
16 篇文章 0 订阅

 

预处理

 

1.ImageFolder读取时需要补零

 

ImageFolder 读取顺序之坑 – 柴犬的犬舍 (doge.ac.cn)

 

2.通道转换用transpose,而不是reshape(我是傻逼)

 

np.reshape()和np.transpose() – 柴犬的犬舍 (doge.ac.cn)

 

3.pytorch ToTensor对部署的影响

 

transforms.ToTensor()操作之后,图像会从[0, 255] -> [0.0,1.0]

 

部署时需要

 

image /= 255.0

 

训练

 

1.train,eval 调整

 

pytorch之坑:model.eval与model.train – 柴犬的犬舍 (doge.ac.cn)

 

2.scheduler.step() optimizer.step() 位置写错

 

这里可以用tensorboard实时监控学习率解决,防止写错位置学习率骤降

 

tensorboard使用 – 柴犬的犬舍 (doge.ac.cn)

 

3.忘记optimizer.zero_grad()

 

模型保存

 

1.save和load方法要对应

 

尽量直接save model,而不是model.state_dict(),这样方便恢复训练

 

torch.save(model, model_path)
model = torch.load(model_path)
model.eval()

 

torch.save(model.state_dict(), PATH)
model.load_state_dict(torch.load(PATH))
model.eval()

 

最终的解决方法

1.训练时用tensorboard监控学习率,处理图像时把预处理结束的图像放在tensorboard上。

2.如果模型不拟合,先用最少的样本测试模型能不能过拟合,测试整个流程有没有出问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值