python - 如何使用具有可变形状输入的 Keras Conv2D 层

标签 python machine-learning tensorflow neural-network keras

我有一个名为 X_train 的 NP 数组,具有以下属性:

X_train.shape = (139,)
X_train[0].shape = (210, 224, 3)
X_train[1].shape = (220,180, 3)

换句话说,有 139 个观察值。每个图像都有不同的宽度和高度,但它们都有 3 个 channel 。因此维度应为 (139, None, None, 3),其中 None = 变量。

由于您没有在图层中包含观测值数量的维度,因此对于 Conv2D 图层,我使用了 input_shape=(None,None,3)。但这给了我错误:

expected conv2d_1_input to have 4 dimensions, but got array with shape (139, 1)

我的猜测是,问题在于输入形状是 (139,) 而不是 (139, None, None, 3)。但我不确定如何转换为该值。

最佳答案

解决您的问题的一种可能的解决方案是用零填充数组,以便它们都具有相似的大小。之后,您的输入形状将类似于 (139, max_x_dimension, max_y_dimension, 3)

以下函数可以完成这项工作:

import numpy as np

def fillwithzeros(inputarray, outputshape):
    """
    Fills input array with dtype 'object' so that all arrays have the same shape as 'outputshape'
    inputarray: input numpy array
    outputshape: max dimensions in inputarray (obtained with the function 'findmaxshape')

    output: inputarray filled with zeros
    """
    length = len(inputarray)
    output = np.zeros((length,)+outputshape, dtype=np.uint8)
    for i in range(length):
        output[i][:inputarray[i].shape[0],:inputarray[i].shape[1],:] = inputarray[i]
    return output

def findmaxshape(inputarray):
    """
    Finds maximum x and y in an inputarray with dtype 'object' and 3 dimensions
    inputarray: input numpy array

    output: detected maximum shape
    """
    max_x, max_y, max_z = 0, 0, 0
    for array in inputarray:
        x, y, z = array.shape
        if x > max_x:
            max_x = x
        if y > max_y:
            max_y = y
        if z > max_z:
            max_z = z
    return(max_x, max_y, max_z)

#Create random data similar to your data
random_data1 = np.random.randint(0,255, 210*224*3).reshape((210, 224, 3))
random_data2 = np.random.randint(0,255, 220*180*3).reshape((220, 180, 3))
X_train = np.array([random_data1, random_data2])

#Convert X_train so that all images have the same shape
new_shape = findmaxshape(X_train)
new_X_train = fillwithzeros(X_train, new_shape)

关于python - 如何使用具有可变形状输入的 Keras Conv2D 层,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45320938/

相关文章:

python - Tensorflow 中 Theano 的 Theano.tensor.ivector 的等价性

python - mlxtendplot_decision_regions 模型适合 Pandas DataFrame?

python - 使用 Tensorflow Serving 服务 Keras 模型

python - 用于在 Python 中查找我连接到的所有网络适配器的脚本

python - 如何重新启动 python 脚本,无论它们退出或崩溃的原因如何?

python - 将离散值映射到颜色

python - 属性错误: 'NoneType' object has no attribute 'text' ?

arrays - 在 Julia 中将数组拆分为训练集和测试集的有效方法是什么?

python - 凯拉斯 - ValueError : The first layer in a Sequential model must get an `input_shape` or `batch_input_shape` argument

python - TensorFlow 2 自定义损失 : "No gradients provided for any variable" error