91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Pytorch十九種損失函數的實現方法

發布時間:2020-07-29 13:42:08 來源:億速云 閱讀:570 作者:小豬 欄目:開發技術

這篇文章主要講解了Pytorch十九種損失函數的實現方法,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

損失函數通過torch.nn包實現,

1 基本用法

criterion = LossCriterion() #構造函數有自己的參數
loss = criterion(x, y) #調用標準時也有參數

2 損失函數

2-1 L1范數損失 L1Loss

計算 output 和 target 之差的絕對值。

torch.nn.L1Loss(reduction='mean')

參數:

reduction-三個值,none: 不使用約簡;mean:返回loss和的平均值; sum:返回loss的和。默認:mean。

2-2 均方誤差損失 MSELoss

計算 output 和 target 之差的均方差。

torch.nn.MSELoss(reduction='mean')

參數:

reduction-三個值,none: 不使用約簡;mean:返回loss和的平均值; sum:返回loss的和。默認:mean。

2-3 交叉熵損失 CrossEntropyLoss

當訓練有 C 個類別的分類問題時很有效. 可選參數 weight 必須是一個1維 Tensor, 權重將被分配給各個類別. 對于不平衡的訓練集非常有效。

在多分類任務中,經常采用 softmax 激活函數+交叉熵損失函數,因為交叉熵描述了兩個概率分布的差異,然而神經網絡輸出的是向量,并不是概率分布的形式。所以需要 softmax激活函數將一個向量進行“歸一化”成概率分布的形式,再采用交叉熵損失函數計算 loss。

Pytorch十九種損失函數的實現方法

torch.nn.CrossEntropyLoss(weight=None, ignore_index=-100, reduction='mean')

參數:

weight (Tensor, optional) – 自定義的每個類別的權重. 必須是一個長度為 C 的 Tensor
ignore_index (int, optional) – 設置一個目標值, 該目標值會被忽略, 從而不會影響到 輸入的梯度。
reduction-三個值,none: 不使用約簡;mean:返回loss和的平均值; sum:返回loss的和。默認:mean。

2-4 KL 散度損失 KLDivLoss

計算 input 和 target 之間的 KL 散度。KL 散度可用于衡量不同的連續分布之間的距離, 在連續的輸出分布的空間上(離散采樣)上進行直接回歸時 很有效.

torch.nn.KLDivLoss(reduction='mean')

參數:

reduction-三個值,none: 不使用約簡;mean:返回loss和的平均值; sum:返回loss的和。默認:mean。

2-5 二進制交叉熵損失 BCELoss

二分類任務時的交叉熵計算函數。用于測量重構的誤差, 例如自動編碼機. 注意目標的值 t[i] 的范圍為0到1之間.

torch.nn.BCELoss(weight=None, reduction='mean')

參數:

weight (Tensor, optional) – 自定義的每個 batch 元素的 loss 的權重. 必須是一個長度為 “nbatch” 的 的 Tensor
pos_weight(Tensor, optional) – 自定義的每個正樣本的 loss 的權重. 必須是一個長度 為 “classes” 的 Tensor

2-6 BCEWithLogitsLoss

BCEWithLogitsLoss損失函數把 Sigmoid 層集成到了 BCELoss 類中. 該版比用一個簡單的 Sigmoid 層和 BCELoss 在數值上更穩定, 因為把這兩個操作合并為一個層之后, 可以利用 log-sum-exp 的 技巧來實現數值穩定.

torch.nn.BCEWithLogitsLoss(weight=None, reduction='mean', pos_weight=None)

參數:

weight (Tensor, optional) – 自定義的每個 batch 元素的 loss 的權重. 必須是一個長度 為 “nbatch” 的 Tensor
pos_weight(Tensor, optional) – 自定義的每個正樣本的 loss 的權重. 必須是一個長度 為 “classes” 的 Tensor

2-7 MarginRankingLoss

torch.nn.MarginRankingLoss(margin=0.0, reduction='mean')

對于 mini-batch(小批量) 中每個實例的損失函數如下:

Pytorch十九種損失函數的實現方法

參數:

margin:默認值0

2-8 HingeEmbeddingLoss

torch.nn.HingeEmbeddingLoss(margin=1.0, reduction='mean')

對于 mini-batch(小批量) 中每個實例的損失函數如下:

Pytorch十九種損失函數的實現方法

