当前位置: 首页 > 编程日记 > 正文

我们期待的TensorFlow 2.0还有哪些变化?

640?wx_fmt=jpeg


来源 | Google TensorFlow 团队


为提高 TensorFlow 的工作效率,TensorFlow 2.0 进行了多项更改,包括删除了多余的 API,使API 更加一致统一,例如统一的 RNNs (循环神经网络),统一的优化器,并且Python 运行时更好地集成了 Eager execution 。


许多 RFC 已经对 TensorFlow 2.0 的这些更改给出了解释。本指南基于您对 TensorFlow 1.x 有一定的了解的前提,为您介绍在 TensorFlow 2.0 中的开发有什么不同。


API 整理


在 TensorFlow 2.0 中,有许多 1.X 的 API 被删除或移动 了。也有部分 1.X 的 API 被 2.0 版本的等价 API 所替代:tf.summary,tf.keras.metrics 和 tf.keras.optimizers。自动应用这些重命名,最简单的方法是使用 TensorFlow 2.0 升级脚本。


Eager execution


TensorFlow 1.X 要求用户通过调用 tf.* API 手动的将抽象语法树(图)拼接在一起。然后,它要求用户将一组输出张量和输入张量传递给 session.run() 调用,来手动编译抽象语法树。相比之下,TensorFlow 2.0 executes eagerly(如正常使用 Python 一样)在 2.0 的版本中,其 graphs(抽象语法树)和 sessions 在实现的细节上应该是一样的。


不再有全局变量


TensorFlow 1.X 非常依赖于隐式全局命名空间。当你调用 tf.Variable 时,它会被放入默认图中,即使你忘记了指向它的 Python 变量它也会留在那里。这时,您可以恢复该 tf.Variable(),但前提是您得知道它已创建的名称。如果您无法控制变量的创建,很难做到这一点。因此,各种机制以及寻找用户创建变量的框架不断涌现,试图帮助用户再次找到他们的变量。


TensorFlow 2.0 取消了所有这些机制(Variables 2.0 RFC),支持默认机制:跟踪变量! 如果你不再用到某个 tf.Variable,它就会被回收。


Functions, not sessions


session.run() 的调用几乎类似于函数调用:指定输入和要调用的函数,然后返回一组输出。在 TensorFlow 2.0 中,您可以使用 tf.function() 来修饰 Python 函数以将其标记为 JIT( Just-In-Time )编译,以便 TensorFlow 将其作为单个图运行(Functions 2.0 RFC)。


这种机制使得 TensorFlow 2.0 拥有图模式的许多优点:


  • 性能:该函数可以被优化,例如节点修剪,内核融合等

  • 可移植性:该函数可以导出 / 重新导入(SavedModel 2.0 RFC),允许用户重用和将 TensorFlow 函数作为模块共享


# TensorFlow 1.X

outputs = session.run(f(placeholder), feed_dict={placeholder: input})# TensorFlow 2.0

outputs = f(input)


由于能够自由地穿插 Python 和 TensorFlow 代码,您能够充分利用 Python 的表现力。而且,可移植的 TensorFlow 在没有 Python 解释器的情况下也可执行。比如:mobile,C ++ 和 JS。避免用户在添加 @tf.function 时重写代码,AutoGraph 会将 Python 构造的一个子集转换成 TensorFlow 等价物。


TensorFlow 2.0 常用的建议


将代码重构为更小的函数


TensorFlow 1.X 中的常见使用模式是 “kitchen sink” 策略,即预先列出所有可能计算的并集,然后通过 session.run() 计算选定的张量。在 TensorFlow 2.0 中,用户应该根据需求将代码重构为更小的函数。通常情况下,没有必要用 tf.function 来修饰这些较小的函数;仅使用 tf.function 来修饰高级计算 — 例如,使用只有一个步骤的训练或使用模型的正向传递,将代码重构为更小的函数。


使用 Keras 层和模型来管理变量


Keras 模型和层提供了方便的变量和 trainable_variables 属性,以递归方式收集所有因变量。这使得本地化管理变量非常方便。


Keras 层 / 模型继承自 tf.train.Checkpointable 并与 @ tf.function 集成,这使得直接检查点或从 Keras 对象导出 SavedModel 成为可能。您不一定要使用 Keras 的 fit() API 来集成。


结合 tf.data.Datasets 和 @tf.function


在迭代适合内存的训练数据时,可以使用常规的 Python 循环。除此之外,tf.data.Dataset 则是从磁盘传输训练数据的最好方法。数据集是可迭代的(不是迭代器),工作方式与其他 Python 循环类似。如果您想使用 AutoGraph 的等效图操作替换 Python 循环,可以通过将代码包装在 tf.function() 中,充分利用数据集异步预取 / 流功能来实现。


