当前位置: 首页 > news >正文

吴裕雄 python 神经网络——TensorFlow 循环神经网络处理MNIST手写数字数据集

#加载TF并导入数据集
import tensorflow as tf
from tensorflow.contrib import rnn
from tensorflow.examples.tutorials.mnist import input_data

mnist = input_data.read_data_sets("E:\\MNIST_data\\", one_hot=True)

#设置训练的超参数,学习率 训练迭代最大次数,输入数据的个数
learning_rate= 0.001   #(learning_rate)
training_iters = 100000
batch_size = 128

# 神经网络参数
n_inputs = 28 #输出层的n
n_steps = 28 # 长度
n_hidden = 128 # 隐藏层的神经元个数
n_classes = 10 # MNIST的分类类别 (0-9)

# 定义输出数据及其权重
# 输入数据的占位符
x = tf.placeholder("float", [None, n_steps, n_inputs])
y = tf.placeholder("float", [None, n_classes])

# 定义权重
weights ={
    'in': tf.Variable(tf.random_normal([n_inputs, n_hidden])),
    'out': tf.Variable(tf.random_normal([n_hidden, n_classes]))
}

biases = {
    'in': tf.Variable(tf.random_normal([n_hidden,])),
    'out': tf.Variable(tf.random_normal([n_classes, ]))
}

#定义RNN模型
def RNN(X, weights, biases):
    #把输入的X转化成X (128 batch * 28 steps ,28 inputs)
    X = tf.reshape(X,[-1,n_inputs])

    #  进入隐藏层
    # X_in = (128 batch * 28 steps ,28 hidden)

    X_in = tf.matmul(X,weights['in']) + biases['in']
    # X_in = (128 batch * 28 steps ,28 hidden)
    X_in=tf.reshape(X_in,[-1,n_steps,n_hidden])
    #采用LSTM循环神经网络单元 basic LSTM Cell
    lstm_cell = tf.contrib.rnn.BasicLSTMCell(n_hidden, forget_bias=1.0,state_is_tuple=True)
    # 初始化为0  lstm 单元 由 h_cell,h_state两部分组成
    init_state=lstm_cell.zero_state(batch_size,dtype=tf.float32)

    # dynamic_rnn接受张量(batch ,steps,inputs)或者(steps,batch,inputs) 作为X_in
    outputs,final_state=tf.nn.dynamic_rnn(lstm_cell,X_in,initial_state=init_state,time_major=False)
    results=tf.matmul(final_state[1], weights['out']) + biases['out']
    return results

#定义损失函数和优化器,采用AdamOptimizer优化器
pred=RNN(x,weights,biases)
cost = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits=pred, labels=y))
train_op= tf.train.AdamOptimizer(learning_rate=learning_rate).minimize(cost)

# 定义模型预测结果及准确率计算方法
correct_pred = tf.equal(tf.argmax(pred,1), tf.argmax(y,1))
accuracy = tf.reduce_mean(tf.cast(correct_pred, tf.float32))


# 训练模型及评估模型

# 定义一个会话,启动图,每20次输出一次准确率
with tf.Session() as sess:
    sess.run(tf.global_variables_initializer())
    step = 0
    # 训练,达到最大迭代次数
    while step * batch_size < training_iters:
        batch_xs, batch_ys = mnist.train.next_batch(batch_size)
        # Reshape data to get 28 seq of 28 elements
        batch_xs = batch_xs.reshape((batch_size, n_steps, n_inputs))
        sess.run(train_op, feed_dict={x: batch_xs, y: batch_ys})
        if step % 20 == 0:
            print(sess.run(accuracy,feed_dict={x:batch_xs, y:batch_ys}))
        step +=1

 

转载于:https://www.cnblogs.com/tszr/p/10863056.html

相关文章:

  • 三层架构详细介绍
  • ElasticSearch Roaring bitmap 和跳表联合查询
  • Redis(一)----安装及基本使用
  • Spring Cloud(3):Ribbon的使用
  • RESTful API批量操作的实现
  • Node.js原生路由
  • C语言基础:break语句使用范例源码
  • 第六次实训作业
  • C# — MongoDB数据库安装
  • k8s 三节点签发所需证书
  • 经典书籍
  • k8s flanneld网络配置
  • 第六章小结(图)
  • SUSE12.2 编译usbutils
  • 类与类加载器
  • 《Javascript高级程序设计 (第三版)》第五章 引用类型
  • 【347天】每日项目总结系列085(2018.01.18)
  • 【从零开始安装kubernetes-1.7.3】2.flannel、docker以及Harbor的配置以及作用
  • conda常用的命令
  • ECMAScript 6 学习之路 ( 四 ) String 字符串扩展
  • express如何解决request entity too large问题
  • JavaScript 基础知识 - 入门篇(一)
  • macOS 中 shell 创建文件夹及文件并 VS Code 打开
  • MQ框架的比较
  • opencv python Meanshift 和 Camshift
  • Python打包系统简单入门
  • Python十分钟制作属于你自己的个性logo
  • Redis 懒删除(lazy free)简史
  • Tornado学习笔记(1)
  • vue2.0项目引入element-ui
  • web标准化(下)
  • 从零搭建Koa2 Server
  • 基于Android乐音识别(2)
  • 容器化应用: 在阿里云搭建多节点 Openshift 集群
  • 世界编程语言排行榜2008年06月(ActionScript 挺进20强)
  • 正则表达式-基础知识Review
  • ​第20课 在Android Native开发中加入新的C++类
  • #Linux(帮助手册)
  • (¥1011)-(一千零一拾一元整)输出
  • (1)bark-ml
  • (13)[Xamarin.Android] 不同分辨率下的图片使用概论
  • (LNMP) How To Install Linux, nginx, MySQL, PHP
  • (Matalb回归预测)PSO-BP粒子群算法优化BP神经网络的多维回归预测
  • (附源码)springboot 个人网页的网站 毕业设计031623
  • (免费领源码)Python#MySQL图书馆管理系统071718-计算机毕业设计项目选题推荐
  • (转)C语言家族扩展收藏 (转)C语言家族扩展
  • (转载)从 Java 代码到 Java 堆
  • (转载)在C#用WM_COPYDATA消息来实现两个进程之间传递数据
  • ***监测系统的构建(chkrootkit )
  • .Net Attribute详解(上)-Attribute本质以及一个简单示例
  • .NET Core 通过 Ef Core 操作 Mysql
  • .NET 中创建支持集合初始化器的类型
  • .NET:自动将请求参数绑定到ASPX、ASHX和MVC(菜鸟必看)
  • .net利用SQLBulkCopy进行数据库之间的大批量数据传递
  • .考试倒计时43天!来提分啦!