深度学习笔记-013 模型权重保存

保存模型参数

state_dict就是一个简单的Python字典,它将模型中的可训练参数(比如weights和biases,batchnorm的running_mean、torch.optim参数等)通过将模型每层与层的参数张量之间一一映射,实现保存、更新、变化和再存储。

首先定义模型的保存位置和文件名(以.pth结尾)
再save模型权重到固定路径

PATH = './my_net.pth'
torch.save(model.state_dict(), PATH)

加载所保存的模型权重

需要初始化之前所定义的网络

new_model = Net()

再使用load_state_dict方法将权重加载进网络

new_model.load_state_dict(torch.load(PATH))

保存测试中最优的参数

代码如下:

best_model_wts = copy.deepcopy(model.state_dict())
best_acc = 0.0

train_loss = []
train_acc = []
test_loss = []
test_acc = []

for epoch in range(epochs):
    epoch_loss, epoch_acc, epoch_test_loss, epoch_test_acc = fit(epoch,
                                                                 model,
                                                                 train_dl,
                                                                 test_dl)
    train_loss.append(epoch_loss)
    train_acc.append(epoch_acc)
    test_loss.append(epoch_test_loss)
    test_acc.append(epoch_test_acc)
    
    #判断是否是最优结果
    if epoch_test_acc > best_acc:
        best_acc = epoch_acc
        best_model_wts = copy.deepcopy(model.state_dict())        
#将最优结果保存
model.load_state_dict(best_model_wts)
model.eval()

完整模型的保存和加载

直接使用torch.save方法对模型进行保存

PATH = './my_whole_model.pth'

torch.save(model, PATH)

new_model2 = torch.load(PATH)
new_model2.eval()
  • 4
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值