pytorch学习之损失函数

损失函数

损失函数:衡量模型输出与真实标签的差异

  • 损失函数(Loss Function)求一个样本的损失函数
  • 代价函数(Cost Functio)求所有样本的平均值
  • 目标函数(Object Function)=(Cost Functio)+Regularization

nn.CrossEntropyLoss

功能:nn.LogSoftmax()nn.NLLLoss()结合,进行交叉熵计算

主要参数:

  • weight:各类别的loss设置权值
  • ignore_index:忽略某个类别
  • reduction:计算模式,可分为none/sum/mean
    none逐个元素计算、sum所有元素求和,返回标量、mean加权平均,返回标量
# 定义损失函数
loss_f_none = nn.CrossEntropyLoss(weight=None, reduction='none')
loss_f_sum = nn.CrossEntropyLoss(weight=None, reduction='sum')
loss_f_mean = nn.CrossEntropyLoss(weight=None, reduction='mean')

# 前向传播之后计算损失函数
loss_none = loss_f_none(inputs, target)
loss_sum = loss_f_sum(inputs, target)
loss_mean = loss_f_mean(inputs, target)

weight

就是每个类别损失函数的权值
例如:

# 因为设置输入的时候,设置了两个类别0、1
# 这里weight的长度为2
weights = torch.tensor([1, 2], dtype=torch.float)

loss_f_none_w = nn.CrossEntropyLoss(weight=weights, reduction='none')
loss_f_sum = nn.CrossEntropyLoss(weight=weights, reduction='sum')
loss_f_mean = nn.CrossEntropyLoss(weight=weights, reduction='mean')

最后输出的损失函数的值:需要分别乘以相对应的权重值
如:最开始标签为[0, 1, 1],未加权重损失函数输出值[0.2, 0.3, 0.4]。则最后的输出值为[0.2, 0.6, 0.8],然后最后计算mean的时候,需要注意此时计算方式已经发生变化:(0.2+0.6+0.8)/ 5

nn.NLLLoss

功能:实现负对数似然函数中符号功能

主要参数:

  • weight:各类别的loss设置权值
  • ignore_index:忽略某个类别
  • reduction:计算方式,可为none/sum/mean

nn.BCELoss

功能:二分类交叉熵

注意事项:输入值取值在[0, 1]

主要参数:

  • weight:各类别的loss设置权值
  • ignore_index:忽略某个类别
  • reduction:计算模式,可分为none/sum/mean

此函数在使用的时候应该注意:输入的值是[0, 1]之间,因此针对输入应该增加一个sigmoid,否则程序易出现错误。当然pytorch也自带一个损失函数能够满足这个要求,即:nn.BGEWithLogitsLoss

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
PyTorch中,进行多任务学习时常用的损失函数包括交叉熵损失函数和相对熵损失函数。交叉熵损失函数适用于分类任务,而相对熵损失函数(也称为KL散度损失函数)则用于衡量两个概率分布之间的差异。 对于多标签分类任务,我们可以使用二进制交叉熵损失函数,即torch.nn.BCELoss。这个损失函数通过将每个标签视为一个二分类问题,来计算每个标签的损失。在PyTorch中,通过将模型的输出与真实标签进行比较,并将结果输入到BCELoss函数中,即可得到多标签分类任务的损失。值得注意的是,BCELoss函数默认是对每个样本的损失进行平均,如果需要对每个样本的损失进行求和,则可以设置参数reduction为'sum'。 除了交叉熵损失函数,相对熵损失函数也是一种常用的多任务学习损失函数。KL散度损失函数用于衡量两个概率分布之间的差异,通常用于训练生成模型。在PyTorch中,我们可以使用torch.nn.KLDivLoss函数来计算相对熵损失。这个函数接受两个概率分布作为输入,其中一个是模型的输出概率分布,另一个是真实标签的概率分布。相对熵损失函数默认对每个样本的损失进行平均,如果需要对每个样本的损失进行求和,则可以设置参数reduction为'sum'。 总结起来,对于多任务学习,常用的损失函数包括交叉熵损失函数和相对熵损失函数。交叉熵损失函数适用于分类任务,而相对熵损失函数则用于衡量两个概率分布之间的差异。在PyTorch中,可以使用torch.nn.BCELoss函数来计算二进制交叉熵损失,使用torch.nn.KLDivLoss函数来计算相对熵损失。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值