如何计算抛硬币的pvalue?

2024-06-12 08:27:01 发布

您现在位置:Python中文网/ 问答频道 /正文

我试图计算以下抛硬币示例的p值:

n = 5
h = 4  # out of 5 toss 4 are head

# calculate pvalue using equal or more extreme cases
pval = P(4H1T) + P(4T1H) + P(5H) + P(5T)
     = 5/32    + 5/32    + 1/32  + 1/32
     = 12/32
     = 0.375

但当我尝试标准方法时:

from scipy import stats

phat = h / n
p0 = 0.5  # for unbiased coin
q0 = 1 - p0
z = (phat - p0) / sqrt(p0q0/n)      

pval = 1 - stats.norm.cdf(z)

我得到:

0.08985624743949994.

问题1

如何使用pythonscipystats(answer=0.375)获得类似的结果

参考资料

在这个statquest视频中,作者解释了如何使用相等或更多的极值获得pvalue,我们得到了0.375

但是在这里

使用给出的公式,我们得到另一个答案

问题2

哪种方法好,我们可以比较pvalue和alpha


Tags: of方法https示例wwwstats硬币out
2条回答

这是一个二项分布的情况。遵循scipy.stats.binom_test中的官方示例:

import numpy as np
from scipy import stats

alpha = 0.05
pval = stats.binom_test(4, n=5, p=0.5, alternative='two-sided')

print('pvalue = ', pval)
if pval< alpha:
    print("We Reject the Null Hypothesis.")
else:
    print("We Accept the Null Hypothesis.")

输出

pvalue =  0.375
We Accept the Null Hypothesis.

z值是正态分布的标准值,不是概率。此外,连续分布中精确值的概率有点棘手。这种情况听起来最适合二项分布

from scipy.stats import binom
binom.pmf(4,5,0.5)

哪些产出:

0.15625

相关问题 更多 >