| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 人工智能 -> 损失函数-pytorch -> 正文阅读 |
|
[人工智能]损失函数-pytorch |
损失函数的作用: 主要用于深度学习中predict与True label “距离”度量或者“相似度度量”,并通过反向传播求梯度,进而通过梯度下降算法更新网络参数,周而复始,通过损失值和评估值反映模型的好坏。 损失函数的种类:主要分为分类损失函数和回归损失函数。
补充知识: ?
作用:对预测正确但是预测概率不高的情况进行惩罚(这种情况的损失值更大)。 公式: 计算过程:
??代码-pytorch
import torch
from torch import nn
m = nn.LogSoftmax(dim=1)
loss = nn.NLLLoss()
input = torch.randn(3, 5, requires_grad=True)
target = torch.tensor([1, 0, 4])
output = loss(m(input), target)
output.backward????????????????
公式: softmax(y)指的就是预测标签的概率。是真实类别标签的one-hot的形式. 计算过程:
?代码:
? ? ? 参数:input.shape=(N, C),target.shape为(N)或者概率形式的target(N,C)。 loss = nn.CrossEntropyLoss()
input = torch.randn(3, 5, requires_grad=True)
target = torch.randn(3, 5).softmax(dim=1)
output = loss(input, target)
output.backward()
可用于二分类、多标签分类,即判断每一个标签是否是前景、背景。
?y为预测当前标签的概率值。使用BCE前,需要通过sigmoid将score转换为预测的概率。
# 1. 在放入BCE Loss前需要对输入使用sigmoid转换为概率,
m = nn.Sigmoid()
loss = nn.BCELoss()
input = torch.randn(3, requires_grad=True)
target = torch.empty(3).random_(2)
output = loss(m(input), target)
output.backward()
(2.4) 可用于多标签分类,即判断每一个标签是否是前景、背景。 BCEWithLogitsLoss损失函数把 Sigmoid 层集成到了 BCELoss 类中。
参数:input和target的shape一致。 loss = nn.BCEWithLogitsLoss()
input = torch.randn(3, requires_grad=True)
target = torch.empty(3).random_(2)
output = loss(input, target)
output.backward()
? (2.6)arcface loss (2.7)magface loss 3.回归损失函数 (3.1) L1Loss-L1范数损失 ??它是把目标值yi与模型输出(估计值)f(xi)?做绝对值得到的误差 ? 代码:torch.nn.L1Loss(reduction='mean') ? 参数:reduction有三个值可选:none: 不使用约简;mean:返回loss和的平均值;sum:返回loss的和。默认:mean。 (3.2) MSELoss-均方误差损失 ??它是把目标值yi与模型输出(估计值)f(xi)做差然后平方得到的误差公式: ?torch.nn.MSELoss(reduction='mean') 参数:reduction有三个值可选:none: 不使用约简;mean:返回loss和的平均值;sum:返回loss的和。默认:mean。 (3.3) SmoothL1Loss简单来说就是平滑版的L1 Loss。公式:?torch.nn.SmoothL1Loss(reduction='mean') SooothL1Loss其实是L2Loss和L1Loss的结合,它同时拥有L2 Loss和L1 Loss的部分优点: ? (6) MarginRankingLoss torch.nn.MarginRankingLoss(margin=0.0,?reduction='mean') 对于 mini-batch(小批量) 中每个实例的损失函数如下: ?参数:margin:默认值0 (7) ?HingeEmbeddingLoss torch.nn.HingeEmbeddingLoss(margin=1.0,??reduction='mean') 对于 mini-batch(小批量) 中每个实例的损失函数如下: ? 参数:margin:默认值1 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 | -2024/12/30 1:34:34- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |