Search code examples
pandasstatisticsmedianoutliersstandard-deviation

Outliers in data


I have a dataset like so -

15643, 14087, 12020, 8402, 7875, 3250, 2688, 2654, 2501, 2482, 1246, 1214, 1171, 1165, 1048, 897, 849, 579, 382, 285, 222, 168, 115, 92, 71, 57, 56, 51, 47, 43, 40, 31, 29, 29, 29, 29, 28, 22, 20, 19, 18, 18, 17, 15, 14, 14, 12, 12, 11, 11, 10, 9, 9, 8, 8, 8, 8, 7, 6, 5, 5, 5, 4, 4, 4, 3, 3, 3, 3, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1

Based on domain knowledge, I know that larger values are the only ones we want to include in our analysis. How do I determine where to cut off our analysis? Should it be don't include 15 and lower or 50 and lower etc?


Solution

  • You can do a distribution check with quantile function. Then you can remove values below lowest 1 percentile or 2 percentile. Following is an example:

    import numpy as np
    data = np.array(data)
    print(np.quantile(data, (.01, .02)))
    

    Another method is calculating the inter quartile range (IQR) and setting lowest bar for analysis is Q1-1.5*IQR

    Q1, Q3 = np.quantile(data, (0.25, 0.75))
    data_floor = Q1 - 1.5 * (Q3 - Q1)