pytorch 状态字典:state_dict

pytorch 中的 state_dict 是一个简单的python的字典对象,将每一层与它的对应参数建立映射关系.(如model的每一层的weights及偏置等等)

(注意,只有那些参数可以训练的layer才会被保存到模型的state_dict中,如卷积层,线性层等等)

优化器对象Optimizer也有一个state_dict,它包含了优化器的状态以及被使用的超参数(如lr, momentum,weight_decay等)

 

备注:

1) state_dict是在定义了model或optimizer之后pytorch自动生成的,可以直接调用.常用的保存state_dict的格式是".pt"或'.pth'的文件,即下面命令的 PATH="./***.pt"

torch.save(model.state_dict(), PATH)

2) load_state_dict 也是model或optimizer之后pytorch自动具备的函数,可以直接调用

model = TheModelClass(*args, **kwargs)
model.load_state_dict(torch.load(PATH))
model.eval()

注意:model.eval() 的重要性,在2)中最后用到了model.eval(),是因为,只有在执行该命令后,"dropout层"及"batch normalization层"才会进入 evalution 模态. 而在"训练(training)模态"与"评估(evalution)模态"下,这两层有不同的表现形式.

-------------------------------------------------------------------------------------------------------------------------------

模态字典(state_dict)的保存(model是一个网络结构类的对象)

1.1)仅保存学习到的参数,用以下命令

    torch.save(model.state_dict(), PATH)

1.2)加载model.state_dict,用以下命令

    model = TheModelClass(*args, **kwargs)
    model.load_state_dict(torch.load(PATH))
    model.eval()

    备注:model.load_state_dict的操作对象是 一个具体的对象,而不能是文件名

-----------

2.1)保存整个model的状态,用以下命令

    torch.save(model,PATH)

2.2)加载整个model的状态,用以下命令:

          # Model class must be defined somewhere

    model = torch.load(PATH)

    model.eval()

--------------------------------------------------------------------------------------------------------------------------------------

state_dict 是一个python的字典格式,以字典的格式存储,然后以字典的格式被加载,而且只加载key匹配的项

----------------------------------------------------------------------------------------------------------------------

如何仅加载某一层的训练的到的参数(某一层的state)

If you want to load parameters from one layer to another, but some keys do not match, simply change the name of the parameter keys in the state_dict that you are loading to match the keys in the model that you are loading into.

conv1_weight_state = torch.load('./model_state_dict.pt')['conv1.weight']

--------------------------------------------------------------------------------------------

加载模型参数后,如何设置某层某参数的"是否需要训练"(param.requires_grad)

for param in list(model.pretrained.parameters()):
    param.requires_grad = False

注意: requires_grad的操作对象是tensor.

疑问:能否直接对某个层直接之用requires_grad呢?例如:model.conv1.requires_grad=False

回答:经测试,不可以.model.conv1 没有requires_grad属性.

 

---------------------------------------------------------------------------------------------

全部测试代码:

#-*-coding:utf-8-*-
import torch
import torch.nn as nn
import torch.nn.functional as F
import torch.optim as optim



# define model
class TheModelClass(nn.Module):
    def __init__(self):
        super(TheModelClass,self).__init__()
        self.conv1 = nn.Conv2d(3,6,5)
        self.pool = nn.MaxPool2d(2,2)
        self.conv2 = nn.Conv2d(6,16,5)
        self.fc1 = nn.Linear(16*5*5,120)
        self.fc2 = nn.Linear(120,84)
        self.fc3 = nn.Linear(84,10)

    def forward(self,x):
        x = self.pool(F.relu(self.conv1(x)))
        x = self.pool(F.relu(self.conv2(x)))
        x = x.view(-1,16*5*5)
        x = F.relu(self.fc1(x))
        x = F.relu(self.fc2(x))
        x = self.fc3(x)
        return x

# initial model
model = TheModelClass()

#initialize the optimizer
optimizer = optim.SGD(model.parameters(),lr=0.001,momentum=0.9)

# print the model's state_dict
print("model's state_dict:")
for param_tensor in model.state_dict():
    print(param_tensor,'\t',model.state_dict()[param_tensor].size())

print("\noptimizer's state_dict")
for var_name in optimizer.state_dict():
    print(var_name,'\t',optimizer.state_dict()[var_name])

print("\nprint particular param")
print('\n',model.conv1.weight.size())
print('\n',model.conv1.weight)

print("------------------------------------")
torch.save(model.state_dict(),'./model_state_dict.pt')
# model_2 = TheModelClass()
# model_2.load_state_dict(torch.load('./model_state_dict'))
# model.eval()
# print('\n',model_2.conv1.weight)
# print((model_2.conv1.weight == model.conv1.weight).size())
## 仅仅加载某一层的参数
conv1_weight_state = torch.load('./model_state_dict.pt')['conv1.weight']
print(conv1_weight_state==model.conv1.weight)

