一、介紹
在深度學習中,我們常常需要對輸入的張量進行填充操作,以便處理不同大小的輸入數據。在PyTorch中,我們可以使用torch.nn.functional.pad函數來實現張量的填充功能。本文將介紹如何使用torch.nn.functional.pad函數對張量進行填充操作。
二、使用torch.nn.functional.pad進行填充
使用torch.nn.functional.pad函數前,我們需要先了解函數的參數。torch.nn.functional.pad函數的參數如下:
torch.nn.functional.pad(input, pad, mode='constant', value=0)
其中,參數input是要進行填充的張量;參數pad是填充的大小,它可以是一個整數,也可以是一個元組;參數mode表示填充的方式,默認是’constant’,表示用常數填充;參數value表示填充的數值,默認是0。
下面是一個簡單的例子,我們對一個2 x 2的張量進行大小為1的填充:
import torch x = torch.ones(2, 2) print(x) x = torch.nn.functional.pad(x, (1, 1, 1, 1)) print(x)
運行結果如下所示:
tensor([[1., 1.], [1., 1.]]) tensor([[0., 0., 0., 0., 0.], [0., 1., 1., 1., 0.], [0., 1., 1., 1., 0.], [0., 1., 1., 1., 0.], [0., 0., 0., 0., 0.]])
可以看出,填充後的張量大小為4 x 4,周圍都填充了1列(或1行)的0。
三、填充的方式和數值
torch.nn.functional.pad函數支持不同的填充方式和不同的填充數值。
1、填充方式
除了常數填充(‘constant’)外,torch.nn.functional.pad函數還支持以下填充方式:
- ‘reflect’:以邊緣為軸,對稱填充。
- ‘replicate’:以邊緣為軸,複製填充。
- ‘circular’:循環填充。
例如,如果我們使用’reflect’填充上面的例子,代碼如下所示:
import torch x = torch.ones(2, 2) print(x) x = torch.nn.functional.pad(x, (1, 1, 1, 1), mode='reflect') print(x)
運行結果如下所示:
tensor([[1., 1.], [1., 1.]]) tensor([[1., 1., 1., 1., 1.], [1., 1., 1., 1., 1.], [1., 1., 1., 1., 1.], [1., 1., 1., 1., 1.], [1., 1., 1., 1., 1.]])
可以看出,使用’reflect’填充後,邊緣處的值被進行了對稱填充。
2、填充數值
我們還可以通過value參數來指定填充的數值。
以填充值為1為例,代碼如下所示:
import torch x = torch.ones(2, 2) print(x) x = torch.nn.functional.pad(x, (1, 1, 1, 1), value=1) print(x)
運行結果如下所示:
tensor([[1., 1.], [1., 1.]]) tensor([[1., 1., 1., 1., 1.], [1., 1., 1., 1., 1.], [1., 1., 1., 1., 1.], [1., 1., 1., 1., 1.], [1., 1., 1., 1., 1.]])
可以看出,填充後的張量中,原張量部分的值為1,填充部分的值也為1。
四、指定不同的填充大小
我們還可以在不同的維度上使用不同的填充大小。
例如,如果我們在第1維度和第2維度上分別使用不同的填充大小,代碼如下所示:
import torch x = torch.ones(2, 2) print(x) x = torch.nn.functional.pad(x, (1, 2, 1, 0), value=1) print(x)
運行結果如下所示:
tensor([[1., 1.], [1., 1.]]) tensor([[1., 1., 1., 1., 1., 1.], [1., 1., 1., 1., 1., 1.], [1., 1., 1., 1., 1., 0.], [1., 1., 1., 1., 1., 0.]])
可以看出,第1維度上的填充大小為(1, 2),第2維度上的填充大小為(1, 0)。
五、結論
torch.nn.functional.pad函數是PyTorch中用於進行張量填充的函數,能夠支持不同的填充方式和不同的填充數值。在使用時,需要注意填充的大小可以是一個整數,也可以是一個元組;填充的方式可以是’constant’、’reflect’、’replicate’或者’circular’;填充的數值可以通過value參數進行指定。同時,我們還可以在不同的維度上使用不同的填充大小。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/199334.html