tensorflow实战google深度学习框架_TensorFlow深度学习框架搭建

  与keras类似,tensorflow是一个很流行的机器学习、深度学习算法框架,开发者只需要专注于模型的设计,大大的提高了开发效率,tensorflow内置的模型丰富可以直接用于实践应用;加上自带有WEBUI监控,我们可以实时观测模型的运行状态。

1 安装与测试

安装环境:联网环境下win7+python3.x

安装:

声明:win7环境下的Tensorflow只能运行在Python 3.X版本中,不可运行下在Python2.X中。

进入CMD 环境中,python  -m pip  install tensorflow

经过漫长的等待后,安装成功!

此次安装没有安装CUDA,tensorflow的计算在单机CPU下进行。

测试:

Python 3.6.3 shell:

Python 3.6.3 (v3.6.3:2c5fed8, Oct 3 2017, 18:11:49) [MSC v.1900 64 bit (AMD64)] on win32

Type "copyright", "credits" or "license()" for more information.

>>> import tensorflow as tf

>>> hello = tf.constant('Hello, TensorFlow!')

>>> sess = tf.Session()

>>> print(sess.run(hello))

b'Hello, TensorFlow!'

>>> a=tf.constant(10)

>>> b=tf.constant(10)

>>> print(sess.run(a+b))

20

>>>

2学习使用

这里先放上两个教程,后续再补充学习心得:

推荐教程:https://github.com/nlintz/TensorFlow-Tutorials

官网教程:http://www.tensorfly.cn/tfdoc/tutorials/overview.html

3 TensorBoard

TensorBoard为tensorflow框架的WEBUI界面,可以实时监控模型运行状态。

搭建tensorboard,查看深度学习图形可视化。 TensorBoard 来展现你的 TensorFlow 图像,绘制图像生成的定量指标图以及附加数据。监控模型训练状态。

进入路径:python3\Lib\site-packages\tensorboard

在此路径下运行:  python main.py  --logdir=path/to/log-directory(替换成自己训练log日志的位置)

logdir =改为训练过程中产生的Log日志对应的路径。出现下图的界面后,在浏览器中输入红框对应的地址。即可打开tensorboard。

5532670155ba1ef640cdee5ca0ab373f.png

在pycharm中运行一下下面的Python脚本,在console中可以看到训练中的结果,同时我们打开TensorBoard。

跑一段大佬的神经网络模型的python代码,来源:https://github.com/nlintz/TensorFlow-Tutorials

代码编写简洁清晰,需要好好拜读!

#!/usr/bin/env python

import tensorflow as tf

from tensorflow.examples.tutorials.mnist import input_data

def init_weights(shape, name):

return tf.Variable(tf.random_normal(shape, stddev=0.01), name=name)

# This network is the same as the previous one except with an extra hidden layer + dropout

def model(X, w_h, w_h2, w_o, p_keep_input, p_keep_hidden):

# Add layer name scopes for better graph visualization

with tf.name_scope("layer1"):

X = tf.nn.dropout(X, p_keep_input)

h = tf.nn.relu(tf.matmul(X, w_h))

with tf.name_scope("layer2"):

h = tf.nn.dropout(h, p_keep_hidden)

h2 = tf.nn.relu(tf.matmul(h, w_h2))

with tf.name_scope("layer3"):

h2 = tf.nn.dropout(h2, p_keep_hidden)

return tf.matmul(h2, w_o)

mnist = input_data.read_data_sets("MNIST_data/", one_hot=True)

trX, trY, teX, teY = mnist.train.images, mnist.train.labels, mnist.test.images, mnist.test.labels

X = tf.placeholder("float", [None, 784], name="X")

Y = tf.placeholder("float", [None, 10], name="Y")

w_h = init_weights([784, 625], "w_h")

w_h2 = init_weights([625, 625], "w_h2")

w_o = init_weights([625, 10], "w_o")

# Add histogram summaries for weights

tf.summary.histogram("w_h_summ", w_h)

tf.summary.histogram("w_h2_summ", w_h2)

tf.summary.histogram("w_o_summ", w_o)

p_keep_input = tf.placeholder("float", name="p_keep_input")

p_keep_hidden = tf.placeholder("float", name="p_keep_hidden")

py_x = model(X, w_h, w_h2, w_o, p_keep_input, p_keep_hidden)

with tf.name_scope("cost"):

cost = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits=py_x, labels=Y))

train_op = tf.train.RMSPropOptimizer(0.001, 0.9).minimize(cost)

