Dropout: A Simple Way to Prevent Neural Networks from Overtting(泛读)

一.文献名字和作者

    Dropout: A Simple Way to Prevent Neural Networks from Overtting
   

二.阅读时间

    2014年11月19日



三.文献的贡献点

    这篇文章主要还是复述了一遍那篇引入dropout的文章《Improving neural networks by preventing co-adaptation of feature detectors》里面的观点:1.Dropout能够克服Overfitting,同时也是一种能够高效整合不同网络结构的技术;2.使用权值梯度的L2模的上限能够获得比使用权值的L2模的惩罚项更好的效果,这样也能叫做max-norm惩罚项。
    使用Dropout的训练过程和测试过程可以用下图表示,在训练过程,每一个隐藏层神经元以概率p的形式进行激活,而在测试过程中,所有的隐藏层神经元都进行激活,但是,每一个隐藏层神经元的输出都乘以p。

    相比于DAEs,dropout主要是用在有监督训练的过程中,其主要思想也是有借鉴DAEs的感觉。
    在使用预训练得到的网络进行Dropout,需要将获得的权值乘以1/p,这样才可以保持在使用Dropout的过程中,神经与的激活和预训练过程程度一样。
    用于避免神经网络Overfitting的惩罚方法有几种:L2衰减,lasso,KL稀疏和最大模惩罚
    对于Dropout来说,一个附件的作用就是能够使得隐藏层神经元出现稀疏性。
    作者也提出了一个Dropout Restricted Boltzmann Machines,具体内容还没自己看,mark一下,以后用到DNN的时候再来深入研究下。
    作者也发现了,使用Dropout的缺点就是会使得训练时间增加,是没使用Dropout网络的2-3倍,因此,加速Dropout也是未来一个研究点。一个在减少时间的同时也获得dropout效果的方法就是加入一个和Dropout效果相同的惩罚项。







版权所有,欢迎转载,转载请注明出处,谢谢微笑













  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: dropout是一种简单的方法,用于防止神经网络过度拟合。它通过在训练过程中随机地将一些神经元的输出设置为零,从而减少了神经元之间的依赖关系,使得网络更加鲁棒和泛化能力更强。这种方法可以有效地提高模型的性能,并且在实际应用中得到了广泛的应用。 ### 回答2: dropout是一种简单有效的防止神经网络过拟合的方法,其原理是在训练神经网络时随机选择一部分神经元不参与计算。具体来说,对于每个训练样本,我们以一定的概率(通常是50%)随机将其中一些神经元的输出设为0。这样做有两个好处:一是可以减少每个神经元的依赖性,从而使网络更加健壮,避免“依赖某些特定神经元”的问题;二是可以防止过拟合,因为每个神经元都有一定的概率被“关闭”,这样可以避免某些神经元在处理训练数据时过于自信,而在处理测试数据时失效。实际实现时,dropout可以在每个层之间添加dropout层或者在每个全连接层之前添加dropout操作。使用dropout时需要注意,dropout的概率不能过高,否则会使网络无法学习到足够的信息。同时,dropout在测试时需要关闭,因为在测试时我们需要利用所有的神经元进行最终的预测。总的来说,dropout是一种简单而有效的防止神经网络过拟合的方法,可以提高网络的泛化性能和鲁棒性。 ### 回答3: 随着深度学习的发展,人们逐渐意识到过拟合问题的严重性。为了解决这个问题,大量的复杂度更高的网络或方法被提出,如L1,L2正则化,数据增强,dropout等。本文将重点介绍dropout这种简单且有效的方法。 dropout是由Geoff Hinton在2012年提出的。其基本思想是在训练神经网络时,通过以概率p(通常为0.5)随机地使一些隐含层单元输出为0。而在预测时,dropout仅仅将所有的单元都保留下来,并将其输出乘以概率p,以避免模型过度依赖于任何一个单元。 dropout的实现方法非常简单,主要包括两个步骤。第一步是在训练时,以概率p决定哪些单元要被保留,哪些要被丢弃。第二步是在预测时,将所有的单元都保留下来,同时将其输出与概率p相乘。 dropout具有以下几个优点: 1. dropout可以显著减少过拟合。通过在模型中随机丢弃一些单元,可以有效地减少模型之间的相互依赖,避免复杂模型过度学习训练数据,从而提高泛化能力。 2. dropout可以提高模型学习速度。相比其他正则化方法,dropout的运算速度非常快,只需要在前向传播中做一些简单的随机化,不会对反向传播过程带来额外的复杂度。 3. dropout可以解决模型中的特征选择问题。dropout的随机丢弃可以促使每个神经元的输出都得到充分利用,即使是那些在训练集中很少出现的特征也会得到一定程度的学习,从而避免了一些过拟合问题。 总之,dropout是一种简单且实用的正则化方法,可以显著减少神经网络过拟合的问题,同时也具有很高的运行速度和模型准确性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值