TensorFlow游乐场是一个通过网页浏览器就可以训练简单神经网络。并实现了可视化训练过程的工具。游乐场地址为http://playground.tensorflow.org/

一、TensorFlow游乐园参数介绍

打开游乐园可以看到有很多的默认参数:

首先我们来解读一下顶部的一些参数:

       Epoch ---> 训练次数。

       learning rate ---> 学习率(是一个超参数,在梯度下降算法中会用到;学习率是人为根据实际情况来设定)。

       Activation ---> 激活函数(默认为非线性函数Tanh;如果对于线性分类问题,这里可以不使用激活函数)。

       Regularization ---> 正则化(正则化是利用范数解决过拟合的问题,这里咱不讨论)。

       Regularization rate ---> 正则率(这里不使用正则化所以无需考虑)。

       Problem type ---> 问题类型(在这里我们要解决的是一个二分类问题,简单解释一下分类问题是指,给定一个新的模式,根据训练集推断它所对应的类别(如:+1,-1),是一种定性输出,也叫离散变量预测;回归问题是指,给定一个新的模式,根据训练集推断它所对应的输出值(实数)是多少,是一种定量输出,也叫连续变量预测;在这里我们属于分类问题)

其次是下发的一些模块:

       DATA ---> 数据集类型(这里提供了四种数据集,我们默认选中第一种;被选中的数据也会显示在最右侧的OUTPUT中;在这个数据中,我们可以看到二维平面上有蓝色和黄色的小点;每一个小点代表一个样例例子;点的颜色代表样例的标签;因为只有两种颜色,所以这里是一个二分类问题;在这里我们以判断某工厂零件是否合格为例子来说明,那么黄色就代表不合格零件,蓝色就代表合格零件)。

       FEATURES ---> 特征向量(为了将一个实际问题对应到空间中的点,我们需要提取特征。在这里我们可以用零件的长度和质量来大致描述;所以这里x1就代表零件长度,x2代表零件质量;特征向量是神经网络的输入)。

       HIDDEN LAYERS ---> 隐藏层(在输入和输出之间的神经网络称为隐藏层;一般神经网络的隐藏层越多这个神经网络越深;这里我们默认有一个隐藏层,这个隐藏层上有4个节点)。

       OUTPUT ---> 输出(显示区分平面以及训练数据)。

二、以TensorFlow游乐园为例介绍神经网络训练过程

图上每一个小格子代表神经网络中的一个神经元,每一条线代表神经元之间的连接。每一个节点和边都被涂上了或深或浅的颜色。但边的颜色和格子中的颜色含义有略微区别。每一条边代表了神经网络的一个权重(可以理解为一个参数),它可以理解为任意实数。神经网络就是利用反向传播算法对权重进行合理修改从而解决分类或者回归问题。边的颜色表现了权重的取值,当边颜色越深这个参数绝对值越大;当边越接近白色,这个参数绝对值趋于0。

每一个节点上的颜色代表了这个节点的区分平面。在这里稍微解释一下区分平面的概念。如果我们把这个平面当成一个笛卡尔坐标系,这个平面上的每一个点就代表了(x1,x2)的一种取值。如果你觉得小图不太清楚,可以把鼠标放到输入节点x1上面,可以看到x1节点此时的区分平面就是Y轴。

因为x1为输入层,输入层的输出值就是x1本身的值。所以当x1小于0时,这个节点输出为负,x1大于灵时节点输出为正。所以Y轴左侧都为橙色,右侧都是蓝色。同理x2的区分平面也很容易理解。
       现在我们来看隐藏层的节点,这里我们只有一个隐藏层,这个隐藏层上有四个节点。先来看第一个。这里我们把隐藏层节点1简称为h1。

可以看到这个节点的区分平面是一条在x轴之上的斜线。为什么会发生这种情况??这里就涉及到我们之前说的权重。在神经网络前向传播的过程中,后面节点的输入是之前与之相连的所有节点的加权和。我们仔细观察连线可以发现x1和h1的连线趋于白色,x2和h1是一条很明显的橙色线。把鼠标移到细线上可以看到权重的值,这里得到公式-0.12x1 + -0.73x2 = h1。所以得到了如图所示的一个区分平面。平面上方都是负值,下方都是正值。其它节点以此类推。在这里可以看到,权重对分类的影响至关重要。

最后我们来看隐藏层到输出层的输出。首先我们来看一下OUTPUT,如果最终要区分蓝色的点和橙色的点,我们的区分平面应该是一个闭合曲线。然而如果我们光靠加权和这种线性变换的话是没有办法准确圈出蓝色和橙色点的分界线。所以在隐藏层到输出层的过程我们增加了一个非线性激活函数Tanh,使得我们最后可以得到一个非线性的结果。综上神经网络解决一个分类问题大致可以分为:

       1.提取特征向量作为输入,比如说本例子中零件的长度和质量。

       2.定义神经网络结构。包括隐藏层数,激活函数等等。

       3.通过训练利用反响传播算法不断优化权重的值,使之达到最合理水平。

       4.使用训练好的神经网络来预测未知数据,这里训练好的网络就是指权重达到最优的情况。

