當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


Python Scipy stats.gausshyper()用法及代碼示例


scipy.stats.gausshyper()是高斯超幾何連續隨機變量,使用標準格式和一些形狀參數定義該變量以完成其規格。

參數:
-> q :上下尾概率
-> x :分位數
-> loc :[可選]位置參數。默認值= 0
-> scale:[可選]比例參數。默認值= 1
-> size :[int型元組,可選]形狀或隨機變量。
-> a,b,c,z:形狀參數
-> moments:[可選]由字母['mvsk']組成; “ m” =均值,“ v” =方差,
“ s” = Fisher的歪斜,“ k” = Fisher的峰度。 (默認=“ MV”)。


Results:高斯超幾何連續隨機變量

代碼1:創建高斯超幾何連續隨機變量

from scipy.stats import gausshyper   
  
numargs = gausshyper  .numargs 
[a, b, c, z] = [0.7, ] * numargs 
rv = gausshyper  (a, b, c, z) 
  
print ("RV:\n", rv) 

輸出:

RV:
 <scipy.stats._distn_infrastructure.rv_frozen object at 0x000001E399AB5A58>

代碼2:高斯超幾何隨機變量和概率分布。

import numpy as np 
quantile = np.arange (0.01, 1, 0.1) 
   
# Random Variates 
R = gausshyper .rvs(a, b, c, z, scale = 2,  size = 10) 
print ("Random Variates:\n", R) 
  
# PDF 
R = gausshyper .pdf(a, b, c, z, quantile, loc = 0, scale = 1) 
print ("\nProbability Distribution:\n", R)

輸出:

Random Variates:
 [1.45915082 0.58184603 1.91448022 1.23505789 0.9253147  0.36681062
 0.19628827 0.91795248 1.95313724 1.63728124]

Probability Distribution:
 [0.83983413 0.82838709 0.81749232 0.80714179 0.79731436 0.78798255
 0.77911641 0.77068563 0.76266077 0.75501387]

代碼3:圖形表示。

import numpy as np 
import matplotlib.pyplot as plt 
  
distribution = np.linspace(0, np.minimum(rv.dist.b, 3)) 
print("Distribution:\n", distribution) 
  
plot = plt.plot(distribution, rv.pdf(distribution))

輸出:

Distribution:
 [0.         0.02040816 0.04081633 0.06122449 0.08163265 0.10204082
 0.12244898 0.14285714 0.16326531 0.18367347 0.20408163 0.2244898
 0.24489796 0.26530612 0.28571429 0.30612245 0.32653061 0.34693878
 0.36734694 0.3877551  0.40816327 0.42857143 0.44897959 0.46938776
 0.48979592 0.51020408 0.53061224 0.55102041 0.57142857 0.59183673
 0.6122449  0.63265306 0.65306122 0.67346939 0.69387755 0.71428571
 0.73469388 0.75510204 0.7755102  0.79591837 0.81632653 0.83673469
 0.85714286 0.87755102 0.89795918 0.91836735 0.93877551 0.95918367
 0.97959184 1.        ]

代碼4:更改位置參數

import matplotlib.pyplot as plt 
import numpy as np 
  
x = np.linspace(0, 5, 100) 
  
# Varying positional arguments 
y1 = gausshyper .pdf(x, a, z, 1, 3) 
y2 = gausshyper .pdf(x, a, z, 1, 4) 
plt.plot(x, y1, "*", x, y2, "r--")

輸出:



相關用法


注:本文由純淨天空篩選整理自vishal3096大神的英文原創作品 scipy stats.gausshyper() | Python。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。