机器学习——神经网络参数的反向传播算法

代价函数

逻辑回归代价函数:
在这里插入图片描述
神经网络代价函数:
在这里插入图片描述

反向传播算法(back propagation algorithm)

δ(l)j 第l层第j个单元的误差

eg. Layer L=4
δ(4)j =a(4)j -yi

δ(3) =(θ(3))Tδ(4),*g(z(3)) (θ是权重)
δ(2) =(θ(2))Tδ(3),*g(z(2))

反向传播算法过程:

训练集:{(x(1),y(1)),…(x(m),y(m))}
set Δ(l)ij =0
在这里插入图片描述
在这里插入图片描述

梯度检测

  • 使用反向传播计算DVec(展开D(1),D(2),D(3)
  • 计算gradApprox在这里插入图片描述
  • 确保DVec与gradApprox之间只有几位小数的差距
  • 关掉梯度检验,使用反向传播算法

组合到一起

训练一个神经网络:

  • 输入单元:特征x的维度
  • 输出单元:类的个数
  • 合理的设置:一个隐藏层,如果大于1,在每一个隐藏层有相同数量的隐藏单元(通常越多越好)

训练神经网络的步骤

  1. 构建一个神经网络,随机初始化权重
  2. 执行前向传播算法,任意输入x(i),得到hθ(x(i))
  3. 通过代码计算出代价函数J(θ)
  4. 执行反向传播算法算出编导数项(J(θ)关于参数θ的偏导数)
  5. 梯度检查
  6. 使用梯度下降算法或更高级算法和反向传播算法去最小化代价函数
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值