前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >停下来思考下神经网络

停下来思考下神经网络

作者头像
zhuanxu
发布2018-08-23 13:01:33
1750
发布2018-08-23 13:01:33
举报
文章被收录于专栏:进击的程序猿进击的程序猿

前面介绍了一个简单的神经网络,用来解决了一个非常简单的模型,文章链接

输入1

输入2

输入3

输出

0

0

1

0

0

1

1

1

1

0

1

1

1

1

1

0

那本节主要是对神经网络的一点思考

1. 优化

在神经网络中backpropagation是非常重要的一个算法,backpropagation能帮助我们测量出每个weight对于最终输出错误的影响。

Backpropagation allowed us to measure how each weight in the network contributed to the overall error.

测量出每个weight对于最终error的影响后,下一步就是想着怎么去更新这些weight了,最终目标是使得error最小,至于这些更新的算法就有很多了,有:

• Annealing

• Stochastic Gradient Descent

• AW-SGD (new!)

• Momentum (SGD)

• Nesterov Momentum (SGD)

• AdaGrad

• AdaDelta

• ADAM

• BFGS

• LBFGS

每个算法都是侧重某一个点做的优化,没有什么万能算法,不过有一点是我们都需要知道的:

有了算法,在运用到实际的过程中,我们都需要去 tuning

谈到tuning就不由想到之前听精英日课里讲到的物理学中的「微调(fine tuning)」,里面说我们的宇宙就像是被人精心微调过似的,像一些关键的物理学公式中的参数,目前都是我们测量出来的,那谁规定这些参数就必须是这样子的呢?如果不是这样子,似乎宇宙就不稳定了,这让我不由想到,现在的神经网络,其模型是越来越复杂,里面需要调优的参数也越来越多,我们也无法去解释这些参数为什么是这个样子的,一切都是计算出来的,目前复杂的网络已经不是人能理解的了,如果宇宙也是通过一个复杂的网络产生的,那我们目前发现的所有规律,可能只是这个网络中的一部分,我们所有的一些测量出来的常量就是神经网络的中的weight,我们会与解释为什么参数是这样子吗?显然不可能,因为所有的参数都是通过输入输出网络自己“学习”出来的!

那可能物理学目前所有的一些公式都只是整个大系统中的一小部分,我们如果不解决系统最初的输入和输出是什么,不可能真正的了解系统,所有的努力只是其中的某一层网络之间的关系而已!

扯远了,回到我们的梯度下降。

2.Gradient Descent

我们看图:

图中的球不断的滚动,最终就会下降到最地点,那球怎么知道要往哪走呢?

人往高处走,水往低处流,球自然往稳定的地方走。

球在移动的过程中,唯一知道的信息就是当时的斜度(slope),如下图:

我们简单的描述下球移动的整个过程:

  1. 计算当前小球所在点的斜度
  2. 如果斜度为负,往右走
  3. 如果斜度为正,往左右
  4. 重复直到斜度为0

解决了小球走向的问题,下一步就是到底走多远的问题,一个简单的方案就是每次都走斜度距离,用数学公式来描述就是:

$$

x = x - slope

$$

现在我们知道了球往哪走,每次走多少,那按照这个规则来走,理论上球最后就能到达底部了。

3.But....球有时候也会凌乱

以上描述的算法也不是万能的,有时候球也会凌乱,走不到底部。

3.1 问题1.当斜率太大

看图:

有时候,当斜度太大的时候,每次球都从一个高出走向另一个方向的更高处,导致越来越偏离,也就是所谓的发散,那怎么解决的呢?

一个显然的做法就是减少每次移动的幅度,数学描述就是

$$

x = x - (alpha*slope)

$$

此处alpha是一个0-1之间的数,通过这种方法,我们就能慢慢的到达底部了。

3.2 问题2.局部最小

看图:

有时候我们有多个低洼处,怎么办呢?方法也很简单,我们随机的放多个球,看哪个球到达的底部最低,如下图:

那在神经网络中,怎么能够达到上述的效果呢?

神经网络中,这是通过增加层数实现的,每个隐藏的node其初始状态都是随机的,这种通过调节hidden node大小的方法,能够让我们尽可能的遍历所有的空间,找到其中最优的值。

讨论.在上图中,我们随机放了好多小球,最后所有的小球都停在了5个地点,那问题是:我们为什么要浪费那么多计算资源来重复计算呢?最后这些小球会到达同一个地方?一个优化显然就是对于那些同样结果的小球,我们就赶紧听下他,这样就能尽可能的减少资源的浪费!

3.3 问题3.当斜率太小

问题1是斜率太大,如果太小呢?

上图我们会发现我们红色的小球走着走着就会卡住!?一脸懵逼了。

如果我们每次移动的步长太小,那结果就是异步小心调入了一个小凹槽,再也出不来了!

再来看一个图:

即使我们没有小凹槽,但是如果步长太小的话,我们也会耗费好长时间才能到达底部

4. 随机梯度下降(SGD)

还是看图,图中这条曲线代表什么?

首先,我们必须要知道在神经网络中,我们都在试着最小化error with respect to the weights

所以上面的曲线含义是:随着一个单子的weight变化,error的变化,这么说可能还是不太好理解,可以看线性回归背后的数学,这里的曲线就是固定住其他weight,单独变化一个weight的曲线。

以上就是目前关于神经网络的所有思考。待继续。。。

以上内容参考了:A Neural Network in 13 lines of Python (Part 2 - Gradient Descent)

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

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 优化
  • 2.Gradient Descent
  • 3.But....球有时候也会凌乱
    • 3.1 问题1.当斜率太大
      • 3.2 问题2.局部最小
        • 3.3 问题3.当斜率太小
        • 4. 随机梯度下降(SGD)
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档