首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用scipy gaussian_kde获得概率密度函数?

如何使用scipy gaussian_kde获得概率密度函数?
EN

Stack Overflow用户
提问于 2018-07-26 17:55:53
回答 1查看 720关注 0票数 0

我有一个保存在1D列表中的1D数据集。获得概率密度函数的最佳方法是什么?我尝试了使用scipy gaussian_kde的常用方法。

代码语言:javascript
复制
array = np.array(values)
kde = gaussian_kde(array)
x = np.linspace(0, 50, 500)
plt.plot(x, kde(x), label="", color="blue")
plt.legend(loc='best')
plt.show()

产生的图不是预期的概率密度函数,因为对于每个x,概率密度函数的值应该在0到1之间。

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-05-16 17:27:07

使用以下代码。

代码语言:javascript
复制
import os
import matplotlib.pyplot as plt
import sys
import math
import numpy as np
import scipy.stats as st
from scipy.stats._continuous_distns import _distn_names
from scipy.optimize import curve_fit

def get_pdf(latency_list):
    np_array = np.array(latency_list)  # convert the list into a numpy array
    ag = st.gaussian_kde(np_array)  # calculate the kernel density function for the latency values
    # list of equidistant values in the range of the latency values
    x = np.linspace(min(latency_list), max(latency_list), (max(latency_list) - min(latency_list)) * 10)
    y = ag(x)  # evaluate the latency values for each x value
    return x, y
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51536068

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档