文章目录

  • 一、损失函数 nn.CrossEntropyLoss()
  • 二、什么是交叉熵
  • 三、Pytorch 中的 CrossEntropyLoss() 函数
  • 参考链接

一、损失函数 nn.CrossEntropyLoss()

交叉熵损失函数 nn.CrossEntropyLoss() ,结合了 nn.LogSoftmax() 和 nn.NLLLoss() 两个函数。

它在做分类(具体几类)训练的时候是非常有用的。


二、什么是交叉熵

交叉熵主要是用来判定 实际的输出与期望的输出的接近程度

举个例子:在做分类训练的时候,如果一个样本属于第 K 类,那么这个类别所对应的输出节点的输出值应该为1,而其他节点的输出都为0,即 [0,0,1,0,….0,0] ,这个数组也就是样本的 Label,是神经网络最期望的输出结果。我们用交叉熵损失函数来衡量网络的实际输出与正确标签的差异,利用这种差异经过反向传播去更新网络参数。

交叉熵:它主要刻画的是实际输出(概率)与期望输出(概率)的距离,也就是交叉熵的值越小,两个概率分布就越接近。假设概率分布p为期望输出,概率分布q为实际输出,则交叉熵定义为:

实际例子:


三、Pytorch 中的 CrossEntropyLoss() 函数

Pytorch中计算的交叉熵并不是采用第 “二” 节中的公式计算得到的,而是采用交叉熵的另外一种方式计算得到的:

Pytorch中CrossEntropyLoss()函数的主要是将softmax-log-NLLLoss合并到一块得到的结果。

  1. Softmax后的数值都在0~1之间,所以 ln 之后值域是负无穷到0。
  2. 然后将Softmax之后的结果取log,将乘法改成加法减少计算量,同时保障函数的单调性 。
  3. NLLLoss 的结果就是把上面的输出与 Label 对应的那个值拿出来,去掉负号,再求均值。

一个实例:直接使用pytorch中的 nn.CrossEntropyLoss() 计算得到的结果与 softmax-log-NLLLoss计算得到的结果是一致的

import torch
import torch.nn as nnx_input = torch.randn(3, 3)  # 随机生成输入
print('x_input:\n', x_input)
y_target = torch.tensor([1, 2, 0])  # 设置输出具体值 print('y_target\n',y_target)# 计算输入softmax,此时可以看到每一行加到一起结果都是1
softmax_func = nn.Softmax(dim=1)
soft_output = softmax_func(x_input)
print('soft_output:\n', soft_output)# 在softmax的基础上取log
log_output = torch.log(soft_output)
print('log_output:\n', log_output)# 对比softmax与log的结合与nn.LogSoftmaxloss(负对数似然损失)的输出结果,发现两者是一致的。
logsoftmax_func=nn.LogSoftmax(dim=1)
logsoftmax_output=logsoftmax_func(x_input)
print('logsoftmax_output:\n', logsoftmax_output)# pytorch中关于NLLLoss的默认参数配置为:reducetion=True、size_average=True
nllloss_func = nn.NLLLoss()
nlloss_output = nllloss_func(logsoftmax_output, y_target)
print('nlloss_output:\n', nlloss_output)# 直接使用pytorch中的loss_func=nn.CrossEntropyLoss()看与经过NLLLoss的计算是不是一样
crossentropyloss = nn.CrossEntropyLoss()
crossentropyloss_output = crossentropyloss(x_input, y_target)
print('crossentropyloss_output:\n', crossentropyloss_output)

输出结果:

x_input:tensor([[ 0.3321,  0.5043, -1.1833],[-2.1702, -1.8563,  1.0706],[ 1.7341,  0.2554, -1.3358]])
soft_output:tensor([[0.4153, 0.4934, 0.0913],[0.0358, 0.0490, 0.9152],[0.7847, 0.1789, 0.0364]])
log_output:tensor([[-0.8787, -0.7064, -2.3940],[-3.3295, -3.0155, -0.0886],[-0.2424, -1.7212, -3.3123]])
logsoftmax_output:tensor([[-0.8787, -0.7064, -2.3940],[-3.3295, -3.0155, -0.0886],[-0.2424, -1.7212, -3.3123]])
nlloss_output:tensor(0.3458)
crossentropyloss_output:tensor(0.3458)

参考链接

  1. Pytorch常用的交叉熵损失函数CrossEntropyLoss()详解