# Add scalar summary for cost

tf.summary.scalar("cost", cost)

with tf.name_scope("accuracy"):

correct_pred = tf.equal(tf.argmax(Y, 1), tf.argmax(py_x, 1)) # Count correct predictions

acc_op = tf.reduce_mean(tf.cast(correct_pred, "float")) # Cast boolean to float to average

# Add scalar summary for accuracy

tf.summary.scalar("accuracy", acc_op)

with tf.Session() as sess:

# create a log writer. run 'tensorboard --logdir=./logs/nn_logs'

writer = tf.summary.FileWriter("./logs/nn_logs", sess.graph) # for 1.0

merged = tf.summary.merge_all()

# you need to initialize all variables

tf.global_variables_initializer().run()

for i in range(100):

for start, end in zip(range(0, len(trX), 128), range(128, len(trX)+1, 128)):

sess.run(train_op, feed_dict={X: trX[start:end], Y: trY[start:end],

p_keep_input: 0.8, p_keep_hidden: 0.5})

summary, acc = sess.run([merged, acc_op], feed_dict={X: teX, Y: teY,

p_keep_input: 1.0, p_keep_hidden: 1.0})

writer.add_summary(summary, i) # Write summary

print(i, acc) # Report the accuracy

writer.close()

Python脚本中通过此函数将模型训练的参数均记录在nn_log中。启动tensorboard要记录下log日志的路径。

writer = tf.summary.FileWriter("./logs/nn_logs", sess.graph) #

此截图中,由于多次训练模型而且都存放在一个log中,才会绘制出这个感觉很奇怪的训练过程,实际工程中应该一个模型对应一个log,模型训练完成后,清理Log或重命名。

5614b41ae041db149fd936ef080f1e69.png

例子:

以上脚本运行一次,记录在nn_log1中,训练过程中结果记录:

控制台中的神经网络的训练过程记录,可以看出来第99次训练分类准确率为98.47%。

0 0.9357

1 0.9632

2 0.9688

3 0.9751

...

90 0.9859

91 0.9856

92 0.9848

93 0.9852

94 0.9849

95 0.9843

96 0.9854

97 0.9839

98 0.985

99 0.9847

4 模型可视化

 2d78b93458a82c09ac2e4095d5989287.png

训练过程

 e3147c00db9f30607ac35d854e1fdee5.png

acc记录

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
每天前100人再送5门编程课! AI+5门300元课程+社群闭门分享会源码开源下载:https://github.com/DjangoPeng/keras-101/tree/master/code_samples 【为什么学AI】 归功于近年来大规模数据和硬件计算能力的大幅度提升,人工智能的概念近两年一直是市场追捧的对象。目前各大厂都争先恐后地布局AI,落地各类AI的的商业应用,也随之打响了一场激烈的人才争夺战。长远来看,越快将 AI 用于自己的工作中就能越早体会到AI带来的收益。 【讲师介绍】 彭靖田 Google Developer Experts。 曾为 TensorFlow Top级 的贡献者,著书《深入理解TensorFlow》,是国内第一本深度剖析 Google AI 框架的畅销书。 曾从0到1深入参与了华为 2012 实验室深度学习平台和华为深度学习云服务的设计与研发工作。 【课程设计】 课程内容基于最新的Keras版本(你也可以使用 TensorFlow 2 的 tf.keras 模块),其中有大量独家解读、案例,以及不少讲师一线实战多年的方法论和深度思考。同时,在层次划分上,难易兼顾,循序渐进。既有核心的基础知识,也有高级的进阶操作,尽量做到“老少皆宜”。 课程分为基础篇、入门篇和实战篇: 一、基础篇: 主要讲解人工智能发展史和深度学习脱颖而出的原由,以及神经网络的基础概念、理论实现、优化原理和计算方法。 二、入门篇: 主攻快速上手,通过7个小节让你从0到1实现环境搭建、模型优化,直接试水2个实战项目。同时,增强AI的理论学习,系统掌握机器学习3大分支、模型评估方法、数据预处理常用手段与过拟合问题的解决方案。 三、实战篇: 通过4个实战全面掌握深度学习理论与实现,涵盖目标检测、图像分类、可视化和可解释性学习、迁移学习、特征提取、数据增强等。带你综合运用前面所学的所有知识,逐渐熟练AI开发流程与技能。 课程包含思维导图上的所有内容(价值199元)前500名立减100元,仅99元买完就能学!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值