【TensorFlow | 升级】TensorFlow 1.0 发布

前面写了 TensorFlow 在Windows上的安装教程,当时版本还是 0.12 。

NOW

首届 TensorFlow 开发者大会(TensorFlow Dev Summit)已于美国时间昨日召开,YouTube 还进行了直播。更重要的是,TensorFlow 1.0 版本发布。Google Research Blog 也于昨天在 博客 中公布了这一消息。

这里写图片描述


改动

这一版本的改动还是比较大的,很多旧的 API 都已经不再使用。在 博客 中可以看到 1.0 版本更快、更灵活、更稳定(production-ready) 。TensorFlow 1.0 版本保证 Python API 的稳定性,即使以后添加新的特性也不用担心会破坏现有代码。

博客中提到的其他新版本两点(为避免翻译造成的偏差,我就直接引用原文了):

  • Python APIs have been changed to resemble NumPy more closely. For this and other backwards-incompatible changes made to support API stability going forward, please use our handy migration guide and conversion script.
  • Experimental APIs for Java and Go
  • Higher-level API modules tf.layers, tf.metrics, and tf.losses - brought over from tf.contrib.learn after incorporating skflow and TF Slim
  • Experimental release of XLA, a domain-specific compiler for TensorFlow graphs, that targets CPUs and GPUs. XLA is rapidly evolving - expect to see more progress in upcoming releases.
  • Introduction of the TensorFlow Debugger (tfdbg), a command-line interface and API for debugging live TensorFlow programs.
  • New Android demos for object detection and localization, and camera-based image stylization.
  • Installation improvements: Python 3 docker images have been added, and TensorFlow’s pip packages are now PyPI compliant. This means TensorFlow can now be installed with a simple invocation of pip install tensorflow.

升级

升级很简单(在这里感谢一下为简化 TensorFlow 安装过程的工程师们),就是一行语句,这也是安装命令:

对于 GPU 版本:

pip3 install --upgrade tensorflow-gpu

对于 CPU 版本:

pip3 install --upgrade tensorflow

升级过程
右键在新标签页打开图片可查看大图

输入完回车就开始升级过程,会下载并卸载重装一些必要的包,时间长短视网速而定。


更新你的旧代码

有两种方法更新你的代码,一种就是我上面提到的用脚本自动升级,另一种就是手动更改,具体可以参考 这里

使用脚本

由于版本改动较大,TensorFlow 甚至出了一个 tf_upgrade.py 脚本来帮助你更新代码,从 这里 获取这份代码,或者点击 这里 直接下载。

对于更新单个文件,可以使用下面的命令:

python tf_upgrade.py --infile InputFile --outfile OutputFile

其中 InputFileOutputFile 分别为你的旧代码和新代码,根据你的文件名做相应的替换。例如我的旧代码是 test.py,将要生成的新代码是 test_1.0.py,则:

python tf_upgrade.py --infile test.py --outfile test_1.0.py

同时,tf_upgrade.py 会生成一个名为 report.txt 的文件,该文件记录了对旧文件做的所有改动,同时也给出了可能需要你手动更改的建议。

对于文件夹(目录),和单个文件类似,使用

python tf_upgrade.py --intree InputDir --outtree OutputDir

例如,我的 programs 位于 /home/user/cool 目录,新的生成的文件我想放到 /home/user/cool_1.0 里,则

python tf_upgrade.py --intree /home/user/cool --outtree /home/user/cool_1.0

手动更改

除了使用脚本自动更新外,还可以使用手动替换的方式。需要替换的东西有很多,我就不一一列举了,大家可以参考 官网


END

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
### 回答1: 要在TensorFlow 2.中运行1.代码,您需要使用TensorFlow 1.x兼容性模块。这个模块可以让您在TensorFlow 2.中使用1.代码,但是您需要注意一些细节,例如变量初始化和会话管理。您可以使用以下代码导入兼容性模块: ``` import tensorflow.compat.v1 as tf tf.disable_v2_behavior() ``` 然后,您可以使用1.代码,例如: ``` x = tf.placeholder(tf.float32, shape=[None, 784]) W = tf.Variable(tf.zeros([784, 10])) b = tf.Variable(tf.zeros([10])) y = tf.nn.softmax(tf.matmul(x, W) + b) ``` 请注意,您需要使用`tf.Session()`来运行计算图: ``` with tf.Session() as sess: sess.run(tf.global_variables_initializer()) result = sess.run(y, feed_dict={x: input_data}) ``` 希望这可以帮助您在TensorFlow 2.中运行1.代码。 ### 回答2: 在TensorFlow 2.0中运行1.0版本的代码有一些注意事项。由于TensorFlow 2.0是向后兼容的,可以运行1.0版本的代码,但需要进行一些修改。TensorFlow 2.0默认使用了eager execution(即即时执行)模式,而1.0版本默认使用了静态图模式。以下是几个需要注意的地方: 1. 导入库:在TensorFlow 2.0中,需要使用`import tensorflow.compat.v1 as tf`来导入1.0版本tensorflow库。这样可以确保使用1.0版本的API和函数。 2. 静态图模式:TensorFlow 2.0的默认模式是即时执行模式(eager execution),如果想要使用1.0版本的静态图模式,需要使用`tf.compat.v1.disable_eager_execution()`来禁用即时执行。 3. placeholder:在TensorFlow 2.0中,`tf.placeholder`已经被移除了。可以使用`tf.compat.v1.placeholder`来代替。 4. Session:在TensorFlow 2.0中,可以直接运行张量,不再需要Session。如果代码中有`Session`相关的操作,需要将其修改为直接执行相应的操作。 5. 变量声明:在TensorFlow 2.0中,`tf.Variable`的默认行为有一些变化。如果想要使用1.0版本的变量声明行为,可以使用`tf.compat.v1.Variable`来代替。 需要注意的是,并非所有1.0版本的代码都可以无修改地在2.0版本上运行,特别是那些使用了一些被废弃的API和函数的代码。因此,在运行1.0版本的代码时,需要根据代码的具体情况进行相应的修改和调整,以确保代码在TensorFlow 2.0上能够正常运行。 ### 回答3: TensorFlow 2.0是相对于早期版本的重大升级,其中包含了许多新特性和改进。因此,如果要在TensorFlow 2.0中运行1.0的代码,可能会遇到一些兼容性问题。以下是一些可能需要处理的问题: 1. 语法差异:TensorFlow 2.0对许多API进行了重大的修改和重命名。因此,1.0版本的代码可能包含已被弃用或删除的函数和参数。需要修改代码以适应新的API。 2. Eager Execution:TensorFlow 2.0默认启用了Eager Execution,这是一个即时执行模式。而1.0版本默认使用的是图计算模式。因此,在运行1.0代码时,可能需要禁用Eager Execution或者修改代码以适应新的执行模式。 3. Keras集成:TensorFlow 2.0将Keras作为其主要的高级API。因此,如果1.0代码使用了其他的高级API,可能需要将其转换为Keras的形式,并使用新的Keras API进行模型构建和训练。 4. 数据集处理:TensorFlow 2.0引入了tf.data API,用于高效处理和预处理数据集。1.0版本中的代码可能使用了不同的数据处理方式,需要修改以适应新的API。 总之,将1.0代码迁移到TensorFlow 2.0需要根据具体的代码进行相应的调整和修改,以适应新版本的语法和功能。但是,由于TensorFlow团队一直致力于保持向后兼容性,因此许多代码可以在2.0版本中无修改地继续运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

secsilm

来一根火腿?

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值