解卷积

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()

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值