作者|Orhan Gazi Yalçın 编译|VK 来源|Towards Datas Science

如果你看看不同的教程,搜索,花大量时间研究关于TensorFlow的Stack Overflow,你可能已经意识到有很多不同的方法来构建神经网络模型。

这一直是TensorFlow面临的问题。这就像是TensorFlow试图找到通往光明的深度学习环境的道路。由于TensorFlow是目前市场上最成熟的深度学习库,这基本上是你能得到的最好的。

Keras-TensorFlow的关系

背景

TensorFlow发展成为一个深度学习平台并不是一夜之间发生的。最初,TensorFlow将自己推销为一个符号数学库,用于跨一系列任务的数据流编程。因此,TensorFlow最初提供的主张并不是一个纯粹的机器学习库。目标是创建一个高效的数学库,以便在这种高效结构上构建的自定义机器学习算法能够在短时间内以高精度进行训练。

然而,用低级api重复地从头构建模型并不是很理想。因此,谷歌的工程师弗兰•库伊斯-克里特开发了Keras,作为一个独立的高层次的深度学习库。虽然Keras已经能够运行在不同的库之上,比如TensorFlow, Microsoft Cognitive Toolkit, Theano 或 PlaidML,但是TensorFlow过去和现在仍然是人们使用Keras的最常见的库。

现状

在看到了模型构建过程中的混乱之后,TensorFlow团队宣布Keras将成为在tensorflow2.0中构建和训练模型的核心高级API。另一种高级API,Estimator api

Estimator API和Keras API

现在,让我们回到问题上来:有很多不同的方法,人们使用TensorFlow来构建他们的模型。这个问题的主要原因是TensorFlow未能采用单一模型API。

在1.x版本中,对于生产级项目,模型构建API是Estimator API。但是,随着最近的变化,keras api几乎赶上了Estimator API。最初,Estimator API具有更高的可伸缩性,允许分布式,并且具有方便的跨平台功能。然而,现在Estimator API的大部分优点都已被消除,因此,很快Keras API将很可能成为构建TensorFlow模型的唯一标准API。

因此,在本文中,我们将只关注在TensorFlow中构建模型的Keras API方法,其中有三种:

  • 使用Sequential API

  • 使用Functional API

  • 模型子类化

我将直接将它们与相应的模型构建代码进行比较,这样你就可以实际测试它们了。让我们深入研究编码。

进行比较的初始代码

为了测试这三种Keras方法,我们需要选择一个深度学习问题。利用MNIST进行图像分类是一个非常简单的任务。我们试图实现的是利用著名的MNIST数据集训练一个识别手写数字的模型。

MNIST数据集(MNIST dataset)是一个大型手写数字数据库,通常用于训练各种图像处理系统。MNIST数据库包含6万张训练图片和1万张测试图片,这些图片来自美国人口普查局员工和美国高中生。如果你想遵循完整的教程,你可以找到我的关于图像分类的单独教程:

https://towardsdatascience.com/image-classification-in-10-minutes-with-mnist-dataset-54c35b77a38d

通过下面的代码,我们将导入所有层和模型,这样在接下来的部分中就不会打扰我们了。我们还下载MNIST数据集并对其进行预处理,以便它可以用于我们将使用这三种不同方法构建的所有模型。只需运行以下代码:

import tensorflow as tf
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Flatten, Dense
from tensorflow.keras import Input
from tensorflow.keras import Model
from tensorflow.estimator import DNNClassifier
from tensorflow.keras.datasets.mnist import load_data(x_train, y_train), (x_test, y_test)= load_data( path="mnist.npz" )# 确保这些值是浮点数,这样除法后就可以得到小数点
x_train = x_train.astype('float32')
x_test = x_test.astype('float32')
# 通过将RGB代码除以最大RGB值来规范化
x_train /= 255
x_test /= 255

现在,这一部分已经结束,让我们集中讨论构建张量流模型的三种方法。

构建Keras模型的3种方法

有三种方法可以在TensorFlow中构建Keras模型:

  • Sequential API:当你试图使用单个输入、输出和层分支构建简单模型时,Sequential API是最好的方法。对于想快速学习的新手来说,这是一个很好的选择。

  • Functional API:函数API是构建Keras模型最流行的方法。它可以完成Sequential API所能做的一切。此外,它允许多个输入、多个输出、分支和层共享。它是一种简洁易用的方法,并且仍然允许很好的定制灵活性。

  • 模型子类化:模型子类化是为需要完全控制模型、层和训练过程的高级开发人员设计的。你需要创建一个定义模型的自定义类,而且你可能不需要它来执行日常任务。但是,如果你是一个有实验需求的研究人员,那么模型子类化可能是最好的选择,因为它会给你所有你需要的灵活性。

