实际上,我发现这个问题已经存在于 TensorFlow 1.13.0 版本中(tensorflow1.12.0 版本运行良好)。
以下是我的代码示例:
def Lambda layer(temp):
print(temp)
return temp
它是我Keras模型中使用的一个lambda层。在tensorflow1.12.0中,print(temp)
可以输出以下详细数据
[<tf.Tensor: id=250, shape=(1024, 2, 32), dtype=complex64, numpy=
array([[[ 7.68014073e-01+0.95353246j, 7.01403618e-01+0.64385843j,
8.30483198e-01+1.0340731j , ..., -8.88018191e-01+0.4751519j ,
-1.20197642e+00+0.6313924j , -1.03787208e+00+0.22964947j],
[-7.94382274e-01+0.56390345j, -4.73938555e-01+0.55901265j,
-8.73749971e-01+0.67095983j, ..., -5.81580341e-01-0.91620034j,
-7.04443693e-01-1.2709806j , -3.23135853e-01-1.0887597j ]],
这是因为我使用了1024作为batch_size。但当我更新到tensorflow1.13.0或TensorFlow 2.0时,相同代码的输出
Tensor("lambda_1/truediv:0", shape=(None, 1), dtype=float32)
这很糟糕,因为我无法知道具体的错误。 那么,有什么解决方法吗?