histogram函数 python_python中直方图的概率密度函数

可以使用累积密度函数从任意分布生成随机数,如described here。

使用直方图生成平滑的累积密度函数并不简单;您可以使用插值,例如scipy.interpolate.interp1d(),用于存储箱中心之间的值,这对于存储箱和项目数量相当大的直方图来说效果很好。然而,你必须决定概率函数尾部的形式,即对于小于或大于最大bin的值。您可以基于将高斯拟合到直方图的例子给出分布高斯尾),或者根据您的问题给出任何其他形式的尾,或者简单地截断分布。

示例:import numpy

import scipy.interpolate

import random

import matplotlib.pyplot as pyplot

# create some normally distributed values and make a histogram

a = numpy.random.normal(size=10000)

counts, bins = numpy.histogram(a, bins=100, density=True)

cum_counts = numpy.cumsum(counts)

bin_widths = (bins[1:] - bins[:-1])

# generate more values with same distribution

x = cum_counts*bin_widths

y = bins[1:]

inverse_density_function = scipy.interpolate.interp1d(x, y)

b = numpy.zeros(10000)

for i in range(len( b )):

u = random.uniform( x[0], x[-1] )

b[i] = inverse_density_function( u )

# plot both

pyplot.hist(a, 100)

pyplot.hist(b, 100)

pyplot.show()

这不处理尾部,它可以更好地处理垃圾箱边缘,但它可以让您开始使用直方图生成具有相同分布的更多值。

另外,你也可以试着用一些数值来拟合一个特定的已知分布(我认为这是你在问题中提到的),但是上面的非参数方法更通用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值