• 采样方法-数据不均衡


    References :

    https://towardsdatascience.com/dealing-with-class-imbalanced-datasets-for-classification-2cc6fad99fd9

    https://www.cnblogs.com/massquantity/p/9382710.html

    https://www.jianshu.com/p/be343414dd24

    a. Undersampling.

    Say, you have 40,000 positive sample and 2,000 negative samples in your dataset. We will use this as our running example henceforth. What you can do is just randomly pick up 2,000 positive samples out of the 40,000, all 2,000 negative samples, and train and validate your model only on these 4,000 samples. This will allow you to use all the classification algorithms in just the usual way. This method is easy to implement and runs very fast as well. However, one downside is that you are potentially discarding the 38,000 positive sample you have and that data is going down the drain.

    To overcome this, you can create an ensemble of models wherein each model uses a different set of 2,000 positive sample and all 2,000 negative samples and is trained and validated separately. Then on your test set, you take a majority vote of all these models. This allows you to take into account all of your data without causing an imbalance. Furthermore, you can even use different algorithms for different sets and then your ensemble would be even more robust. However, this would be a bit computationally expensive.

    b. Oversampling

    In this method, you generate more samples of your minority class. You can do this either by first creating a generative model and then creating new samples or by just picking existing samples with replacement. There exist a number of oversampling techniques such as SMOTE, ADASYN, etc. You will have to see which works best for your use case. Also, oversampling itself is a computationally expensive procedure. The major advantage is that this allows one model of yours to take all of your data into consideration at once and also helps you generate new data.

       

       

       

    SMOTE 算法(Synthetic Minority Oversampling Technique)

       

       

     Borderline SMOTE

    只考虑 k近邻中有超过一半是多数样本的少数样本(dangerous 点)

    ADASYN 算(Adaptive synthetic)

       

       

       

       

       

     weight balancing

    weight balancing to make all classes contribute equally to our loss.

     对于多数样本,可以乘以一个小的系数,使得loss变小,对于少数样本,可以乘以一个大的系数,使得loss变大

  • 相关阅读:
    selenium的持续问题解决
    为什么使用Nginx
    [转]性能测试场景设计深度解析
    [转]CentOS7修改时区的正确姿势
    [转]利用Fiddler模拟恶劣网络环境
    [转]什么是微服务
    [转] WebSocket 教程
    [转] Python实现简单的Web服务器
    shell修改配置文件参数
    [转] linux shell 字符串操作(长度,查找,替换)详解
  • 原文地址:https://www.cnblogs.com/wuxiangli/p/10447109.html
Copyright © 2020-2023  润新知