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)的更多相关文章

  1. ASP.NET MVC下的四种验证编程方式[续篇]

    在<ASP.NET MVC下的四种验证编程方式>一文中我们介绍了ASP.NET MVC支持的四种服务端验证的编程方式("手工验证"."标注Validation ...

  2. ASP.NET MVC下的四种验证编程方式

    ASP.NET MVC采用Model绑定为目标Action生成了相应的参数列表,但是在真正执行目标Action方法之前,还需要对绑定的参数实施验证以确保其有效性,我们将针对参数的验证成为Model绑定 ...

  3. thinkphp四种url访问方式详解

    本文实例分析了thinkphp的四种url访问方式.分享给大家供大家参考.具体分析如下: 一.什么是MVC thinkphp的MVC模式非常灵活,即使只有三个中和一个也可以运行. M -Model 编 ...

  4. ASP.NET MVC下的四种验证编程方式[续篇]【转】

    在<ASP.NET MVC下的四种验证编程方式> 一文中我们介绍了ASP.NET MVC支持的四种服务端验证的编程方式(“手工验证”.“标注ValidationAttribute特性”.“ ...

  5. ASP.NET MVC下的四种验证编程方式【转】

    ASP.NET MVC采用Model绑定为目标Action生成了相应的参数列表,但是在真正执行目标Action方法之前,还需要对绑定的参数实施验证以确保其有效 性,我们将针对参数的验证成为Model绑 ...

  6. thinkPHP四种URL访问方式(二)

    原文:thinkPHP四种URL访问方式(二) 四.url的4种访问方式      1.PATHINFO 模式 -- (重点) http://域名/项目名/入口文件/模块名/方法名/键1/值1/键2/ ...

  7. python接口自动化(十)--post请求四种传送正文方式(详解)

    简介 post请求我在python接口自动化(八)--发送post请求的接口(详解)已经讲过一部分了,主要是发送一些较长的数据,还有就是数据比较安全等.我们要知道post请求四种传送正文方式首先需要先 ...

  8. 快速理解VirtualBox的四种网络连接方式

    VirtualBox中有4中网络连接方式: NAT Bridged Adapter Internal Host-only Adapter VMWare中有三种,其实他跟VMWare 的网络连接方式都是 ...

  9. python3+requests:post请求四种传送正文方式(详解)

    前言:post请求我在python接口自动化2-发送post请求详解(二)已经讲过一部分了,主要是发送一些较长的数据,还有就是数据比较安全等,可以参考Get,Post请求方式经典详解进行学习一下. 我 ...

随机推荐

  1. Python语言-selenium webdriver操作记录汇总

    1.控制浏览器大小 set_window_size() 设置浏览器大小 该方法有两个参数,第一个参数是宽,第二个是高 maximize_window() 设置浏览器全屏显示,无参数 chrome谷歌浏 ...

  2. stand up meeting 12/29/2015

    part 组员                今日工作              工作耗时/h 明日计划 工作耗时/h    UI 冯晓云 重写popup UI添加笔记功能     6 mergeUI ...

  3. 机器学习常见面试题—支持向量机SVM

    前言 总结了2017年找实习时,在头条.腾讯.小米.搜狐.阿里等公司常见的机器学习面试题. 支持向量机SVM 关于min和max交换位置满足的 d* <= p* 的条件并不是KKT条件 Ans: ...

  4. js多线程的实现

    我们都知道JS是一种单线程语言,即使是一些异步的事件也是在JS的主线程上运行的(具体是怎么运行的,可以看我另一篇博客JS代码运行机制).像setTimeout.ajax的异步请求,或者是dom元素的一 ...

  5. 今天我们谈一下HTML标签中的<map>标签的用法和使用场景

    首先我们看下这个标签到底是干什么的! W3C的定义: 然后兼容性: 然后与之配套使用的另一个标签: <area/>规定其区域: 我们来看看<map>标签支不支持全局属性:=== ...

  6. JWT验证机制【Python版Flask或自己写的后端可以用】【刘新宇】

    JWT Json Web Token(JWT) JSON Web Token(JWT)是一个非常轻巧的规范.这个规范允许我们使用JWT在两个组织之间传递安全可靠的信息. 官方定义:JSON Web T ...

  7. c++<cstdlib>文件中的函数产生随机数

    C++中没有自带的random函数,要生成随机数就需要用c文件"stdlib.h"里的函数rand()和srand(),不过,由于rand()的内部实现是用线性同余法做的, 所以生 ...

  8. REDHAT7进入单用户模式

    Redhat7采用的是grub2,和Redhat6.x进入单用户的方法不同. 一.init方法 1.centos7的grub2界面会有两个入口,正常系统入口和救援模式: 2.修改grub2引导 在正常 ...

  9. 从GC的SuppressFinalize方法带你深刻认识Finalize底层运行机制

    如果你经常看开源项目的源码,你会发现很多Dispose方法中都有这么一句代码: GC.SuppressFinalize(this); ,看过一两次可能无所谓,看多了就来了兴趣,这篇就跟大家聊一聊. 一 ...

  10. java并发中CountDownLatch的使用

    文章目录 主线程等待子线程全都结束之后再开始运行 等待所有线程都准备好再一起执行 停止CountdownLatch的await java并发中CountDownLatch的使用 在java并发中,控制 ...