笔记-计算图

在神经网络算法中,数据总是在各个神经层中传播,其中,沿着输入层到输出层方向的传播称为前向传播,沿着输出层到输入层方向的传播称为反向传播。那么我们应该如何理解传播呢?传播在神经网络中又是如何起作用的呢?下面我们通过一个例子来解释。

对于一个三元函数J(a,b,c)=3(a+bc),我们的计算过程可以分为以下三步:

1.u=bc

2.v=a+u

3.J=3v

表示成计算图就是:

以上计算过程我们称为前向传播,也就是数据传播方向是从左到右的过程。

那么反向传播便是数据从右到左的过程,一般是对函数进行求导。在微积分中有一个链式法则,简单来说,便是导数\frac{\partial J}{\partial a}=\frac{\partial J}{\partial v}\cdot \frac{\partial v}{\partial a}

也就是计算\frac{\partial J}{\partial a}可以分为三步:

1.计算\frac{\partial J}{\partial v}

2.计算\frac{\partial v}{\partial a}

3.计算\frac{\partial J}{\partial a}=\frac{\partial J}{\partial v}\cdot \frac{\partial v}{\partial a}

表示成计算图就是(图中红色线条指示的部分):

这个从右到左的过程便是反向传播,它是计算机实现梯度下降法的具体编程方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值