TensorFlow推出命令式、可定义的运行接口Eager Execution

简介:
本文来自AI新媒体量子位(QbitAI)

今天凌晨,谷歌宣布推出TensorFlow的eager execution。这是一个命令式的、可定义的运行接口,它们由Python调用,可用来立即执行操作。

简单来说,eager execution有四大优势:

  • 立即快速调试运行错误并与Python工具集成
  • 支持用易用Python控制流的动态模型
  • 支持自定义和高阶梯度
  • 几乎所有TensorFlow操作均可用

我们可以通过一些代码更好理解eager execution,这是很技术的问题,熟悉TensorFlow将帮你更好理解。

使用eager execution

当启用eager execution时,操作将立即执行并将值返回给Python,无需调用session.run()。例如,把两个矩阵相乘,写出来是这样的:

用print或Python调试程序检查中间结果也很简单:

此外,还可以用Python flow控制构建动态模型。这是考拉兹猜想(Collatz conjecture)的一个例子,用到了TensorFlow中算术运算:

在这种情况下,用tf.constant(12)张量对象(即代码中的Tensor对象)将把所有数学运算推广到张量运算,并且所有返回值都是张量。

编写代码新变化

使用eager execution应该对当前TensorFlow用户来说更直观了。原因有多种,比如里面只有少数eager-specific API,并且大多数现有API和操作都支持eager。值得注意的还有以下几点:

  • 如果你还没用过tf.data做输入处理,应该着手学习一下了。它更容易使用,并且通常处理速度更快。

tf.data介绍

https://developers.googleblog.com/2017/09/introducing-tensorflow-datasets.html

  • 在使用如tf.layer.Conv2D()或Keras等面向对象的层时,它们可以显式存储变量。
  • 对大多数模型来说,你可以编写代码让它作用于eager execution和构建计算图。也有例外情况,比如用Python控制流根据输入改变计算。
  • 一旦调用了tfe.enable_eager_execution(),就无法关闭。如要获取计算图行为,需要启动新的Python会话。

参考资料及下载

谷歌研究博客地址:

https://research.googleblog.com/2017/10/eager-execution-imperative-define-by.html

GitHub代码地址:

https://github.com/tensorflow/tensorflow/blob/master/tensorflow/contrib/eager/README.md

代码使用手册:

https://github.com/tensorflow/tensorflow/blob/master/tensorflow/contrib/eager/python/g3doc/guide.md

祝你玩得开心~

本文作者:安妮
原文发布时间:2017-11-01
相关文章
|
8月前
|
Ubuntu 定位技术 TensorFlow
源码编译安装ROCm以运行tensorflow-rocm(适用于Ubuntu 23.04)
总结一番,完成这趟奇妙的技术之旅后,乐趣多多,还能享受 tensorflow-rocm 带来的便利和速度。这趟旅程需要耐心,勇气,以及对技术的热爱。朋友,做好准备,让你的Ubuntu系统展翅高飞吧!
452 9
|
TensorFlow 算法框架/工具 Python
TensorFlow2 Eager Execution模式
【8月更文挑战第18天】TensorFlow2 Eager Execution模式。
1857 9
|
TensorFlow API 算法框架/工具
【Tensorflow】解决Inputs to eager execution function cannot be Keras symbolic tensors, but found [<tf.Te
文章讨论了在使用Tensorflow 2.3时遇到的一个错误:"Inputs to eager execution function cannot be Keras symbolic tensors...",这个问题通常与Tensorflow的eager execution(急切执行)模式有关,提供了三种解决这个问题的方法。
191 1
|
机器学习/深度学习 TensorFlow API
Keras是一个高层神经网络API,由Python编写,并能够在TensorFlow、Theano或CNTK之上运行。Keras的设计初衷是支持快速实验,能够用最少的代码实现想法,并且能够方便地在CPU和GPU上运行。
Keras是一个高层神经网络API,由Python编写,并能够在TensorFlow、Theano或CNTK之上运行。Keras的设计初衷是支持快速实验,能够用最少的代码实现想法,并且能够方便地在CPU和GPU上运行。
|
分布式计算 并行计算 Hadoop
Tensorflow目标检测接口配合tflite量化模型(二)
Tensorflow目标检测接口配合tflite量化模型
554 0
Tensorflow目标检测接口配合tflite量化模型(二)
|
XML 存储 TensorFlow
Tensorflow目标检测接口配合tflite量化模型(一)
Tensorflow目标检测接口配合tflite量化模型
351 0
Tensorflow目标检测接口配合tflite量化模型(一)
|
Ubuntu Shell TensorFlow
TensorFlow Lite开发系列之C++接口解析(二)
TensorFlow Lite开发系列之C++接口解析
448 0
TensorFlow Lite开发系列之C++接口解析(二)
|
Linux TensorFlow 算法框架/工具
TensorFlow Lite开发系列之python接口解析(一)
环境: tensorflow2.x, 一定要使用linux系统,后期转换模型windows会出现bug
416 0
TensorFlow Lite开发系列之python接口解析(一)
|
XML 人工智能 TensorFlow
OpenVINO运行Tensorflow模型
OpenVINO运行Tensorflow模型
OpenVINO运行Tensorflow模型
|
PyTorch TensorFlow 算法框架/工具
斯坦福tensorflow教程(四) 贪婪执行Eager Execution
TensorFlow饱受诟病的痛点就是只支持静态图模型。也就是说,在处理数据前必须预先定义好一个完整的模型。如果数据非常规整,那还好。但实际工程和研究项目中的数据,难免有一些边角的情况。很多项目,其实需要大量实验才能选择正确的图模型。这就很痛苦了。因此,很多项目转而采用了PyTorch等支持动态图模型的框架,以便在运行程序的时候动态修正模型。
225 0
斯坦福tensorflow教程(四) 贪婪执行Eager Execution