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请求方式经典详解进行学习一下. 我 ...
随机推荐
- JuiceSSH:安卓平台免费好用的 SSH 客户端
为了解决上下班路上或者没带电脑时,查看 Linux 服务器日志或者紧急运维的需求,最终找到了 JuiceSSH 这款软件,强烈推荐给大家. 简介 JuiceSSH 是一个为 Android 打造的全功 ...
- 45道SQL数据题详解1
准备阶段: 创建表: //创建学生表,前面的s表示学生,相应的标签前面加t表示老师 CREATE TABLE students (sno VARCHAR(3) NOT NULL, sname VARC ...
- D - Three Integers CodeForces - 1311D
题意: a<=b<=c 输出A,B,C要求B是A的倍数,C是B的倍数,并且输出a,b,c变成A,B,C需要的最小次数. 题解:写了半天的二分,后来发现思路错了,,,暴力就能过.. 三层fo ...
- jmeter事务控制器
jmeter事务控制器常用于压力测试时如果一个功能包括多个请求时,需要测试这个功能的压力情况,则需要把多个请求放到一个事务控制器里面
- [PHP]PHP设计模式:单例模式
单例模式(职责模式): 简单的说,一个对象(在学习设计模式之前,需要比较了解面向对象思想)只负责一个特定的任务: 单例类: 1.构造函数需要标记为private(访问控制:防止外部代码使用new操作符 ...
- 爬虫与反爬相生相克,道高一丈魔高一尺,如何隐藏ID(附代码)
Python 反爬篇之 ID 混淆 作为爬虫的一方,如果知道了某个站点的数据自增 ID,那么就能轻而易举把整个站点都爬下来. 是不是有点耸人听闻,你去看很多大站例如油管.P 站等,他们都不会轻易把业务 ...
- ES6让字符串String增加了哪些好玩的特性呢?
确实因为现在天气变热了,所以一天天的这么写我也很累.所以如果阅读的时候有什么错误还请大家指出来,不好意思.学习永无止境. OK,今天继续讲解ES6系列知识 学过上一节的解构赋值就知道,ES6确实给我们 ...
- 详解 Discuz 的 PHP经典加密解密函数 authcode
函数注释: // $string: 明文 或 密文 // $operation:DECODE表示解密,其它表示加密 // $key: 密匙 // $expiry:密文有效期 function auth ...
- CSRF与平行越权的区别
.CSRF攻击者不需要登录,越权攻击者也得登录,只是没有做针对性的控制: .CSRF攻击者自己不访问受攻击页面,诱导受害者在登录被攻击系统后点击攻击页面:越权攻击者可以直接访问受攻击页面: .CSRF ...
- 不论是 Basic Auth 还是 Digest Auth,都会有 Authorization 字段
GET /dir/index.html HTTP/1.0 Host: localhost Authorization: Digest username="Mufasa", real ...