当数据量不够大的时候,有啥方法可以提高CNN训练效果

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了当数据量不够大的时候,有啥方法可以提高CNN训练效果相关的知识,希望对你有一定的参考价值。

做图像增强,扭曲翻转等等,keras里面好像有集成 参考技术A 利用pre_trained模型进行迁移学习,fine-tuning预训练模型 参考技术B 原来还是摆脱不了大数据。。。。有没有一个标准,多少张训练集才不算样本少。

随机梯度下降批尺寸的影响

随机梯度下降批尺寸有什么影响呢???

当数据量足够大的时候可以适当的减小batch_size,由于数据量太大,内存不够。但盲目减少会导致无法收敛,batch_size=1时为在线学习,

也是标准的SGD,这样学习,如果数据量不大,noise数据存在时,模型容易被noise带偏,如果数据量足够大,noise的影响会被“冲淡”,对模型几乎不影响。

Batch_Size(批尺寸)是机器学习中一个重要参数,涉及诸多矛盾,下面逐一展开。

首先,为什么需要有 Batch_Size 这个参数?

Batch 的选择,首先决定的是下降的方向。如果数据集比较小,完全可以采用全数据集 ( Full Batch Learning )的形式,这样做至少有 2 个好处:

其一,由全数据集确定的方向能够更好地代表样本总体,从而更准确地朝向极值所在的方向。

其二,由于不同权重的梯度值差别巨大,因此选取一个全局的学习率很困难。Full Batch Learning 可以使用 Rprop 只基于梯度符号并且针对性单独

更新各权值。

对于更大的数据集,以上 2 个好处又变成了 2 个坏处:

其一,随着数据集的海量增长和内存限制,一次性载入所有的数据进来变得越来越不可行。

其二,以 Rprop 的方式迭代,会由于各个 Batch 之间的采样差异性,各次梯度修正值相互抵消,无法修正。这才有了后来 RMSProp 的妥协方案。

既然 Full Batch Learning 并不适用大数据集,那么走向另一个极端怎么样?

所谓另一个极端,就是每次只训练一个样本,即 Batch_Size = 1。这就是在线学习(Online Learning)。

线性神经元在均方误差代价函数的错误面是一个抛物面,横截面是椭圆。对于多层神经元、非线性网络,在局部依然近似是抛物面。

使用在线学习,每次修正方向以各自样本的梯度方向修正,横冲直撞各自为政,难以达到收敛。如图所示:

技术分享图片

可不可以选择一个适中的 Batch_Size 值呢?

当然可以,这就是批梯度下降法(Mini-batches Learning)。因为如果数据集足够充分,那么用一半(甚至少得多)的数据训练算出来的梯度与用全部数据训练出来的梯度是几乎一样的。

在合理范围内,增大 Batch_Size 有何好处?

  • 内存利用率提高了,大矩阵乘法的并行化效率提高。
  • 跑完一次 epoch(全数据集)所需的迭代次数减少,对于相同数据量的处理速度进一步加快。
  • 在一定范围内,一般来说 Batch_Size 越大,其确定的下降方向越准,引起训练震荡越小。

盲目增大 Batch_Size 有何坏处?

  • 内存利用率提高了,但是内存容量可能撑不住了。
  • 跑完一次 epoch(全数据集)所需的迭代次数减少,要想达到相同的精度,其所花费的时间大大增加了,从而对参数的修正也就显得更加缓慢。
  • Batch_Size 增大到一定程度,其确定的下降方向已经基本不再变化。

调节 Batch_Size 对训练效果影响到底如何?

技术分享图片

技术分享图片

 运行结果如上图所示,其中绝对时间做了标幺化处理。运行结果与上文分析相印证:

  • Batch_Size 太小,算法在 200 epoches 内不收敛。
  • 随着 Batch_Size 增大,处理相同数据量的速度越快。
  • 随着 Batch_Size 增大,达到相同精度所需要的 epoch 数量越来越多。
  • 由于上述两种因素的矛盾, Batch_Size 增大到某个时候,达到时间上的最优。
  • 由于最终收敛精度会陷入不同的局部极值,因此 Batch_Size 增大到某些时候,达到最终收敛精度上的最优。
  • 过大的batchsize的结果是网络很容易收敛到一些不好的局部最优点。同样太小的batch也存在一些问题,比如训练速度很慢,训练不容易收敛等。
  • 具体的batch size的选取和训练集的样本数目相关。

 

---------------------
作者:ycheng_sjtu
来源:CSDN
原文:https://blog.csdn.net/ycheng_sjtu/article/details/49804041

 




以上是关于当数据量不够大的时候,有啥方法可以提高CNN训练效果的主要内容,如果未能解决你的问题,请参考以下文章

当机器学习遇到数据量不够时,这几个 Python 技巧为你化解难题

数据并行:提升训练吞吐的高效方法 |深度学习分布式训练专题

数据量太大,分页查询变慢,有啥优化查询的方法吗

深度学习中的Data Augmentation方法(转)基于keras

Windows文件服务器共享的时候分配权限对于目录深文件量大的情况下,权限写入非常慢,有啥办法可以解决

有啥方法可以提高 PySpark 输出的效率吗?