@tf.function

def train(model, dataset, optimizer):

for x, y in dataset:

with tf.GradientTape() as tape:

prediction = model(x)

loss = loss_fn(prediction, y)

gradients = tape.gradients(loss, model.trainable_variables)

optimizer.apply_gradients(gradients, model.trainable_variables)


如果您使用 Keras.fit() API,则无需担心数据集迭代。


model.compile(optimizer=optimizer, loss=loss_fn)

model.fit(dataset)


利用 AutoGraph 和 Python 控制流程


AutoGraph 提供了一种将依赖于数据的控制流转换为图模式等价的方法,如 tf.cond 和 tf.while_loop。


数据相关控制流常见出现于序列模型中。tf.keras.layers.RNN 包装了 RNN 单元,允许您静态或动态地展开循环神经网络。为了演示,您可以重新实现动态展开,如下所示:


class DynamicRNN(tf.keras.Model):

def __init__(self, rnn_cell):

super(DynamicRNN, self).__init__(self)

self.cell = rnn_cell

def call(self, input_data):

# [batch, time, features] -> [time, batch, features]

input_data = tf.transpose(input_data, [1, 0, 2])

outputs = tf.TensorArray(tf.float32, input_data.shape[0])

state = self.cell.zero_state(input_data.shape[1], dtype=tf.float32)

for i in tf.range(input_data.shape[0]):

output, state = self.cell(input_data[i], state)

outputs = outputs.write(i, output)

return tf.transpose(outputs.stack(), [1, 0, 2]), state


使用 tf.metrics 聚合数据,使用 tf.summary 记录数据


一套完整的 tf.summary 接口即将发布。您可以使用以下命令访问 tf.summary 的 2.0 版本:


from tensorflow.python.ops import summary_ops_v2


有关详细信息,请参阅文末链接:

https://github.com/tensorflow/docs/blob/master/site/en/r2/guide/effective_tf2.md


(本文仅代表作者观点,转载请联系原作者)

精彩推荐

640?wx_fmt=png

推荐阅读:

  • 对标Bert?刷屏的GPT 2.0意味着什么

  • 一次性掌握机器学习基础知识脉络 | 公开课笔记

  • Python助你抢红包

  • 3分钟实现9种经典排序算法的可视化|Python

  • 骗局翻新, 暗网活跃度倍增, 2018加密货币犯罪报告敢看吗?

  • 云漫圈 | 学Python还是Java, 8张漫画带你全面分析

  • 35 岁程序员,年后第一天被辞退

  • 手机辐射排行榜:小米、一加远超 iPhone;阿里开工彩票最高奖金 1000 万;苹果再遭集体诉讼

  • 2月报告:Python逆袭成功?踢馆Java,碾压C++!

640?wx_fmt=png

点击“阅读原文”,打开CSDN APP 阅读更贴心。

相关文章:

多线程概念与编程

一、多线程的生命周期:新建(New)、就绪(Runnable)、运行(Running)、阻塞(Blocked)和死亡(Dead) 1、新建状态:程序初始化一个Thread时,线程处于新建状态 2、就绪状态:线程Thread调用s…

C技巧:结构体参数转成不定参数

下面这段程序是一个C语言的小技巧&#xff0c;其展示了如何把一个参数为结构体的函数转成一个可变参数的函数&#xff0c;其中用到了宏和内建宏“__VA_ARGS__”&#xff0c;下面这段程序可以在GCC下正常编译通过&#xff1a; #include <stdio.h> #define func(...) myfun…

Arbitrage--POJ 2240

1、题目类型&#xff1a;图论、最短路径、Floyd算法。 2、解题思路&#xff1a;Floyd算法的简单应用&#xff1b;STL中map的简单应用。 3、注意事项&#xff1a;避免map报警告&#xff0c;文件开始调用#pragma warning(disable:4786)。 4、实现方法: #pragmawarning(disable:47…

【视频】V4L2之应用流程

####打开设备文件 int fd = open(Devicename,mode); Devicename:/dev/video0、/dev/video1 …… Mode:O_RDWR [| O_NONBLOCK] 如果使用非阻塞模式调用视频设备,则当没有可用的视频数据时,不会阻塞,而立刻返回。 ####取得设备的capability struct v4l2_capability capabil…

Android NDK开发之旅29 云服务器Ubuntu下搭建NDK环境,并编译FFmpeg

###前言 因为在Linux环境下编译FFmpeg生成库和头文件下比较方便&#xff0c;所以接下来主要操作在Linux环境下进行。但是对于Android NDK 开发新手来说&#xff0c;自己电脑配置Ubuntu Linux环境过程比较繁琐。而采用云服务器极大的方便了此过程&#xff0c;服务器对客户端远程…

