深度学习-前向传播与反向传播

概述

对于全连接的神经网络(MLP),其结构看似复杂, 其实只是简单结构的不断重复。
这里的简单结构就是sigmoid函数即LR:
对于x=(x_0,x_1,...,x_n)w=(w_0,w_1,...,w_n) 和 标量b 使y=\sigma(wx+b)=\frac{1}{1+exp(\sum_{i=0}^{n}w_ix_i+b)}
z=wx+b
当然随着激活函数的发展,\sigma函数也在变化。这里先从一般情况介绍。
\sigma(x)'=\sigma(x)(1-\sigma(x))
这就是神经网络的一个神经元,它把上一层所有输出作为自己的输入,同时有自己的一套w

前向神经网络

图1:简单神经网络

如上图,
x_0=a^0表示第一层即输入层,接收一个样本的特征,他有n_0个神经元。
a^1,a^2,...,a^{l-1}表示隐层每一层的结果是上一层的输出也是下一层的输入,分别有n_1,n_2,...,n_{l-1}个神经元
a^l=y'表示输出层,当然,对于二分类,输出层是一个神经元,如果是多分类,就可以是多个神经元。有n_l个神经元
W^l表示第l-1层与l层之间的权重矩阵。shape(W^l)=(n_l,n_{l-1})
b^l表示第l层的偏至值。shape(b^l)=shape(a^l)=(n_l,1)
除第一层外其他层中每个圆即神经元,都是一个LR模型。
\begin{alignedat}{2} a^0 &= x_0 \\ z^1&=W^1a^0+b^1 \\ a^1&=\sigma(z^1) \\ ... \\ z^l&=W^la^{l-1}+b^l \\ a^l&=\sigma(z^l)=(\sigma(z^l_0),\sigma(z^l_1),...,\sigma(z^l_{n_l}))^T \\ y' &= a^L \end{alignedat}
(这里的输出是通用输出,没按图1来。输出层神经元有n_L个,模型共L层)
上述的计算值,从输入层开始,逐层向前传播,经过隐层到达输出层。所以叫做前向传播

反向传播

反向传播用于计算每一层W^l,b^l的梯度,用于更新
现在模型建立好了,对于一个样本的输入,可以得到一个预测值y'
现在需要设计一个损失函数来指导模型学习
C=f(y',y)
那有了损失函数后,就要求损失函数关于参数的梯度了,即需要求解
\frac{\partial C}{\partial W^l},\frac{\partial C}{\partial b^l},l=1,2,...L

\begin{alignedat}{2} \frac{\partial C}{\partial W^L}&=\frac{\partial C}{\partial z^L}\frac{\partial z^L}{\partial W^L} \\ &=(\frac{\partial C}{\partial a^L}\odot\frac{\partial a^L}{\partial z^L})\frac{\partial z^L}{\partial W^L} \\ &=(C'(a^L)\odot \sigma'(z^L))(a^{L-1})^T \\\\ \frac{\partial C}{\partial b^L}&=\frac{\partial C}{\partial z^L}\frac{\partial z^L}{\partial b^L} \\ &=C'(a^L)\odot \sigma'(z^L) \end{alignedat}
其中
C'(a^l)=(C'(a^l_1),C'(a^l_2),...,C'(a^l_{nl}))^T
\frac{\partial a^l}{\partial z^l}=\sigma'(z^l) =(\sigma'(z^l_1),\sigma'(z^l_2),...,\sigma'(z^l_{n_l}) )^T
C'(a^l)\odot \sigma'(z^l)=(C'(a^l_1)\sigma'(z^l_1),C'(a^l_2)\sigma'(z^l_2),...,C'(a^l_{nl})\sigma'(z^l_{n_l}) )^T

