【机器学习】神经网络(二)——反向传播算法

反向传播算法是目前用来训练人工神经网络的最常用且最有效的算法。
摘要由CSDN通过智能技术生成

前言:前篇博文神经网络(一)中我们使用了神经网络模型来识别0-9十个数字。但是,模型参数都是教程已经给好的,我们还没有知道这些参数是怎么训练出来的。本文就会介绍神经网络的学习算法——反向传播算法(Back Propagation, BP)。

一、反向传播算法
反向传播算法是目前用来训练人工神经网络的最常用且最有效的算法。其主要思想是:
(1)将训练集数据输入到神经网络的输入层,经过隐藏层,最后达到输出层并输出结果,这是神经网络的前向传播过程;
(2)由于神经网络的输出结果与实际结果有误差,则计算估计值与实际值之间的误差,并将该误差从输出层向隐藏层反向传播,直至传播到输入层;
(3)在反向传播的过程中,根据误差调整各种参数的值;不断迭代上述过程,直至收敛。

二、算法推导
1.神经网络的代价函数(cost function):

J(Θ)=1m[i=1mk=1Ky(i)klog(hΘ(x(i)))k+(1y(i)k)log(1(hΘ(x(i)))k)]+λ2l=1L1i=1sl+1j=1sl+1(Θ(l)ji)2

前一项的目的是使所有单元的误差和最小(采用对数损失函数),后一项是正则化项,旨在控制模型复杂度,防止过拟合;
对比Logistic回归:
J(θ)=1m[i=1my(i)loghθ(x(
  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值