ReplicationPad2d β€” PyTorch 2.7 documentation (original) (raw)

class torch.nn.ReplicationPad2d(padding)[source][source]ΒΆ

Pads the input tensor using replication of the input boundary.

For N-dimensional padding, use torch.nn.functional.pad().

Parameters

padding (int, tuple) – the size of the padding. If is int, uses the same padding in all boundaries. If a 4-tuple, uses (padding_left\text{padding\_left},padding_right\text{padding\_right}, padding_top\text{padding\_top}, padding_bottom\text{padding\_bottom})

Shape:

Examples:

m = nn.ReplicationPad2d(2) input = torch.arange(9, dtype=torch.float).reshape(1, 1, 3, 3) input tensor([[[[0., 1., 2.], [3., 4., 5.], [6., 7., 8.]]]]) m(input) tensor([[[[0., 0., 0., 1., 2., 2., 2.], [0., 0., 0., 1., 2., 2., 2.], [0., 0., 0., 1., 2., 2., 2.], [3., 3., 3., 4., 5., 5., 5.], [6., 6., 6., 7., 8., 8., 8.], [6., 6., 6., 7., 8., 8., 8.], [6., 6., 6., 7., 8., 8., 8.]]]])

using different paddings for different sides

m = nn.ReplicationPad2d((1, 1, 2, 0)) m(input) tensor([[[[0., 0., 1., 2., 2.], [0., 0., 1., 2., 2.], [0., 0., 1., 2., 2.], [3., 3., 4., 5., 5.], [6., 6., 7., 8., 8.]]]])