前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Keras:基于Theano和TensorFlow的深度学习库之中文文档

Keras:基于Theano和TensorFlow的深度学习库之中文文档

作者头像
深度学习思考者
发布2018-01-15 11:28:42
7720
发布2018-01-15 11:28:42
举报

Keras官网:http://keras.io/

Github项目:https://github.com/fchollet/keras

中文文档主页:http://keras-cn.readthedocs.io/en/latest/

Github中文文档:https://github.com/MoyanZitto/keras-cn.git

  本博客主要给出某些必备的部分(一直更新中),详细内容请移步至Github以及MoyanZitto的主页。

第一部分:快速开始Keras

  Keras的核心数据结构是“模型”,模型是一种组织网络层的方式。Keras中主要的模型是Sequential模型,Sequential是一系列网络层按顺序构成的栈。   Sequential模型如下:

代码语言:javascript
复制
from keras.models import Sequential

model = Sequential()

  将一些网络层通过.add()堆叠起来,就构成了一个模型:

代码语言:javascript
复制
from keras.layers.core import Dense, Activation

model.add(Dense(output_dim=64, input_dim=100))
model.add(Activation("relu"))
model.add(Dense(output_dim=10))
model.add(Activation("softmax"))

  完成模型的搭建后,我们需要使用.compile()方法来编译模型:

代码语言:javascript
复制
model.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy'])

  编译模型时必须指明损失函数和优化器,如果你需要的话,也可以自己定制损失函数。Keras的一个核心理念就是使得事情在简单的同时,保证用户对他们希望做的事情有足够的控制力度(最绝对的控制来自于源代码的可扩展性)

代码语言:javascript
复制
from keras.optimizers import SGD
model.compile(loss='categorical_crossentropy', optimizer=SGD(lr=0.01, momentum=0.9, nesterov=True))

  完成模型编译后,我们在训练数据上按batch进行一定次数的迭代训练,以拟合网络:

代码语言:javascript
复制
model.fit(X_train, Y_train, nb_epoch=5, batch_size=32)

  当然,我们也可以手动将一批批的数据送入网络中训练,这时候需要使用:

代码语言:javascript
复制
model.train_on_batch(X_batch, Y_batch)

  随后,我们可以使用一行代码对我们的模型进行评估,看看模型的指标是否满足我们的要求:

代码语言:javascript
复制
loss_and_metrics = model.evaluate(X_test, Y_test, batch_size=32)

  或者,我们可以使用我们的模型,对新的数据进行预测:

代码语言:javascript
复制
classes = model.predict_classes(X_test, batch_size=32)
proba = model.predict_proba(X_test, batch_size=32)

未完

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016年05月06日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档