美文网首页
数据集shuffle的重要性

数据集shuffle的重要性

作者: top_小酱油 | 来源:发表于2019-04-06 22:44 被阅读0次
image

深度学习项目,在训练之前,一般均会对数据集做shuffle,打乱数据之间的顺序,让数据随机化,这样可以避免过拟合。

那为什么shuffle可以有效的避免过拟合?

以猫狗分类为例,

假如数据集是

Dog,Dog,Dog,... ,Dog,Dog,Dog,Cat,Cat,Cat,Cat,... ,Cat,Cat

所有的狗都在猫前面,如果不shuffle,模型训练一段时间内只看到了Dog,必然会过拟合于Dog,一段时间内又只能看到Cat,必然又过拟合于Cat,这样的模型泛化能力必然很差。

那如果Dog和Cat一直交替,会不会就不过拟合了呢?

Dog,Cat,Dog,Cat,Dog ,Cat,Dog,...

依然会过拟合,模型是会记住训练数据路线的,为啥呢?

首先我们需要明白固定的数据集顺序,意味着给定迭代步,对应此迭代步的训练数据是固定的。

假如目标函数是J(θ1, θ2),则使用梯度下降优化J 。给定权重取值 θ1、θ2和迭代步step的情况下,固定的数据集顺序意味着固定的训练样本,也就意味着权值更新的方向是固定的,而无顺序的数据集,意味着更新方向是随机的。如下图中的A点,如果固定的更新方向是红色箭头方向,则很难收敛到最优点,而如果更新方向是随机的,则有可能就沿着白色箭头方向收敛到最优点。

image

所以固定的数据集顺序,严重限制了梯度优化方向的可选择性,导致收敛点选择空间严重变少,容易导致过拟合。

所以模型是会记住数据路线的,所以shuffle很重要,一定要shuffle。

相关文章

  • 数据集shuffle的重要性

    深度学习项目,在训练之前,一般均会对数据集做shuffle,打乱数据之间的顺序,让数据随机化,这样可以避免过拟合。...

  • tf.data.Dataset.shuffle(buffer_s

    tensorflow中的数据集类Dataset有一个shuffle方法,用来打乱数据集中数据顺序,训练时非常常用。...

  • 【Spark】Spark 存储原理--shuffle 过程

    本篇结构: Spark Shuffle 的发展 Spark Shuffle 中数据结构 Spark Shuffle...

  • 对数据集进行shuffle操作

    Keras使用的数据类型是numpy,有时候需要手动打乱数据集。

  • Spark数据倾斜问题

    什么是数据倾斜 在对一个数据集进行并行处理的过程中,当执行Shuffle操作的时候,是通过Key来进行Value的...

  • MapReduce shuffle

    shuffle过程 shuffle概念 shuffle的本意是洗牌、混洗的意思,把一组有规则的数据尽量打乱成无规则...

  • NumPy记录

    1.对数据进行shuffle 直接shuffle数组:1⃣️np.random.permutation 2⃣️np...

  • MapReduce Shuffle 和 Spark Shuffl

    更多大数据技术干货,欢迎关注“大数据技术进阶”微信公众号。 Shuffle简介 Shuffle的本意是洗牌、混洗的...

  • Spark Shuffle基础

    Shuffle 基本概念 概述: Shuffle描述着数据从map task输出到reduce task 输入的这...

  • hadoop之MapReduce---Shuffle机制

    Shuffle机制 Map方法之后,Reduce方法之前的数据处理过程称之为Shuffle Partition分区...

网友评论

      本文标题:数据集shuffle的重要性

      本文链接:https://www.haomeiwen.com/subject/dlgdiqtx.html