Python實(shí)現(xiàn)的概率分布運(yùn)算操作示例
本文實(shí)例講述了Python實(shí)現(xiàn)的概率分布運(yùn)算操作。分享給大家供大家參考,具體如下:
1. 二項(xiàng)分布(離散)
import numpy as np from scipy import stats import matplotlib.pyplot as plt ''' # 二項(xiàng)分布 (binomial distribution) # 前提:獨(dú)立重復(fù)試驗(yàn)、有放回、只有兩個(gè)結(jié)果 # 二項(xiàng)分布指出,隨機(jī)一次試驗(yàn)出現(xiàn)事件A的概率如果為p,那么在重復(fù)n次試驗(yàn)中出現(xiàn)k次事件A的概率為: # f(n,k,p) = choose(n, k) * p**k * (1-p)**(n-k) ''' # ①定義二項(xiàng)分布的基本信息 p = 0.4 # 事件A概率0.4 n = 5 # 重復(fù)實(shí)驗(yàn)5次 k = np.arange(n+1) # 6種可能出現(xiàn)的結(jié)果 #k = np.linspace(stats.binom.ppf(0.01,n,p), stats.binom.ppf(0.99,n,p), n+1) #另一種方式 # ②計(jì)算二項(xiàng)分布的概率質(zhì)量分布 (probability mass function) # 之所以稱為質(zhì)量,是因?yàn)殡x散的點(diǎn),默認(rèn)體積(即寬度)為1 # P(X=x) --> 是概率 probs = stats.binom.pmf(k, n, p) #array([ 0.07776, 0.2592 , 0.3456 , 0.2304 , 0.0768 , 0.01024]) #plt.plot(k, probs) # ③計(jì)算二項(xiàng)分布的累積概率 (cumulative density function) # P(X<=x) --> 也是概率 cumsum_probs = stats.binom.cdf(k, n, p) #array([ 0.07776, 0.33696, 0.68256, 0.91296, 0.98976, 1. ]) # ④根據(jù)累積概率得到對(duì)應(yīng)的k,這里偷懶,直接用了上面的cumsum_probs k2 = stats.binom.ppf(cumsum_probs, n, p) #array([0, 1, 2, 3, 4, 5]) # ⑤偽造符合二項(xiàng)分布的隨機(jī)變量 (random variates) X = stats.binom.rvs(n,p,size=20) #array([2, 3, 1, 2, 2, 2, 1, 2, 2, 3, 3, 0, 1, 1, 1, 2, 3, 4, 0, 3]) #⑧作出上面滿足二項(xiàng)分布隨機(jī)變量的頻數(shù)直方圖(類似group by) plt.hist(X) #⑨作出上面滿足二項(xiàng)分布隨機(jī)變量的頻率分布直方圖 plt.hist(X, normed=True) plt.show()
2. 正態(tài)分布(連續(xù))
''' 標(biāo)準(zhǔn)正態(tài)分布 密度函數(shù):f(x) = exp(-x**2/2)/sqrt(2*pi) ''' x = np.linspace(stats.norm.ppf(0.01), stats.norm.ppf(0.99), 100) # 概率密度分布函數(shù)(Probability density function) # 之所以稱為密度,是因?yàn)檫B續(xù)的點(diǎn),默認(rèn)體積為0 # f(x) --> 不是概率 probs = norm.pdf(x) # plt.plot(x, probs, 'r-', lw=5, alpha=0.6, label='norm pdf') # 累積概率密度函數(shù) Cumulative density function # 定積分 ∫_-oo^a f(x)dx --> 是概率 cumsum_probs = stats.norm.cdf(x) # 偽造符合正態(tài)分布的隨機(jī)變量X # 通過(guò)loc和scale參數(shù)可以指定隨機(jī)變量的偏移和縮放參數(shù)。對(duì)于正態(tài)分布的隨機(jī)變量來(lái)說(shuō),這兩個(gè)參數(shù)相當(dāng)于指定其期望值和標(biāo)準(zhǔn)差: X = stats.norm.rvs(loc=1.0, scale=2.0, size=1000) #⑨作出上面正態(tài)分布隨機(jī)變量的頻率分布直方圖 plt.hist(X, normed=True, histtype='stepfilled', alpha=0.2) plt.legend(loc='best', frameon=False) plt.show() # 對(duì)給定的數(shù)據(jù)進(jìn)行參數(shù)估計(jì)。這里偷懶了,就用上面的X mean, std = stats.norm.fit(X) #array(1.01810091), array(2.00046946)
附:NumPy、SciPy與MatPlotLib模塊下載地址:
NumPy: http://sourceforge.net/projects/numpy/files/NumPy/1.9.2/
SciPy: http://sourceforge.net/projects/scipy/files/scipy/0.15.1/
MatPlotLib: http://matplotlib.org/downloads.html
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)學(xué)運(yùn)算技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
- Python統(tǒng)計(jì)列表中的重復(fù)項(xiàng)出現(xiàn)的次數(shù)的方法
- python實(shí)現(xiàn)簡(jiǎn)單中文詞頻統(tǒng)計(jì)示例
- Python實(shí)現(xiàn)統(tǒng)計(jì)單詞出現(xiàn)的個(gè)數(shù)
- Python實(shí)現(xiàn)對(duì)excel文件列表值進(jìn)行統(tǒng)計(jì)的方法
- python統(tǒng)計(jì)一個(gè)文本中重復(fù)行數(shù)的方法
- 用Python中的字典來(lái)處理索引統(tǒng)計(jì)的方法
- Python中統(tǒng)計(jì)函數(shù)運(yùn)行耗時(shí)的方法
- python統(tǒng)計(jì)cpu利用率的方法
- python數(shù)據(jù)結(jié)構(gòu)之二叉樹的統(tǒng)計(jì)與轉(zhuǎn)換實(shí)例
- python高斯分布概率密度函數(shù)的使用詳解
- python實(shí)現(xiàn)beta分布概率密度函數(shù)的方法
- Python統(tǒng)計(jì)分析模塊statistics用法示例
相關(guān)文章
pandas數(shù)據(jù)框,統(tǒng)計(jì)某列數(shù)據(jù)對(duì)應(yīng)的個(gè)數(shù)方法
下面小編就為大家分享一篇pandas數(shù)據(jù)框,統(tǒng)計(jì)某列數(shù)據(jù)對(duì)應(yīng)的個(gè)數(shù)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-04-04Python并發(fā)編程隊(duì)列與多線程最快發(fā)送http請(qǐng)求方式
假如有一個(gè)文件,里面有10萬(wàn)個(gè)url,需要對(duì)每個(gè)url發(fā)送http請(qǐng)求,并打印請(qǐng)求結(jié)果的狀態(tài)碼,如何編寫代碼盡可能快的完成這些任務(wù)呢2021-09-09python中的生成器實(shí)現(xiàn)周期性報(bào)文發(fā)送功能
本文主要介紹了python中的生成器實(shí)現(xiàn)周期性報(bào)文發(fā)送功能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03PyTorch實(shí)現(xiàn)重寫/改寫Dataset并載入Dataloader
這篇文章主要介紹了PyTorch實(shí)現(xiàn)重寫/改寫Dataset并載入Dataloader,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07使用python實(shí)現(xiàn)省市三級(jí)菜單效果
本文給大家分享的是使用使用python實(shí)現(xiàn)省市三級(jí)菜單效果的代碼,非常的實(shí)用,有需要的小伙伴可以參考下。2016-01-01Python使用scrapy抓取網(wǎng)站sitemap信息的方法
這篇文章主要介紹了Python使用scrapy抓取網(wǎng)站sitemap信息的方法,涉及Python框架scrapy的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-04-04Python生命游戲?qū)崿F(xiàn)原理及過(guò)程解析(附源代碼)
這篇文章主要介紹了Python生命游戲?qū)崿F(xiàn)原理及過(guò)程解析(附源代碼),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08