【发布时间】:2019-02-04 19:04:17
【问题描述】:
import numpy as np
import matplotlib.pyplot as plt
from scipy import stats
observed = [0.294, 0.2955, 0.235, 0.2536, 0.2423, 0.2844, 0.2099, 0.2355, 0.2946, 0.3388, 0.2202, 0.2523, 0.2209, 0.2707, 0.1885, 0.2414, 0.2846, 0.328, 0.2265, 0.2563, 0.2345, 0.2845, 0.1787, 0.2392, 0.2777, 0.3076, 0.2108, 0.2477, 0.234, 0.2696, 0.1839, 0.2344, 0.2872, 0.3224, 0.2152, 0.2593, 0.2295, 0.2702, 0.1876, 0.2331, 0.2809, 0.3316, 0.2099, 0.2814, 0.2174, 0.2516, 0.2029, 0.2282, 0.2697, 0.3424, 0.2259, 0.2626, 0.2187, 0.2502, 0.2161, 0.2194, 0.2628, 0.3296, 0.2323, 0.2557, 0.2215, 0.2383, 0.2166, 0.2315, 0.2757, 0.3163, 0.2311, 0.2479, 0.2199, 0.2418, 0.1938, 0.2394, 0.2718, 0.3297, 0.2346, 0.2523, 0.2262, 0.2481, 0.2118, 0.241, 0.271, 0.3525, 0.2323, 0.2513, 0.2313, 0.2476, 0.232, 0.2295, 0.2645, 0.3386, 0.2334, 0.2631, 0.226, 0.2603, 0.2334, 0.2375, 0.2744, 0.3491, 0.2052, 0.2473, 0.228, 0.2448, 0.2189, 0.2149]
a, b, loc, scale = stats.beta.fit(observed,floc=0,fscale=1)
ax = plt.subplot(111)
ax.hist(observed, alpha=0.75, color='green', bins=104, density=True)
ax.plot(np.linspace(0, 1, 100), stats.beta.pdf(np.linspace(0, 1, 100), a, b))
plt.show()
α和β不正常(α=6.056697373013153,β=409078.57804704335) 合身的形象也是不合理的。直方图和 beta 分布在 Y 轴上的高度不同。
平均数据约为0.25,但根据beta分布的期望值计算,6.05/(6.05+409078.57)=1.47891162469e-05。这似乎违反直觉。
【问题讨论】:
-
嗨!欢迎来到 StackOverflow!现在无法重现您观察到的内容,因为没有足够的代码/信息来运行您发布的内容。这使得重现您的错误变得不必要。我建议您修改您的问题以包含minimal example。
-
请包括
import,一个最小的试验数据集(输入),你的预期输出是什么。清楚地陈述你的问题。构建minimal reproducible example 是解决方案非常重要的一步。 -
@norok2 我们亲爱的医生。充满了神秘的火焰。对不起,我是中国人,英语不是我的强项,请见谅。现在我已经编辑了问题
-
不用担心语言问题,我们并非都是母语人士。
observed您的标准箱和模态范围是 (0, 1) 吗?因为您的直方图远非 Beta 分布。 -
这是意料之中的,特别是如果您使用与直方图中样本大小一样多的 bin。此外,强制
loc和scale为0和1可能不是最好的做法,但你应该比我更清楚。
标签: python statistics distribution mle