【问题标题】:How to specify filter in keras conv2d如何在 keras conv2d 中指定过滤器
【发布时间】:2018-01-16 08:01:16
【问题描述】:

我正在尝试在我的 Keras 模型中实现一个使用特定高斯滤波器的 conv2D 层。我有制作过滤器的代码,尽管现有的Keras Conv2D 没有过滤器本身的参数。相反,有一个filters 参数,它是一个指定输出空间维度的整数,以及kernel_size,它是一个指定内核维度的元组。

我已经尝试使用 Keras 后端的东西来解决这个问题,因为 conv2D 函数here 允许您按照我的意愿输入特定的过滤器。问题是我不知道如何将它恢复到我的模型中,所以我再次陷入困境。我还发现了与我类似的问题,例如 this 一个建议编写我自己的层,但我不确定我将如何去做,如果有更简单的方法,我希望避免它。

一如既往,非常感谢任何帮助。

【问题讨论】:

  • 你找到处理它的方法了吗?我有一个类似的用例。我需要在我的第一个 CNN 层中使用高斯和高斯导数滤波器,并学习它们的一些线性组合。但我不知道如何在我的第一层引入高斯。

标签: python filter keras convolution keras-layer


【解决方案1】:

长答案短:

你根本不需要卷积层

卷积层的目的是为您找到合适的过滤器。正如您已经知道要使用哪个过滤器一样,您可以愉快地跳过整个卷积层,直接跳到全连接层。

  1. 将高斯滤镜应用于您的图像。

  2. 使用 Flatten() 层将图像直接馈送到 MLP。

希望对您有所帮助。

【讨论】:

    【解决方案2】:

    我刚刚发布了对linked 问题的答案,但这里作为如何在 Keras 中应用自定义过滤器的示例可能很有用。对于您的高斯示例,请使用适用于 2D 的this 来获取过滤器,

    import numpy as np
    import scipy.stats as st
    
    def gkern(kernlen=[21,21], nsig=[3, 3]):
        """Returns a 2D Gaussian kernel array."""
    
        assert len(nsig) == 2
        assert len(kernlen) == 2
        kern1d = []
        for i in range(2):
            interval = (2*nsig[i]+1.)/(kernlen[i])
            x = np.linspace(-nsig[i]-interval/2., nsig[i]+interval/2., kernlen[i]+1)
            kern1d.append(np.diff(st.norm.cdf(x)))
    
        kernel_raw = np.sqrt(np.outer(kern1d[0], kern1d[1]))
        kernel = kernel_raw/kernel_raw.sum()
        return kernel
    
    import matplotlib.pyplot as plt
    plt.imshow(gkern([7,7]), interpolation='none')
    plt.show()
    

    然后您可以将其设置为初始过滤器并冻结该层,使其不再训练,看起来像这样,

    from keras.models import Sequential
    from keras.layers import Conv2D
    
    #Set Some Image
    image = [[4,3,1,0],[2,1,0,1],[1,2,4,1],[3,1,0,2]]
    
    # Pad to "channels_last" format 
    # which is [batch, width, height, channels]=[1,4,4,1]
    image = np.expand_dims(np.expand_dims(np.array(image),2),0)
    
    #Initialise to set kernel to required value
    def kernel_init(shape):
        kernel = np.zeros(shape)
        kernel[:,:,0,0] = gkern([shape[0], shape[1]])
        return kernel 
    
    #Build Keras model
    model = Sequential()
    #We would freeze training of the layers if we
    # wanted to keep a Gaussian filter
    Gausslayer = Conv2D(1, [3,3], kernel_initializer=kernel_init, 
                        input_shape=(4,4,1), padding="valid")
    Gausslayer.trainable = False
    model.add(Gausslayer)
    #Add some more layers here
    #model.add(Conv2D(...)
    model.build()
    
    # To apply existing filter, we use predict with no training
    out = model.predict(image)
    print(out[0,:,:,0])
    

    并且可以适应添加更多可训练的层。

    【讨论】:

    • 回溯(最近一次调用最后):文件“gkern.py”,第 48 行,在 model.add(Gausslayer) 文件“/usr/local/lib/python3.8/dist -packages/tensorflow/python/training/tracking/base.py”,第 517 行,在 _method_wrapper 结果 = 方法(self,*args,**kwargs)文件“/usr/local/lib/python3.8/dist-packages /tensorflow/python/keras/engine/sequential.py”,第 208 行,添加 layer(x) 文件“/usr/local/lib/python3.8/dist-packages/tensorflow/python/keras/engine/base_layer. py",第 946 行,在 call 中返回 self._functional_construction_call(inputs, args, kwargs,
    猜你喜欢
    • 2018-12-13
    • 1970-01-01
    • 2021-05-20
    • 2018-06-22
    • 1970-01-01
    • 2019-09-05
    • 2020-12-31
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多