京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 6798|回复: 0

一文看尽 TensorFlow“奋斗史”!|CSDN 博文精选

[复制链接]

9

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2019-10-5 19:44:29 | 显示全部楼层 |阅读模式 来自 中国

- I% I& }- k1 j5 }: A
# [# e# G% X' y# y6 a" r
作者 | 小宋是呢,CSDN 博客专家
$ ]3 U; P; ?5 b+ T本文精选自 CSDN 博客. V; _( |1 E' O( H" P. {
封图 | CSDN 付费下载自东方 IC$ q' \" e' d% {! o' }& \

  Z$ p3 g! t- P; `1 d% b& j

, d3 F  n0 C1 m# h% f0 ~6 \
) d2 D, A5 \, B4 u
序篇8 s- D3 h* c2 i( Y  N% d* K

" ?# t/ n, E2 A' @$ ?

- r7 |8 t  |1 X' g" h5 R2015 年 11 月,Google 正式发布了 Tensorflow 的白皮书并开源 TensorFlow 0.1 版本。" D$ z) t% W& L1 H9 S, T1 W
2017 年 02 月,Tensorflow 正式发布了 1.0.0 版本,同时也标志着稳定版的诞生。: W/ G0 P! ^# q& W
2019 年 10 月,TensorFlow 在经历七个多月(2019 年 3 月 1 日 -2019 年 10 月 1 日)的 2.0 Alpha 版本的更新迭代后,发布 2.0 正式版。
1 `) H# F' n3 P: O& L( K2 Q. R8 O
, Z7 |5 c8 y7 I" z7 U2.0 正式版官方介绍视频3 X2 v4 o5 O+ L* H
虽然 2.0 正式版才刚刚发布,就已经引起了学术界与科研界广泛关注与好评:4 b4 t9 n8 p) y6 Q
    . ~% |7 ^- O+ r8 ^, `% w" I
  • Google 深度学习科学家以及 Keras 的作者表示,TensorFlow 2.0 是一个新时代的机器学习平台,这将改变了一切。: E7 `. f3 u1 L0 j2 s- Y
  • 深度学习研究和教育者、fast.ai 创始人 Jeremy Howard 也称赞 2.0 版本的发布是”令人兴奋的一步,与 TensorFlow 一代相比是一个巨大的飞跃“。$ _" G5 o' R& ~# f5 i
  • 目前 GitHub 上排名第一的 NLP 机器学习课程 practicalAI 的作者以及苹果公司 AI 研究员 Goku Mohandas 在推特上说,他们正在从 PyTorch 转向 TensorFlow 2.0。
    8 n$ T( E* b0 q5 f
为什么 TensorFlow 2.0 的发布能够引发了广泛的讨论和关注?下面笔者通过对于 TensorFlow“奋斗史”介绍与解读来分析 TensorFlow 如何成就的王霸之路。# ?! N' |0 Y- C: u" ^
TensorFlow 的“奋斗史”包括三个章节:锋芒初露(0.1),中原逐鹿(1.0),王者归来(2.0)。
8 M" [+ \' W) ~* |
; \( F3 l( b$ l7 K! v: ?
) T6 M" X9 |+ k9 r4 y4 f) c% A  g) f

0 |# O' D0 H) ^7 K+ p4 X6 I2 \锋芒初露·源起1 N. V0 h0 L3 Z+ v+ V# w, B. J! H
; v  C' |$ X/ x* _4 Z. J8 A, M
: a# q2 Z  N( v: J! q
在 2011 年,Google Brain 内部孵化出一个项目叫做 DistBelief,它是为深度神经网络构建的一个机器学习系统。虽然这个著名的系统并没有开源,但是 Google 研究者有大量关于它设计的论文被大家所熟知,它也被广泛应用于 Google 内部的科研和商业产品中。这个项目最早可以追溯到 2009 年,由 Geoffery Hinton 带领的团队开发的一个实现了广义反向传播算法的框架,基于这个框架,Google 内部可以快速试验新的深度学习算法并提高算法精度。比如在使用这套框架后,Google 内部语音识别的错误率降低了 25%。
9 m) v7 F; z5 h9 a后来,Google 决定将 DistBelief 打造成更加稳健、快速、通用的机器学习框架,调动了相当多的工程师和科学家投入到对 DistBelief 的改造,这其中就包括大名鼎鼎的 Jeff Dean。有了这样的豪华开发阵容,DistBelief 迅速成熟蜕变,成为一个高鲁棒和工业级的机器学习框架,这就是后来于 2015 年 11 月发布的 TensorFlow 0.1 版。- @" |- O+ y. \( b& ^" f
虽然相较于较早开源的 Caffe、MXNet 等优秀的机器学习框架,TensorFlow 还略显年轻,但是作为 Google 内部的第二代机器学习框架,TensorFlow 有了更加有趣的灵魂。相较于侧重于卷积的 Caffe 与刚从校园走出来的 MXNet,TensorFlow 以更加成熟完备的姿态展露锋芒。它是基于 DataFlow 的计算模型,算子相组合形成一个计算图,计算的过程就是数据在这个计算图的节点进行计算并流动。同时,这个计算图可以被切成不同的子图,并分配到不同的 Device 上,包括 CPU、GPU 和其他的计算设备,这样天然地对分布式友好。此外,TensorFlow 从一开始就被设计成运行在多个平台上,如 inference 可以运行在 iOS 和 Android 设备上,训练则可以运行在不同的硬件设备上。3 Q, B7 ^# ^2 g* P. ?
2016 年 4 月 14 日,Google 发布了分布式 TensorFlow,版本号为 0.8,这是 TensorFlow 发布之后的比较重大的版本更新。Google 的博文介绍了 TensorFlow 在图像分类的任务中,在 100 个 GPUs 和不到 65 小时的训练时间下,达到了 78%的正确率。在激烈的商业竞争中,更快的训练速度是人工企业的核心竞争力。而分布式 TensorFlow 意味着它能够真正大规模进入到人工智能产业中,产生实质性影响。- e6 p. [2 ]  X1 `  q, s4 m/ y
在 2016 年 6 月,TensorFlow 发布了新版本的早期版本,版本号为 0.9,增加了对 iOS 的支持。随着谷歌增加了 TensorFlow 对 iOS 的支持,应用程序将能够在更聪明的功能集成到它们的应用程序,最终使它们更聪明和能干。+ U+ k) F4 {6 F) h. A; Z2 Q% W
7 L5 _1 c0 O( ^1 D
从 0.9 版本开始,TensorFlow 支持了多平台,并且进入高速发展时期,开始不断赶超并拉开与其他深度学习框架的距离。虽只是源起,却锋芒毕露,初现王霸之气。6 Y( h3 Q0 K6 O% s3 V% S

+ [8 ^: b3 T( i1 d: \) g3 d3 L7 v

. o+ ~! }5 ?! D" }6 Q( r$ ?& L

% }8 z6 d  q! H7 u中原逐鹿·盛极$ |! S, E8 {3 z+ Q8 G5 P# b

# \* W* a9 k6 O. t

1 X' F, [% k5 a0 b" L& w时间到了,2017 年 1 月初,谷歌公布了 TensorFlow 1.0.0-alpha ,即 TensorFlow 1.0 的第一个“草稿”版本。2017 年 2 月,TensorFlow 在发布了 1.0.0 版本,也标志着稳定版的诞生。4 f; Q2 S5 q$ Y! o/ Z3 l
与已有版本相比,全新的 TensorFlow 1.0 主要有以下改进:
# u, [0 v% q+ |8 x: ~& ^& p2 h; a; M& ^
    2 ]8 d# i$ q- H' f/ Q+ J
  • 更快:TensorFlow 1.0 超乎想象地快!TensorFlow 1.0 为未来更多的性能改进打下了基础,而 tensorflow.org 现在可提供模型优化的提示和技巧,以达到最高速度。4 ~8 b9 u# @, K0 K& a4 ~8 j8 n
  • 更灵活:TensorFlow 1.0 为 TensorFlow 引进了带有 tf.layers,tf.metrics 和 tf.losses 模块的高级别应用程序界面。TensorFlow 团队引进能够与 Keras 完全兼容的新 tf.keras 模块。/ B' w. v2 r6 k" M, x
  • 随时就绪:TensorFlow 1.0 可确保 Python 应用程序界面的稳定性 Python 能够在不打破现有代码的情况下,更容易地获取新功能。+ b. J9 S( q% {
1.0 版本不仅为 TensorFlow 机器学习函数库带来多重升级,而且为 Python 和 Java 用户使用 TensorFlow 做开发降低了难度。另外,新版本的修补也得到了改善。更有意思的是,由于对 TensorFlow 计算做优化的新编译器,在智能手机上运行基于 TensorFlow 的机器学习 APP 将成为可能。Tensorflow 它已成为 GitHub 最受欢迎的开源项目。
1 i0 C/ K, U1 H8 q. j下图是 KDnuggets 网站对 2018 年的机器学习框架的使用做的一个调查统计,可以看出当时 TensorFlow 已经遥遥领先于其他竞争(Keras 是一个上层封装,底层调用的还是 TensorFlow),奠定了其深度学习霸主的地位。& {7 z% S; \' V& ?) ^( v
- J0 K, k" O% ?. E) G
中国有句古话:盛极必衰,否极泰来,这句话对于 Google 的 TensorFlow 也同样适用。1.x 版本在高速发展过程中,也为自己后来发展筑起一道山,TensorFlow 也产生了很多被人诟病的地方,比如 API 的稳定性、效率和基于静态计算图的编程上的复杂性等。同时,坚持静态图模式也培养起来了足以撼动 TensorFlow 霸主地位的框架(上述图中默默无闻的第三名,后来强势崛起的 PyTorch)。: H; a! |, H$ |- j3 H; {' k
1.x 版本后期,TensorFlow 发展由于自身原因(1. 为自己后来发展筑起一道山 2.坚持静态图模式)遭遇到瓶颈。PyTorch 以动态图开发模式,统一化的模块命名方式,更加人性化的编程的方式(Pythonic),强势出道。这些优势无一不击中 TensorFlow 的痛点,不断追赶、威胁 TensorFlow 霸主地位。
) B% }) K1 l. R5 \+ j5 y0 S7 F下图通过搜索全世界对机器学习和人工智能类别的兴趣(Google Interest),采用过去六个月的平均兴趣分数,并将其与前六个月的平均兴趣分数进行了比较。可以看出,TensorFlow 的平均兴趣分数处于下降状态,PyTorch 却呈上升趋势。3 F6 h/ d. B7 D8 Z- S8 H

7 i0 C9 _) E" O, {0 u下面谷歌的图表显示了过去一年的搜索兴趣。TensorFlow 为蓝色,Keras 为黄色,PyTorch 为红色,fastai 为绿色。可以看出 TensorFlow 总体呈现下降趋势,而 PyTorch 却呈现持续增长姿态,不断缩小与 TensorFlow 的距离。  {0 b4 A9 \( A: C0 B# T0 Y+ V; W& x

( N- w. u$ J' _5 b. b9 z6 V7 m按这样的趋势,PyTorch 在用户搜索兴趣方面追赶上 TensorFlow 指日可待了,TensorFlow 遭遇到出生以来最大的挑战(其实 TensorFlow 也就才三岁多)。TensorFlow 会如何应对这个挑战呢?是按部就班,在 1.x 版本上进行小修小补,得过且过(这个词用得有些过了,之所以会用是刚好写到这里的时候听到这首歌,同时这个词语与表达笔者对上述方法的不苟同);还是推倒重来,重新设计新版 TensorFlow,涅槃重生。这个选择会关乎到以后 TensorFlow 数年的发展和与 PyTorch 竞争的成败。笔者相信,Google 并不会做选择,小孩才会做选择,大人全都要。以谷歌的巨大体量,在内部执行两个方案,最后看市场反馈推出最合适的。Google 是大公司,以稳为主的策略还是很容易让人理解的。
- v. w$ |* w- j0 @7 E0 e3 b  T5 o& P3 y/ @
" r: T& r" j% ]/ J4 g6 a1 e# V: O. n
$ _; }1 X( A! R( f9 ]: f
王者归来·槃涅
- A6 B) i9 X+ d
' [# L% G8 ^- ?

1 E' \. s% R. B9 W! v- ^; B我们都知道 Google 推出了后者方案,选择涅槃重生,重塑自身。那么全新的 TensorFlow 2.0 究竟新在哪里呢?TensorFlow 官网给出了答复:, X% ]- V) e, I7 G- H$ N1 r, E, N
    7 ^6 j- E* r) {5 c6 `8 Q
  • Keras 与 TensorFlow 紧密集成,默认 eager execution,执行 Pythonic 函数。官方表示,对开发者来说,TensorFlow 2.0 用起来跟 Python 差不多;对于研究者来说,新框架也在低级 API 方面进行了重点投入。
    $ R; U9 T: j" q  B4 i8 L3 v8 W
  • 为了在各种平台上运行,SavedModel 文件格式进行了标准化。* Q# ?  l' L0 Z7 e
  • 针对高性能训练场景,可以使用 Distribution Strategy API 进行分布训练,且只需进行少量代码修改就能获得出色的性能。支持 Keras Model.fit、自定义训练循环、多 GPU 等等。
    % Z5 ]- C, |9 q4 f) d; j% Y
  • TensorFlow 2.0 提高了在 GPU 上的性能表现。以 ResNet-50 和 BERT 为例,只需要几行代码,混合精度使用 Volta 和 Turing GPU,训练表现最高可以提升 3 倍。
    ; @5 z! D/ s6 U# M3 [6 o8 R" k
  • 新增 TensorFlow Datasets,为包含大量数据类型的大型数据集提供了标准接口。. H. T. k3 V: G
  • 虽然保留了传统的基于 Session 的编程模型,但官方现在建议使用 eager execution 进行常规的 Python 开发。tf.function 装饰器可以把代码转换成可以远程执行、序列化、性能优化的图。在 Autograph 的帮助下,能把常规的 Python 控制流直接转成 TensorFlow 控制流。
    - S" E. e  J/ _' ?' s
  • 官方提供了 TensorFlow 1.x 升级 2.0 的迁移指南,TF2.0 还有一个自动转换的脚本。1 `% h# w7 z; X6 g6 d$ X: k! ?% Q
  • TensorFlow 2.0 提供了易用的 API,能够灵活快速的实现新想法。模型的训练和 serving 也已经无缝集成在基础架构中。
    3 A8 N1 k, v4 }
  • 更多关于 TensorFlow 2.0 的信息,可以访问官网:https://www.tensorflow.org/
    # K6 K* t4 m  C* r
4 e* Q6 D3 I" y7 e/ L. q
几乎每一条都直击 TensorFlow1.x 用户的痛点,广大使用 TensorFlow1.x 转到 PyTorch 的用户表示 TensorFlow 2.0 真香,纷纷倒戈。
/ o+ P1 P2 P4 P1 `6 M9 W6 V( xGoogle 深度学习科学家以及 Keras 的作者表示,TensorFlow 2.0 是一个新时代的机器学习平台,这将改变了一切。
5 o7 w8 X! S  P# S深度学习研究和教育者、fast.ai 创始人 Jeremy Howard 也称赞 2.0 版本的发布是“令人兴奋的一步,与 TensorFlow 一代相比是一个巨大的飞跃”。8 I" g4 C. ]- R7 N! C( g4 m. G$ D/ V
目前 GitHub 上排名第一的 NLP 机器学习课程 practicalAI 的作者以及苹果公司 AI 研究员 Goku Mohandas 在 Twitter 上说,他们正在从 PyTorch 转向 TensorFlow 2.0。6 b. H9 @8 R/ v9 u/ O3 l
此后,PyTorch 在与 TensorFlow 的争霸中将再难有胜算,TensorFlow 1.x 版本的失误给了 PyTorch 赶超的机会,PyTorch 已尽力追赶了,但是还是没有实现赶超。Now,TensorFlow 2.0 已经补全缺点,同时具备比 PyTorch 更加完备的多平台支持、更成熟的部署方式与数量巨大的用户基数。如果 PyTorch 早出生一年,或者 TensorFlow 2.0 晚发布一年,PyTorch 还是有机会的,但是没有如果,Google 依旧是最强大科技公司之一,很难反复给对手机会赶超。TensorFlow 再次呈现对于其他框架压倒式优势,实现王者归来。* j5 O, m+ A9 Q! X9 J- J, A
" K: |) V8 k4 s9 D$ q

7 y2 Y( t* _- ?' e

* q# t5 q( t; ]$ v; X( T终章
3 G% K1 x7 ^& Y* t3 e+ t

* L# a# _0 o; b% |- G' |( p
0 H! i' @8 Q6 `2 i* S/ q- x; t* c

3 @. J. N: e! s0 [$ GTensorFlow 从最开始 0.1 版本诞生时受到广泛关注,到 1.0 版本的全面爆发,再到今年 2.0 版本正式发布,它已趋于完美。TensorFlow 的成长依托于 Google 的强大研发与号召力,但 TensorFlow 的成功更归功于设计的完备性、审时度势和适时革新。
7 C8 Y4 g- H* o经历四年时光,TensorFlow 的发展与成功离不开先天的优秀天赋(Google Brain),更有赖于后天的努力拼搏(适时革新)。有天分又有努力,TensorFlow 的成功理所应当。" a9 H3 I7 V0 L: W7 C8 @" h
附:
4 T: c$ z* w) T7 Z+ T, O; Z5 a想要体验正式版本 TensorFlow 2.0 可以访问=>『TensorFlow2.0 正式版教程』极简安装 TF2.0 正式版(CPU&GPU)教程:$ G5 t5 \4 H1 v% p6 a
https://xiaosongshine.blog.csdn.net/article/details/1018449262 h4 m' E8 Z0 Z7 D7 l' Y
扫描下方二维码,下载 CSDN App,即刻与博主互动起来!# f. J: F, ]  t& s1 h

1 G4 }. O  H* Y【END】
- n) n" g. {! d
; U/ f# G: Q! e 热 文 推 荐 : }6 F+ `0 w! X% t: X- |! p7 x* d0 M
☞ 蚂蚁金服自研数据库打败Oracle拿下世界第一;三星手机全面退出中国;微软发布Windows 10X双屏系统 | 极客头条☞ 中国物联网激荡 20 年!$ W9 S! ~2 o& Z) t
☞ 鸿蒙 OS 的微内核技术究竟是什么?☞ 200 行代码解读国产数据库阿里 OceanBase 的速度源头!| CSDN 博文精选
& @4 W0 k/ q9 I☞ 程序员 45 岁怎么了?对比C++和Python,谈谈指针与引用肖仰华:知识图谱构建的三要素、三原则和九大策略 | AI ProCon 2019以太坊交易量第一合约FAIRWIN被爆漏洞, 竟是因为这个接口被滥用……点击阅读原文,即刻与博主互动起来。
4 n: @0 D) T( W& h: {& }) O7 D你点的每个“在看”,我都认真当成了喜欢
& J6 S. H- t1 O1 g6 Q来源:http://mp.weixin.qq.com/s?src=11&timestamp=1570273204&ver=1894&signature=wbyR5eEK5ZNuCYUNykmgSbu7lZdav7yVeotRnfrhvE*aLGBype63FQP9YgT5B2PjfShoStsKB9izwIC-OLC2YyqInaVXUYykzxGSKYW*HJypZrly6mkJ98trZtQEPJrN&new=1
8 S2 K* \6 [9 W, [7 A4 [7 B% l免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

帖子地址: 

梦想之都-俊月星空 优酷自频道欢迎您 http://i.youku.com/zhaojun917
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

站长推荐上一条 /6 下一条

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2025-7-14 01:54 , Processed in 0.063383 second(s), 27 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表