1

我有一个航班延误数据集,并尝试在采样前将该集拆分为训练集和测试集。准时案件约占总数据的 80%,延误案件约占总数据的 20%。

通常在机器学习中,训练集和测试集大小的比例为 8:2。但是数据太不平衡了。所以考虑到极端情况,大部分列车数据是准时情况,大部分测试数据是延迟情况,准确性会很差。

所以我的问题是如何正确拆分不平衡的数据集来训练和测试集?

4

3 回答 3

2

可能仅通过使用训练和测试的比率,您可能无法获得正确的预测和结果。

如果您正在处理不平衡的数据集,您应该尝试重新采样技术以获得更好的结果。在数据集不平衡的情况下,分类器总是“预测”最常见的类,而不对特征进行任何分析。

在数据集不平衡的情况下,还可以使用不同的指标进行性能测量,例如 F1 分数等

请通过下面的链接,它会让你更清楚。

为分类问题拆分数据集的正确程序是什么?

克利夫兰心脏病数据集 - 无法描述该类

于 2019-07-27T23:24:37.260 回答
0

从 50/50 开始,然后继续将设置更改为 60/40、70/30、80/20、90/10。宣布所有结果并得出一些结论。在我的航班延误预测项目的一项工作中,我使用了 60/40 数据库并使用 MLP NN 获得了 86.8% 的准确度。

于 2019-07-27T08:33:55.563 回答
0

您可以采取两种方法。

  1. 一个简单的方法:不对数据集进行预处理,而是对数据集进行仔细采样​​,以便两个类在测试和训练子集中以相同的比例表示。您可以通过首先按类拆分,然后从两组中随机抽样来做到这一点。

    import sklearn
    
    XclassA = dataX[0]  # TODO: change to split by class
    XclassB = dataX[1]
    YclassA = dataY[0]
    YclassB = dataY[1]
    
    XclassA_train, XclassA_test, YclassA_train, YclassA_test = sklearn.model_selection.train_test_split(XclassA, YclassA, test_size=0.2, random_state=42)
    
    
    XclassB_train, XclassB_test, YclassB_train, YclassB_test = sklearn.model_selection.train_test_split(XclassB, YclassB, test_size=0.2, random_state=42)
    
    Xclass_train = XclassA_train + XclassB_train
    Yclass_train = YclassA_train + YclassB_train
    
  2. 一个更复杂,可以说更好的一个,你可以先尝试平衡你的数据集。为此,您可以使用多种技术之一(欠采样、过采样、SMOTE、AdaSYN、Tomek 链接等)。我建议您查看imbalanced-learn打包方法。完成平衡后,您可以使用典型方法使用普通的测试/训练拆分,而无需任何额外的中间步骤。

第二种方法更好,不仅从拆分数据的角度来看,而且从速度甚至训练模型的能力来看(对于严重不平衡的数据集,不能保证有效)。

于 2020-02-12T13:09:05.260 回答