之父讲解 Keras 几行代码就能在分布式环境训练模型 Keras (之父有哪些)

文章编号:45321 资讯动态 2024-12-09 TensorFlow

Keras 之父讲解 Keras:几行代码就能在分布式环境训练模型 | Google I/O 2017

雷锋网按:在上周的谷歌开发者大会 I/O 2017 的讲座中,Keras 之父 Francois Chollet 被请出来向全世界的机器学习开发者进行一场对 Keras 的综合介绍以及实战示例。说起来,这个子小小的男人不但是畅销书 《Deep learning with Python》的作者,更在 Kaggle 的数据科学家中世界排名第 17 位(最高),堪称是青年 AI 工程师中的翘楚。也因此,在开发出 Keras 之后被谷歌挖走为 TensorFlow 背书。

作为号称是 TensorFlow 最好用、对新手最友好的 API,一起来看看它的神通在哪里。

Francois Chollet: 对许多使用场景而言,canned estimator 是相当不错的选择。但如果你要做的事并没有现成的 canned estimator,怎么办?如果需要写自己的定制模型呢?这时,就到了 Keras API 派上用场的时候。

什么是 Keras API?

简而言之,它就是一个用于创建 TensorFlow 模型的高级 API,你可以与它一起使用 estimator class 以及 experiment class。

众所周知,TensorFlow 的特点是非常低级的编程界面,你大多数时间花在矩阵、矢量乘法上。这使它成为一件非常强力的深度学习工具。但对于创建十分复杂先进的模型,这种操作方式说不上“理想”。

在谷歌,我们相信,未来深度学习将存在于每一个普通 IT 开发者的工具箱中,不再局限于机器学习专家。原因很简单:每个开发者都需要做出更智能的应用。

为了让这成为现实,我们需要降低深度学习的使用门槛,搞出每一个人都能用的工具,而不应该只有专家才能用深度学习解决问题。

我有一个问题想让大家思考:

如果设计一个没有任何束缚限制的深度学习界面,它应该是什么样的?

深度学习的核心理念很容易理解,它的实现也不应该复杂。对于模型核心部件,与其从头实现所有功能,应该让开发者利用现存部件,快速搭建数据处理流水线;就像乐高积木那样。这正是我们设计 Keras 的理念——成为“深度学习的乐高”。

Keras 能做什么?

下面,我来讲讲 Keras 都能做什么。

首先,我不建议把 Keras 看做是 codebase、框架或库,它只是个高级 API。它有不同的实现,最主要的当然是 TensorFlow,但还有基于其它平台的——目前有 Theano、MxNet 和 Java;对更多框架的支持正在路上。

Keras 之父讲解 Keras:几行代码就能在分布式环境训练模型 | Google I/O 2017

有一个特点,是 Keras 区别于其他所有深度学习操作界面的地方,让它鹤立鸡群——那就是用户体验。 说白了,Keras 的精髓就是它对用户体验的执着,让开发者用着更舒服、简化工作流。尤其在于提供易于使用的组件、符合直觉的推理、更好的报错方面。因而,Keras 降低了操作难度,降低使用者的认知负担。

当然,让深度学习变得更简单,同时意味着更多的人能上手。Keras 的终极目标,是让尽可能更多人接触、使用深度学习。

直到现在,Keras API 的 TensorFlow 实现,是以外部开源资源库的形式存在的。但现在,我们把 Keras API 直接整合入 TensorFlow 项目中,这样能与你的已有工作流无缝结合。至此,Keras 成为了 TensorFlow 内部的一个新模块:tf.keras,它包含完整的 Keras API。

下面,我们一起来看看你的工作流会是什么样子。我会向大家展示一个简单但挺先进的例子。该例子中,我用 Keras API 定义模型,用 TensorFlow estimator 和 experiments 在分布式环境训练模型。

示例:视频内容问答

这是一个视频问答问题。我们有一组 10 秒短视频组成的数据集,视频内容是人从事各种活动。一个深度学习模型将会观察这些视频的每一帧画面,进行理解,然后你可以用简短的自然语言问它视频内容。

