# 6.5.7 实例：用于MLP 训练的反向传播

这一节将6.5.4的算法进一步细化。

假设这是一个三层的MLP网络。\
输入层：X 隐藏层：参数为W(1)，输入为X，激活函数为H=max{0, XW(1)}\
输出层：参数为W(2)，输入为H，用于计算类的非归一化对数的概率。

\[?]类的非归一化对数概率？

$J\_{MLE}$为非归一化的对数概率的交叉熵。\
正则项为W(1)和W(2)的二阶范式。\
最终cost为：

$$
J = J\_{MLE} + \lambda\left(\sum\_{i,j}(W^{(1)}*{i,j})^2 + (W^{(2)}*{i,j})^2\right)
$$

图为这个网络的正反传播的计算图：\
![](http://windmissing.github.io/images_for_gitbook/Bible-DeepLearning/6.png)\
\[?]反向传播算法可以自动生成梯度？这句话什么意思？

作为一个例子，我们利用反向传播算法来训练多层感知机。

这里，我们考虑一个具有单个隐藏层的非常简单的多层感知机。 为了训练这个模型，我们将使用小批量随机梯度下降算法。 反向传播算法用于计算单个小批量上的代价的梯度。

> **\[sucess]**\
> ![](/files/-M4DmULBnO86rzm0Gbis)\
> $\nabla\_y C = \[\frac{\partial C}{\partial y\_1} \frac{\partial C}{\partial y\_2} \cdots \frac{\partial C}{\partial y\_n}]^\top$

具体来说，我们使用训练集上的一小批量实例，将其规范化为一个设计矩阵$X$以及相关联的类标签向量$y$。 网络计算隐藏特征层$H=\max{0, XW^{(1)}}$。 为了简化表示，我们在这个模型中不使用偏置。 假设我们的图语言包含relu操作，该操作可以对$\max{0,Z}$表达式的每个元素分别进行计算。 类的非归一化对数概率的预测将随后由$HW^{(2)}$ 给出。 假设我们的图语言包含cross*entropy操作，用以计算目标$y$和由这些未归一化对数概率定义的概率分布间的交叉熵。 所得到的交叉熵定义了代价函数$J*\text{MLE}$。最小化这个交叉熵将执行对分类器的最大似然估计。

> **\[success]** 分类问题的交叉熵代价函数\
> 假设真实结果为$\hat y = 0 0 0 \cdots 1 \cdots 0]$，1在第r个位置\
> 预测结果为y。\
> 交叉熵代价为$C = -\log y\_r$，其中y来自预测结果，r来自真实结果\
> 具体来说：
>
> $$
> \begin{aligned}
> \frac{\partial C}{\partial y\_i} & = & -\frac{1}{y\_r} && i=r \\
> & = & 0 && i \ne r
> \end{aligned}
> $$

然而，为了使得这个例子更加真实，我们也包含一个正则项。 总的代价函数为

$$
\begin{aligned}
J = J\_{\text{MLE}} + \lambda \left ( \sum\_{i, j} \left (W\_{i, j}^{(1)} \right )^2 + \sum\_{i, j} \left (W\_{i, j}^{(2)} \right)^2 \right )
\end{aligned}
$$

包含了交叉熵和系数为$\lambda$的权重衰减项。 它的计算图在图6.11中给出。

> **\[success]** 网上找了不带正则化的计算图\
> ![](/files/-M49IQ88K9GITOa-LoQc)\
> 图中的上标1、2不是幂的意思。\
> $\frac{\partial C}{\partial y}$在上面已经讲过\
> $\frac{\partial y}{\partial z^{(2)}}$是一个Jacobian矩阵。i=j时，$\frac{\partial y*i}{\partial z\_j^{(2)}}=$激活函数的偏导。$i \ne j$时偏导为0。（如果激活函数是softmax函数，这个矩阵就不是对角矩阵了）。*\
> *$\frac{\partial z\_i^{(i)}}{\partial a\_j^{(1)}} = W*{ij}^2$\
> $\frac{\partial z^{(2)}}{\partial W^{(2)}}$是一个三维的张量。i=j时，$\frac{\partial z*i^{(i)}}{\partial W*{jk}^{(2)}} = a\_k^{(1)}$。$i \ne j$时偏导为0。\
> ![](/files/-M4DmULE0zH3krHL1BBA)

这个示例的梯度计算图实在太大，以致绘制或者阅读都将是乏味的。 这显示出了反向传播算法的优点之一，即它可以自动生成梯度，而这种计算对于软件工程师来说需要进行直观但冗长的手动推导。

> **\[warning]** 自动生成梯度？

我们可以通过观察图6.11中的正向传播图来粗略地描述反向传播算法的行为。 为了训练，我们希望计算$\nabl&#x61;*{W^{(1)}} J$和$\nabla*{W^{(2)}} J$。 有两种不同的路径从$J$后退到权重：一条通过交叉熵代价，另一条通过权重衰减代价。 权重衰减代价相对简单，它总是对$W^{(i)}$上的梯度贡献$2\lambda W^{(i)}$。

另一条通过交叉熵代价的路径稍微复杂一些。 令$G$是由cross*entropy操作提供的对未归一化对数概率$U^{(2)}$的梯度。 反向传播算法现在需要探索两个不同的分支。 在较短的分支上，它使用对矩阵乘法的第二个变量的反向传播规则，将$H^\top G$加到$W^{(2)}$的梯度上。 另一条更长些的路径沿着网络逐步下降。 首先，反向传播算法使用对矩阵乘法的第一个变量的反向传播规则，计算$\nabla*{H} J = GW^{(2)\top}$。 接下来，relu操作使用其反向传播规则对先前梯度的部分位置清零，这些位置对应着$U^{(1)}$中所有小于0的元素。记上述结果为$G'$。 反向传播算法的最后一步是使用对matmul操作的第二个变量的反向传播规则，将$X^\top G'$加到$W^{(1)}$的梯度上。

> **\[warning]** 这一段没看懂？

在计算了这些梯度以后，梯度下降算法或者其他优化算法所要做的就是使用这些梯度来更新参数。

对于MLP，计算成本主要来源于矩阵乘法。 在前向传播阶段，我们乘以每个权重矩阵，得到了$O(w)$数量的乘-加，其中$w$是权重的数量。 在反向传播阶段，我们乘以每个权重矩阵的转置，这具有相同的计算成本。 算法主要的存储成本是我们需要将输入存储到隐藏层的非线性中去。 这些值从被计算时开始存储，直到反向过程回到了同一点。 因此存储成本是$O(mn\_h)$，其中$m$是小批量中样本的数目，$n\_h$是隐藏单元的数量。


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://windmising.gitbook.io/bible-deeplearning/0introduction/0introduction-2/7mlptraining.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