一个App卖了4亿美元,这家听声识曲公司为何得到Apple的青睐?

作者 | 琥珀 出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09; 是否可以将 Shazam 称为有听歌识曲功能应用的鼻祖&#xff1f; 2018 年 9 月&#xff0c;苹果最终以 4 亿美金完成对 Shazam 公司的收购&#xff0c;让不少人为之振奋&#xff0c;在当时对外公布的一份声…

Product Orders(生产订单)状态相关函数BAPI

[相关表] JEST-对象的系统状态&#xff08;I****&#xff09;和用户状态(E****) JSTO-状态对象信息 TJ02T-系统状态文本 -用户状态文本 【锁对象】&#xff1a;生产订单锁对象 ESORDER 函数&#xff1a; ENQUEUE_ESORDER&#xff0c; DEQUEUE_ESORDER [函数1]&#xff1a;检…

5行代码就能入门爬虫?

作者 | 苏克1900来源 | 第2大脑&#xff08;ID&#xff1a;Mocun6&#xff09;责编 | swallow不少读者是刚刚入门Python或者想学习Python的&#xff0c;今天就来谈谈如何用快速入门爬虫。先说结论&#xff1a;入门爬虫很容易&#xff0c;几行代码就可以&#xff0c;可以说是学习…

【云周刊】第146期:史上最大规模人机协同的双11,12位技术大V揭秘背后黑科技...

摘要&#xff1a;史上最大规模人机协同的双11&#xff0c;12位技术大V揭秘背后黑科技&#xff0c;INTERSPEECH 2017系列 | 语音识别之语言模型技术&#xff0c;机器学习初学者必须知道的十大算法&#xff0c;云数据库SQL Server 2016和新技术应用...更多精彩内容&#xff0c;尽…

【驱动】GNSS驱动基础

GNSS:Global Navigation Satellite System(全球卫星导航系统) GPS:Global Positioning System(全球定位系统) GPS是美国的卫星导航系统。 还有&#xff0c;俄罗斯的GLONASS&#xff1b;欧盟的Galileo&#xff1b;中国的北斗。 这几大导航系统统称为GNSS GLONASS、Galileo、…

ibaits插入即获取主键(mssql,mysql,oracle)

oracle主键需预先生成&#xff0c;通过sequence&#xff1b;mysql和mssql是插入后生成。 mysql: <insert id"insertStu_mysql" parameterClass"stu"> insert into stu(name) values (#name#) <selectKey resultClass"int" keyProper…

【驱动】GNSS驱动:gpsOneXTRA 援助技术

什么是 “gpsOneXTRA 援助技术”&#xff1f; 高通 gpsOneXTRA 的援助技术在公司的改进中扩展了 gps 芯片组, 允许通过互联网连接下载辅助 gps。芯片组为更精确的位置发现提供了更高的灵敏度, 尤其是在通常难以找到 GPS 信号的位置。 gpsOneXTRA:帮助提高了独立的性能&#x…

2017年书单整理

android书籍: Android进阶之光 刘望舒 点评一下&#xff0c;这本书呢&#xff0c;涉猎很广&#xff0c;涉及的技术&#xff0c;开源库挺多的&#xff0c;适合广度面上的知识增长&#xff0c;对于深度上的提高价值不大&#xff0c;我觉得对我没啥太大价值额 Android安全技术揭秘…

华南理工大学院长涉嫌篡改8名研究生成绩,4人已停职

整理 | 一一出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;2 月 11 日&#xff0c;网友平凡的世界overlooker 在新浪微博上报料&#xff0c;称华南理工大学计算机科学与工程学院的院领导于 2018 年研究生复试结束后&#xff0c;篡改 8 位考生的考试成绩&#xff0c;…

我心中的最佳阵容

世界杯的激情还在心中涤荡&#xff0c;但新赛季的各大联赛却已悄然开打&#xff0c;这里给出我心中的几项最佳&#xff0c;期待他们本赛季的完美表现。 最佳球队&#xff1a;切尔西&#xff08;上赛季切尔西在安帅执掌球队的首个赛季便夺得英超冠军&#xff0c;欧冠虽惜败于曾经…

如何让AI教机器自己玩俄罗斯方块?

作者 | Ahab转载自公众号Ahab杂货铺&#xff08;ID:PythonLearningCamp&#xff09;人工智能大火的今天&#xff0c;如果还是自己玩俄罗斯方块未免显得太 LOW&#xff0c;为什么不对游戏升级&#xff0c;让机器自己去玩俄罗斯方块呢&#xff1f;有了这个想法之后&#xff0c;我…

【驱动】内核打印级别设置

在uboot中设置 setenv loglevel loglevel8 setenv loglevel debug setenv loglevel quiet setenv loglevel setenv mmcargs run set_disp; setenv bootargs console${console},${baudrate} ${loglevel} ${smp} root${mmcroot} ${disp_args}内核对应代码 main.c (init) 467 s…

