Pytorch的梯度控制

在之前的实验中遇到一些问题,因为之前计算资源有限,我就想着微调其中一部分参数做,于是我误打误撞使用了with torch.no_grad,可是发现梯度传递不了,于是写下此文来记录梯度控制的两个方法与区别。

在PyTorch中,控制梯度计算对于模型训练和微调至关重要。这里区分两个常用方法:

1. tensor.requires_grad = False

  • 目标: 单个张量(通常是模型参数 nn.Parameter)。
  • 行为:
    • "参数冻结" :这个张量本身不会计算梯度 (.gradNone)。
    • "参数不更新" :优化器不会更新这个张量。
    • "梯度可穿透" :如果它参与的运算的输入是 requires_grad=True 的,梯度仍然会通过这个运算传递给输入。它不阻碍梯度流向更早的可训练层。
  • 场景:
    • 微调:冻结预训练模型的某些层,只训练其他层。
    • 例子:pretrained_layer.weight.requires_grad = False

2. with torch.no_grad():

  • 目标: 一个代码块 (with 语句块内部)。

  • 行为:

    • "全局梯度关闭" (块内):块内所有新创建的张量默认 requires_grad=False
    • "不记录计算图" :块内的运算不被追踪,不构建反向传播所需的计算图。
    • "梯度截断" :梯度流到这个块的边界就会停止,无法通过块内的操作继续反向传播
  • 场景:

    • 模型评估/推理 (Inference/Evaluation):不需要梯度,节省内存和计算。
    • 执行不需要梯度的任何计算。
    • 例子:
    python 复制代码
     with torch.no_grad():
         outputs = model(inputs)
         # ...其他评估代码

核心区别速记:

特性 requires_grad=False with torch.no_grad():
谁不更新? 这个参数自己 (块内)没人更新
梯度能过吗? 能过! 不能过! (被截断)
影响范围? 单个张量 整个代码块

一句话总结:

  • 想让某个参数不更新但梯度能流过 ,用 requires_grad=False
  • 想让一段代码完全不计算梯度也不让梯度流过 ,用 with torch.no_grad()

搞清楚这两者的区别,能在PyTorch中更灵活地控制模型的训练过程!

相关推荐
EasyDSS9 分钟前
EasyRTC音视频实时通话助力微信小程序:打造低延迟、高可靠的VoIP端到端呼叫解决方案
人工智能·音视频
lagrahhn19 分钟前
文本相似度识别的“利器”:揭秘 Simhash 算法及其应用
人工智能·算法
鸢想睡觉23 分钟前
Mask_RCNN 环境配置及训练
人工智能·笔记·目标检测·mask_rcnn
暴躁哥25 分钟前
深入理解设计模式之解释器模式
python·设计模式·解释器模式
我想睡觉26130 分钟前
Python打卡训练营Day42
开发语言·人工智能·python·深度学习·算法
LitchiCheng36 分钟前
Python UV 环境下的 PyKDL 运动学库安装
开发语言·python·uv
武子康37 分钟前
AI炼丹日志-25 - OpenAI 开源的编码助手 Codex 上手指南
人工智能·gpt·ai·语言模型·自然语言处理·开源
Freshman小白38 分钟前
PINNs案例——二维磁场计算
人工智能·python·神经网络
waterHBO44 分钟前
python 空气质量可视化,数据分析 + 前后端分离 + ppt 演讲大纲
python·数据分析
蹦蹦跳跳真可爱5891 小时前
Python----目标检测(《基于区域提议网络的实时目标检测方法》和Faster R-CNN)
人工智能·python·深度学习·神经网络·目标检测·机器学习·cnn