- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经在互联网上搜索了几天,试图找到此错误的解决方案,但我找不到特别适用的:
ValueError: Error when checking target: expected dense_2 to have shape (300,) but got array with shape (60,)
这是生成错误的代码(数据预处理除外):
model = keras.Sequential([
keras.layers.Conv1D(5,input_shape=(1,60), kernel_size=12, padding='same'),
keras.layers.Conv1D(10, padding='same',activation=tf.nn.relu, kernel_size=10),
keras.layers.Conv1D(20, padding='same',activation=tf.nn.relu, kernel_size=6),
keras.layers.Conv1D(30, padding='same',activation=tf.nn.relu, kernel_size=5),
keras.layers.Flatten(),
keras.layers.Dense(70, activation="relu"),
keras.layers.Dense(300,activation="tanh")
])
model.compile(optimizer=tf.train.AdamOptimizer(0.001),
loss='mse',
metrics=['mae'])
model.fit(traindata,trainlabels, epochs=10, batch_size=int(len(traindata)/60))
我不太确定导致此错误的原因,但我做了一些故障排除以尝试缩小可能性。
我尝试的第一件事是尝试运行 TensorFlow 网站上的一个示例,我选择了位于 here 的 MNIST 时尚示例.
它运行时没有错误,并且训练得很好,所以我不认为这是我的 TensorFlow 或 Python 下载中的错误。
然后,我尝试复制 MNIST 时尚示例中使用的模型来测试我的模型中是否存在错误。这是代码:
model = keras.Sequential([
keras.layers.Flatten(input_shape=(60,)),
keras.layers.Dense(128, activation=tf.nn.relu),
keras.layers.Dense(10, activation=tf.nn.softmax)
])
model.compile(optimizer=tf.train.AdamOptimizer(),
loss = 'sparse_categorical_cross_entropy',
metrics = ['accuracy']
)
我对模型所做的唯一更改是第一层的输入形状,这样它就能够接收我的数据。但是错误仍然存在:
ValueError: Error when checking target: expected dense_1 to have shape (10,) but got array with shape (60,)
我尝试的最后一件事是制作自己的密集模型,该模型将采用通过np.random.random
创建的虚拟数据。
这是整个文件:
import tensorflow as tf
from tensorflow import keras
import numpy as np
import matplotlib.pyplot as plt
data = np.random.random((50,60))
datalabels = np.random.random((50,60))
model = keras.Sequential([
keras.layers.Dense(128,input_shape=(60,), activation="relu"),
keras.layers.Dense(50, activation="relu"),
keras.layers.Dense(10, activation="tanh")
])
model.compile(optimizer=tf.train.AdamOptimizer(),
loss="mae",
metrics=['mse'])
model.fit(data, datalabels, epochs=5, batch_size=10)
这也收到了错误,我很困惑为什么,但我认为这可能与我的虚拟数据的生成有关
ValueError: Error when checking target: expected dense_2 to have shape (10,) but got array with shape (60,)
如果有帮助的话,我打印了最后一个模型的所有图层及其输入和输出形状:
Layer: dense
input_shape: (None, 60)
output_shape: (None, 128)
Layer: dense_1
input_shape: (None, 128)
output_shape: (None, 50)
Layer: dense_2
input_shape: (None, 50)
output_shape: (None, 10)
这个错误最让我困惑的是它只在输出层上出现错误。如果我在模型的末尾添加另一层,该层将出错,除非输出层中的单元数等于模型输入的形状(例如:使用 input_shape=(60,)
最后一层单元的数量等于 60)。有谁知道为什么会发生这种情况?
最佳答案
使用model.summary()
,您将看到每层的输出形状。在您提供的第一个示例中,最后一层的输出形状(也是模型的输出形状)为(None, 300)
。这意味着它期望形状为 (300,)
的标签(即每个标签的形状)。但是,您在调用 fit
时向模型提供的标签数组(即 trainlabels
)似乎具有 (num_samples, 60)
的形状。然而,它必须与模型的输出形状一致,因此形状为(num_samples, 300)
。同样的事情也适用于你提到的所有其他失败的例子。
关于python - TensorFlow/Keras : shape error on output layer,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53678978/
我正在用 C 语言实现一个带有输入和输出重定向的 shell。我可以成功进行输入重定向,但输出重定向不起作用。例如,如果我执行 ls > out.txt,则 out.txt 包含文本“out.txt”
我正在处理创建 AWS API 网关。我正在尝试创建 CloudWatch Log 组并将其命名 API-Gateway-Execution-Logs_${restApiId}/${stageName
我正在修改原作者使用数组构建网页的一些代码: $output[]=$stuff_from_database; $output[]='more stuff'; // etc echo join(
我只想知道它们之间的区别: sort < output 和 sort output 在 Linux 中。它是如何工作的? 最佳答案 这已经在 unix.stackexchange 上讨论过:Perfo
我正在生成外部控制台应用程序并使用异步输出重定向。 as shown in this SO post 我的问题是,在我收到 OutputDataReceived 事件通知之前,生成的进程似乎需要产生一
在 Udemy 上开设类(class)时,我们一直允许使用组件类中的 @Input() 装饰器向组件传递数据。 在阅读 ngBook-2 时,我发现还有另一种方法,即在 @Component 装饰器中
考虑一个 Linux 服务器,它在您的用户的 .bash_profile 中有以下行: echo "Hello world" 因此,每次您通过 ssh 进入它时,您都会看到 Hello world 现
public static void main(String[] args) { String input = new String(JOptionPane.showInputDialog("
我正在使用 MSVS 2008 中的 FFTW3 库对某些数据执行 r2c DFT (n=128)。我已经发现只使用了真实数据 DFT 输出的前半部分……如果我查看我的输出,这似乎是正确的: 0-64
我制作了一个 C 程序,可以从二进制文件中打印出很多值。我相信程序完成它的功能并在它实际显示它吐出的值之前结束。因此,结果我得到了一个可爱的 RUN SUCCESSFUL(总时间:198ms) 突然出
在 hadoop 作业计数器中,“映射输出具体化字节”与“映射输出字节”之间有什么区别?当我禁用映射输出压缩时我没有看到前者所以我猜它是真正的输出字节(压缩)而后者是未压缩的字节? 最佳答案 我认为你
有很多 Stack Overflow 文章与此相关,但没有直接的答案。 这条命令会输出一堆单词 OutputVariable.exe %FILEPATH% 输出: Mary had a little
互联网上的许多文章都使用“标准输入/输出/错误流”术语好像每个术语都与使用的“标准输入/输出/错误设备”术语具有相同的含义在其他文章上。例如,很多文章说标准输出流默认是监视器,但可以重定向到文件、打印
我在 Keras 中使用一些 tensorflow 函数(reduce_sum 和 l2_normalize)在最后一层构建模型时遇到了这个问题。我已经搜索了一个解决方案,但所有这些都与“Keras
我有来自 API 的自定义输出,我想将其格式化为带有一些颜色值的字符串。 最佳答案 输出 channel 可以用 TmLanguage grammar 着色. Output Colorizer扩展扩展
我正在寻找一种方法来查看虚拟机创建过程中发生的情况,因为我使用复杂的集群配置并测试其是否正常工作,我需要能够查看输出,在某些情况下我是不是因为敏感。这与运行remote-exec选项有关 module
当谷歌搜索此错误时没有看到任何相关结果,所以我想发布它。 stack build Building all executables for `gitchapter' once. After a suc
假设module_a里面有register_a,它需要链接到module_b。 register_a 是否应该单独声明并分配给 module_a 的输出: reg register_a; assign
我正在寻找一种方法来查看虚拟机创建过程中发生的情况,因为我使用复杂的集群配置并测试其是否正常工作,我需要能够查看输出,在某些情况下我是不是因为敏感。这与运行remote-exec选项有关 module
输入文件如下 eno::ename::dept::sal 101::emp1::comp1::2800000 201::emp2::comp2::2800000 301::emp3::comp3::3
我是一名优秀的程序员,十分优秀!