前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >[译]标准化Keras:TensorFlow 2.0中的高级API指南

[译]标准化Keras:TensorFlow 2.0中的高级API指南

作者头像
云水木石
发布于 2019-07-02 07:16:33
发布于 2019-07-02 07:16:33
1.9K00
代码可运行
举报
运行总次数:0
代码可运行

Tensorflow 2.0带来的一个重大变化就是采用keras API作为TensorFlow的标准上层API,因为我在编码中使用到keras比较多,所以对这个变化感到高兴,现翻译一篇Tensorflow团队发布的文档:Standardizing on Keras: Guidance on High-level APIs in TensorFlow 2.0。原文地址:https://medium.com/tensorflow/standardizing-on-keras-guidance-on-high-level-apis-in-tensorflow-2-0-bad2b04c819a ,略有删减。点击阅读原文可以跳转到该文章,需要访问外国网站哦!

Keras是一个非常受欢迎的构建和训练深度学习模型的高级API。它用于快速原型设计、最前沿的研究以及产品中。虽然现在的TensorFlow已经支持Keras,在2.0中,我们将Keras更紧密地集成到TensorFlow平台。

将Keras作为TensorFlow的高级API,使得新的机器学习开发人员更容易开始使用TensorFlow。单一的高级API可以减少混乱,让我们能够专注于为研究人员提供高级功能。

我们希望您能像我们一样喜欢使用它!

Keras有几个关键优势:

  • 用户友好:Keras拥有为常见使用场景特别优化的简单、一致的接口。它为用户错误提供了清晰且可操作的反馈,以及易于理解的错误消息,并且通常提供有用的建议。
  • 模块化和可组合:Keras模型将可配置的构建块连接在一起,几乎没有限制。无需使用框架甚至不了解框架提供的所有内容的情况下,Keras的部件也可以重复使用。例如,您可以使用图层或优化器而无需使用Keras Model 进行训练。
  • 易于扩展:您可以编写自定义构建块来表达新的研究想法,包括新的图层、损失函数和[在此插入您的想法]以开发最先进的想法。
  • 针对初学者和专家:深度学习开发人员具有不同的背景和经验水平,而Keras提供了有用的API,无论您刚刚开始,还是拥有多年的经验。

综上,这些可以在更广泛的使用场景,从学习ML到研究、到应用程序开发、到部署,实现更轻松,更高效的工作流程。

首先,我们将回答几个问题。接下来,我们将仔细研究TensorFlow附带的Keras版本能够做到的事情。

FAQ

我以为Keras是一个单独的库?

首先,Keras是一个API规范。Keras的参考实现是作为独立的开源项目维护的,您可以在www.keras.io上找到它。该项目独立于TensorFlow,并拥有一个活跃的贡献者和用户社区。TensorFlow包含Keras API的完整实现(在tf.keras模块中),并有一些TensorFlow特有的增强功能。

Keras只是TensorFlow或其他库的包装器吗?

不,这是一个常见的(但可以理解的)误解。Keras是一个用于定义和训练机器学习模型的API标准。 Keras与特定实现无关:Keras API具有TensorFlow、MXNet、TypeScript、JavaScript、CNTK、Theano、PlaidML、Scala、CoreML和其他库的实现。

内置于TensorFlow的Keras版本与我在keras.io上可以找到的版本有什么区别?

TensorFlow包含Keras API(在tf.keras模块中)的实现,并有一些TensorFlow特定的增强功能,包括支持直观调试和快速迭代的eager execution,支持TensorFlow SavedModel模型交换格式,以及对分布式训练的集成支持,包括在TPU上训练。