參數:

margin:默認值1

2-9 多標簽分類損失 MultiLabelMarginLoss

torch.nn.MultiLabelMarginLoss(reduction='mean')

對于mini-batch(小批量) 中的每個樣本按如下公式計算損失:

Pytorch十九種損失函數的實現方法

2-10 平滑版L1損失 SmoothL1Loss

也被稱為 Huber 損失函數。

torch.nn.SmoothL1Loss(reduction='mean')

Pytorch十九種損失函數的實現方法

其中

Pytorch十九種損失函數的實現方法

2-11 2分類的logistic損失 SoftMarginLoss

torch.nn.SoftMarginLoss(reduction='mean')

Pytorch十九種損失函數的實現方法

2-12 多標簽 one-versus-all 損失 MultiLabelSoftMarginLoss

torch.nn.MultiLabelSoftMarginLoss(weight=None, reduction='mean')

Pytorch十九種損失函數的實現方法

2-13 cosine 損失 CosineEmbeddingLoss

torch.nn.CosineEmbeddingLoss(margin=0.0, reduction='mean')

Pytorch十九種損失函數的實現方法

參數:

margin:默認值0

2-14 多類別分類的hinge損失 MultiMarginLoss

torch.nn.MultiMarginLoss(p=1, margin=1.0, weight=None, reduction='mean')

Pytorch十九種損失函數的實現方法

參數:

p=1或者2 默認值:1
margin:默認值1

2-15 三元組損失 TripletMarginLoss

torch.nn.TripletMarginLoss(margin=1.0, p=2.0, eps=1e-06, swap=False, reduction='mean')

Pytorch十九種損失函數的實現方法

其中:

Pytorch十九種損失函數的實現方法

2-16 連接時序分類損失 CTCLoss

CTC連接時序分類損失,可以對沒有對齊的數據進行自動對齊,主要用在沒有事先對齊的序列化數據訓練上。比如語音識別、ocr識別等等。

torch.nn.CTCLoss(blank=0, reduction='mean')

參數:

reduction-三個值,none: 不使用約簡;mean:返回loss和的平均值; sum:返回loss的和。默認:mean。

2-17 負對數似然損失 NLLLoss

負對數似然損失. 用于訓練 C 個類別的分類問題.

torch.nn.NLLLoss(weight=None, ignore_index=-100, reduction='mean')

參數:

weight (Tensor, optional) – 自定義的每個類別的權重. 必須是一個長度為 C 的 Tensor
ignore_index (int, optional) – 設置一個目標值, 該目標值會被忽略, 從而不會影響到 輸入的梯度.

2-18 NLLLoss2d

對于圖片輸入的負對數似然損失. 它計算每個像素的負對數似然損失.

torch.nn.NLLLoss2d(weight=None, ignore_index=-100, reduction='mean')

參數:

weight (Tensor, optional) – 自定義的每個類別的權重. 必須是一個長度為 C 的 Tensor
reduction-三個值,none: 不使用約簡;mean:返回loss和的平均值; sum:返回loss的和。默認:mean。

2-19 PoissonNLLLoss

目標值為泊松分布的負對數似然損失

torch.nn.PoissonNLLLoss(log_input=True, full=False, eps=1e-08, reduction='mean')

參數:

log_input (bool, optional) – 如果設置為 True , loss 將會按照公 式 exp(input) - target * input 來計算, 如果設置為 False , loss 將會按照 input - target * log(input+eps) 計算.
full (bool, optional) – 是否計算全部的 loss, i. e. 加上 Stirling 近似項 target * log(target) - target + 0.5 * log(2 * pi * target).
eps (float, optional) – 默認值: 1e-8

看完上述內容,是不是對Pytorch十九種損失函數的實現方法有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

个旧市| 建平县| 昌黎县| 延庆县| 临清市| 彭山县| 德安县| 扶沟县| 梁山县| 苍山县| 永寿县| 汝州市| 文昌市| 固阳县| 枣阳市| 武功县| 阜南县| 开平市| 富源县| 老河口市| 砚山县| 静宁县| 聂荣县| 天祝| 正镶白旗| 赤壁市| 齐河县| 北宁市| 准格尔旗| 鄂伦春自治旗| 仙游县| 原平市| 泸州市| 周宁县| 平武县| 大田县| 华宁县| 金溪县| 个旧市| 体育| 牡丹江市|