測試代碼參考:https://blog.csdn.net/tmk_01/article/details/80679549
首先我們先來看看pytorch官方文檔有關這個方法的介紹:
下面進行測試:
import torch
import torch.nn as nn
m = nn.BatchNorm2d(2,affine=True) #權重w和偏重將被使用 #affine默認爲True,用於使用權重w和偏重b
input = torch.randn(1,2,3,4)
output = m(input)
# print('m的第一個值',m.weight[0])
# print('m的第一個偏移值',m.bias[0])
print("輸入圖片:")
print(input)
print("歸一化權重:")
print(m.weight)
print("歸一化的偏重:")
print(m.bias)
print("歸一化的輸出:")
print(output)
print("輸出的尺度:")
print(output.size())
# i = torch.randn(1,1,2)
print("輸入的第一個維度:")
print(input[0][0])
firstDimenMean = torch.Tensor.mean(input[0][0]) #通道均值
firstDimenVar= torch.Tensor.var(input[0][0],False) #Bessel's Correction貝塞爾校正不會被使用
#通道方差
print(m.eps)
print("輸入的第一個維度平均值:")
print(firstDimenMean)
print("輸入的第一個維度方差:")
print(firstDimenVar)
bacthnormone = \
((input[0][0][0][0] - firstDimenMean)/(torch.pow(firstDimenVar+m.eps,0.5) ))\
* m.weight[0] + m.bias[0]
print(bacthnormone)
結果: