import numpy as np
import tensorflow as tf
def convOne():
input = tf.Variable(tf.random_normal([1 ,3 ,3 ,5]))
filter = tf.Variable(tf.random_normal([1 ,1 ,5 ,1]))
op = tf.nn.conv2d(input, filter, strides=[1, 1, 1, 1], padding='VALID')
with tf.Session() as sess:
sess.run(tf.initialize_all_variables())
res = (sess.run(op))
print (res.shape)
print ( res )
print ('input:' , sess.run(input))
print('filter:', sess.run(filter))
def convTwo():
inp0 = np.array( [
[
[
[11.,21.,31.,41.,51.],[101.,201.,301.,401.,501.],[1001.,2001.,3001.,4001.,5001.]
],
[
[12., 22., 32., 42., 52.], [102., 202., 302., 402., 502.], [1002., 2002., 3002., 4002., 5002.]
],
[
[13., 23., 33., 43., 53.], [103., 203., 303., 403., 503.], [1003., 2003., 3003., 4003., 5003.]
]
]
] )
input0 = tf.Variable( inp0 )
fil = np.array( [
[
[
[1.],[1],[1],[1],[1]
]
]
] )
filter = tf.Variable(tf.random_normal([1 ,1 ,5 ,1]))
filter0 = tf.Variable(fil)
op = tf.nn.conv2d(input0, filter0, strides=[1, 1, 1, 1], padding='VALID')
dop = tf.nn.conv2d_transpose(op, filter0, output_shape = [1, 3, 3, 5] , strides=[1, 1, 1, 1], padding='VALID')
with tf.Session() as sess:
sess.run(tf.initialize_all_variables())
res = (sess.run(op))
print (res.shape)
print ( res )
res = (sess.run(dop))
print ('dres.shape ',res.shape)
print ( res )
'''
inputV0 = sess.run( input0.value() )
print ('input0:' , inputV0 )
print('input0 shape:', inputV0.shape)
print('filter:', sess.run(filter))
'''
convTwo()