model_2 = TheModelClass()
model_2.load_state_dict(torch.load('./model_state_dict.pt'))
model_2.conv1.requires_grad=False
print(model_2.conv1.requires_grad)
print(model_2.conv1.bias.requires_grad)

 

 

 

 

 

### 回答1: PyTorchstate_dict是一个字典对象,它将每个层或参数与其对应的张量关联起来。state_dict可以很方便地保存和加载模型的参数,用于模型的训练和推断。 state_dict中的键是层或参数的名称,值是对应的张量。张量包含了层或参数的权重和偏置等参数。在保存模型时,state_dict可以使用`torch.save()`函数将其保存为.pth文件,以便在将来加载使用。 在加载模型时,可以使用`torch.load()`函数加载.state_dict文件,并使用`model.load_state_dict()`函数将参数加载到模型中。这是因为模型state_dict中的层或参数的名称要一致。 使用state_dict有以下优势: 1. 方便保存和加载模型state_dict提供了一种方便的方式来保存和加载模型参数,可以方便地在不同的环境中迁移模型或继续训练。 2. 灵活性:state_dict允许我们选择性地保存和加载模型中的特定层或参数,可以更灵活地控制模型的加载和存储。 3. 安全性:state_dict只保存模型参数的数据,不保存模型的结构,因此可以更安全地共享模型而不暴露模型的实现细节。 总结:PyTorchstate_dict是一个方便且灵活的字典对象,用于保存和加载模型的参数。它简化了模型的管理和共享,并提高了训练和推断的效率。 ### 回答2: PyTorch中的state_dict是一个Python字典,它将每个模型层和对应的权重参数(张量)映射起来。state_dict中的键是层的名称,而值是层的权重参数。state_dict提供了灵活的方式来保存、加载以及在不同模型之间拷贝这些权重参数。 在PyTorch中,可以通过调用模型state_dict()方法来获取该模型state_dict。例如,如果我们有一个名为"model"的模型,我们可以使用model.state_dict()来获得它的state_dict。这个state_dict可以保存到硬盘上,并在需要的时候通过调用torch.load()进行加载。 通过保存和加载模型state_dict,我们可以方便地将模型的训练状态保存下来,以供后续使用。这对于断点续训以及模型热启动等场景非常有用。 另外,state_dict还可以用于将一个模型的权重参数复制到另一个模型。这在迁移学习、模型融合等任务中非常常见。通过将源模型state_dict加载到目标模型中,我们可以将源模型的权重参数复制到目标模型,从而使目标模型具有源模型的相似特性和性能。 需要注意的是,state_dict只保存模型的权重参数,不保存模型的架构。因此,在加载state_dict时,我们需要重新定义模型的架构,并根据state_dict调整模型的权重参数。 总之,PyTorchstate_dict是一个非常有用的工具,它提供了一种方便的方式来保存、加载和复制模型的权重参数。通过使用state_dict,我们可以方便地管理和处理模型状态,使得模型训练和迁移更加灵活和高效。 ### 回答3: pytorchstate_dict是一个字典对象,它保存了神经网络模型的参数和缓存项。state_dict以键值对的形式存储了每个参数的名称和对应的张量。 state_dictpytorch中有多种用途。首先,它可以用于保存和加载模型的参数。例如,我们可以使用torch.save(state_dict, PATH)将state_dict保存到硬盘上的文件中,并使用torch.load(PATH)将其加载回内存中。这是在训练期间保存和加载模型的常用方法,因为state_dict对象只包含了模型的参数,不包含网络结构本身,因此能够更轻便地保存和加载。 其次,state_dict还可以用于需定制化的更改或迁移模型。当我们需要修改或迁移模型时,可以使用state_dict对象来访问和修改模型的不同参数。通过修改state_dict中的值,我们可以实现一些特定的需求,比如参数的重命名、删除或替换等。这样我们就不需要修改整个神经网络的结构,只需对特定的参数进行操作。 最后,state_dict还可以用于模型的参数分析。我们可以通过state_dict对象来查看每个层参数的值和统计信息,比如平均值、方差等。这对于模型的调试、优化和结果分析非常有帮助。 总之,pytorchstate_dict是一个非常重要的对象,它保存了神经网络模型的参数和缓存项,并且可以在模型训练、保存、加载、修改和分析等方面发挥重要作用。它简化了模型的保存和加载流程,同时也为模型的定制化和调试提供了便利。
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值