Keras 之父讲解 Keras:几行代码就能在分布式环境训练模型 | Google I/O 2017

本例子中,一个男人把纸板箱放进车的行李箱里。任务是回答这个人在做什么。模型会处理该视频和问题,试图在可能的答案中挑选出正确的那一个。这次,它的回答是“装货”。这个答案很有意思:如果仅仅看一帧画面,是得不出该结论的——这个人也有可能在卸货。所以,我们不仅要求模型能理解视频画面的内容,还要能理解每一帧画面的先后顺序。

放到三四年前,Keras 和 TensorFlow 诞生之前,这会是一个无比棘手的难题,全世界只有个位数的研究机构能处理。即便是一只由世界级专家学者、工程师组成的团队,也需要半年左右的时间来一点一点解决。而现在,所有具备基础 Python 编程技能的人都能借助工具处理该问题。我们这也是在使深度学习民主化。

下图便是我们的神经网络方案。它的结构可分为三个部分:

Keras 之父讲解 Keras:几行代码就能在分布式环境训练模型 | Google I/O 2017

首先,一个分支会导入视频输入,把它转化为对视频内容编码的矢量。另一个分支导入问题,也把它转化为矢量。现在,你可以把视频矢量和问题矢量连结起来,在它们之上添加一个分类器。该分类器的任务,是从一堆潜在回答中,选出正确的那一个。

第一步,是把视频输入矢量转化为张量。一个视频只是一组连续的画面帧,每一帧都是一个图像。对于图像处理,你要做的全部的事,就是运行一个 CNN。

每个 CNN,会从每帧画面提取一个矢量表示。最后所得到的,是对每帧画面进行编码的矢量序列。当遇到一个序列,你会做什么?当然是用序列处理模块—— LSTM 把它跑一遍。LSTM 会把序列简化为一个单一矢量,该矢量编码了视频的所有信息,包括每一帧画面、以及它们的顺序。

下一步,使用类似的过程来处理问句。它是一个由词语组成的序列,需要用内嵌模块把每个词语映射为一个词矢量。你就获得了一个词向量序列,再用另一个 LSTM 层来简化。

当视频、问题的矢量表示都有了以后,就可以把它们连接起来,在上面添加一个用于选择正确答案的分类器。

这就是深度学习的魔力:把复杂的输入,比如视频、图像、语言、声音变成矢量,变成几何空间中的不同的点——把了信息变成了几何空间中的点,这就是深度学习的本质。

而当完成之后,你就可以用线性代数来处理几何空间,捕捉到到有趣的映射模式。在上面的例子中,该模型就是在学习一个视频、问题空间到答案空间的映射。而执行的方式,是把不同的信息处理模块组合起来。这是一个十分自然的操作:对象是图像,就用图像处理模块 CNN;对象是序列,就用序列处理模块 LSTM;如果需要从一组候选中选择一个,就用分类器。

因而,创建深度学习模型,在概念上和拼乐高积木是很相似的,前者的实现也应该这么简单。这张图,就是对我们的模型在 Keras 上的直观结构。

Keras 之父讲解 Keras:几行代码就能在分布式环境训练模型 | Google I/O 2017

我们用一个按时间分布的层,把 CNN 应用于由输入视频和张量组成的时间轴上的每一帧画面。然后把输入导入 LSTM 层,前者被简化为单一张量。InceptionV3 CNN 会内置预训练的权重,这一点很重要,因为以目前的视频输入,靠我们自己是无法学习到有趣的视觉特征的。我们需要利用现有的、在大型数据集上学习到的视觉特征。这个例子里是 ImageNet。在深度学习里,这是一个常见的举措,而 Keras 使它变得更方便。问题的编码更加简单。把词语序列导入内嵌层(embedding layer),生成矢量序列,再用 LSTM 层简化为单一矢量。

代码展示

下面是视频编码机器人的完整代码,加起来只有几行,非常简洁。你从确认视频输入开始,高亮部分就是你的视频输入:

