首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >图解pytorch padding方法 ReflectionPad2d

图解pytorch padding方法 ReflectionPad2d

作者头像
烤粽子
发布2021-07-07 18:18:42
发布2021-07-07 18:18:42
1.1K00
代码可运行
举报
运行总次数:0
代码可运行

torch.nn.ReflectionPad2d(padding)这个函数简单来说就是:利用输入边界的反射来填充输入张量。

官方文档里给了该padding的输入输出如下所示:

代码语言:javascript
代码运行次数:0
运行
复制
CLASS torch.nn.ReflectionPad2d(padding: Union[T, Tuple[T, T, T, T]])

  • Input: ( N , C , H i n , W i n ) (N, C, H_{in}, W_{in}) (N,C,Hin​,Win​)
  • Output: ( N , C , H o u t , W o u t ) (N, C, H_{out}, W_{out}) (N,C,Hout​,Wout​)where KaTeX parse error: Expected '}', got '_' at position 33: …+ \text{padding_̲top} + \text{pa… KaTeX parse error: Expected '}', got '_' at position 33: …+ \text{padding_̲left} + \text{p…

官方文档比较简单,我们先直接看代码:

代码语言:javascript
代码运行次数:0
运行
复制
import torch
import torch.nn as nn

m = nn.ReflectionPad2d(1)
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([[[[4., 3., 4., 5., 4.],
          [1., 0., 1., 2., 1.],
          [4., 3., 4., 5., 4.],
          [7., 6., 7., 8., 7.],
          [4., 3., 4., 5., 4.]]]])
------------------------------
n = nn.ReflectionPad2d(2)
n(input)
-------
tensor([[[[8., 7., 6., 7., 8., 7., 6.],
          [5., 4., 3., 4., 5., 4., 3.],
          [2., 1., 0., 1., 2., 1., 0.],
          [5., 4., 3., 4., 5., 4., 3.],
          [8., 7., 6., 7., 8., 7., 6.],
          [5., 4., 3., 4., 5., 4., 3.],
          [2., 1., 0., 1., 2., 1., 0.]]]])
-------------------------------
m = nn.ReflectionPad2d((1, 1, 2, 0))
m(input)
-----
tensor([[[[8., 7., 6., 7., 8., 7., 6.],
          [5., 4., 3., 4., 5., 4., 3.],
          [2., 1., 0., 1., 2., 1., 0.],
          [5., 4., 3., 4., 5., 4., 3.],
          [8., 7., 6., 7., 8., 7., 6.],
          [5., 4., 3., 4., 5., 4., 3.],
          [2., 1., 0., 1., 2., 1., 0.]]]])
1. 填充一个整数

从上面的例子看,填充的值就是对应边界旁边的值按填充参数反射过去,即反射填充。

填充顺序是左-右-上-下,

nn.ReflectionPad2d((1, 1, 2, 0))中,这几个数字表示左右上下分别要填充的层数。我们画图表示更清楚,如下:

几幅图已经比较清楚的表达了该padding方法的过程。

Note: padding的大小要小于输入的大小

Reference:

几幅图已经比较清楚的表达了该padding方法的过程。

Note: padding的大小要小于输入的大小

Reference:

PyTorch: REFLECTIONPAD2D

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/02/22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 填充一个整数
  • Reference:
  • Reference:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档