tensorflow与高版本numpy不兼容的问题

当Tensorflow与高于1.16.0版本的NumPy配合使用时,会出现FutureWarning。解决方法包括降级NumPy到1.16.0或直接修改Tensorflow源码。降级后,系统能正常运行;若选择修改代码,在`dtypes.py`和`tensorboard/compat/tensorflow_stub/dtypes.py`中,将涉及的dtype定义修改,添加括号和逗号解决警告。
部署运行你感兴趣的模型镜像

下载tensorflow:

pip install tensorflow -i https://pypi.tuna.tsinghua.edu.cn/simple/

执行

import tensorflow as tf

会提示

~/python3.6/site-packages/tensorflow/python/framework/dtypes.py:516: 
FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; 
in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.
  _np_qint8 = np.dtype([("qint8", np.int8, 1)])

检查版本

print(tf.__version__)
print(numpy.__version__)

 结果:

tensorflow版本 1.14.0

numpy版本1.19.5

发现原因:numpy版本太高

解决方式有两种:降低numpy版本、修改tensorflow对应行代码

两种方式都试过了,都是可行的。

1. 降低numpy版本

numpy降到1.16.0就能正常运行

先卸载

pip uninstall numpy

再下载低版本

pip install numpy==1.16.0 -i https://pypi.tuna.tsinghua.edu.cn/simple/

2.修改对应行代码

因为先尝试了第一种方法,numpy已经被降到了1.16.0,现需要将numpy升级回1.19.5

pip install -U numpy -i https://pypi.tuna.tsinghua.edu.cn/simple/

编辑提示中的文件,修改报错的行。

如先修改文件 ~/site-packages/tensorflow/python/framework/dtypes.py 的516行:

_np_qint8 = np.dtype([("qint8", np.int8,1)])

修改为

_np_qint8 = np.dtype([("qint8", np.int8,(1,))])

* 修改内容:添加括号和逗号 _np_qint8 = np.dtype([("qint8", np.int8,(1,))])

我的提示中有两个文件:

~/site-packages/tensorflow/python/framework/dtypes.py

~/site-packages/tensorboard/compat/tensorflow_stub/dtypes.py

两个都修改完之后就可以愉快的使用了~

您可能感兴趣的与本文相关的镜像

TensorFlow-v2.15

TensorFlow-v2.15

TensorFlow

TensorFlow 是由Google Brain 团队开发的开源机器学习框架,广泛应用于深度学习研究和生产环境。 它提供了一个灵活的平台,用于构建和训练各种机器学习模型

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值