Python使用numpy产生正态分布随机数的向量或矩阵操作示例


Posted in Python onAugust 22, 2018

本文实例讲述了Python使用numpy产生正态分布随机数的向量或矩阵操作。分享给大家供大家参考,具体如下:

简单来说,正态分布(Normal distribution)又名高斯分布(Gaussian distribution),是一个在数学、物理及工程等领域都非常重要的概率分布,在统计学的许多方面有着重大的影响力。一般的正态分布可以通过标准正态分布配合数学期望向量和协方差矩阵得到。如下代码,可以得到满足一维和二维正态分布的样本。

示例1(一维正态分布):

# coding=utf-8
'''
作者:采石工
来源:知乎
'''
import numpy as np
from numpy.linalg import cholesky
import matplotlib.pyplot as plt
sampleNo = 1000;
# 一维正态分布
# 下面三种方式是等效的
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)
# 二维正态分布
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()

运行结果:

Python使用numpy产生正态分布随机数的向量或矩阵操作示例

示例2(正态分布):

#-*- coding:utf-8 -*-
# Python实现正态分布
# 绘制正态分布概率密度函数
import numpy as np
import matplotlib.pyplot as plt
import math
u = 0  # 均值μ
u01 = -2
sig = math.sqrt(0.2) # 标准差δ
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()

运行结果:

Python使用numpy产生正态分布随机数的向量或矩阵操作示例

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
python使用在线API查询IP对应的地理位置信息实例
Jun 01 Python
Python基于scrapy采集数据时使用代理服务器的方法
Apr 16 Python
将Python代码嵌入C++程序进行编写的实例
Jul 31 Python
Python实现代码统计工具(终极篇)
Jul 04 Python
python输入整条数据分割存入数组的方法
Nov 13 Python
python批量图片处理简单示例
Aug 06 Python
Pandas时间序列:重采样及频率转换方式
Dec 26 Python
python标准库sys和OS的函数使用方法与实例详解
Feb 12 Python
Django 解决开发自定义抛出异常的问题
May 21 Python
基于python和flask实现http接口过程解析
Jun 15 Python
Selenium python时间控件输入问题解决方案
Jul 22 Python
python cookie反爬处理的实现
Nov 01 Python
用Python将mysql数据导出成json的方法
Aug 21 #Python
windows下python 3.6.4安装配置图文教程
Aug 21 #Python
Python多进程与服务器并发原理及用法实例分析
Aug 21 #Python
Python socket实现的简单通信功能示例
Aug 21 #Python
Python多进程原理与用法分析
Aug 21 #Python
python安装twisted的问题解析
Aug 21 #Python
使用python的pandas库读取csv文件保存至mysql数据库
Aug 20 #Python
You might like
CodeIgniter输出中文乱码的两种解决办法
2014/06/12 PHP
ThinkPHP实现动态包含文件的方法
2014/11/29 PHP
浅析ThinkPHP缓存之快速缓存(F方法)和动态缓存(S方法)(日常整理)
2015/10/26 PHP
PHP中抽象类、接口的区别与选择分析
2016/03/29 PHP
PHP 传输会话curl函数的实例详解
2017/09/12 PHP
PHP配置ZendOpcache插件加速
2019/02/14 PHP
利用jquery包将字符串生成二维码图片
2013/09/12 Javascript
制作jquery遮罩层效果导航菜单代码分享
2013/12/25 Javascript
JS记录用户登录次数实现代码
2014/01/15 Javascript
js实现内容显示并使用json传输数据
2016/03/16 Javascript
jQuery Easyui 验证两次密码输入是否相等
2016/05/13 Javascript
ionic js 复选框 与普通的 HTML 复选框到底有没区别
2016/06/06 Javascript
判断数组的最佳方法(推荐)
2016/10/11 Javascript
详解ElementUI之表单验证、数据绑定、路由跳转
2017/06/21 Javascript
vue实现前进刷新后退不刷新效果
2018/01/26 Javascript
angularjs 动态从后台获取下拉框的值方法
2018/08/13 Javascript
详解webpack打包时排除其中一个css、js文件或单独打包一个css、js文件(两种方法)
2018/10/26 Javascript
javascript实现异形滚动轮播
2019/11/28 Javascript
[03:58]兄弟们,回来开黑了!DOTA2昔日战友招募宣传视频
2016/07/17 DOTA
[03:23:49]2016.12.17日完美“圣”典全回顾
2016/12/19 DOTA
Python文件处理
2016/02/29 Python
利用Python中unittest实现简单的单元测试实例详解
2017/01/09 Python
pandas 快速处理 date_time 日期格式方法
2018/11/12 Python
详解Python中is和==的区别
2019/03/21 Python
详解Python给照片换底色(蓝底换红底)
2019/03/22 Python
Pytoch之torchvision.transforms图像变换实例
2019/12/30 Python
matplotlib对象拾取事件处理的实现
2021/01/14 Python
英国领先的新鲜松露和最好的松露产品供应商:TruffleHunter
2019/08/26 全球购物
名词解释型面试题(主要是网络)
2013/12/27 面试题
加油口号大全
2014/06/13 职场文书
元旦趣味活动方案
2014/08/22 职场文书
政府四风问题整改措施
2014/10/04 职场文书
2016廉洁教育心得体会
2016/01/20 职场文书
2016年党员岗位承诺书
2016/03/24 职场文书
MyBatis XPathParser解析器使用范例详解
2022/07/15 Java/Android
ssh服务器拒绝了密码 请再试一次已解决(亲测有效)
2022/08/14 Servers