《昇思25天学习打卡营第9天|LXS》

保存与加载

  • 模型训练完后要进行保存,方便随时加载和进一步训练微调,首先构建一个模型
def network():
    model = nn.SequentialCell(
                nn.Flatten(),
                nn.Dense(28*28, 512),
                nn.ReLU(),
                nn.Dense(512, 512),
                nn.ReLU(),
                nn.Dense(512, 10))
    return model
  • 保存模型使用save_checkpoint接口,传入网络和指定的保存路径
model = network()
mindspore.save_checkpoint(model, "model.ckpt")
  • 加载模型就使用load_checkpoint
model = network()
param_dict = mindspore.load_checkpoint("model.ckpt")
param_not_load, _ = mindspore.load_param_into_net(model, param_dict)
print(param_not_load)
  • 除了load_checkpoint加载方式以外,MIndspore还提供了云侧与端侧中间统一的方式,export方式
model = network()
inputs = Tensor(np.ones([1, 1, 28, 28]).astype(np.float32))
mindspore.export(model, inputs, file_name="model", file_format="MINDIR")
  • 继续往MIndspore中装入模式,可以确定为是Graph静态图模式,需要加载时将midIR放入,即上述的中间方式,即可加载模型
mindspore.set_context(mode=mindspore.GRAPH_MODE)

graph = mindspore.load("model.mindir")
model = nn.GraphCell(graph)
outputs = model(inputs)
print(outputs.shape)
  • 保存的模型如下所示,分别为ckpt与mindir

在这里插入图片描述在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值