Tensorflow框架tf.nn.conv2d函数

最近学习了tensorglow框架,今天主要学习了下conv2d函数。

conv2d函数实现了卷积运算,声明如下:

tf.nn.conv2d( input, filter, strides, padding, use_cudnn_on_gpu=True, data_format='NHWC', dilations=[1, 1, 1, 1], name=None )

input:即输入,是一个维度为[batch,height,weight,in_channel]的tensor;

filter:即卷积核,是一个维度为[height,weight,in_channel,out_channels]的tensor;

strides:步长,是一个4维tensor,每一维均表示input输入对应的4个维度方向的移动步长;

padding:string类型,可以是:"SAME", "VALID",要使用的填充算法的类型。

代码如下:

import matplotlib.pyplot as plt
import tensorflow as tf
import numpy as np

g1 = tf.Graph()

with g1.as_default():
    # 读入二进制文件
    image_raw = tf.gfile.FastGFile('./flow1.jpg','rb').read()
 
    # 解码为tf中的图像格式
    img = tf.image.decode_jpeg(image_raw)  #Tensor
    
    M = tf.reshape(img,[1, 375,500, 3])
    M = tf.to_float(M) 

    x = tf.placeholder('float32', [1, None, None, 3])    
    filter_weight = tf.get_variable('weights', [3, 3, 3, 3], 
                                initializer = tf.constant_initializer([[[0,-1, 0],[-1,4, -1],[0,-1, 0]],[[0,-1, 0],[-1,4, -1],[0,-1, 0]],[[0,-1, 0],[-1,4, -1],[0,-1, 0]]]))
    biases = tf.get_variable('biases', [3], initializer = tf.constant_initializer(1))
    
    conv = tf.nn.conv2d(x, filter_weight, strides = [1, 2, 2, 1], padding = 'SAME')
    bias = tf.nn.bias_add(conv, biases)

    init = tf.global_variables_initializer()

with tf.Session(graph=g1) as sess:
    sess.run(init)
    rel_M = M.eval()
    print(rel_M.shape)

    conv_rel = sess.run(bias,feed_dict={x:rel_M})
    new = np.reshape(conv_rel,(188,250,3))
    print(new.shape)

    plt.figure(1)
    plt.imshow(new)
    plt.show()

输出:

Tensorflow框架tf.nn.conv2d函数_第1张图片

注意:如果filter_weight的维度为[3, 3, 3, 1],那卷积运算后得到的图像只有一个通道。因为,卷积核会在各个通道做相同的卷积,然后各像素后的卷积值求和。

你可能感兴趣的:(tensorflow)