深度学习神经网络 MNIST手写数据辨识 1 前向传播和反向传播

本文主要是介绍深度学习神经网络 MNIST手写数据辨识 1 前向传播和反向传播,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先是前向传播的程序。为了更清晰我们分段讲解。

第一部分导入模块,并设置输入节点为28*28,输出节点为10(0到9共10个数字),第一层的节点为500(随便设的)

import tensorflow as tf
INPUT_NODE = 784
OUTPUT_NODE = 10
LAYER1_NODE = 500

然后是生成单个层次网络的结构,判断损失函数是否加入正则

#定义神经网络的输入,参数和输出,定义前向传播过程
def get_weight(shape,regularizer):w = tf.Variable(tf.random_normal(shape,stddev=0.1),dtype=tf.float32) #生成随机参数if regularizer != None:tf.add_to_collection('losses',tf.contrib.layers.l2_regularizer(regularizer)(w))return w

同时设置偏置项,偏置项不需要正则化。

def get_bias(shape):b = tf.Variable(tf.constant(0.01,shape=shape))return b

在总的前向传播网络中设置两层网络:

def forward(x,regularizer):w1 = get_weight([INPUT_NODE,LAYER1_NODE],regularizer)b1 = get_bias([LAYER1_NODE])y1 = tf.nn.relu(tf.matmul(x,w1)+b1)w2 = get_weight([LAYER1_NODE, OUTPUT_NODE], regularizer)b2 = get_bias([OUTPUT_NODE])y = tf.matmul(y1, w2) + b2return y

然后反向传播。这里实现了一种机制:每次训练前,先查看一下已有的模型,

首先仍然是加载模型和设置初始常量:正则系数为0.0001,不算很大。然后滑动平均值衰减设为0.99.

import tensorflow as tf
from tensorflow.examples.tutorials.mnist import input_data
import mnist_forward2
import osBATCH_SIZE = 200
LEARNING_RATE_BASE = 0.1
LEARNING_RATE_DECAY = 0.99
REGULARIZER = 0.0001STEPS = 50000MOVING_AVERAGE_DECAY = 0.99MODEL_SAVE_PATH="./model/" #模型保存路径
MODEL_NAME="mnist_model" #模型保存文件名

然后是反向传播函数  def backward(mnist) :

输入数据和输出占位就先不说了,这里提一下损失函数:

采用最后输出为softmax的网络激活函数,并把损失函数定义为交叉熵

    #定义损失函数ce = tf.nn.sparse_softmax_cross_entropy_with_logits(logits=y,labels=tf.argmax(y_,1))cem = tf.reduce_mean(ce)loss = cem + tf.add_n(tf.get_collection('losses'))

学习率的设置方法和以前一样,然后定义反向传播方法,并设置和启用滑动平均值。

之后我们使用保存模型的函数:

    saver = tf.train.Saver()

在会话中我们先查看模型目录下有没有训练好的模型和参数,如果有,就恢复:

    with tf.Session() as sess:ckpt = tf.train.get_checkpoint_state(MODEL_SAVE_PATH)if ckpt and ckpt.model_checkpoint_path:  # 先判断是否有模型saver.restore(sess, ckpt.model_checkpoint_path)  # 恢复模型到当前会话#可以观察到当前的会话已经包含当前的正确globalstep了currentstep = ckpt.model_checkpoint_path.split('/')[-1].split('-')[-1]print(currentstep)

值得注意的是,我们之前在当前的模型里使用了滑动平均值,这里恢复的时候恢复了滑动平均后的数据,然后继续根据global_step来计算新的滑动平均值。而且,因为在模型中我们嵌入了global_step,所以恢复的时候,global_step也被恢复了。

然后开始训练。

        for i in range(STEPS):xs,ys = mnist.train.next_batch(BATCH_SIZE)_,loss_value,step = sess.run([train_op,loss,global_step],feed_dict={x:xs,y_:ys})if i % 1000 == 0:print("After " + str(i) + " steps, loss is: " + str(loss_value))saver.save(sess,os.path.join(MODEL_SAVE_PATH,MODEL_NAME),global_step=global_step)

