ValueError:检查输入时出错:预期 input_1 有 4 个维度,但得到的数组具有形状(无、无、无)

Posted

技术标签:

【中文标题】ValueError:检查输入时出错:预期 input_1 有 4 个维度,但得到的数组具有形状(无、无、无)【英文标题】:ValueError: Error when checking input: expected input_1 to have 4 dimensions, but got array with shape (None, None, None) 【发布时间】:2021-12-03 12:58:30 【问题描述】:

我是 Tensorflow 的新手,我尝试使用 CNN 对 PDF 文件进行分类,方法是将其转换为图像并将其提供给模型。 我使用 keras(使用 this tutorial)创建了一个自定义 DataGenerator,运行 model.fit() 时出现 ValueError。

我运行 model.summary() 时的输入层是:input_1 (InputLayer) [(None, 224, 224, 3)]

以下是我的 __ getitem __ 和 __data_generation 代码:

    def __getitem__(self, index):
    index = self.index[index * self.batch_size:(index + 1) * self.batch_size]
    batch = [self.indices[k] for k in index]
    X, y = self.__data_generation(batch)
    return X, y

    def __data_generation(self, batch):
        df = self.df
        X = np.empty((self.batch_size, *self.dim))
        y = np.empty((self.batch_size), dtype=int)
        for i, id in enumerate(batch):
            
            # Loading the image :
            doc_row = df.loc[i]
            path = str(doc_row['PATH'])
            path = os.path.join(dataset_path,path)
            typologie = str(doc_row['TYPOLOGIE'])
            img_i = convert_from_path(path)[0]

            # Converting the image :
            img_i = img_i.resize((224,224), Image.ANTIALIAS)
            gray_img_i = ImageOps.grayscale(img_i)
            array_image_i = np.array(gray_img_i,dtype='float32')
            array_image_i = np.expand_dims(array_image_i, axis=0)
            X[i,] = array_image_i
            y[i] = self.map_classes[typologie]
        X = [np.array(X)]
        Y = np.array(y)
        Y = tf.keras.utils.to_categorical(Y, num_classes = self.num_classes)
        return X, Y

ValueError:检查输入时出错:预期 input_1 有 4 个维度,但得到的数组具有形状(无、无、无)

我尝试按照here 的建议使用 np.expand_dims(),但这并没有解决我的问题。

我怀疑转换部分不好,但我不知道问题出在哪里。

【问题讨论】:

如果您在“X = [np.array(X)]”行之前打印它,您能否提供“np.shape(np.array(X))”的输出?跨度> @MarcFelix 形状为 (1, 224, 224)。刚刚查了一下发现错误,谢谢!我需要删除灰度以获得正确的形状 【参考方案1】:

我在这段代码中犯了 2 个错误:

    我换了

    gray_img_i = ImageOps.grayscale(img_i)
    array_image_i = np.array(gray_img_i,dtype='float32')
    

    作者:

    array_image_i = np.array(img_i,dtype='float32')
    

通过这样做,我将每个图像的形状从 (1, 224, 224) 更改为 (1, 224, 224, 3)。 形状中的“3”表示我需要一张 RGB 图像(每张图像 3 个通道),因此去除灰度非常有用!

    我换了

    doc_row = df.loc[i]
    

    作者:

    doc_row = df.loc[id]
    

我在 for 循环中颠倒了 iid

【讨论】:

以上是关于ValueError:检查输入时出错:预期 input_1 有 4 个维度,但得到的数组具有形状(无、无、无)的主要内容,如果未能解决你的问题,请参考以下文章

ValueError:检查输入时出错:预期的dense_26_input具有形状(45781,)但得到的数组具有形状(2,)

ValueError:检查输入时出错:预期 input_1 有 4 个维度,但得到的数组具有形状(无、无、无)

model.fit 给出 ValueError :检查输入时出错:预期的 conv2d 得到了形状为 () 的数组

ValueError:检查输入时出错:预期dense_11_input 具有3 维,但得到了形状为(0, 1) 的数组

ValueError:检查输入时出错:预期 lstm_1_input 具有 3 个维度,但得到的数组具有形状 (393613, 50)

ValueError:检查输入时出错:预期 permute_input 有 4 个维度,但得到了形状为 (1, 4) 的数组