Pytorch 四种边界填充方式(Padding)
1. 选用卷积之前填充(强烈建议)
小生非常推荐大家不再使用卷积所带的填充方式,虽然那种方式简单,但缺陷太多。① 不能根据自己的需要来决定上与下填充不等的边界,左右填充不等的边界;② 边界填充零容易出现伪影的情况,对实验效果影响比较大。将卷积中的Padding方式换为卷积前Padding效果会更佳,以下列了四种填充方式(零填充,常数填充,镜像填充,复制填充)。
小生就不赘言了,客官请下观~~
2. 边界填充之零填充
零填充是常数填充的特例,这种填充方式和卷积中的填充的类似,都是填充零元素,不过这个比卷积填充更灵活,我们可以根据自己的需要再上下左右分别填充相应的0元素。
2.1 Code
import torch
import torch.nn as nn # ================== 零填充 ==================
def conv_ZeroPad2d():
# 定义一个四维数据:(batchSize, channel, height, width)
data = torch.tensor([[[[1, 2, 3],
[4, 5, 6],
[7, 8, 9]]]]).float()
print("data_shape: ", data.shape)
print("data: ", data)
# 零填充,在边界填充n个0,分别为:左、右、上、下
ZeroPad = nn.ZeroPad2d(padding=(1, 2, 1, 2))
data1 = ZeroPad(data)
print("data1_shape: ", data1.shape)
print("data1: ", data1) if __name__ == '__main__':
conv_ZeroPad2d()
2.2 结果显示
可以看到,分别在左边填充1列0元素,右边填充2列0元素,上边填充1列0元素,下边填充2列0元素。

3. 边界填充之常数填充
常数填充方式, 可以根据自己的需要在上下左右分别填充指定的元素。
3.1 Code
import torch # ================== 常量填充 ==================
def conv_ConstantPad2d():
# 定义一个四维数据:(batchSize, channel, height, width)
data = torch.tensor([[[[1, 2, 3],
[4, 5, 6],
[7, 8, 9]]]]).float()
print("data_shape: ", data.shape)
print("data: ", data)
# 用给定的纸填充,0填充是常亮填充的特列,分别为:左、右、上、下
ConstantPad = nn.ConstantPad2d(padding=(1, 2, 1, 2), value=10)
data1 = ConstantPad(data)
print("data1_shape: ", data1.shape)
print("data1: ", data1) if __name__ == '__main__':
conv_ConstantPad2d()
3.2 结果显示
可以看到,分别在左边填充1列10元素,右边填充2列10元素,上边填充1列10元素,下边填充2列10元素。

4. 边界填充之镜像填充
镜像填充方式是根据对称性来填充的。
4.1 Code
import torch # ================== 镜像填充 ==================
def conv_ReflectionPad2d():
# 定义一个四维数据:(batchSize, channel, height, width)
data = torch.tensor([[[[1, 2, 3],
[4, 5, 6],
[7, 8, 9]]]]).float()
print("data_shape: ", data.shape)
print("data: ", data)
# 复制边界n次,分别为:左、右、上、下
ReflectionPad = nn.ReflectionPad2d(padding=(1, 2, 1, 2))
data1 = ReflectionPad(data)
print("data1_shape: ", data1.shape)
print("data1: ", data1) if __name__ == '__main__':
conv_ReflectionPad2d()
4.2 结果显示

5. 边界填充之复制填充
复制填充方式,小生非常推荐。复制填充是复制最外边界的元素来填充,这样填充的元素与边界元素相近,对实验结果的影响会降到最小。
5.1 Code
import torch # ================== 重复填充 ==================
def conv_ReplicationPad2d():
# 定义一个四维数据:(batchSize, channel, height, width)
data = torch.tensor([[[[1, 2, 3],
[4, 5, 6],
[7, 8, 9]]]]).float()
print("data_shape: ", data.shape)
print("data: ", data)
# 用对称位置的像素来填充,分别为:左、右、上、下
ReplicationPad = nn.ReplicationPad2d(padding=(1, 2, 1, 2))
data1 = ReplicationPad(data)
print("data1_shape: ", data1.shape)
print("data1: ", data1) if __name__ == '__main__':
conv_ReplicationPad2d()
5.2 结果显示
可以看到,填充的元素与最外边界的元素相同。

