IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: 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

均方误差/MSE/二次损失/L2损失

M S E = 1 N ∑ i = 1 N ( y ? y ˉ ) 2 如 果 y 和 y ˉ 是 向 量 , 那 么 ( y ? y ˉ ) 2 = ( ∑ i = 1 m ( y i ? y i ˉ ) 2 ) 2 MSE=\frac{1}{N}\sum_{i = 1}^{N}(y-\bar{y})^2\\ 如果y和\bar{y}是向量,那么(y-\bar{y})^2=(\sqrt{\sum_{i = 1}^{m}(y_i-\bar{y_i})^2})^2 MSE=N1?i=1N?(y?yˉ?)2yyˉ?(y?yˉ?)2=(i=1m?(yi??yi?ˉ?)2 ?)2

理论上N表示batch_size,但在实现上通常还会再除以一个y向量的维度,这样并不会改变梯度方向和优化方向**

y = torch.tensor([1,2,3,0,2])
y = F.one_hot(y, 4)

out = torch.randn(5, 4)

F.mse_loss(y, out)
Out[21]: tensor(2.0983)
    
torch.mean(torch.square(y - out))
Out[21]: tensor(2.0983)
    
torch.square((y-out).norm(2)) / (4*5)
Out[21]: tensor(2.0983)

平均绝对误差/MAE/L1损失

M A E = 1 N ∑ i = 1 N ∣ y ? y ˉ ∣ 如 果 y 和 y ˉ 是 向 量 , 那 么 ∣ y ? y ˉ ∣ = ∑ i = 1 m ( y i ? y i ˉ ) 2 MAE=\frac{1}{N}\sum_{i = 1}^{N}|y-\bar{y}|\\ 如果y和\bar{y}是向量,那么|y-\bar{y}|=\sqrt{\sum_{i = 1}^{m}(y_i-\bar{y_i})^2} MAE=N1?i=1N?y?yˉ?yyˉ?y?yˉ?=i=1m?(yi??yi?ˉ?)2 ?

使用平方误差MSE更容易收敛,但使用绝对误差MAE对异常值更稳健

理论上N表示batch_size,但在实现上通常还会再除以一个y向量的维度,这样并不会改变梯度方向和优化方向**

y = torch.tensor([1,2,3,0,2])
y = F.one_hot(y, 4)

out = torch.randn(5, 4)

F.l1_loss(y.float(), out)
Out[25]: tensor(1.0248)
    
torch.mean(torch.abs(y-out))
Out[27]: tensor(1.0248)
    
(y-out).norm(1) / (4*5)
Out[28]: tensor(1.0248)

交叉熵损失/Cross Entropy

熵越小 信息量越大 越不稳定 惊喜度越大
连 续 : E n t r o p y = ? ∫ p l o g 2 p 离 散 : E n t r o p y = ? ∑ i p i l o g 2 p i 连续:Entropy=-\int plog_2p\\ 离散:Entropy=-\sum_{i}p_ilog_2p_i Entropy=?plog2?pEntropy=?i?pi?log2?pi?

交叉熵

H ( p , q ) = ? ∑ i p i l o g 2 q i H ( p , q ) = H ( p ) + K L ( p ∣ ∣ q ) 注 : H ( p , q ) 和 H ( p ) 可 以 直 接 计 算 , K L ( p ∣ ∣ q ) 通 过 H ( p , q ) ? H ( p ) 来 计 算 对 于 独 热 编 码 , 其 熵 为 0 , 例 如 H ( p : [ 0 , 1 , 0 ] ) = ? ( 0 ? l o g 2 0 + 1 ? l o g 2 1 + 0 ? l o g 2 0 ) = 0 H ( p , q ) 若 p 为 独 热 编 码 [ 0 , 1 , 0 ] , 则 H ( p , q ) = K L ( p ∣ ∣ q ) = ? l o g 2 q 1 , 若 p , q 相 同 则 H ( p , q ) = 0 所 以 其 可 以 作 为 分 类 任 务 的 目 标 函 数 ( p 为 l a b e l , q 为 o u t ) , H ( p , q ) 越 小 p 和 q 越 接 近 H(p,q)=-\sum_{i}p_ilog_2q_i\\ H(p,q)=H(p)+KL(p||q)\\ 注:H(p,q)和H(p)可以直接计算,KL(p||q)通过H(p,q)-H(p)来计算\\ 对于独热编码,其熵为0,例如H(p:[0,1,0])=-(0*log_20+1*log_21+0*log_20)=0\\ H(p,q)若p为独热编码[0,1,0],则H(p,q)=KL(p||q)=-log_2q_1,若p,q相同则H(p,q)=0\\ 所以其可以作为分类任务的目标函数(p为label,q为out),H(p,q)越小p和q越接近 H(p,q)=?i?pi?log2?qi?H(p,q)=H(p)+KL(pq)H(p,q)H(p)KL(pq)H(p,q)?H(p)0H(p:[0,1,0])=?(0?log2?0+1?log2?1+0?log2?0)=0H(p,q)p[0,1,0]H(p,q)=KL(pq)=?log2?q1?p,qH(p,q)=0(plabelqout)H(p,q)pq

特 别 的 , 对 于 二 分 类 任 务 : H ( p , q ) = ? ( p l o g 2 q + ( 1 ? p ) l o g 2 ( 1 ? q ) ) 其 中 , p 为 真 实 是 正 例 的 概 率 , q 是 预 测 是 正 例 的 概 率 。 特别的,对于二分类任务:\\ H(p,q)=-(plog_2q+(1-p)log_2(1-q))\\ 其中,p为真实是正例的概率,q是预测是正例的概率。 H(p,q)=?(plog2?q+(1?p)log2?(1?q))pq

理论上对数以2为底,但是实践上通常对数以e为底,这样并不会改变梯度方向和优化方向**

Pytorch中 CrossEntropyLoss = LogSoftmax + NLLLoss

NLLLoss(negative log likelihood loss)
H ( p , q ) = ? ∑ i p i l o g q i 先 对 q 做 s o f t m a x : H ( p , q ) = ? ∑ i p i l o g e x p ( q i ) ∑ j e x p ( q j ) 假 设 p 为 o n e _ h o t 且 p k ≠ 0 , 则 H ( p , q ) = ? l o g e x p ( q k ) ∑ j e x p ( q j ) = ? q k + l o g ∑ j e x p ( q j ) H(p,q)=-\sum_{i}p_ilogq_i\\ 先对q做softmax:H(p,q)=-\sum_{i}p_ilog\frac{exp(q_i)}{\sum_{j}exp(q_j)}\\ 假设p为one\_hot且p_k\neq0,则\\ H(p,q)=-log\frac{exp(q_k)}{\sum_{j}exp(q_j)}=-q_k+log\sum_{j}exp(q_j) H(p,q)=?i?pi?logqi?qsoftmax:H(p,q)=?i?pi?logj?exp(qj?)exp(qi?)?pone_hotpk??=0H(p,q)=?logj?exp(qj?)exp(qk?)?=?qk?+logj?exp(qj?)

C r o s s E n t r o p y L o s s : H ( p , q ) = ? l o g e x p ( q k ) ∑ j e x p ( q j ) = ? q k + l o g ∑ j e x p ( q j ) L o g S o f t m a x ( x i ) = l o g e x p ( x i ) ∑ j e x p ( x j ) N L L L o s s ( p , q ) = ? q k ???? ( p 为 o n e _ h o t 且 p k ≠ 0 ) CrossEntropyLoss:H(p,q)=-log\frac{exp(q_k)}{\sum_{j}exp(q_j)} =-q_k+log\sum_{j}exp(q_j)\\ LogSoftmax(x_i)=log\frac{exp(x_i)}{\sum_{j}exp(x_j)}\\ NLLLoss(p,q)=-q_k\:\:\:\:(p为one\_hot且p_k\neq0) CrossEntropyLoss:H(p,q)=?logj?exp(qj?)exp(qk?)?=?qk?+logj?exp(qj?)LogSoftmax(xi?)=logj?exp(xj?)exp(xi?)?NLLLoss(p,q)=?qk?(pone_hotpk??=0)

out
Out[91]: 
tensor([[-1.9675, -0.0030,  1.4072,  0.6208],
        [-1.1345, -0.5482,  0.9298,  1.0552],
        [ 1.1224,  1.8556,  0.0283,  1.6605],
        [ 0.5614, -0.2457, -0.4221, -1.6666],
        [ 0.8162, -0.9078, -1.0052, -0.2580]])
y
Out[92]: tensor([1, 2, 3, 0, 2])
    
#  LogSoftmax
torch.log(F.softmax(out, dim=1))
Out[94]: 
tensor([[-3.9250, -1.9605, -0.5503, -1.3367],
        [-2.9760, -2.3897, -0.9117, -0.7864],
        [-1.6350, -0.9018, -2.7290, -1.0969],
        [-0.6564, -1.4636, -1.6399, -2.8844],
        [-0.5198, -2.2438, -2.3413, -1.5941]])

F.log_softmax(out, dim=1)
Out[95]: 
tensor([[-3.9250, -1.9605, -0.5503, -1.3367],
        [-2.9760, -2.3897, -0.9117, -0.7864],
        [-1.6350, -0.9018, -2.7290, -1.0969],
        [-0.6564, -1.4636, -1.6399, -2.8844],
        [-0.5198, -2.2438, -2.3413, -1.5941]])

# NLLLoss
-out[[0,1,2,3,4], y]
Out[106]: tensor([ 0.0030, -0.9298, -1.6605, -0.5614,  1.0052])
    
F.nll_loss(out, y, reduction='none')
Out[107]: tensor([ 0.0030, -0.9298, -1.6605, -0.5614,  1.0052])
    
# CrossEntropyLoss
# 不加reduction='none'则取均值
F.cross_entropy(out, y, reduction='none')
Out[108]: tensor([1.9605, 0.9117, 1.0969, 0.6564, 2.3413])
    