下面我们点击开始训练按钮,下图是训练489次后的情况。观察OUTPUT,这时模型其实已经很准确的进行了分类。

TensorFlow游乐园介绍及其神经网络训练过程相关推荐

  1. 神经网络的三种训练方法,神经网络训练过程图解

    如何训练神经网络 1.先别着急写代码训练神经网络前,别管代码,先从预处理数据集开始.我们先花几个小时的时间,了解数据的分布并找出其中的规律. Andrej有一次在整理数据时发现了重复的样本,还有一次发 ...

  2. 练习推导一个最简单的BP神经网络训练过程【个人作业/数学推导】

    写在前面: 各式资料中关于BP神经网络的讲解已经足够全面详尽,故不在此过多赘述.本文重点在于由一个"最简单"的神经网络练习推导其训练过程,和大家一起在练习中一起更好理解神经网络训练 ...

  3. 基于tensorflow实现图像分类——理解神经网络运作过程、tensorflow入门

    1. 人工神经网络 1.1 神经网络结构 人工神经网络(简称神经网络)是模拟人类大脑神经元构造的一个数学计算模型. 一个神经网络的搭建,需要满足三个条件. 输入和输出 权重(w)和阈值(b) 多层感知 ...

  4. 神经网络训练的一般步骤,神经网络训练过程详解

    1.想要学习人工神经网络,需要什么样的基础知识? 人工神经网络理论百度网盘下载: 链接:https://pan.baidu.com/s/1Jcg4s2ETCrag2Vo-OA57Og 提取码:rxlc ...

  5. 人工神经网络的训练步骤,神经网络训练过程图解

    如何通过人工神经网络实现图像识别 . 人工神经网络(ArtificialNeuralNetworks)(简称ANN)系统从20世纪40年代末诞生至今仅短短半个多世纪,但由于他具有信息的分布存储.并行处 ...

  6. 神经网络常用的训练方式,神经网络训练过程详解

    神经网络参数如何确定 神经网络各个网络参数设定原则:①.网络节点  网络输入层神经元节点数就是系统的特征因子(自变量)个数,输出层神经元节点数就是系统目标个数.隐层节点选按经验选取,一般设为输入层节点 ...

  7. 人工神经网络研究的目的,人工神经网络训练过程

    1.什么是样本训练? 一般指对人工神经网络训练. 向网络足够多的样本,通过一定算法调整网络的结构(主要是调节权值),使网络的输出与预期值相符,这样的过程就是神经网络训练.根据学习环境中教师信号的差异, ...

  8. bp神经网络训练函数选择,BP神经网络训练过程

    BP神经网络的训练集需要大样本吗?一般样本个数为多少? BP神经网络的训练集需要大样本吗?一般样本个数为多少? BP神经网络样本数有什么影响学习神经网络这段时间,有一个疑问,BP神经网络中训练的次数指 ...

  9. 神经网络测试集loss不变_神经网络训练过程中不收敛或者训练失败的原因

    在面对模型不收敛的时候,首先要保证训练的次数够多.在训练过程中,loss并不是一直在下降,准确率一直在提升的,会有一些震荡存在.只要总体趋势是在收敛就行.若训练次数够多(一般上千次,上万次,或者几十个 ...

最新文章

  1. 我们期待的TensorFlow 2.0还有哪些变化?
  2. 提取网页中的超级链接
  3. python安装numpy-如何为python安装numpy和scipy?
  4. html中函数的意义,理解函数式 CSS
  5. 数据处理的两个基本问题---汇编学习笔记
  6. sprintf作用2
  7. js计算器代码加减乘除_如何用jQuery做一个简易版计算器
  8. 关于Icon,Image,ImageIcon的简单的对比参考 上篇
  9. java读取文件方法
  10. 开源管理软件 OpenEMR 被曝多个漏洞,可被用于攻陷医疗基础设施
  11. spring-cloud Sleuth
  12. Python 定时任务的几种实现方式
  13. 虚拟机VMware下载与安装教程(windows)
  14. ilo找不到服务器,云计算服务器忘记iLO登录账号的解决方法
  15. flea-jersey使用之Flea RESTful接口服务端接入
  16. PhoneApplicationFrame以及设置Obscured/Unobscured的event handler
  17. java语音播报天气_Home Assistant系列 -- 自动语音播报天气
  18. 如何在 SAP ABAP 系统中使用 Adobe Form 试读版
  19. Java诊断工具Arthas使用说明
  20. ENSP的AR40问题解决

热门文章

  1. 2021年03月-程序员薪资分布,看看你拖后腿了吗?
  2. 计算机术语多态意思,C ++中的多态性
  3. 鼠标滑至某位置,在鼠标旁边出现详情弹窗div
  4. GPU服务器查询进程所属用户
  5. Unity 关于MatchVS使用static类型导致GameObject.Find与Action等不可用的解决方法
  6. idea:Unable to compile class for JSP , jsp自定义标签问题
  7. C语言编译器卡顿,Objective - C 性能优化(一)卡顿产生原因及避免
  8. win7下硬盘安装win7+linuxUbuntu双系统方法
  9. 最优二叉搜索树相关内容
  10. 基于五等均分法和Bob Stone法衡量RFM顾客价值