设置自动执行的函数main() :

def main():mnist = input_data.read_data_sets("./data/",one_hot=True)backward(mnist)if __name__ == '__main__':main()

现在前向传播和后向传播都已经设置好了。大家多运行几次,就会发现每次都是从上一次训练好的模型中开始然后继续训练的。

这篇关于深度学习神经网络 MNIST手写数据辨识 1 前向传播和反向传播的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/883656

相关文章

51单片机学习记录———定时器

文章目录 前言一、定时器介绍二、STC89C52定时器资源三、定时器框图四、定时器模式五、定时器相关寄存器六、定时器练习 前言 一个学习嵌入式的小白~ 有问题评论区或私信指出~ 提示:以下是本篇文章正文内容,下面案例可供参考 一、定时器介绍 定时器介绍:51单片机的定时器属于单片机的内部资源,其电路的连接和运转均在单片机内部完成。 定时器作用: 1.用于计数系统,可

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

[word] word设置上标快捷键 #学习方法#其他#媒体

word设置上标快捷键 办公中,少不了使用word,这个是大家必备的软件,今天给大家分享word设置上标快捷键,希望在办公中能帮到您! 1、添加上标 在录入一些公式,或者是化学产品时,需要添加上标内容,按下快捷键Ctrl+shift++就能将需要的内容设置为上标符号。 word设置上标快捷键的方法就是以上内容了,需要的小伙伴都可以试一试呢!

AssetBundle学习笔记

AssetBundle是unity自定义的资源格式,通过调用引擎的资源打包接口对资源进行打包成.assetbundle格式的资源包。本文介绍了AssetBundle的生成,使用,加载,卸载以及Unity资源更新的一个基本步骤。 目录 1.定义: 2.AssetBundle的生成: 1)设置AssetBundle包的属性——通过编辑器界面 补充:分组策略 2)调用引擎接口API

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

大学湖北中医药大学法医学试题及答案,分享几个实用搜题和学习工具 #微信#学习方法#职场发展

今天分享拥有拍照搜题、文字搜题、语音搜题、多重搜题等搜题模式,可以快速查找问题解析,加深对题目答案的理解。 1.快练题 这是一个网站 找题的网站海量题库,在线搜题,快速刷题~为您提供百万优质题库,直接搜索题库名称,支持多种刷题模式:顺序练习、语音听题、本地搜题、顺序阅读、模拟考试、组卷考试、赶快下载吧! 2.彩虹搜题 这是个老公众号了 支持手写输入,截图搜题,详细步骤,解题必备

《offer来了》第二章学习笔记

1.集合 Java四种集合:List、Queue、Set和Map 1.1.List:可重复 有序的Collection ArrayList: 基于数组实现,增删慢,查询快,线程不安全 Vector: 基于数组实现,增删慢,查询快,线程安全 LinkedList: 基于双向链实现,增删快,查询慢,线程不安全 1.2.Queue:队列 ArrayBlockingQueue:

19.手写Spring AOP

1.Spring AOP顶层设计 2.Spring AOP执行流程 下面是代码实现 3.在 application.properties中增加如下自定义配置: #托管的类扫描包路径#scanPackage=com.gupaoedu.vip.demotemplateRoot=layouts#切面表达式expression#pointCut=public .* com.gupaoedu

17.用300行代码手写初体验Spring V1.0版本

1.1.课程目标 1、了解看源码最有效的方式,先猜测后验证,不要一开始就去调试代码。 2、浓缩就是精华,用 300行最简洁的代码 提炼Spring的基本设计思想。 3、掌握Spring框架的基本脉络。 1.2.内容定位 1、 具有1年以上的SpringMVC使用经验。 2、 希望深入了解Spring源码的人群,对 Spring有一个整体的宏观感受。 3、 全程手写实现SpringM

【服务器运维】MySQL数据存储至数据盘

查看磁盘及分区 [root@MySQL tmp]# fdisk -lDisk /dev/sda: 21.5 GB, 21474836480 bytes255 heads, 63 sectors/track, 2610 cylindersUnits = cylinders of 16065 * 512 = 8225280 bytesSector size (logical/physical)