F.nll_loss(F.log_softmax(out, dim=1), y, reduction='none')
Out[109]: tensor([1.9605, 0.9117, 1.0969, 0.6564, 2.3413])
    
- out[[0,1,2,3,4], y] + torch.log(torch.sum(torch.exp(out), dim=1))
Out[111]: tensor([1.9605, 0.9117, 1.0969, 0.6564, 2.3413])

Info NCE

对比学习,有的称为自监督学习/无监督学习(实际上自监督学习是无监督学习的一种形式)。目标就是聚类。

image-20220522085247819

代理任务(pretext task)+目标函数(objective function)

代理任务定义正负样本(实际上就是为样本生成一个label),目标函数最大化一致。

例如上图:代理任务 对于同一样本x生成xi和xj两个样本;特征提取;MLP映射;优化损失。

Information Noise Contrastive Estimation,该损失函数在数学上比CrossEntropyLoss仅多一个温度系数
I n f o _ N C E = ? l o g e x p ( q ? k + / τ ) ∑ j e x p ( q ? k j / τ ) q ? k 均 为 特 征 向 量 , k + 和 q 同 类 , k j ( j ≠ + ) 和 q 不 同 类 Info\_NCE=-log\frac{exp(q·k_+/\tau)}{\sum_{j}exp(q·k_j/\tau)}\\ q\:k均为特征向量,k_+和q同类,k_j(j\neq+)和q不同类 Info_NCE=?logj?exp(q?kj?/τ)exp(q?k+?/τ)?qk,k+?qkj?(j?=+)q

例如现有batch_size个图片x,通过代理任务(例如旋转,裁剪等操作)生成两种图片x_q和x_k(均为batch_size个,共2*batch_size个图片)。经过特征图提取,MLP映射之后得到q shape[batch_size, feature_len],k shape[batch_size, feature_len]。q和k对应位置的特征向量表示的是同一张图片(同类),通过Info NCE可以最大化其相关性,同时最小化与其他负例的相关性。
处 理 1 : q i 有 k i ? 1 个 正 例 , k j ( j ≠ i ) ? ( b ? 1 ) 个 负 例 , q ? k T 得 到 [ b , b ] 的 矩 阵 , 第 i 行 的 主 对 角 线 元 素 为 q i 与 对 应 的 k + 的 相 关 性 分 数 处 理 2 : q i 有 q i , k i ? 2 个 正 例 , q j , k j ( j ≠ i ) ? ( 2 b ? 2 ) 个 负 例 , [ q , k ] ? [ q , k ] T 得 到 [ 2 b , 2 b ] 的 矩 阵 , 第 i 行 ( i ∈ [ 1 , b a t c h _ s i z e ] ) 的 第 b + i 个 元 素 为 q i 与 对 应 的 k + 的 相 关 性 分 数 第 i 行 ( i ∈ [ b a t c h _ s i z e + 1 , 2 ? b a t c h _ s i z e ] ) 的 第 b + i 个 元 素 为 q i 与 对 应 的 k + 的 相 关 性 分 数 处理1:q_i有k_i\:1个正例,k_j(j\neq i)\:(b-1)个负例,q·k^T得到[b, b]的矩阵,\\ 第i行的主对角线元素为q_i与对应的k_+的相关性分数\\\\ 处理2:q_i有q_i,k_i\:2个正例,q_j,k_j(j\neq i)\:(2b-2)个负例,[q,k]·[q,k]^T得到[2b, 2b]的矩阵,\\ 第i行(i\in[1,batch\_size])的第b+i个元素为q_i与对应的k_+的相关性分数\\ 第i行(i\in[batch\_size+1,2*batch\_size])的第b+i个元素为q_i与对应的k_+的相关性分数\\ 1qi?ki?1kj?(j?=i)(b?1)q?kT[b,b]i线qi?k+?2qi?qi?,ki?2qj?,kj?(j?=i)(2b?2)[q,k]?[q,k]T[2b,2b]ii[1,batch_size]b+iqi?k+?ii[batch_size+1,2?batch_size]b+iqi?k+?

import torch
from torch.nn import functional as F

# 温度系数
tau = 1
batch_size = 4
feature_len = 10
q = torch.randn(batch_size, feature_len)
k = torch.randn(batch_size, feature_len)


# 处理1
# k+在每一行的位置
position_positive = torch.arange(batch_size)
# cross_entropy不加reduction='none'则包含取均值的操作即 batch_size行共batch_size个值取均值
info_nce = F.cross_entropy(q@k.t()/tau, position_positive)

# 处理2
# k+在每一行的位置
position_positive = torch.cat((torch.arange(batch_size) + batch_size, torch.arange(batch_size)))
qk = torch.cat((q, k), dim=0)
info_nce = F.cross_entropy(qk@qk.t()/tau, position_positive)
  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-05-24 18:10:12  更:2022-05-24 18:14:58 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/1 22:44:57-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码