gpt4 book ai didi

应用于行的所有成对组合的 Python pandas 函数

转载 作者:太空狗 更新时间:2023-10-29 21:56:38 24 4
gpt4 key购买 nike

我正在尝试对 pandas 数据框中所有成对的行组合运行一个函数(相关):

stats = dict()
for l in itertools.combinations(dat.index.tolist(),2):
stats[l] = pearsonr(dat.loc[l[0],:], dat.loc[l[1],:]) # stores (r, p)

当然这很慢,我想知道如何通过使用类似 apply() 或其他方式来做同样的事情。

注意:我知道我可以直接找到数据帧与 pandas corr() 的相关性函数,但是它不返回关联的 p 值(我需要它用于过滤目的)

最佳答案

这应该可以加快您的速度。定义函数 Pearson,修改自 Primer 链接中的文档:

def Pearson(r, n=len(dat)):
r = max(min(r, 1.0), -1.0)
df = n - 2
if abs(r) == 1.0:
prob = 0.0
else:
t_squared = r**2 * (df / ((1.0 - r) * (1.0 + r)))
prob = betai(0.5*df, 0.5, df/(df+t_squared))

return (r,prob)

使用applymap它对 dat.corr 进行逐元素操作。您正在将相关系数 r 传递给 Pearson:

np.random.seed(10)
dat = pd.DataFrame(np.random.randn(5, 5))
dat[0] = np.arange(5) # seed two correlated cols
dat[1] = np.arange(5) # ^^^

dat.corr().applymap(Pearson)

0 1 2 3 4
0 (1.0, 0.0) (1.0, 0.0) (0.713010395675, 0.176397305541) (0.971681374885, 0.00569624513678) (0.0188249871501, 0.97603269768)
1 (1.0, 0.0) (1.0, 0.0) (0.713010395675, 0.176397305541) (0.971681374885, 0.00569624513678) (0.0188249871501, 0.97603269768)
2 (0.713010395675, 0.176397305541) (0.713010395675, 0.176397305541) (1.0, 0.0) (0.549623945218, 0.337230071385) (-0.280514871109, 0.647578381153)
3 (0.971681374885, 0.00569624513678) (0.971681374885, 0.00569624513678) (0.549623945218, 0.337230071385) (1.0, 0.0) (0.176622737448, 0.77629170593)
4 (0.0188249871501, 0.97603269768) (0.0188249871501, 0.97603269768) (-0.280514871109, 0.647578381153) (0.176622737448, 0.77629170593) (1.0, 0.0)

dat 很大时,您确实看到了使用此方法的加速,但由于元素操作,它仍然很慢。

np.random.seed(10)
dat = pd.DataFrame(np.random.randn(100, 100))

%%timeit
dat.corr().applymap(Pearson)

10 loops, best of 3: 118 ms per loop

%%timeit
stats = dict()

for l in combinations(dat.index.tolist(),2):
stats[l] = pearsonr(dat.loc[l[0],:], dat.loc[l[1],:])

1 loops, best of 3: 1.56 s per loop

关于应用于行的所有成对组合的 Python pandas 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34903637/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com