首页 > 编程知识 正文

python画经验分布函数,如何用python画正态分布

时间:2023-05-05 17:18:44 阅读:264876 作者:3980

我知道statsmodels.tools.tools.ECDF,但是由于计算empricial累积分布函数(ECDF)是非常直接的,而且我希望最小化项目中的依赖项,所以我希望手动编写它。

在给定的list()/np.array()Pandas.Series中,每个元素的ECDF可以计算为given in Wikipedia:

下面是Pandas数据框dfser,我想得到values列的ecdf。文中还给出了两个一次线性解。

有没有更快的方法可以做到这一点?速度在我的应用程序中很重要。# Note that in my case indices are unique identifiers so I cannot reset them.

import numpy as np

import pandas as pd

# all indices are unique, but there may be duplicate measurement values (that belong to different indices).

dfser = pd.DataFrame({'group':['a','b','b','a','d','c','e','e','c','a','b','d','d','c','d','e','e','a'],

'values':[2.01899E-06, 1.12186E-07, 8.97467E-07, 2.91257E-06, 1.93733E-05,

0.00017889, 0.000120963, 4.27643E-07, 3.33614E-07, 2.08352E-12,

1.39478E-05, 4.28255E-08, 9.7619E-06, 8.51787E-09, 1.28344E-09,

3.5063E-05, 0.01732035,2.08352E-12]},

index = [123, 532, 235, 645, 747, 856, 345, 245, 845, 248, 901, 712, 162, 126,

198,748, 127,395] )

# My 1st Solution - list comprehension

dfser['ecdf']=[sum( dfser['values'] <= x)/float(dfser['values'].size) for x in dfser['values']]

# My 2nd Solution - ranking

dfser['rank'] = dfser['values'].rank(ascending = 0)

dfser['ecdf_r']=(len(dfser)-dfser['rank']+1)/len(dfser)

dfser

group values ecdf rank ecdf_r

123 a 2.018990e-06 0.555556 9.0 0.555556

532 b 1.121860e-07 0.333333 13.0 0.333333

235 b 8.974670e-07 0.500000 10.0 0.500000

645 a 2.912570e-06 0.611111 8.0 0.611111

747 d 1.937330e-05 0.777778 5.0 0.777778

856 c 1.788900e-04 0.944444 2.0 0.944444

345 e 1.209630e-04 0.888889 3.0 0.888889

245 e 4.276430e-07 0.444444 11.0 0.444444

845 c 3.336140e-07 0.388889 12.0 0.388889

248 a 2.083520e-12 0.111111 17.5 0.083333

901 b 1.394780e-05 0.722222 6.0 0.722222

712 d 4.282550e-08 0.277778 14.0 0.277778

162 d 9.761900e-06 0.666667 7.0 0.666667

126 c 8.517870e-09 0.222222 15.0 0.222222

198 d 1.283440e-09 0.166667 16.0 0.166667

748 e 3.506300e-05 0.833333 4.0 0.833333

127 e 1.732035e-02 1.000000 1.0 1.000000

395 a 2.083520e-12 0.111111 17.5 0.083333

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。