使用tf.keras模型子类API时,eager execution特别有用。此API的灵感来自Chainer,使您能够强制性地编写模型的正向传递。tf.keras紧密集成在TensorFlow生态系统中,还包括对以下支持:

  • tf.data,使您能够构建高性能输入管道。如果您愿意,可以使用NumPy格式的数据训练模型,或出于扩展和性能考虑,使用tf.data进行训练。
  • 分发策略,用于在各种计算配置中分发训练,包括分布在许多计算机上的GPU和TPU。
  • 导出模型。使用tf.keras API创建的模型可以序列化为TensorFlow SavedModel格式,可用TensorFlow Serving部署或用其他语言绑定(Java,Go,Rust,C#等)提供服务。
  • 导出的模型可以部署在使用TensorFlow Lite的移动和嵌入式设备上,也可用于TensorFlow.js(注意:您也可以使用相同的Keras API直接在JavaScript中开发模型)。
  • 特性列,用于有效地表示和分类结构化数据
  • 还有更多。
我该如何安装tf.keras?我还需要通过pip安装Keras吗?

tf.keras包含在TensorFlow中。您无需单独安装Keras。例如,如果在Colab Notebook中运行:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
!pip install tensorflow
import tensorflow as tf
Dense = tf.keras.layers.Dense

您就用上了tf.keras。如果您还不熟悉导入,可以查看一些最近的教程以获取示例。

您提到TensorFlow为初学者和专家提供不同样式的API。看起来怎么样?

TensorFlow开发人员具有有多种经验水平(从第一次学习ML的学生到ML专家和研究人员)。而TensorFlow的优势之一是它提供了多种API来支持不同的工作流程和目标。同样,这也是TensorFlow Keras集成的主要设计目标,用户可以选择Keras的一部分,而不必采用整个框架。

Sequential API

如果您是学习ML的学生,我们建议您开始时使用tf.keras Sequential API。它直观、简洁,适用于实践中95%的ML问题。使用此API,您可以用大约10行代码编写出第一个神经网络。

定义模型的最常用方法是构建图层图,最简单的模型类型是层的堆叠。您可以使用Sequential API定义这样的模型,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
model = tf.keras.Sequential()
model.add(layers.Dense(64, activation=’relu’))
model.add(layers.Dense(64, activation=’relu’))
model.add(layers.Dense(10, activation=’softmax’))
Such a model can then be compiled and trained in a few lines:
model.compile(optimizer=’adam’,
              loss=’sparse_categorical_crossentropy’,
              metrics=[‘accuracy’])
model.fit(x_train, y_train, epochs=5)
model.evaluate(x_test, y_test)

您可以在“学习和使用ML”部分的tensorflow.org/tutorials上找到更多的使用Sequential API的示例。

单击此处获取教程,该教程将引导您使用Sequential API在Fashion MNIST数据集上训练您的第一个神经网络。

Functional API

当然,序列模型是一种简单的图层堆叠,不能表示任意模型。使用Functional API可以构建更高级的模型,使您可以定义复杂的拓扑,包括多输入和多输出模型,具有共享层的模型以及具有残差连接的模型。

在使用Functional API构建模型时,图层是可以调用(在张量上)的,并返回张量作为输出。然后可以使用这些输入张量和输出张量来定义模型。例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
inputs = tf.keras.Input(shape=(32,))
# A layer instance is callable on a tensor, and returns a tensor.
x = layers.Dense(64, activation=’relu’)(inputs)
x = layers.Dense(64, activation=’relu’)(x)
predictions = layers.Dense(10, activation=’softmax’)(x)
# Instantiate the model given inputs and outputs.
model = tf.keras.Model(inputs=inputs, outputs=predictions)

可以使用如上那样简单的命令来编译和训练这样的模型。您可以在此处了解有关Functional API的更多信息。

Model Subclassing API

使用Model Subclassing API可以构建完全可自定义的模型,您可以在类方法的主体中以此样式强制定义自己的前向传递。 例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class MyModel(tf.keras.Model):
 def __init__(self):
   super(MyModel, self).__init__()
   # Define your layers here.
   self.dense_1 = layers.Dense(32, activation=’relu’)
   self.dense_2 = layers.Dense(num_classes, activation=’sigmoid’)
 def call(self, inputs):
   # Define your forward pass here,
   # using layers you previously defined in `__init__`
   x = self.dense_1(inputs)
   return self.dense_2(x)

这些模型更灵活,但可能更难调试。可以使用前面显示的简单编译和拟合命令编译和训练所有三种类型的模型,或者您可以编写自己的自定义训练循环以进行完全控制。

例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
model = MyModel()
with tf.GradientTape() as tape:
  logits = model(images, training=True)
  loss_value = loss(logits, labels)
grads = tape.gradient(loss_value, model.variables)
optimizer.apply_gradients(zip(grads, model.variables))

有关Model Subclassing样式的更多示例,请访问tensorflow.org/tutorials(请参阅“研究和实验”部分)。

使用Model Subclassing API实现的Neural Machine Translation with Attention

使用Model Subclassing API实现的GAN

如果我的研究不适合这些风格怎么办?

如果您发现tf.keras限制了你的应用领域,您有很多选择。您可以:

  • 将tf.keras.layers与Keras模型定义分开使用,编写自己的梯度和训练代码。您可以单独和独立地使用tf.keras.optimizers,tf.keras.initializers,tf.keras.losses或tf.keras.metrics。
  • 完全忽略tf.keras,使用低级TensorFlow API,Python和AutoGraph来达到你的目标。

这完全取决于您!请注意,tf.layers中的非面向对象的层将被废弃,并且tf.contrib.*(包括tf.contrib.slim和tf.contrib.learn等高级API)将在TF 2.0中不可用。

Estimators会发生什么变化?

Estimators广泛用于Google以及范围更广的TensorFlow社区。几种模型已被打包为Premade Estimators,包括线性分类器、DNN分类器、组合DNN线性分类器(又名Wide and Deep Models)和Gradient Boosted Trees。这些模型已经用于产品并得到广泛部署,由于所有这些原因,Estimator API(包括Premade Estimators)将包含在TensorFlow 2.0中。

对于Premade Estimators的用户来说,广受关注的Keras和eager execution对其影响将是微乎其微的。我们可能会更改Premade Estimators的实现,但会保持API接口相同。我们还将努力添加Premade Estimators实现的Keras版本,而且我们将扩展Keras以更好地满足大规模产品要求。

也就是说,如果您正在开发自定义架构,我们建议使用tf.keras来构建模型而不是Estimator。如果您正在使用需要Estimators的基础架构,您可以使用model_to_estimator()来转换模型,同时确保Keras工作在TensorFlow生态系统中。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-03-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 云水木石 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Nginx 内嵌GeoIP库
作者:matrix 被围观: 9 次 发布时间:2025-06-05 分类:零零星星 | 无评论 »
HHTjim 部落格
2025/06/06
1140
21.4 Python 使用GeoIP2地图定位
GeoIP2是一种IP地址定位库,它允许开发人员根据IP地址查找有关位置和地理位置的信息。它使用MaxMind公司的IP地址数据库,并提供一个方便的Python API。GeoIP2可以用于许多不同的应用程序,例如网站分析、广告定位和身份验证。GeoIP2提供了许多不同的信息,例如国家、城市、邮政编码、经纬度、时区等等。它还可以使用IPv6地址进行查询。
王 瑞
2023/10/24
8250
21.4 Python 使用GeoIP2地图定位
Python 运用Dpkt库解析数据包
dpkt项目是一个python模块,用于快速、简单的数据包解析,并定义了基本TCP/IP协议,使用该库可以快速解析通过各类抓包工具抓到的数据包,从而提取分析包内的参数。
王 瑞
2022/12/28
2K0
9.Nginx实践之使用MaxMind的GeoIP2实现处理不同国家或城市的访问最佳实践指南
描述: 为了实现根据访问者访问我们的网站时根据其IP显示其所属地,也为获取不同地区访问者的IP地址等相关信息为目的,所以在搜索引擎中查找解决方案,在网络上查询到如下几种方案Nginx+GeoIP2、使用收费 IP 识别接口、DNS 根据地域解析,然后经过多方面考究,最终还是使用Nginx+GeoIP2解决方案。
全栈工程师修炼指南
2022/09/29
6.3K0
9.Nginx实践之使用MaxMind的GeoIP2实现处理不同国家或城市的访问最佳实践指南
[喵咪开源软件推荐(3)]全球IP库-GeoLite2-City
[喵咪开源软件推荐(3)]全球IP库-GeoLite2-City #w-blog博客 哈喽大家好啊!喵咪开源软件推荐(3)终于和大家见面了,这次我们来说说什么呢?大家有没有遇到过这样一个场景,当你出国
喵了个咪233
2018/03/02
5.7K0
[喵咪开源软件推荐(3)]全球IP库-GeoLite2-City
通过GeoIP2分析访问者IP地理位置
MaxMind GeoIP2 服务能识别互联网用户的地点位置与其他特征,应用广泛,包括个性化定制内容、诈欺检测、广告定向、网站流量分析、执行规定、地理目标定位、地理围栏定位 (geo-fencing)以及数字版权管理。目前使用 GeoIP 更多是配合Nginx或Apache服务器进行日志分析获取网站访问量地域分布状况
Tinywan
2019/07/15
2.7K0
Python 开发代码片段笔记
作者编写的一些代码片段,本版本为残废删减版,没有加入多线程,也没有实现任何有价值的功能,只是一个临时记事本,记录下本人编写代码的一些思路,有价值的完整版就不发出来了,自己组织吧,代码没啥技术含量,毕竟Python这一块没怎么认真研究过,代码也都是随性瞎写的,大佬不要喷我,将就着看吧。
王 瑞
2022/12/28
1.2K0
Python 开发代码片段笔记
Tengine编译GeoIP2
nginx geoip geoip2 模块,集成了最新的免费 maxmind geoip mmdb 数据,可以使用nginx去获取访问IP具体归属国家地区,或者根据地区去进行流量分发功能
用户6792968
2022/08/30
8110
Tengine编译GeoIP2
pygeoip通过域名 IP获得地理位置
很多恶意的网络行为,会很明显的在ip位置中凸显出来,比如一个域名,经常访问的大多数人应该位置于中国大陆,可以是最近出现了美国纽约的ip与该域名的文件通信。
Tim在路上
2020/08/04
2.1K0
21.3 Python 使用DPKT分析数据包
dpkt项目是一个Python模块,主要用于对网络数据包进行解析和操作。它可以处理多种协议,例如TCP、UDP、IP等,并提供了一些常用的网络操作功能,例如计算校验和、解析DNS数据包等。由于其简单易用的特性,dpkt被广泛应用于网络安全领域,例如流量分析、漏洞利用、入侵检测等。使用该库可以快速解析通过各类抓包工具抓到的数据包,从而提取分析包内的参数。
王 瑞
2023/10/20
1.2K0
21.3 Python 使用DPKT分析数据包
全网的 IP 归属地显示,带你5分钟加上,就是这么简单!
最近,继新浪微博之后,今日头条、腾讯、抖音、知乎、快手、小红书、百家号等各大平台陆陆续续都上线了"网络用户IP地址显示功能",境外用户显示的是国家,国内的用户显示的省份,而且此项显示无法关闭,归属地强制显示;
一行Java
2022/05/17
2.4K0
全网的 IP 归属地显示,带你5分钟加上,就是这么简单!
python 根据ip获取地理位置
import dpkt import socket import pygeoip import optparse
用户5760343
2019/07/31
1.9K0
Python编写渗透工具学习笔记二 | 0x04编写程序分析流量检测ddos攻击
0x04编写程序分析流量 检测ddos攻击 1使用dpkt发现下载loic的行为 LOIC,即Low Orbit Ion Cannon低轨道离子炮,是用于压力测试的工具,通常被攻击者用来实现DDoS攻击。 我们要编写py脚本来解析http流量,并检查其中有无通过http get获取压缩过的loic二进制可执行文件的情况。为了检查http流量,我们必须先把数据包的以太网部分、ip层以及tcp层部分分解出来,注意http协议是位于tcp协议层之上的。如果http层中使用了get方法,则解析http get所要获
安恒网络空间安全讲武堂
2018/02/06
3.4K0
Python编写渗透工具学习笔记二 | 0x04编写程序分析流量检测ddos攻击
openresty基于lua/geoIp/redis实现ip限制
一、问题背景二、聊一嘴ip库三、解决方案四、下载安装openresty五、验证效果六、geoIp自动更新七、参考
叔牙
2023/02/26
4.6K0
openresty基于lua/geoIp/redis实现ip限制
利用Wireshark与Geolite地址库进行IP定位、地图分布可视化及特征报文深入分析
网络扫描和DDoS攻击等行为频繁出现,对网络安全构成严重威胁。为了更好地应对这些安全挑战,我们需要对网络流量来源分布和行为进行深入分析,从而识别潜在的威胁。本文将介绍如何使用MaxMind地址库(包括GeoLite2 ASN、GeoLite2 City和GeoLite2 Country)结合Wireshark进行IP地理位置信息的解析与分析,以及通过Wireshark内置的26个Geo相关字段如何精准过滤我们想要的特征报文,并让它们呈现在地图分布上。
RokasYang
2024/08/09
1.7K4
利用Wireshark与Geolite地址库进行IP定位、地图分布可视化及特征报文深入分析
小课堂 | 根据ip获取城市名
到目前为止,很多开放接口,如淘宝、新浪、腾讯、百度等开放接口或失效或需要key。很多接口已不再免费调用,本文提供3种方式:
孟君
2021/11/16
4.2K0
小课堂 | 根据ip获取城市名
异步任务实战之远程拉取和风天气API 发布于
在上一篇文章《并发编排与响应式初步》,我们已经对CompletableFuture的功能进行了深入的探讨,并简要介绍了Reactor响应式流相关的概念。然而,要熟练掌握异步任务编排并非一朝一夕之事,尤其是在需要处理 I/O 密集型应用或者一些特殊场景,如:任务间无顺序依赖关系,或者需要在所有任务完成后一次性处理所有返回结果。
DioxideCN
2023/10/21
3340
一文教你识别IP地址所属国家和城市
在网关的应用中,有时会有限制服务在指定的国家和城市进行开放,目前主流的方案有使用付费的在线API和使用离线的IP数据库。接下来将介绍这两种方案的实际应用。
码之有理
2024/05/13
1.5K0
将ip转换为地理位置存入elasticsearch
有些需要将一些数据基于地址位置进行分析,比如哪些区域比较活跃,在什么时间范围内活跃,但是后端仅能获取ip地址,因此需要将ip地址转换为地理位置,幸运的是我们有开源的工具可以使用,maxmind/GeoIP2-java使用GeoLite2-City.mmdb库就可以由ip分析得到对应的经纬度,下面给出具体操作步骤:
johnhuster的分享
2022/03/29
1.1K0
将ip转换为地理位置存入elasticsearch
Grafana展示精美的nginx访问日志图表
获取 Grafana Nginx 图表 链接下载,公众号后台回复 g-nginx-1 下载。
YP小站
2021/03/17
4.4K0
Grafana展示精美的nginx访问日志图表
推荐阅读
相关推荐
Nginx 内嵌GeoIP库
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验