用Python學分析 - 二項分佈

 

二項分佈(Binomial Distribution)
對Bernoulli試驗序列的n次序列,結局A出現的次數x的機率分佈服從二項分佈
- 兩分類變量並不是必定會服從二項分佈
- 模擬伯努利試驗中n次獨立的重複,每次試驗成功的機率爲piide

特徵值
- 均值(數學指望)和方差:
  - 不一樣的值,二項式分佈有着不一樣的形態和偏度值
  - pi值越大,呈負偏度;pi值越小,呈正偏度
  - 當 pi = 0.5時,分佈是對稱的
  - 當 n * pi 與 n * (1-pi) >= 5 時,樣本比例p的抽樣分佈趨向於正態分佈
- 當 n 較大,pi不太極端時,能夠採用正態近似方法計算機率分佈規律spa

應用code

- 博彩行業的規則設定
- 正常值範圍的設定(例:醫療行業)orm

# 對二項分佈概念的理解及計算blog

 1 # 對二項分佈概念的理解及計算
 2 
 3 from scipy.stats import binom  4 
 5 pi = .3; n = 10
 6 k = 2; m = 8
 7 
 8 # 求成功次數爲i的機率
 9 pk = 0 10 for i in range(n): 11     p = binom( n, pi ).pmf( i ) 12     if i <= k: 13         pk += p 14     print( 'P(x = {0:d}) = {1:.4f}'.format( i , p )) 15 
16 # 求成功小於k次的機率
17 print('-'*20) 18 p = binom( n, pi ).cdf( k ) 19 print( 'P(x <= {0:d}) = {1:.4f}'.format( k , p )) 20 print( '比較累加值:', pk) 21 
22 # 求成功大於k次,小於m次的機率
23 print('-'*20) 24 p = binom( n, pi ).cdf( m ) - binom( n, pi ).cdf( k ) 25 print( 'P({0:d} < x <= {1:d}) = {2:.4f}'.format( k , m, p ))
View Code

運行結果:ip

 

# 比較:p對結果的影響ci

 1 import numpy as np  2 from scipy.stats import binom  3 import matplotlib.pyplot as plt  4 
 5 num_trials = 60
 6 x = np.arange(num_trials)  7 
 8 plt.plot(x, binom(num_trials, 0.2).pmf(x), 'o-', label='p=0.2')  9 plt.plot(x, binom(num_trials, 0.5).pmf(x), 'o-', label='p=0.5') 10 plt.plot(x, binom(num_trials, 0.7).pmf(x), 'o-', label='p=0.7') 11 plt.legend() 12 plt.title( '二項分佈:p對結果的影響' ) 13 plt.show() 14 print('當p不一樣時,成功m次的能性的最大值都出如今均值處,對應機率爲n*p')
View Code

結果:數學

# 比較:n對結果的影響it

 1 import numpy as np  2 from scipy.stats import binom  3 import matplotlib.pyplot as plt  4 
 5 n1 = 10
 6 n2 = 15
 7 n3 = 20
 8 p = 0.5
 9 x = np.arange( max([n1,n2,n3])+1 ) 10 
11 plt.plot( x, binom.pmf( x, p = 0.5, n = n1), 'o-', label='n=10') 12 plt.plot( x, binom.pmf( x, p = 0.5, n = n2), 'o-', label='n=15') 13 plt.plot( x, binom.pmf( x, p = 0.5, n = n3), 'o-', label='n=20') 14 plt.legend() 15 plt.title( '二項分佈:n對結果的影響' ) 16 plt.show() 17 print('當N不一樣時,成功m次的可能性的最大值都出如今均值處,對應機率爲n*p。')
View Code

結果:io

相關文章
相關標籤/搜索