卷积和转置卷积,都涉及到padding, 那么添加padding 的具体方式,就会影响到计算结果,所以搞清除tensorflow中卷积和转置卷积的具体实现有助于模型的灵活部署应用。

一、卷积

举例说明:

    X:  1        2        3        4          5

       6        7        8        9         10

      11      12      13       14        15

      16      17       18      19        20

      21       22      23      24        25

    w:    1   1   1   1

1    2   1   1

      1    1   3   1

1    1   1   4

如对于:tf.nn.conv2(X,w,stride=[1,1],padding='SAME')

需要在X 中添加3 行 3列, 那么在tensorflow 中的添加方式如下:

left_w =  3/2    up_h =3/2

right_w = 3-left_w    down_h = 3- up_h

也即:  添加padding 时如左右、上下不能呢个平均分配,则左边<=右边,上边<=下边

故,卷积后的 (0,0)位置的值为,  1*2 + 2*1+ 3*1+ 6*1+7*3+8*1+11*1+12*1+14*4

二 、转置卷积

X:    1        2        3        4          5             w:    1         1         1          1

  6        7        8        9          10                    1         2         1          1

  11      12      13      14        15       1         2         3          1

  16      17      18      19        20

  21      22      23      24        25

tf.nn.conv2d_transpose(X,W,tf.stack([10,10]),strides=[2,2],padding="SAME")

1、对X扩展,

strides=[2,2] 故扩展后的 X 为:(shape:10X10)

1     0     2     0     3    0     4    0     5     0

0     0     0     0     0    0     0    0     0     0

6     0     7     0     8    0     9    0     10   0

.      .      .      .      .     .      .     .       .     .

.      .      .      .      .     .      .     .       .     .

2、加padding,由于padding = "SAME"  所以需要加 3行 3列

对X 扩展再加padding 后的 高和宽为:

H = X.H * stride + (w.H-1)

W = X.W*stride + (w.W-1)

l_h = ceil(((w.H - 1)*1.0 + (stride - 1)) / 2.0);       // 向上取整数

l_h = l_h>(w.H - 1) ? (w.H - 1) : l_h;  // 在左边添加padding 的列数

up_w = ceil(((w.W - 1)*1.0 + (stride - 1)) / 2.0)    // 向上取整数

up_w = up_w>(w.W - 1) ? (w.W - 1) : up_h;   // 在上边添加padding 的行数

说明:

input.shape:  5X5   ; stride = 3 ; w.shape =5*5  padding = "SAME" 时

扩展后,input.shape = 15*15 , 其中 最右边扩展2列, 最下边扩展2行

加padding后, input.shape = 19*19, 其中在最左边扩展3列, 最上边扩展3行; 最右边再扩展1列,最下边再扩展1行

卷积(步长为1)后  , output .shape = 15*15

3、卷积

tensorflow 中conv2d_transpose对卷积的实现有别于conv2,  相当于将 w 进行reverse 后进行卷积。

