• 关于requires_grad和优化器optim中parameters的记录


    在模型中如果设置了requires_grad=True,则表示该层要进行梯度计算,标记为False则不计算梯度,在迁移学习中一般会设置成False,这样会大量减少算力。

    而optim中的parameters是定义要对那些层进行参数优化

    一般在迁移学习的代码过程中我们会先把加载的模型所有层定义成requires_grad=False,再

    将模型编辑成我们需要的样子,例如将全连接层的输出定义成我们要的输出。

    然后根据没有冻结的层创建优化器。

    1. # 加载模型
    2. model_ft = torchvision.models.resnet18(weights=torchvision.models.ResNet18_Weights.DEFAULT)
    3. # 冻结模型
    4. for param in model_ft.parameters():
    5. param.requires_grad = False
    6. # 编辑模型
    7. num_ftrs = model_ft.fc.in_features
    8. model_ft.fc = nn.Linear(num_ftrs, 10)
    9. # 取出未冻结的层
    10. param_update= []
    11. for param in model_ft.parameters():
    12. if param.requires_grad:
    13. param_update.append(param)
    14. # 定义优化器
    15. optimizer_ft = optim.Adam(param_update, lr=0.001)

    这样做的好处是可以节省计算梯度和优化的算力

    但是这样做有一个问题:

    我在代码中会保存优化器以便于之后的继续测试

    1. state = {
    2. 'state_dict': mymodel.state_dict(),
    3. 'optimizer': optimizer.state_dict()
    4. }
    5. torch.save(state, "save_test.pth")

    读取的时候

    1. model_ft = torchvision.models.resnet18(weights=torchvision.models.ResNet18_Weights.DEFAULT)
    2. # 此时不冻结任何层 对全部层进行训练
    3. optimizer = optim.Adam(model_ft.parameters(), lr=1e-2)
    4. checkpoint = torch.load("save_test.pth")
    5. optimizer.load_state_dict(checkpoint['optimizer'])

    如果保存的时候对优化器设置的是只针对某几个层进行优化,而读取的时候希望对所有的层进行优化程序就会报错:

    File "D:\anaconda3\envs\pytorch_gpu\lib\site-packages\torch\optim\optimizer.py", line 171, in load_state_dict
        raise ValueError("loaded state dict contains a parameter group "
    ValueError: loaded state dict contains a parameter group that doesn't match the size of optimizer's group

    所以,在读取优化器记录的时候要注意,如果保存的数据是针对某些层保存的,而加载的时候又希望对所有层进行训练,这时候优化器数据就没必要加载了,要么写个try,要么就把这行注释掉。

  • 相关阅读:
    使用AVX2指令集加速推荐系统MMR层余弦相似度计算
    SpringCloud 完整版--(Spring Cloud Netflix 体系)
    【JVM】初步认识Java虚拟机
    给定一个m x n大小的矩阵(m行,n列),按螺旋的顺序返回矩阵中的所有元素
    PCL 点云转深度图像
    电子表格工具
    【Python基础】2万字-详解Python基础函数,包教包会
    MapReduce排序--倒排序索引
    约束(constraint)
    C++ 炼气期之变量的生命周期和作用域
  • 原文地址:https://blog.csdn.net/immc1979/article/details/128109715