python - tf.layers.conv2d 和 tf.layers.Conv2D 有什么区别?

标签 python tensorflow

tf.layers.conv2dtf.layers.Conv2D 有什么区别?

为什么 tf.layers.Conv2D 在此 paper 的示例代码中使用?

这是一个完整的代码片段:

class AddCoords(base.Layer):
    """Add coords to a tensor"""
    def __init__(self, x_dim=64, y_dim=64, with_r=False):
        super(AddCoords, self).__init__()
        self.x_dim = x_dim
        self.y_dim = y_dim
        self.with_r = with_r

    def call(self, input_tensor):
        """
        input_tensor: (batch, x_dim, y_dim, c)
        """
        batch_size_tensor = tf.shape(input_tensor)[0]
        xx_ones = tf.ones([batch_size_tensor, self.x_dim], dtype=tf.int32)
        xx_ones = tf.expand_dims(xx_ones, -1)
        xx_range = tf.tile(tf.expand_dims(tf.range(self.x_dim), 0), [batch_size_tensor, 1])
        xx_range = tf.expand_dims(xx_range, 1)
        xx_channel = tf.matmul(xx_ones, xx_range)
        xx_channel = tf.expand_dims(xx_channel, -1)
        yy_ones = tf.ones([batch_size_tensor, self.y_dim], dtype=tf.int32)
        yy_ones = tf.expand_dims(yy_ones, 1)
        yy_range = tf.tile(tf.expand_dims(tf.range(self.y_dim), 0), [batch_size_tensor, 1])
        yy_range = tf.expand_dims(yy_range, -1)
        yy_channel = tf.matmul(yy_range, yy_ones)
        yy_channel = tf.expand_dims(yy_channel, -1)
        xx_channel = tf.cast(xx_channel, 'float32') / (self.x_dim - 1)
        yy_channel = tf.cast(yy_channel, 'float32') / (self.y_dim - 1)
        xx_channel = xx_channel*2 - 1
        yy_channel = yy_channel*2 - 1
        ret = tf.concat([input_tensor, xx_channel, yy_channel], axis=-1)
        if self.with_r:
            rr = tf.sqrt(tf.square(xx_channel-0.5) + tf.square(yy_channel-0.5))
            ret = tf.concat([ret, rr], axis=-1)
        return ret

class CoordConv(base.Layer):
    """CoordConv layer as in the paper."""
    def __init__(self, x_dim, y_dim, with_r, *args, **kwargs):
        super(CoordConv, self).__init__()
        self.addcoords = AddCoords(x_dim=x_dim, y_dim=y_dim, with_r=with_r)
        self.conv = tf.layers.Conv2D(*args, **kwargs)
        def call(self, input_tensor):
            ret = self.addcoords(input_tensor)
            ret = self.conv(ret)
            return ret

最佳答案

tf.layers.conv2d 是一个简单的函数/方法来计算其输入的卷积,所以它需要输入特征映射kernelfilter 来运行这个方法。一个用户只是调用这个方法来计算卷积。
但是tf.layers.Conv2d是一个Class(一个面向对象的概念),在使用它之前,你应该用特定的filter实例化它。实例化后,您可以向其输入不同的输入并获得输出。一个使用这个 Class 来设计和编写一个新的 Class 或一种新的操作类型供其他用户使用。

关于python - tf.layers.conv2d 和 tf.layers.Conv2D 有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52011509/

相关文章:

tensorflow - 使用 LSTM 从单元素序列进行预测

python - Pandas - 如何根据两个 DataFrame 之一给出的顺序对它们进行排序?

python - 如何从字符串列表中导出二进制数组

python - 如何使用 Python 删除文件夹中除最后 5 个项目之外的所有文件

python - keras:未启用急切执行时,张量对象不可迭代

tensorflow - 在tf-slim中实现混合精度训练

python - 从右开始累计

python - 仅使用字母的名称输入验证

python - 为什么tensorflow中的 `tf.nn.nce_loss`无法在GPU上运行?

python - 如何高效更新 Keras 变量切片?