Python使用numpy產(chǎn)生正態(tài)分布隨機數(shù)的向量或矩陣操作示例
本文實例講述了Python使用numpy產(chǎn)生正態(tài)分布隨機數(shù)的向量或矩陣操作。分享給大家供大家參考,具體如下:
簡單來說,正態(tài)分布(Normal distribution)又名高斯分布(Gaussian distribution),是一個在數(shù)學(xué)、物理及工程等領(lǐng)域都非常重要的概率分布,在統(tǒng)計學(xué)的許多方面有著重大的影響力。一般的正態(tài)分布可以通過標(biāo)準(zhǔn)正態(tài)分布配合數(shù)學(xué)期望向量和協(xié)方差矩陣得到。如下代碼,可以得到滿足一維和二維正態(tài)分布的樣本。
示例1(一維正態(tài)分布):
# coding=utf-8 ''' 作者:采石工 來源:知乎 ''' import numpy as np from numpy.linalg import cholesky import matplotlib.pyplot as plt sampleNo = 1000; # 一維正態(tài)分布 # 下面三種方式是等效的 mu = 3 sigma = 0.1 np.random.seed(0) s = np.random.normal(mu, sigma, sampleNo ) plt.subplot(141) plt.hist(s, 30, normed=True) np.random.seed(0) s = sigma * np.random.randn(sampleNo ) + mu plt.subplot(142) plt.hist(s, 30, normed=True) np.random.seed(0) s = sigma * np.random.standard_normal(sampleNo ) + mu plt.subplot(143) plt.hist(s, 30, normed=True) # 二維正態(tài)分布 mu = np.array([[1, 5]]) Sigma = np.array([[1, 0.5], [1.5, 3]]) R = cholesky(Sigma) s = np.dot(np.random.randn(sampleNo, 2), R) + mu plt.subplot(144) # 注意繪制的是散點圖,而不是直方圖 plt.plot(s[:,0],s[:,1],'+') plt.show()
運行結(jié)果:
示例2(正態(tài)分布):
#-*- coding:utf-8 -*- # Python實現(xiàn)正態(tài)分布 # 繪制正態(tài)分布概率密度函數(shù) import numpy as np import matplotlib.pyplot as plt import math u = 0 # 均值μ u01 = -2 sig = math.sqrt(0.2) # 標(biāo)準(zhǔn)差δ x = np.linspace(u - 3*sig, u + 3*sig, 50) y_sig = np.exp(-(x - u) ** 2 /(2* sig **2))/(math.sqrt(2*math.pi)*sig) print x print "="*20 print y_sig plt.plot(x, y_sig, "r-", linewidth=2) plt.grid(True) plt.show()
運行結(jié)果:
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進階經(jīng)典教程》
希望本文所述對大家Python程序設(shè)計有所幫助。
- Python中的Numpy入門教程
- 關(guān)于Numpy數(shù)據(jù)類型對象(dtype)使用詳解
- 在NumPy中創(chuàng)建空數(shù)組/矩陣的方法
- python中numpy.zeros(np.zeros)的使用方法
- Python numpy 提取矩陣的某一行或某一列的實例
- 詳解Numpy數(shù)組轉(zhuǎn)置的三種方法T、transpose、swapaxes
- Numpy數(shù)據(jù)類型轉(zhuǎn)換astype,dtype的方法
- numpy中的delete刪除數(shù)組整行和整列的實例
- 淺談numpy數(shù)組的幾種排序方式
- 簡單快捷:NumPy入門教程的環(huán)境設(shè)置
相關(guān)文章
Python數(shù)據(jù)可視化 pyecharts實現(xiàn)各種統(tǒng)計圖表過程詳解
這篇文章主要介紹了Python數(shù)據(jù)可視化 pyecharts實現(xiàn)各種統(tǒng)計圖表過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-08-08

Python實現(xiàn)ssh批量登錄并執(zhí)行命令

python創(chuàng)建學(xué)生成績管理系統(tǒng)