前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >pytorch mseloss_pytorch handbook

pytorch mseloss_pytorch handbook

作者头像
全栈程序员站长
发布2022-10-02 13:22:24
3490
发布2022-10-02 13:22:24
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

均方损失函数:

loss(xi,yi)=(xi−yi)2 loss ( x i , y i ) = ( x i − y i ) 2

\text{loss}(\mathbf{x}_i, \mathbf{y}_i)=(\mathbf{x}_i - \mathbf{y}_i)^2

这里 loss, x, y 的维度是一样的,可以是向量或者矩阵,i 是下标。

很多的 loss 函数都有 size_average 和 reduce 两个布尔类型的参数。因为一般损失函数都是直接计算 batch 的数据,因此返回的 loss 结果都是维度为 (batch_size, ) 的向量。

(1)如果 reduce = False,那么 size_average 参数失效,直接返回向量形式的 loss
(2)如果 reduce = True,那么 loss 返回的是标量
代码语言:javascript
复制
a)如果 size_average = True,返回 loss.mean();
b)如果 size_average = False,返回 loss.sum();

注意:默认情况下, reduce = True,size_average = True

代码语言:javascript
复制
import torch
import numpy as np

1、返回向量

代码语言:javascript
复制
loss_fn = torch.nn.MSELoss(reduce=False, size_average=False)
代码语言:javascript
复制
a=np.array([[1,2],[3,4]])
b=np.array([[2,3],[4,5]])
代码语言:javascript
复制
input = torch.autograd.Variable(torch.from_numpy(a))
target = torch.autograd.Variable(torch.from_numpy(b))

这里将Variable类型统一为float()(tensor类型也是调用xxx.float())

代码语言:javascript
复制
loss = loss_fn(input.float(), target.float())
代码语言:javascript
复制
print(loss)
代码语言:javascript
复制
tensor([[ 1.,  1.],
        [ 1.,  1.]])

2、返回平均值

代码语言:javascript
复制
a=np.array([[1,2],[3,4]])
b=np.array([[2,3],[4,4]])
代码语言:javascript
复制
loss_fn = torch.nn.MSELoss(reduce=True, size_average=True)
代码语言:javascript
复制
input = torch.autograd.Variable(torch.from_numpy(a))
target = torch.autograd.Variable(torch.from_numpy(b))
代码语言:javascript
复制
loss = loss_fn(input.float(), target.float())
代码语言:javascript
复制
 print(loss)
代码语言:javascript
复制
tensor(0.7500)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/192029.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年9月18日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 均方损失函数:
    • (1)如果 reduce = False,那么 size_average 参数失效,直接返回向量形式的 loss
      • (2)如果 reduce = True,那么 loss 返回的是标量
      相关产品与服务
      批量计算
      批量计算(BatchCompute,Batch)是为有大数据计算业务的企业、科研单位等提供高性价比且易用的计算服务。批量计算 Batch 可以根据用户提供的批处理规模,智能地管理作业和调动其所需的最佳资源。有了 Batch 的帮助,您可以将精力集中在如何分析和处理数据结果上。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档