tensorflow中卷积、转置卷积具体实现方式的更多相关文章

  1. 第十四节,TensorFlow中的反卷积,反池化操作以及gradients的使用

    反卷积是指,通过测量输出和已知输入重构未知输入的过程.在神经网络中,反卷积过程并不具备学习的能力,仅仅是用于可视化一个已经训练好的卷积神经网络,没有学习训练的过程.反卷积有着许多特别的应用,一般可以用 ...

  2. 深度学习卷积网络中反卷积/转置卷积的理解 transposed conv/deconv

    搞明白了卷积网络中所谓deconv到底是个什么东西后,不写下来怕又忘记,根据参考资料,加上我自己的理解,记录在这篇博客里. 先来规范表达 为了方便理解,本文出现的举例情况都是2D矩阵卷积,卷积输入和核 ...

  3. TensorFlow中tf.ConfigProto()配置Sesion运算方式

    博主个人网站:https://chenzhen.online tf.configProto用于在创建Session的时候配置Session的运算方式,即使用GPU运算或CPU运算: 1. tf.Con ...

  4. TensorFlow中CNN的两种padding方式“SAME”和“VALID”

    来源 dilation_rate为一个可选的参数,默认为1,这里我们可以先不管它. 整理一下,对于"VALID",输出的形状计算如下: new_height=new_width=⌈ ...

  5. 由浅入深:CNN中卷积层与转置卷积层的关系

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由forrestlin发表于云+社区专栏 导语:转置卷积层(Transpose Convolution Layer)又称反卷积层或分数卷 ...

  6. tensorflow 卷积/反卷积-池化/反池化操作详解

    Plese see this answer for a detailed example of how tf.nn.conv2d_backprop_input and tf.nn.conv2d_bac ...

  7. TensorFlow中设置学习率的方式

    目录 1. 指数衰减 2. 分段常数衰减 3. 自然指数衰减 4. 多项式衰减 5. 倒数衰减 6. 余弦衰减 6.1 标准余弦衰减 6.2 重启余弦衰减 6.3 线性余弦噪声 6.4 噪声余弦衰减 ...

  8. TensorFlow中实现RNN,彻底弄懂time_step

    这篇博客不是一篇讲解原理的博客,这篇博客主要讲解tnesorlfow的RNN代码结构,通过代码来学习RNN,以及讲解time_steps,如果这篇博客没有让你明白time_steps,欢迎博客下面评论 ...

  9. Tensorflow中卷积的padding方式

    根据tensorflow中的Conv2D函数,先定义几个基本符号: 输入矩阵W*W,这里只考虑输入宽高相等的情况,如果不相等,推导方法一样 filter矩阵F*F,卷积核 stride值S,步长 输出 ...

随机推荐

  1. 【Java Web开发学习】远程方法调用RMI

    Java RMI 远程方法调用Remote Method Invocation 转载:http://www.cnblogs.com/yangchongxing/p/9078061.html 1.创建远 ...

  2. 建议3:正确处理Javascript特殊值---(1)正确使用NaN和Infinity

    NaN时IEEE 754中定义的一个特殊的数量值.他不表示一个数字,尽管下面的表达式返回的是true typeof(NaN) === 'number' //true 该值可能会在试图将非数字形式的字符 ...

  3. 手把手教你DIY尼康ML-L3红外遥控器

    项目介绍 ML-L3是用于尼康部分型号相机的无线红外遥控器,可以通过红外方式来控制快门的释放,支持B门拍摄.官方售价100RMB左右,山寨版售价10RMB左右.虽然也能实现基本的遥控功能,但是功能还是 ...

  4. PDF提取表格的网页工具——Excalibur

      在之前的文章另类爬虫:从PDF文件中爬取表格数据中,我们知道如何利用Python的camelot模块,通过写Python程序来提取PDF中的表格数据.本文我们将学习如何用更便捷的工具从PDF中提取 ...

  5. C# 派生和继承(派生类与基类)

    using System; using System.Collections.Generic; using System.Text; namespace 继承 { class Program { st ...

  6. android studio学习----目录结构

    项目结构:一个窗口只有一个项目,项目 叫  Project 代表一个workspace 一个项目的结构跟eclipse区别还是蛮大的: 首先看APP结构:app放的其实就是  java文件和资源文件 ...

  7. JVM调优之服务内存超过阈值报警

    今早收到一条短信,具体报警信息如下: [UMP JVM监控内存报警]应用名:发券worker(jdos_couponwkr);KEY[coupon.send.worker.jvm],主机名:[host ...

  8. Java中数组与集合的相互转换

    数组与List的相互转换 List转数组:采用集合的toArray()方法 数组转List:采用Arrays的asList()方法 数组转换为集合 注意:在数组转集合的过程中,要注意是否使用了视图的方 ...

  9. 一篇文章看懂JS闭包,都要2020年了,你怎么能还不懂闭包?

     壹 ❀ 引 我觉得每一位JavaScript工作者都无法避免与闭包打交道,就算在实际开发中不使用但面试中被问及也是常态了.就我而言对于闭包的理解仅止步于一些概念,看到相关代码我知道这是个闭包,但闭包 ...

  10. 对token机制的学习和分析

    token,中文意思为令牌,是用户登录后会返回的一个字符串,里面包括用户信息.登录时间等,但是是加密过的密文,其加解密方式由后端决定. 在登录之后的接口请求中,前端需在请求中统一加上token,从而识 ...