【Pytorch】分类问题交叉熵

1️⃣ 为什么分类问题不用 MSE(均方误差)?

表格

复制

场景 标签 预测 MSE 损失
分类 [0,0,1] [0.3,0.3,0.4] (0.4-1)²=0.36
分类 [0,0,1] [0.1,0.2,0.7] (0.7-1)²=0.09

看起来合理,但:

  1. sigmoid/softmax 输出在 0/1 附近梯度几乎为零梯度消失

  2. MSE 把"概率差"当数值差" → 不符合概率直觉;

  3. 收敛慢,还容易卡在鞍点。


2️⃣ 交叉熵(Cross Entropy)思想

一句话 :衡量「真实分布 p」与「预测分布 q」之间的信息差距

公式(离散版):

CE(p,q) = − Σ p(i) log q(i)

  • p 是 one-hot 标签(比如 [0,0,1])

  • q 是 softmax 输出(比如 [0.1,0.2,0.7])

因为 p 只有一个 1,其余为 0,所以求和只剩一项

CE = − log q(正确类)

直观

  • 若 q(正确类)=0.7 → CE ≈ 0.36

  • 若 q(正确类)=0.98 → CE ≈ 0.02
    预测越准,损失越小 ,且梯度不饱和(后面会算给你看)。


3️⃣ 手推一条二分类例子

表格

复制

样本 真实 y 预测 p
1 0.8
0 0.1

二元交叉熵(BCE):

L = − [y log p + (1−y) log(1−p)]

样本 1(猫):

L = − [1·log0.8 + 0·log0.2] = −log0.8 ≈ 0.223

样本 2(狗):

L = − [0·log0.1 + 1·log0.9] = −log0.9 ≈ 0.105

平均损失 ≈ 0.164,预测越离谱,值越大


4️⃣ PyTorch 一行代码算完

Python

复制代码
import torch.nn.functional as F

logits = torch.tensor([[1.0, 2.0, 0.5]])   # 模型输出(未归一化)
target = torch.tensor([1])                  # 正确类别索引

loss = F.cross_entropy(logits, target)
print(loss.item())          #  tensor(0.8309)

内部干了啥

  1. softmax(logits) → 概率

  2. log(softmax) → 对数概率

  3. -log q(正确类) → 损失


5️⃣ 数值稳定性技巧

不要手写:

Python

复制

复制代码
prob = F.softmax(logits)
log_prob = torch.log(prob)
loss = F.nll_loss(log_prob, target)

推荐直接用:

Python

复制代码
loss = F.cross_entropy(logits, target)

内部实现 log-sum-exp 技巧 ,避免 log(softmax) 造成数值溢出。


6️⃣ 对比实验(直观感受)

表格

复制

方法 损失曲线 梯度大小 收敛速度
MSE 平坦区早 极小
CE 无平坦区 稳定

7️⃣ 小结口诀(背下来)

分类用 CE,回归用 MSE
CE = −log q(对类)
PyTorch:F.cross_entropy(logits, target)
别手写 softmax+log!


8️⃣ 课后 5 分钟动手

  1. F.cross_entropy 算一条三分类样本。

  2. logits 乘 10 再算一次,观察损失变化。

  3. 对比 F.mse_lossF.cross_entropy 的梯度大小(.grad)。

相关推荐
测试员周周4 小时前
【Appium 系列】第16节-WebView-H5上下文切换 — 混合应用的自动化难点
运维·开发语言·人工智能·功能测试·appium·自动化·测试用例
K姐研究社6 小时前
怎么用AI制作电商口播视频,开拍APP一键生成
人工智能·音视频
LaughingZhu6 小时前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
传说故事7 小时前
【论文阅读】MotuBrain: An Advanced World Action Model for Robot Control
论文阅读·人工智能·具身智能·wam
北京耐用通信7 小时前
全域适配工业场景耐达讯自动化Modbus TCP 转 PROFIBUS 网关轻松实现以太网与现场总线互通
网络·人工智能·网络协议·自动化·信息与通信
火山引擎开发者社区7 小时前
TRAE × 火山引擎 Supabase:为你的 AI 应用装上“数据引擎”
人工智能
小a彤8 小时前
GE 在 CANN 五层架构中的位置
人工智能·深度学习·transformer
前端若水8 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Upsy-Daisy8 小时前
AI Agent 项目学习笔记(八):Tool Calling 工具调用机制总览
人工智能·笔记·学习
企学宝8 小时前
企学宝5月专题课程丨《OpenClaw AI 智能体实战营:从零基础部署到全场景自动化落地》
人工智能·ai·企业培训