【TensorFlow】tf.nn.max_pool实现池化操作

原创 2016年12月04日 14:28:39

max pooling是CNN当中的最大值池化操作,其实用法和卷积很类似

有些地方可以从卷积去参考【TensorFlow】tf.nn.conv2d是怎样实现卷积的? 

tf.nn.max_pool(value, ksize, strides, padding, name=None)

参数是四个,和卷积很类似:

第一个参数value:需要池化的输入,一般池化层接在卷积层后面,所以输入通常是feature map,依然是[batch, height, width, channels]这样的shape

第二个参数ksize:池化窗口的大小,取一个四维向量,一般是[1, height, width, 1],因为我们不想在batch和channels上做池化,所以这两个维度设为了1

第三个参数strides:和卷积类似,窗口在每一个维度上滑动的步长,一般也是[1, stride,stride, 1]

第四个参数padding:和卷积类似,可以取'VALID' 或者'SAME'

返回一个Tensor,类型不变,shape仍然是[batch, height, width, channels]这种形式


示例源码:

假设有这样一张图,双通道

第一个通道:

第二个通道:

用程序去做最大值池化:

import tensorflow as tf

a=tf.constant([
        [[1.0,2.0,3.0,4.0],
        [5.0,6.0,7.0,8.0],
        [8.0,7.0,6.0,5.0],
        [4.0,3.0,2.0,1.0]],
        [[4.0,3.0,2.0,1.0],
         [8.0,7.0,6.0,5.0],
         [1.0,2.0,3.0,4.0],
         [5.0,6.0,7.0,8.0]]
    ])

a=tf.reshape(a,[1,4,4,2])

pooling=tf.nn.max_pool(a,[1,2,2,1],[1,1,1,1],padding='VALID')
with tf.Session() as sess:
    print("image:")
    image=sess.run(a)
    print (image)
    print("reslut:")
    result=sess.run(pooling)
    print (result)
这里步长为1,窗口大小2×2,输出结果:

image:
[[[[ 1.  2.]
   [ 3.  4.]
   [ 5.  6.]
   [ 7.  8.]]

  [[ 8.  7.]
   [ 6.  5.]
   [ 4.  3.]
   [ 2.  1.]]

  [[ 4.  3.]
   [ 2.  1.]
   [ 8.  7.]
   [ 6.  5.]]

  [[ 1.  2.]
   [ 3.  4.]
   [ 5.  6.]
   [ 7.  8.]]]]
reslut:
[[[[ 8.  7.]
   [ 6.  6.]
   [ 7.  8.]]

  [[ 8.  7.]
   [ 8.  7.]
   [ 8.  7.]]

  [[ 4.  4.]
   [ 8.  7.]
   [ 8.  8.]]]]
池化后的图就是:

证明了程序的结果是正确的。


我们还可以改变步长

pooling=tf.nn.max_pool(a,[1,2,2,1],[1,2,2,1],padding='VALID')
最后的result就变成:

reslut:
[[[[ 8.  7.]
   [ 7.  8.]]

  [[ 4.  4.]
   [ 8.  8.]]]]


版权声明:本文为博主原创文章,转载请注明出处。

相关文章推荐

tf.nn.max_pool作什么用?

先来看一下API的说明:tf.nn.max_pool(value, ksize, strides, padding, data_format='NHWC', name=None)Performs th...

池化操作 tensorflow tf.nn.max_pool

池化操作待补充tf.nn.max_pool(value, ksize, strides, padding, data_format='NHWC', name=None)value表示输入数据形式。da...
  • lxg0807
  • lxg0807
  • 2017年04月21日 10:08
  • 594

tf.nn.max_pool 实例

import numpy as np import tensorflow as tf#input:x x_image = tf.placeholder(tf.float32,shape=[4,4]) ...

TensorFlow学习(九):卷积网络CNN

tensorflow的卷积网络手写体识别

tensorflow `conv2d max_pool 方法参数

第一篇 1、padding的方式: 说明: 1、摘录自http://stackoverflow.com/questions/37674306/what-is-the-...

Tensorflow一些常用基本概念与函数(1)

摘要:本文主要对tf的一些常用概念与方法进行描述。
  • lenbow
  • lenbow
  • 2016年08月08日 16:00
  • 54616

学习TensorFlow,多层卷积神经网络

学习TensorFlow,多层卷积神经网络

tensorflow(二)学习记录

这个网络的结果是: input–>conv1–>relu–>maxpooling–>dropout–>conv2–>reul–>maxpooling –>dropout–>reshape–>inne...

tensorflow_conv2d_max_pool卷积池化padding参数为SAME和VALID的区别

卷积:conv2 "VALID" = without padding: inputs: 1 2 3 4 5 6 7 8 9 10 11 (12 ...

TensorFlow 从入门到精通(六):tensorflow.nn 详解

看过前面的例子,会发现实现深度神经网络需要使用 tensorflow.nn 这个核心模块。我们通过源码来一探究竟。# Copyright 2015 Google Inc. All Rights Res...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【TensorFlow】tf.nn.max_pool实现池化操作
举报原因:
原因补充:

(最多只允许输入30个字)