L1Loss#
- class torch.nn.modules.loss.L1Loss(size_average=None, reduce=None, reduction='mean')[原始碼]#
建立一個標準,用於衡量輸入 和目標 之間每個元素的平均絕對誤差 (MAE)。
未約簡的(即
reduction設定為'none')損失可以描述為其中 是批次大小。如果
reduction不是'none'(預設為'mean'),則:和 是任意形狀的張量,每個張量包含 個元素。
求和操作仍然作用於所有元素,併除以 。
可以透過將
reduction = 'sum'來避免除以 。支援實值和復值輸入。
- 引數
size_average (bool, optional) – 已棄用 (參見
reduction)。預設情況下,損失值在批次中的每個損失元素上取平均值。請注意,對於某些損失,每個樣本有多個元素。如果欄位size_average設定為False,則損失值在每個小批次中而是求和。當reduce為False時忽略。預設值:Truereduce (bool, optional) – 已棄用 (參見
reduction)。預設情況下,損失值在每個小批次中根據size_average對觀測值進行平均或求和。當reduce為False時,返回每個批次元素的損失值,並忽略size_average。預設值:Truereduction (str, optional) – 指定應用於輸出的歸約方法:
'none'|'mean'|'sum'。'none':不應用歸約,'mean':輸出的總和將除以輸出中的元素數量,'sum':輸出將求和。注意:size_average和reduce正在被棄用,在此期間,指定其中任何一個引數都會覆蓋reduction。預設為:'mean'
- 形狀
輸入: ,其中 表示任意數量的維度。
目標:,與輸入形狀相同。
輸出:標量。如果
reduction為'none',則 ,形狀與輸入相同。
示例
>>> loss = nn.L1Loss() >>> input = torch.randn(3, 5, requires_grad=True) >>> target = torch.randn(3, 5) >>> output = loss(input, target) >>> output.backward()