【Pytorch】交叉熵损失函数 CrossEntropyLoss() 详解相关推荐

  1. 交叉熵损失函数原理详解

    交叉熵损失函数原理详解 之前在代码中经常看见交叉熵损失函数(CrossEntropy Loss),只知道它是分类问题中经常使用的一种损失函数,对于其内部的原理总是模模糊糊,而且一般使用交叉熵作为损失函 ...

  2. 交叉熵损失函数原理详解,KL散度

    https://blog.csdn.net/b1055077005/article/details/100152102 https://blog.csdn.net/tsyccnh/article/de ...

  3. Pytorch专题实战——交叉熵损失函数(CrossEntropyLoss )

    文章目录 1.用CrossEntropyLoss预测单个目标 2.用CrossEntropyLoss预测多个目标 3.二分类使用BCELoss损失函数 4.多分类使用CrossEntropyLoss损 ...

  4. 【机器学习】 二次损失函数的不足及交叉熵损失softmax详解

    二次代价函数的不足: 以sigmoid激活函数为例,由于初始化是随机的,假设目标值为0,第一次随机初始化使得输入为0.82,那么还可以,多次迭代之后可以收敛到0.09,但如果第一次随机初始化到0.98 ...

  5. 解决pytorch二分类任务交叉熵损失函数CrossEntropyLoss报错:IndexError: Target 1 is out of bounds.

    解决方法 修改nn.CrossEntropyLoss()为nn.BCELoss() 问题解析 pytorch 中二分类任务交叉熵要用二分类交叉熵(Binary Cross Entropy),BCELo ...

  6. Pytorch交叉熵损失函数torch.nn.functional as F

    loss = F.cross_entropy(outputs, labels)

  7. 【交叉熵损失函数】关于交叉熵损失函数的一些理解

    目录 0. 前言 1.损失函数(Loss Function) 1.1 损失项 1.2 正则化项 2. 交叉熵损失函数 2.1 softmax 2.2 交叉熵 0. 前言 有段时间没写博客了,前段时间主 ...

  8. 深入理解Pytorch负对数似然函数(torch.nn.NLLLoss)和交叉熵损失函数(torch.nn.CrossEntropyLoss)

    在看Pytorch的交叉熵损失函数torch.nn.CrossEntropyLoss官方文档介绍中,给出的表达式如下.不免有点疑惑为何交叉熵损失的表达式是这个样子的 loss ⁡ ( y , clas ...

  9. 交叉熵损失函数详解推导

    交叉熵损失函数「Cross Entropy Loss」公式: 我们已经对这个交叉熵函数非常熟悉,大多数情况下都是直接拿来使用就好.但是它是怎么来的?为什么它能表征真实样本标签和预测概率之间的差值?上面 ...

最新文章

  1. bezier曲线_Bezier算法
  2. linux c remove 删除文件或目录函数
  3. java collections 用法_Java Collections unmodifiableCollection()用法及代码示例
  4. Java Swing井字游戏
  5. 阿里云肖力:跳过量变过程的安全质变
  6. QT:不停的提示“文件已改变”
  7. 解决maven dependencies xxx not found
  8. camera (13)---智能手机双摄像头工作原理详解:RBG +RGB, RGB + Mono
  9. 解决windows 下 mysql命令行导入备份文件 查询时乱码的问题
  10. Android 四大组件面试
  11. javawebJSP餐厅点餐系统源码JSP点餐系统JSP网上订餐系统JSP在线订餐系统JSP外卖系统
  12. php 调用speex解码库,怎么增加speex解码库
  13. 如何解决微软自带输入法突然变成繁体
  14. 导出手机QQ聊天记录到电脑
  15. php执行fastlane,fastlane教程
  16. 【新概念二】 28-No parking
  17. 计算机技术对艺术的影响,数字化技术对当代艺术发展的影响--理论
  18. Deep Match to Rank Model for Personalized Click-Through Rate Prediction
  19. ListView数据动态刷新
  20. 状压dp(python)蓝桥杯补给

热门文章

  1. Linux下redis安装并设置开机自启(超详细)
  2. Linux 操作系统课程练习题(二)VI 编辑器
  3. 【通信原理】五、模拟调制系统
  4. 【电脑技巧】windows11启动ie浏览器
  5. 验证TAR Oracle部署
  6. 走进海尔考察||探秘--《精益·6S管理研修》
  7. 本聰造幣 天雨粟 夜鬼哭
  8. 一次javascript深拷贝引发的深入思考
  9. sendmessage获取usb摄像机_师出同门却又更胜一筹-小蚁云台摄像机开箱评测
  10. 全球及中国空气采样器系统行业运营态势及投资价值分析报告2021年版