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

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

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

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

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

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

# 加载模型
model_ft = torchvision.models.resnet18(weights=torchvision.models.ResNet18_Weights.DEFAULT)

# 冻结模型
for param in model_ft.parameters():
    param.requires_grad = False

# 编辑模型
num_ftrs = model_ft.fc.in_features
model_ft.fc = nn.Linear(num_ftrs, 10)

# 取出未冻结的层
param_update= []
for param in model_ft.parameters():
    if param.requires_grad:
        param_update.append(param)

# 定义优化器
optimizer_ft = optim.Adam(param_update, lr=0.001)

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

但是这样做有一个问题:

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

state = {
        'state_dict': mymodel.state_dict(),
        'optimizer': optimizer.state_dict()
    }
torch.save(state, "save_test
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值