【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)。

相关推荐
用户51914958484515 小时前
原型污染攻击工具揭秘:Prototype Pollution Gadgets Finder
人工智能·aigc
VXHAruanjian88815 小时前
以智促效,释放创新力量,RPA助力企业全面自动化变革
大数据·人工智能
Godspeed Zhao15 小时前
自动驾驶中的传感器技术76——Navigation(13)
人工智能·机器学习·自动驾驶
CoovallyAIHub15 小时前
首届AI交易大赛对决!中国模型包揽冠亚军,GPT-5亏损62%垫底
人工智能·google·数据分析
王中阳Go15 小时前
5 - 工具调用 - AI 超级智能体项目教程
人工智能
智塑未来15 小时前
广州全运会即将开幕,获得文远知行自动驾驶技术支持
人工智能·机器学习·自动驾驶
国科安芯15 小时前
抗辐照MCU芯片在激光雷达领域的适配性分析
网络·人工智能·单片机·嵌入式硬件·fpga开发
王中阳Go16 小时前
4 - RAG 知识库进阶 - AI 超级智能体项目教程
人工智能·agent
qq_2337727116 小时前
*曲速引擎的核心思想
人工智能·量子计算
阿然16516 小时前
我如何使用 Claude Code 的每一个功能
人工智能·ai编程·claude