Keras 之父讲解 Keras:几行代码就能在分布式环境训练模型 | Google I/O 2017

这是一个由合理帧数组成的序列。“None”就是帧数,它没有被定义,你可以不同的 batch 进行修改。每一帧画面的分辨率是 150*150。下一步,仅用一行我们就定义了整个 InceptionV3 模型。它装满了从 ImageNet 得到的预训练权重。所有这些已经内置于 Keras 中,你不需要做任何多余操作,仅此一行代码足矣。代码并不包含顶层,因为并不相关,但在顶部加入了 pooling,使得我们能从每一帧抓取一个矢量。

下一步,CNN 被设置为不可训练,意味它的参数表示并不会在训练中更新。这一步很重要,因为该 CNN 已经有了非常不错的表示,没必要更改。再强调一遍,这是深度学习的常用操作,把封住不再改动的预训练模型添加入流水线。在 Keras 中,这项操作变得十分简便。有了不再变动的 CNN 之后,我们用一个时间分配层(TIME distributed layer),把它在视频输入的时间轴上均衡分配。这样做的结果,是得到所有帧的张量,再导入 LSTM 层得到单一矢量。

Keras 之父讲解 Keras:几行代码就能在分布式环境训练模型 | Google I/O 2017

如上图,问题处理就更加简单。最终的问题输入,被处理为整数序列。为什么是整数呢?每一个整数,都会用某些词汇映射到一个矢量。随后把整数序列导入嵌入层,这会把每个整数映射到一个矢量上。这些训练过的嵌入是模型的一部分。再把矢量序列导入 LSTM,简化为单一矢量。

这里有一个有意思的地方。通常使用 LSTM 的时候,有许多东西需要考虑、许多套路需要参考。但在这里,除了设置输入单位的数量,我们并没有做任何其他操作配置 LSTM 层——所有“最佳套路”,都已经成为 Keras 的默认设置。这是 Keras 的一大特点,已知的最佳方案被用于默认设置。对于开发者,这意味着模型直接就能用,不需要对所有参数都进行调参。

Keras 之父讲解 Keras:几行代码就能在分布式环境训练模型 | Google I/O 2017

在完成对视频、问题的编码之后,你只需要用 concate up 把它们转化为单一矢量,然后在顶端加入两个密集层,它们会从备选词汇中选出一个作为答案。

Keras 之父讲解 Keras:几行代码就能在分布式环境训练模型 | Google I/O 2017

下一步,使用输入和输出初始化 Keras 模型,本质上它是一个神经网络各层的图(a graph of layers)的容器。然后要确定训练设置,比如优化器、Adam 优化器和损失函数。到现在一切都很简单,我们已经定义了模型和训练设置。下面是在分布式环境训练模型,或许在 Cloud ML 上。

Keras 之父讲解 Keras:几行代码就能在分布式环境训练模型 | Google I/O 2017

只用几行代码,你就可以用 TensorFlow Estimator 和 Experiment 类训练模型。所有需要你做的事,仅仅是写 experiment 函数,用内置的 get_estimator 方法在其中定义模型,并用模型来初始化Estimator。有了estimator 之后,再用它创建Experiment,在其中你确认输入数据。

仅仅用几行非常直观、具有高度可读性的 Python 代码就可以实现,我们就定义了一个相当先进的模型、在分布式环境训练它,来解决视频问答难题。而这在几年前是完全难以想象的。

到这里,你应该已经看到,像 Keras 这样的 API 是如何推动 AI 民主化。这借助两个东西实现:

把它们结合到一起,使得开发者们能够以相当小的时间、经历代价处理任何深度学习难题。

雷锋网注:感兴趣的童鞋可翻墙到 观看完整视频,雷锋网编译。

李飞飞:我把今天AI所处的发展阶段称为“AI in vivo” | Google I/O 2017

六大亮点解读:计算机视觉技术无处不在 | Google I/O 2017

