基于MSELoss()与CrossEntropyLoss()的区别详解

作者:Foneone 时间:2022-05-17 19:18:27 

基于pytorch来讲

MSELoss()多用于回归问题,也可以用于one_hotted编码形式,

CrossEntropyLoss()名字为交叉熵损失函数,不用于one_hotted编码形式

MSELoss()要求batch_x与batch_y的tensor都是FloatTensor类型

CrossEntropyLoss()要求batch_x为Float,batch_y为LongTensor类型

(1)CrossEntropyLoss() 举例说明:

比如二分类问题,最后一层输出的为2个值,比如下面的代码:


class CNN (nn.Module ) :
 def __init__ ( self , hidden_size1 , output_size , dropout_p) :
   super ( CNN , self ).__init__ ( )
   self.hidden_size1 = hidden_size1
   self.output_size = output_size
   self.dropout_p = dropout_p

self.conv1 = nn.Conv1d ( 1,8,3,padding =1)
   self.fc1 = nn.Linear (8*500, self.hidden_size1 )
   self.out = nn.Linear (self.hidden_size1,self.output_size )

def forward ( self , encoder_outputs ) :
   cnn_out = F.max_pool1d ( F.relu (self.conv1(encoder_outputs)),2)
   cnn_out = F.dropout ( cnn_out ,self.dropout_p) #加一个dropout
   cnn_out = cnn_out.view (-1,8*500)
   output_1 = torch.tanh ( self.fc1 ( cnn_out ) )
   output = self.out ( ouput_1)
   return output

最后的输出结果为:

基于MSELoss()与CrossEntropyLoss()的区别详解

上面一个tensor为output结果,下面为target,没有使用one_hotted编码。

训练过程如下:


cnn_optimizer = torch.optim.SGD(cnn.parameters(),learning_rate,momentum=0.9,\
             weight_decay=1e-5)
criterion = nn.CrossEntropyLoss()

def train ( input_variable , target_variable , cnn , cnn_optimizer , criterion ) :
 cnn_output = cnn( input_variable )
 print(cnn_output)
 print(target_variable)
 loss = criterion ( cnn_output , target_variable)
 cnn_optimizer.zero_grad ()
 loss.backward( )
 cnn_optimizer.step( )
 #print('loss: ',loss.item())
 return loss.item() #返回损失

说明CrossEntropyLoss()是output两位为one_hotted编码形式,但target不是one_hotted编码形式。

(2)MSELoss() 举例说明:

网络结构不变,但是标签是one_hotted编码形式。下面的图仅做说明,网络结构不太对,出来的预测也不太对。

基于MSELoss()与CrossEntropyLoss()的区别详解

如果target不是one_hotted编码形式会报错,报的错误如下。

基于MSELoss()与CrossEntropyLoss()的区别详解

目前自己理解的两者的区别,就是这样的,至于多分类问题是不是也是样的有待考察。

来源:https://blog.csdn.net/foneone/article/details/90127707

标签:MSELoss,CrossEntropyLoss
0
投稿

猜你喜欢

  • 解决python2.7 查询mysql时出现中文乱码

    2024-01-14 18:34:57
  • php巧获服务器端信息

    2023-10-04 02:18:39
  • Python中根据时间自动创建文件夹的代码实现

    2023-07-06 02:42:01
  • SQL server分页的4种方法示例(很全面)

    2024-01-27 15:09:47
  • 用Python一键搭建Http服务器的方法

    2021-08-09 19:36:32
  • python 爬虫 实现增量去重和定时爬取实例

    2022-01-26 01:01:37
  • python opencv对图像进行旋转且不裁剪图片的实现方法

    2023-03-12 02:40:09
  • 浅谈Pytorch中的torch.gather函数的含义

    2022-12-26 02:25:54
  • 用python画了个圣诞树给女朋友

    2022-06-03 00:54:44
  • python中defaultdict的用法详解

    2021-05-02 11:11:07
  • PyCharm 常用快捷键和设置方法

    2022-04-09 01:40:59
  • jupyter notebook快速入门及使用详解

    2023-07-17 07:48:57
  • Python xlwt工具使用详解,生成excel栏位宽度可自适应内容长度

    2024-01-03 20:20:20
  • 解决pip安装的第三方包在PyCharm无法导入的问题

    2022-10-18 11:20:27
  • tensorflow 动态获取 BatchSzie 的大小实例

    2023-03-05 16:56:48
  • python结合shell查询google关键词排名的实现代码

    2023-10-11 21:28:47
  • 19个MySQL性能优化要点解析

    2024-01-18 16:03:14
  • 基于mysql全文索引的深入理解

    2024-01-15 15:28:41
  • Win10下配置VScode远程开发ssh-remote(免密登录)

    2022-07-17 23:01:13
  • php实现网站留言板功能

    2023-11-23 21:06:36
  • asp之家 网络编程 m.aspxhome.com