pytorch的CrossEntropyLoss交叉熵损失函数默认reduction是平均值

pytorch中使用nn.CrossEntropyLoss()创建出来的交叉熵损失函数计算损失默认是求平均值的,即多个样本输入后获取的是一个均值标量,而不是样本大小的向量。

复制代码
net = nn.Linear(4, 2)
loss = nn.CrossEntropyLoss()
X = torch.rand(10, 4)
y = torch.ones(10, dtype=torch.long)
y_hat = net(X)
l = loss(y_hat, y)
print(l)

打印的结果:tensor(0.7075, grad_fn=<NllLossBackward0>)

以上是对10个样本做的均值的标量

复制代码
net = nn.Linear(4, 2)
loss = nn.CrossEntropyLoss(reduction='none')
X = torch.rand(10, 4)
y = torch.ones(10, dtype=torch.long)
y_hat = net(X)
l = loss(y_hat, y)
print(l)

在构造CrossEntropyLoss时候加入 reduction='none',就把默认求平均取消掉了

打印结果:

复制代码
tensor([0.6459, 0.7372, 0.6373, 0.6843, 0.6251, 0.6555, 0.5510, 0.7016, 0.6975,
        0.6849], grad_fn=<NllLossBackward0>)

以上是10个样本各自的loss值

上图是pytorch的CrossEntropyLoss的构造方法,默认是 reduction='mean'

此外,使用反向传播计算梯度也会发生变化,loss值调用backward()要求loss值是一个tensor标量,如果是reduction='none',loss值得到的是tensor向量,会报错。 loss值需要求和或者求平均得到标量再进行backward()的计算

复制代码
l = loss(y_hat, y)
l.sum().backward()

至于为什么求和或者求平均都可以,首先要看下更新梯度的计算公式

求和学习率就调整的大一点,求均值的话学习率就可以小一点,总之就是除以样本数这个操作可以放到调整学习率中

相关推荐
人工智能AI技术6 小时前
什么是多模态
人工智能
HAREWORK_FFF7 小时前
非技术背景人士的AI赋能路径分析:从辅助到主导的角色演进
人工智能
AI浩7 小时前
ViT-5:面向2020年代中期的视觉Transformer
人工智能·深度学习·transformer
大连好光景7 小时前
PyTorch深度学习----优化器
pytorch·深度学习·学习
relis7 小时前
深度学习模型 CPU 移植实战:将 MinivLLM 从 GPU 迁移到 CPU 环境
人工智能·深度学习
两万五千个小时7 小时前
构建mini Claude Code:06 - Agent 如何「战略性遗忘」(上下文压缩)
人工智能·python
GatiArt雷7 小时前
2026丙午马年新春AI创意祝福生成系统:设计与实现
人工智能
两万五千个小时7 小时前
构建mini Claude Code:12 - 从「文件冲突」到「分身协作」:Worktree 如何让多 Agent 安全并行
人工智能·python·架构
yuki_uix7 小时前
为什么我的 Auth Token 藏在了 Network 面板的 Doc 里?
前端·python·debug
老纪的技术唠嗑局7 小时前
OpenClaw 是怎么让 AI 变得 “像人” 的?
人工智能