我们发现,其实\frac{\partial z^l}{\partial W^l}是很容易求解的,而且求导过程与其他层没有关系。那么关键就是求\frac{\partial C}{\partial z^l}
我们令\delta^l=\frac{\partial C}{\partial z^l}
\delta^L=C'(a^L)\odot \sigma'(z^L)=(C'(a^l_L)\sigma'(z^l_L),C'(a^l_L)\sigma'(z^l_L),...,C'(a^l_{nL})\sigma'(z^l_{n_L}) )^T, shape=(n_L,1)
如果已知\delta^l 根据链式求导法则尤其是链式向量求导这个 (其实这里最重要的就是要确保链式求导的维度最终组合和初始的维度相同,那么对于向量求导就会涉及到转置和位置的交换。如果不觉得有问题,完全可以先对几个元素求导,然后总结出规律后来指导向量求导的组合)
我们首先约定一些东西。

  • 每次的损失是一个标量,而W则是矩阵。当我们求\frac{\partial C}{\partial W^l}时,要保证结果和W的shape时一样的,即shape(\frac{\partial C}{\partial W^l})=shape(W^l)=(n_l,n_{l-1})
  • z^l,a^l,b^l 都是列向量
    \begin{alignedat}{2} shape(\delta^l)&=(n_l,1)\\\\ \delta^{l-1}&=\frac{\partial C}{\partial z^{l-1}}=\frac{\partial C}{\partial z^l}\frac{\partial z^l}{\partial z^{l-1}}=\delta^l\frac{\partial z^l}{\partial z^{l-1}},shape=(n_{l-1},1)\\\\ \frac{\partial z^l}{\partial z^{l-1}}&=\frac{\partial z^l}{\partial a^{l-1}}\odot\frac{\partial a^{l-1}}{\partial z^{l-1}}=(W^{l})^T\odot\sigma'(z^{l-1}),shape=(n_{l-1},n_l) \\\\ so\\\\ \delta^{l-1}&=\delta^l((W^{l})^T\odot\sigma'(z^{l-1})) \end{alignedat}
    但是发现如上式那么组合的话,维度上是不相容的,所以应该调整成如下式:
    \delta^{l-1}=((W^{l})^T\odot\sigma'(z^{l-1}))\delta^l=(W^{l})^T\delta^l\odot\sigma'(z^{l-1})
    所以反向传播算法,关键记住如下几点:
    • \delta^L=C'(a^L)\odot\sigma'(z^L)

    • \delta^l=(W^{l+1})^T\delta^{l+1}\odot\sigma'(z^l)

    • \frac{\partial C}{\partial W^l}=\delta^l (a^{l-1})^T

    • \frac{\partial C}{\partial b^l}=\delta^l

MLP 一般训练过程

随机梯度下降:

对于一个样本(x,y)输入模型
首先,前向传播记录下每一层激活值a^l以及权重W^l
然后,计算\delta^L以及逐层\delta^l
然后,计算每层权重的梯度\frac{\partial C}{\partial W^l},\frac{\partial C}{\partial b^l}
最后,更新每层的权重
W^l=W^l-\eta\frac{\partial C}{\partial W^l}
b^l=W^l-\eta\frac{\partial C}{\partial b^l}

批量梯度下降

对于m个样本(x,y),依次输入模型
首先,前向传播记录下每一层激活值a^l以及权重W^l
然后,计算\delta^L以及逐层\delta^l
然后,计算每层权重的梯度\frac{\partial C}{\partial W^l},\frac{\partial C}{\partial b^l}
最后,更新每层的权重
W^l=W^l-\eta\sum\frac{\partial C}{\partial W^l}
b^l=W^l-\eta\sum\frac{\partial C}{\partial b^l}

不同损失函数与激活函数所带来的训练的不同

看不清楚请看:https://www.jianshu.com/p/1d6d7b4857d6

C=\frac{1}{2}(y'-y)^2,\sigma=sigmoid() C=-ylogy'-(1-y)log(1-y'),\sigma=sigmoid() C=-\sum y_ilogy_i'\sigma^l=sigmoid(),\sigma^L=softmax()
导数 C'=y'-y,\sigma'=\sigma(1-\sigma) C'=\frac{1-y}{1-y'}-\frac{y}{y'},\sigma'=\sigma(1-\sigma) C'(a^L_i)=-\frac{1}{a^L_i} , softmax'(z^L_i)=a^L_i(1-a^L_i)
\delta^L=C'\odot\sigma' (a^L-y)\odot\sigma(1-\sigma) a^L-y (0,0,...,a^L_i-1,..,0)^T
\frac{\partial C}{\partial W^L} \delta^L(a^{L-1})^T \delta^L(a^{L-1})^T \delta^L(a^{L-1})^T
\delta^l (W^{l+1})^T\delta^{l+1}\odot\sigma'(z^l) (W^{l+1})^T\delta^{l+1}\odot\sigma'(z^l) (W^{l+1})^T\delta^{l+1}\odot\sigma'(z^l)
\frac{\partial C}{\partial W^l} \delta^l(a^{l-1})^T \delta^l(a^{l-1})^T \delta^l(a^{l-1})^T
\frac{\partial C}{\partial b^l} \delta^l \delta^l \delta^l

对比前两列,最大的不同在\delta^L,使用交叉熵的模型少乘了一个\sigma',而\sigma'往往是很小的(只在0附近比较大),所以第二列会比第一列收敛快。

但关键是在\delta^l,大家都一样,但是随着l的不断减小,累乘的\sigma'越来越多,最后导致有的\delta^l越来越小趋近于0造成梯度消失(因为0<sigmoid'\le0.25)。这样导致底层网络权重得不到有效训练。同样,有的激活函数导数可能会很容易>1,这样就会造成梯度爆炸。总结起来就是,由于反向传播算法的固有缺陷,在网络层数过多时,会出现梯度学习问题,为了解决有如下常用方法,具体见上链接。

  • 针对梯度爆炸,可以人为设定最大的梯度值,超过了就等于最大梯度值。这种做法叫梯度剪切。另外也可以对权重做正则化,来确保每次权重都不会太大。
  • 针对梯度消失,如果激活函数的导数=1,那么就不会出现消失或爆炸,于是提出了ReLu激活函数
    另外还有残差网络,batchnorm等技术

根本上就是针对BP的\delta^l的组成,要么从激活函数导数入手,要么从权重W入手,要么从连乘的传递结构入手等等。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容