深度学习库 Keras 2 重磅发布,与 TensorFlow 联系更紧密

版权文章,未经授权禁止转载。详情见 转载须知 。

Keras 之父讲解 Keras:几行代码就能在分布式环境训练模型 | Google I/O 2017

全局中部横幅
海南航空官网

海南航空官网,提供国内国际机票预订,航班查询,特价机票打折机票预订,飞行通产品销售,机加酒预定,金鹏会员服务等,海航官网官网预订机票价优保障,海航24小时服务热线95339

香港网站导航大全

LOL网址导航网是专业的上网导航网站,精心收录各类优质热门网站信息,同时提供天气、快递、违章等各种生活便民查询工具网址,为您提供安全便捷的上网导航服务,现已被众多网友设为上网主页,网址导航大全首选LOL网址导航.

小龙虾加盟品牌

四川虾霸天餐饮连锁管理有限公司是一家经营特色小龙虾餐饮的服务型机构平台,全部采用深水精养小龙虾,是全国规模较大的自有小龙虾养殖基地,已成为原生态小龙虾的领导者。

海南猎头招聘研发中心

海南猎头招聘研发中心是为了进一步深入贯彻落实总书记坚持面向世界科技前沿、面向经济主战场、面向国家重大需求、面向人民生命健康,深入实施新时代人才强国战略,牢牢把握“四个面向”战略方向,全面推进“百万人才进海南”战略,奋力开创海南自由贸易港人才事业发展新局面而设立的高级人才招聘机构。

山东聚盈防水材料有限公司,公司专业生产销售:聚乙烯丙(涤)纶高分子防水卷材,聚氯乙烯(PVC)防水卷材,热塑性聚烯烃(TPO)防水卷材,自粘聚合物改性沥青防水卷材,自粘聚合物改性沥青聚酯胎防水卷材,自粘预铺防水卷材,自粘湿铺防水卷材,非沥青基高分子自粘胶膜防水卷材,电话:18653600312

山东聚盈防水材料有限公司生产聚乙烯丙(涤)纶高分子防水卷材,聚氯乙烯(PVC)防水卷材,热塑性聚烯烃(TPO)防水卷材,自粘聚合物改性沥青防水卷材,自粘聚合物改性沥青聚酯胎防水卷材,自粘预铺防水卷材,自粘湿铺防水卷材,非沥青基高分子自粘胶膜防水卷材,单/双组分聚氨酯防水涂料、非固化橡胶沥青防水涂料、聚合物水泥(JS)复合防水涂料等十几种防水产品

陕西老三届企业集团

陕西老三届实业有限责任公司老三届世纪星老三级首座盛邦物业陕西克力地产有限责任公司西安千秋置业有限责任公司

hahah

一家家装为您提供优质的装修服务,拥有优质的装修建材,精湛的装修工艺,让您售前无虑,售后无忧。

钻铣床

浙江西菱股份有限公司(www.zjxltz.com)是专注于钻铣床,攻丝机,悬臂攻丝机,齿轮式牙距攻丝机,摇臂攻丝机的数控攻丝机厂家,西菱有多品种、多规格、系列化覆盖同行业同类产品,欢迎来电洽谈

土工格栅

山东朋程工程材料有限公司,从事生产销售土工格栅,玻纤格栅,玻纤土工格栅,钢塑土工格栅,单向塑料土工格栅,双向塑料土工格栅,玄武岩土工格栅,涤纶土工格栅,土工布,土工膜,聚酯玻纤布,防裂贴,抗裂贴,灌缝胶等产品的生产厂家,销售热线:18253878888

道路运输客车展

道路运输客车展—客车展-道路运输客车展—客车展

安徽码上物联网络科技有限公司

安徽码上物联网络科技有限公司,码上追防伪追溯系统多用户版

搜好货网

搜好货网(www.912688.com)互联网+智能营销云B2B电子商务平台,为您提供丰富的B2B行业资讯、供应、求购、库存信息、品牌信息等,是企业做电子商务网络贸易的网站平台。

全局底部横幅