让我们看看这些方法是如何实现的。我们将建立一个具有单一平坦层的基本前馈神经网络,将二维图像阵列转换为一维阵列和两个全连接层。

Sequential API

在Sequential API中,我们需要tf.keras.Models模块。我们可以简单地将下面的所有层作为一个单独的层来传递。如你所见,这很简单。

model = Sequential([ Flatten(input_shape=(28, 28)), Dense(256,'relu'), Dense(10, "softmax"),])

Functional API

对于Functional API,我们需要单独定义我们的输入。然后,我们需要创建一个输出对象,同时创建所有层,这些层相互关联并与输出相关联。最后,我们创建一个接受输入和输出作为参数的模型对象。代码仍然非常干净,但是我们在Functional API中有了更大的灵活性。

inputs = Input(shape=(28, 28))
x = Flatten()(inputs)
x = Dense(256, "relu")(x)
outputs = Dense(10, "softmax")(x) model = Model(inputs=inputs, outputs=outputs, name="mnist_model")

模型子类化

让我们继续讨论模型子类化。在模型子类化中,我们从创建一个扩展类基于tf.keras.Model 。模型子类化有两个关键功能:

  • __init__函数充当构造函数。多亏了__init__,我们可以初始化模型的属性(例如,layer)。super调用父构造函数( tf.keras.Model中的构造函数)self用于引用实例属性。
  • call function是在定义层之后定义操作的地方。

为了使用模型子类化来构建同一个模型,我们需要编写更多的代码,如下所示:

class CustomModel(tf.keras.Model):def __init__(self, **kwargs):super(CustomModel, self).__init__(**kwargs)self.layer_1 = Flatten()self.layer_2 = Dense(256, "relu")self.layer_3 = Dense(10, "softmax")def call(self, inputs):x = self.layer_1(inputs)x = self.layer_2(x)x = self.layer_3(x)return xmodel = CustomModel(name='mnist_model')

结尾代码

现在你可以用三种不同的方法创建同一个模型,你可以选择其中任何一个,构建模型,并运行下面的代码。

model.compile(optimizer='adam', loss='sparse_categorical_crossentropy', metrics=['accuracy'])model.fit(x=x_train,y=y_train, epochs=10)model.evaluate(x_test, y_test)

上面的行负责模型配置、训练和评估。当我们比较这三种方法的性能时,我们发现它们非常接近,但略有不同。

Method Sequential API Functional API Model Subclassing
Loss 0.08746038377285004 0.08131594955921173 0.0781003013253212
Accuracy 97.82% 98.06% 98.20%

我们更复杂的模型子类化方法优于Sequential API和Functional API。这表明,这些方法在低端的设计上也有细微差别。然而,这些差异可以忽略不计。

最终评估

现在,你已经了解了这三种Keras方法之间的异同。但是,让我们用一个表格来总结一下:

Feature Sequential API Functional API Model Subclassing
Customization Low Medium High
Difficulty to Build Easy Medium Difficult
Layer Sharing No Yes Yes
Multiple Branch No Yes Yes
Multiple Input No Yes Yes
Multiple Output No Yes Yes
Best Suited For Beginners Professionals Resarchers

总之,如果你刚刚起步,请坚持使用Sequential API。在深入研究更复杂的模型时,请尝试Functional API。如果你正在攻读博士学位,或者只是喜欢进行独立研究,试试模型子类化。如果你是专业人士,请坚持使用Functional API。它可能会满足你的需要。

原文链接:https://towardsdatascience.com/3-ways-to-build-neural-networks-in-tensorflow-with-the-keras-api-80e92d3b5b7e

欢迎关注磐创AI博客站: http://panchuang.net/

sklearn机器学习中文官方文档: http://sklearn123.com/

欢迎关注磐创博客资源汇总站: http://docs.panchuang.net/