vue基本标签

2019独角兽企业重金招聘Python工程师标准>>> vue基本是数据驱动&#xff0c;数据双向绑定&#xff0c;组件化&#xff0c;常用标签v-modal,v-html,v-if,v-else,v-show,v-for,v-on(简写)&#xff0c;v-bind(简写 :) vue.js 兼具 angular.js 和 react.js 的优点&#…

C#操作域用户

using System;using System.DirectoryServices;namespace SystemFrameworks.Helper{ /// ///活动目录辅助类。封装一系列活动目录操作相关的方法。 /// public sealed class ADHelper { /// ///域名 /// private static s…

Redis进阶实践之三如何在Windows系统上安装安装Redis

一、Redis的简介 Redis是一个key-value存储系统。和Memcached类似&#xff0c;它支持存储的value类型相对更多&#xff0c;包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash&#xff08;哈希类型&#xff09;。这些数据类型都支持push/po…

31页PPT概述:图神经网络表达能力有多强?

整理 | 一一出品 | AI科技大本营近年来&#xff0c;图神经网络的研究成为深度学习领域的热点。图是一种数据结构&#xff0c;它对一组对象&#xff08;节点&#xff09;及其关系&#xff08;边&#xff09;进行建模&#xff0c;由于图结构的强大表现力&#xff0c;用机器学习方…

【linux】Linux kernel uapi header file(用户态头文件)

uapi目录的创建原因 Linux在3.7以后把很多header file移到 include/uapi或是arch/xxxx/include/uapi下&#xff0c;为了解决include recursive&#xff08;循环包含头文件&#xff09;的问题。 英文参考文档&#xff1a;https://lwn.net/Articles/507794/ 解决include recur…

诊断IIS中的ASP0115错误

诊断IIS中的ASP0115错误 作者:未知 重要说明&#xff1a;本文包含有关修改注册表的信息。修改注册表之前&#xff0c;一定要备份注册表&#xff0c;并且一定要知道在发生问题时如何还原注册表。有关如何备份、还原和编辑注册表的信息&#xff0c;请单击下面的文章…

【imx6】libipu.so.0说明

###代码位置 在目录fsl-release-bsp/build-fb/tmp/work/imx6qsabresd-poky-linux-gnueabi/imx-lib/1_3.14.28-1.0.0-r0/imx-lib-3.14.28-1.0.0/ipu中 编译完成后有如下文件列表 ipu$ ls Android.mk libipu.so Makefile mxc_ipu_hl_lib_dummy.c mxc_ipu_hl_lib.…

“安利”一款debug神器:在AI面前,bug都不是事儿

作者 | 琥珀出品 | AI科技大本营&#xff08;公众号ID&#xff1a;rgznai100&#xff09;为了帮程序员解决 bug 问题&#xff0c;Facebook 可算是操碎了心&#xff01;你可以这么想&#xff0c;如果在开发和测试阶段没有发现 bug 问题&#xff0c;那么 bug 将会随着产品发布&am…

Spring中@Value用法收集

一、配置方式 Value需要参数&#xff0c;这里参数可以是两种形式&#xff1a; Value("#{configProperties[t1.msgname]}") 或者 Value("${t1.msgname}")&#xff1b; 这两形式&#xff0c;在配置上有什么区别&#xff1a; 1、Value("#{configPropert…

vue从入门到进阶:指令与事件(二)

一.插值 v-once 通过使用 v-once 指令&#xff0c;你也能执行一次性地插值&#xff0c;当数据改变时&#xff0c;插值处的内容不会更新。但请留心这会影响到该节点上所有的数据绑定&#xff1a; span v-once>这个将不会改变: {{ msg }}</span> v-html 双大括号会将数据…

【ubuntu工具】bless:二进制查看工具,类似win下的UltraEdit

###安装 sudo apt-get install bless 使用 bless filename 或者执行bless&#xff0c;在图形界面中打开准备操作的文件 工具主界面

马斯克连发三推,发布退出OpenAI内情

整理 | 一一出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;美国时间 2 月 17 日&#xff0c;特斯拉 CEO 马斯克在 Twitter 连发三帖&#xff0c;道出自己退出人工智能研究组织 OpenAI的缘由。他在推文中表示&#xff0c;他已经有一年多时间没有深度参与 OpenAI 事务…

开发代码命名规范!

今天查看以前的资料看见代码命名规范。呵呵 就拿出来给大家分享以下&#xff0c;还是比较老的。估计现在也是这种开发的命名规范。仅供参考&#xff01;谢谢。 1.用Pascal规则来命名方法和类型。 public class DataGrid { public void DataBind() {…