场景:

读取已保存的TfRecords文件, 在解析数组数据时,解析出来的数组长度是该原数组长度的2倍,导致无法正确reshape

问题描述

tensorflow.python.framework.errors_impl.InvalidArgumentError: 2 root error(s) found.
(0) Invalid argument: Input to reshape is a tensor with 110592 values, but the requested shape has 55296

原因:

tensorflow默认的float数据是32位的,也就是tf.float32, 而python中numpy数组的float数据默认是64位的,也就是np.float64, 所以保存64位数组数据后,再用tensorflow解析时会将64位的数据解析成两个32位的数据,导致数据长度变成2倍,与原数组shape不匹配。

解决方案

在将数组数据写入TfRecords文件时,先将数组数据类型改成np.float32,如数组arr:
arr = arr.astype(np.float32)

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