用Keras构建神经网络的3种方法相关推荐

  1. TensorFlow2.0(三)--Keras构建神经网络回归模型

    Keras构建神经网络回归模型 1. 前言 1. 导入相应的库 2. 数据导入与处理 2.1 加载数据集 2.2 划分数据集 2.3 数据归一化 3. 模型构建与训练 3.1 神经网络回归模型的构建 ...

  2. Keras深度学习实战(2)——使用Keras构建神经网络

    Keras深度学习实战(2)--使用Keras构建神经网络 0 前言 1. Keras 简介与安装 2. Keras 构建神经网络初体验 3. 训练香草神经网络 3.1 香草神经网络与 MNIST 数 ...

  3. TensorFlow2.0(二)--Keras构建神经网络分类模型

    Keras构建分类模型 1. tf.keras简介 2. 利用tf.keras构建神经网络分类模型 2.1 导入相应的库 2.2 数据读取与展示 2.3 数据归一化 2.4 构建模型 2.5 模型的编 ...

  4. Pytorch构建模型的3种方法

    这个地方一直是我思考的地方!因为学的代码太多了,构建的模型各有不同,这里记录一下! 可以使用以下3种方式构建模型: 1,继承nn.Module基类构建自定义模型. 2,使用nn.Sequential按 ...

  5. 速成pytorch学习——9天构建模型的3种方法

    可以使用以下3种方式构建模型: 1,继承nn.Module基类构建自定义模型. 2,使用nn.Sequential按层顺序构建模型. 3,继承nn.Module基类构建模型并辅助应用模型容器进行封装( ...

  6. 使用 CSS 构建调色板:3 种方法

    为网站确定调色板是一项艰巨的工作.这个过程在很大程度上依赖于设计.色彩理论和对比度方面的知识. 在全面的网页设计过程开始之前,我们通常会从 Figma 这样的设计工具开始.使用这个设计工具,我们可以精 ...

  7. TensorFlow2.0(四)--Keras构建深度神经网络(DNN)

    Keras构建深度神经网络(DNN) 1. 深度神经网络简介 2. Kerase搭建DNN模型 2.1 导入相应的库 2.2 数据加载与归一化 2.3 网络模型的构建 2.4 批归一化,dropout ...

  8. 实战篇:如何用Keras建立神经网络(附全部代码)

    摘要: 机器学习实战篇:用简单的代码打造属于自己的神经网络模型- Keras是目前最受欢迎的深度学习库之一,对人工智能的商业化做出了巨大贡献.它使用起来非常简单,它使你能够通过几行代码就可以构建强大的 ...

  9. pytorch神经网络因素预测_实战:使用PyTorch构建神经网络进行房价预测

    微信公号:ilulaoshi / 个人网站:lulaoshi.info 本文将学习一下如何使用PyTorch创建一个前馈神经网络(或者叫做多层感知机,Multiple-Layer Perceptron ...

最新文章

  1. 2017-04-09,周日整理
  2. java young gc_java old GC和young GC
  3. Ambari HDP 完整安装手册
  4. ubuntu + pycharm + anaconda + pyqt5 + tools 配置
  5. 【NLP应用之智能司法】最强之谷歌BERT模型在智能司法领域的实践浅谈
  6. 青鸟影院售票系统(一)
  7. 如何计算代码运行的时间?
  8. C语言排序(冒泡排序、选择排序、插入排序和快速排序)
  9. python函数长度单位换算,(最新整理)长度单位换算
  10. 汽车车架号识别 VIN码识别,在汽车后市场的应用
  11. 电商api全境,Python网络爬虫与数据采集
  12. base URL是什么意思?干什么用的?
  13. MYS-6ULX-IOT 开发板测评——实现简单的物联网应用
  14. 高通 Camx debug log控制
  15. Android判断有无外置SD卡(TF卡),并读写文件
  16. 【zt】克服当众怕羞的心理1
  17. 随机信号的参数建模法--AR模型及Matlab实现
  18. Python实现天气查询功能(外加Excel技巧)
  19. 挑灯夜读——Java(一):类与对象
  20. 【算法】几分钟时间让你彻底学会—时间复杂度

热门文章

  1. OpenGL超级宝典学习笔记——操作矩阵
  2. BZOJ4735 你的生命已如风中残烛(组合数学)
  3. SiO2/KH550修饰四氧化三铁纳米磁性颗粒|PDA包裹四氧化三铁磁性纳米颗粒(科研级)
  4. sheng的学习笔记-平衡二叉树(AVL)和3+4重构
  5. Word 中添加目录的一般方法
  6. 一个Vue.js音乐项目
  7. 去掉em默认样式 html,HTML的各个标签的默认样式
  8. 计算机组装兴趣小组考核,中职计算机专业课程学生成绩考核之我见
  9. Vue 安装echarts-gl引入vue报错
  10. Committer 蔡正昕专访:勇敢迈出第一步,做开源没有那么难