首页 > 其他 > 详细

pytorch实现网络的保存和提取

时间:2020-02-12 19:58:10      阅读:100      评论:0      收藏:0      [点我收藏+]

代码如下:

#实现网络的保存和提取
import torch
from torch.autograd import Variable
import matplotlib.pyplot as plt

#设置随机种子实现结果复现,在神经网络中,参数默认是进行随机初始化的。
# 不同的初始化参数往往会导致不同的结果,当得到比较好的结果时我们通常希望这个结果是可以复现的,
# 在pytorch中,通过设置随机数种子也可以达到这么目的
torch.manual_seed(1)

#生成数据
x = torch.unsqueeze(torch.linspace(-1, 1, 100), dim=1)
y = x.pow(2) + 0.2*torch.rand(x.size())
x,y = Variable(x, requries_grad=False), Variable(y,requries_grad=False)

#保存网络
def save():
    net1 = torch.nn.Sequential(   #顺序搭建层
        torch.nn.Linear(1, 10),
        torch.nn.ReLU(),
        torch.nn.Linear(10, 1)
    )
    optimizer = torch.optim.SGD(net.parameters(), lr=0.5)
    loss_func = torch.nn.MSELoss()

    for t in range(100):
        prediction = net1(x)
        loss = loss_func(prediction, y) #预测值和真实值
        optimizer.zero_grad()
        loss.backward()
        optimizer.step()

    torch.save(net1, net1.pkl)                       #保存整个神经网络到net1.pkl中
    torch.save(net1.state_dict(), net1_paras.pkl)    #保存网络里的参数到net1_paras.pkl中

    #画图


#提取方式1
#提取整个网络
def restore_net():
    net2 = torch.load(net1.pkl)    
    
#提取方式2
#先建一个一样的网络,再把保存的参数放进去
def restore_paras():
    net3 = torch.nn.Sequential(   #建立和net1一样的层,不过参数肯定不同
        torch.nn.Linear(1, 10),
        torch.nn.ReLU(),
        torch.nn.Linear(10, 1)
    )
    net3.load_state_dict(torch.load(net1_paras.pkl))

 

pytorch实现网络的保存和提取

原文:https://www.cnblogs.com/loyolh/p/12299878.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!