6. 总结
努力去爱周围的每一个人,付出,不一定有收获,但是不付出就一定没有收获! 给街头卖艺的人零钱,不和深夜还在摆摊的小贩讨价还价。愿我的博客对你有所帮助(*^▽^*)(*^▽^*)!
如果客官喜欢小生的园子,记得关注小生哟,小生会持续更新(#^.^#)(#^.^#)!
Pytorch 四种边界填充方式(Padding)的更多相关文章
- ASP.NET MVC下的四种验证编程方式[续篇]
在<ASP.NET MVC下的四种验证编程方式>一文中我们介绍了ASP.NET MVC支持的四种服务端验证的编程方式("手工验证"."标注Validation ...
- ASP.NET MVC下的四种验证编程方式
ASP.NET MVC采用Model绑定为目标Action生成了相应的参数列表,但是在真正执行目标Action方法之前,还需要对绑定的参数实施验证以确保其有效性,我们将针对参数的验证成为Model绑定 ...
- thinkphp四种url访问方式详解
本文实例分析了thinkphp的四种url访问方式.分享给大家供大家参考.具体分析如下: 一.什么是MVC thinkphp的MVC模式非常灵活,即使只有三个中和一个也可以运行. M -Model 编 ...
- ASP.NET MVC下的四种验证编程方式[续篇]【转】
在<ASP.NET MVC下的四种验证编程方式> 一文中我们介绍了ASP.NET MVC支持的四种服务端验证的编程方式(“手工验证”.“标注ValidationAttribute特性”.“ ...
- ASP.NET MVC下的四种验证编程方式【转】
ASP.NET MVC采用Model绑定为目标Action生成了相应的参数列表,但是在真正执行目标Action方法之前,还需要对绑定的参数实施验证以确保其有效 性,我们将针对参数的验证成为Model绑 ...
- thinkPHP四种URL访问方式(二)
原文:thinkPHP四种URL访问方式(二) 四.url的4种访问方式 1.PATHINFO 模式 -- (重点) http://域名/项目名/入口文件/模块名/方法名/键1/值1/键2/ ...
- python接口自动化(十)--post请求四种传送正文方式(详解)
简介 post请求我在python接口自动化(八)--发送post请求的接口(详解)已经讲过一部分了,主要是发送一些较长的数据,还有就是数据比较安全等.我们要知道post请求四种传送正文方式首先需要先 ...
- 快速理解VirtualBox的四种网络连接方式
VirtualBox中有4中网络连接方式: NAT Bridged Adapter Internal Host-only Adapter VMWare中有三种,其实他跟VMWare 的网络连接方式都是 ...
- python3+requests:post请求四种传送正文方式(详解)
前言:post请求我在python接口自动化2-发送post请求详解(二)已经讲过一部分了,主要是发送一些较长的数据,还有就是数据比较安全等,可以参考Get,Post请求方式经典详解进行学习一下. 我 ...
随机推荐
- 你知道如何自动保存 Spring Boot 应用进程号吗
1. 前言 欢迎阅读 Spring Boot 2 实战 系列文章. PID 对于系统运维来说并不陌生,但是对于一些开发者特别是新手还是要简单介绍一下的.它是 Process ID 的简称,是系统分配给 ...
- @ModelAttribute 的使用
@ModelAttribute注解可被应用在 方法 或 方法参数 上. 对方法使用 @ModelAttribute 注解: 注解在方法上的@ModelAttribute说明了方法的作用是用于添加一个或 ...
- 2019应届生,用python爬虫记录自己求职经历,分享求职中的一些坑
前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取http ...
- L3 多层感知机
**本小节用到的数据下载 1.涉及语句 import d2lzh1981 as d2l 数据1 : d2lzh1981 链接:https://pan.baidu.com/s/1LyaZ84Q4M75G ...
- Python套接字之UDP
目录 基于UDP的socket 发送消息 接收消息 基于UDP的socket 面向无连接的不可靠数据传输,可以没有服务器端,只不过没有服务器端,发送的数据会被直接丢弃,并不能到达服务器端 发送消息 在 ...
- 网站假死 重启NGINX无效 必须重启PHP 原因分析
一.错误提示说明: Nginx 502 Bad Gateway:请求的PHP-CGI已经执行,但是由于某种原因(一般是读取资源的问题)没有执行完毕而导致PHP-CGI进程终止. Nginx 504 G ...
- vue2.x学习笔记(二十二)
接着前面的内容:https://www.cnblogs.com/yanggb/p/12633051.html. 自定义指令 简介 除了核心功能默认内置的指令([v-mode]和[v-show]等),v ...
- 关于JS垃圾回收机制
一.垃圾回收机制的必要性 由于字符串.对象和数组没有固定大小,所以当它们的大小已知时,才能对它们进行动态的存储分配.JavaScript程序每次创建字符串.数组或对象时,解释器都必须分配内存来存储那个 ...
- JavaScript表达式和运算符 —— 基础语法(4)
JavaScript基础语法(4) 运算符 运算符用于将一 个或者多个值变成结果值. 使用运算符的值称为操作数,运算符和操作数的组合称为表达式 JS中的运算符可以分成下面几类: 算术运算符 逻辑运算符 ...
- How to permit SSH root Login in Ubuntu 18.04
https://www.ubuntu18.com/ssh-permitrootlogin/ SSH root login is disabled by default in Ubuntu 18.04. ...