今天学习了用python生成仿真数据的一些基本方法和技巧,写成博客和大家分享一下。

本篇博客主要讲解如何从给定参数的的正态分布/均匀分布中生成随机数以及如何以给定概率从数字列表抽取某数字或从区间列表的某一区间内生成随机数,按照内容将博客分为3部分,并附上代码。

1 从给定参数的正态分布中生成随机数

当考虑从正态分布中生成随机数时,应当首先知道正态分布的均值和方差(标准差),有了这些,就可以调用python中现有的模块和函数来生成随机数了。这里调用了Numpy模块中的random.normal函数,由于逻辑非参简单,所有直接贴上代码如下:

import numpy as np

# 定义从正态分布中获取随机数的函数

def get_normal_random_number(loc, scale):

"""

:param loc: 正态分布的均值

:param scale: 正态分布的标准差

:return:从正态分布中产生的随机数

"""

# 正态分布中的随机数生成

number = np.random.normal(loc=loc, scale=scale)

# 返回值

return number

# 主模块

if __name__ == "__main__":

# 函数调用

n = get_normal_random_number(loc=2, scale=2)

# 打印结果

print(n)

# 结果:3.275192443463058

2 从给定参数的均匀分布中获取随机数的函数

考虑从均匀分布中获取随机数的时候,要事先知道均匀分布的下界和上界,然后调用Numpy模块的random.uniform函数生成随机数。

import numpy as np

# 定义从均匀分布中获取随机数的函数

def get_uniform_random_number(low, high):

"""

:param low: 均匀分布的下界

:param high: 均匀分布的上界

:return: 从均匀分布中产生的随机数

"""

# 均匀分布的随机数生成

number = np.random.uniform(low, high)

# 返回值

return number

# 主模块

if __name__ == "__main__":

# 函数调用

n = get_uniform_random_number(low=2, high=4)

# 打印结果

print(n)

# 结果:2.4462417140153114

3 按照指定概率生成随机数

有时候我们需要按照指定的概率生成随机数,比如已知盒子中每种颜色的球的比例,猜测下一次取出的球的颜色。在这里介绍的问题和上面的例子相似,要求给定一个概率列表,从列表对应的数字列表或区间列表中生成随机数,分两部分讨论。

3.1 按照指定概率从数字列表中随机抽取数字

假设给定一个数字列表和一个与之对应的概率列表,两个列表对应位置的元素组成的元组即表示该数字在数字列表中以多大的概率出现,那么如何根据这些已知条件从数字列表中按概率抽取随机数呢?在这里我们考虑用均匀分布来模拟概率,代码如下:

import numpy as np

import random

# 定义从均匀分布中获取随机数的函数

def get_uniform_random_number(low, high):

"""

:param low: 均匀分布的下界

:param high: 均匀分布的上界

:return: 从均匀分布中产生的随机数

"""

# 均匀分布的随机数生成

number = np.random.uniform(low, high)

# 返回值

return number

# 定义从一个数字列表中以一定的概率取出对应区间中数字的函数

def get_number_by_pro(number_list, pro_list):

"""

:param number_list:数字列表

:param pro_list:数字对应的概率列表

:return:按概率从数字列表中抽取的数字

"""

# 用均匀分布中的样本值来模拟概率

x = random.uniform(0, 1)

# 累积概率

cum_pro = 0.0

# 将可迭代对象打包成元组列表

for number, number_pro in zip(number_list, pro_list):

cum_pro += number_pro

if x < cum_pro:

# 返回值

return number

# 主模块

if __name__ == "__main__":

# 数字列表

num_list = [1, 2, 3, 4, 5]

# 对应的概率列表

pr_list = [0.1, 0.3, 0.1, 0.4, 0.1]

# 函数调用

n = get_number_by_pro(number_list=num_list, pro_list=pr_list)

# 打印结果

print(n)

# 结果:1

3.2 按照指定概率从区间列表中的某个区间内生成随机数

给定一个区间列表和一个与之对应的概率列表,两个列表相应位置的元素组成的元组即表示某数字出现在某区间内的概率是多少,已知这些,我们如何生成随机数呢?这里我们通过两次使用均匀分布达到目的,代码如下:

import numpy as np

import random

# 定义从均匀分布中获取随机数的函数

def get_uniform_random_number(low, high):

"""

:param low: 均匀分布的下界

:param high: 均匀分布的上界

:return: 从均匀分布中产生的随机数

"""

# 均匀分布的随机数生成

number = np.random.uniform(low, high)

# 返回值

return number

# 定义从一个数字列表中以一定的概率取出对应区间中数字的函数

def get_number_by_pro(number_list, pro_list):

"""

:param number_list:数字列表

:param pro_list:数字对应的概率列表

:return:按概率从数字列表中抽取的数字

"""

# 用均匀分布中的样本值来模拟概率

x = random.uniform(0, 1)

# 累积概率

cum_pro = 0.0

# 将可迭代对象打包成元组列表

for number, number_pro in zip(number_list, pro_list):

cum_pro += number_pro

if x < cum_pro:

# 从区间[number. number - 1]上随机抽取一个值

num = get_uniform_random_number(number, number - 1)

# 返回值

return num

# 主模块

if __name__ == "__main__":

# 数字列表

num_list = [1, 2, 3, 4, 5]

# 对应的概率列表

pr_list = [0.1, 0.3, 0.1, 0.4, 0.1]

# 函数调用

n = get_number_by_pro(number_list=num_list, pro_list=pr_list)

# 打印结果

print(n)

# 结果:3.49683787011193

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

python生成随机数方法_详解用python生成随机数的几种方法相关推荐

  1. vue动态设置文字布局方式_详解Vue动态添加模板的几种方法

    动态添加模板需要收集原始数据的页面,这个时候我们需要很多原始数据收集模板,下面给大家详解Vue 动态添加模板的几种方法,希望对你学习这方面知识有所帮助. 通常我们会在组件里的 template 属性定 ...

  2. python编写数据库连接工具_详解使用Python写一个向数据库填充数据的小工具(推荐)...

    一. 背景 公司又要做一个新项目,是一个合作型项目,我们公司出web展示服务,合作伙伴线下提供展示数据. 而且本次项目是数据统计展示为主要功能,并没有研发对应的数据接入接口,所有展示数据源均来自数据库 ...

  3. python zxing 识别条码_详解利用python识别图片中的条码(pyzbar)及条码图片矫正和增强...

    前言 这周和大家分享如何用python识别图像里的条码.用到的库可以是zbar.希望西瓜6辛苦码的代码不要被盗了.(zxing的话,我一直没有装好,等装好之后再写一篇) 具体步骤 前期准备 用open ...

  4. 利用python处理dna序列_详解基于python的全局与局部序列比对的实现(DNA)

    程序能实现什么 a.完成gap值的自定义输入以及两条需比对序列的输入 b.完成得分矩阵的计算及输出 c.输出序列比对结果 d.使用matplotlib对得分矩阵路径的绘制 一.实现步骤 1.用户输入步 ...

  5. 用python写管理系统局域网_详解用python -m http.server搭一个简易的本地局域网

    工作时同事间几mb小文件的传输,一般使用QQ或者微信就足够了,但当传输文件几百MB或者几十G时,这种方法的效率就显得不足了.本篇就是简单说明一个python小功能,让大家能利用python方便的搭建一 ...

  6. python解释器在哪里_详解查看Python解释器路径的两种方式

    进入python的安装目录, 查看python解释器 进入bin目录 # ls python(看一下是否有python解释器版本) # pwd (查看当前目录) 复制当前目录即可 1. 通过脚本查看 ...

  7. python hist直方图拟合曲线_详解用Python为直方图绘制拟合曲线的两种方法

    直方图是用于展示数据的分组分布状态的一种图形,用矩形的宽度和高度表示频数分布,通过直方图,用户可以很直观的看出数据分布的形状.中心位置以及数据的离散程度等. 在python中一般采用matplotli ...

  8. python登录系统文件版_详解用python实现基本的学生管理系统(文件存储版)(python3)...

    这个是升级的版本,比较进阶一点的,相对与之前的文件管理系统,数据只是存储到了内存中,而不是存储到硬盘上,我们想让文件存储到硬盘上的话,一个是存储到文件里,一个是存储到数据库中,存储到数据库中的版本会后 ...

  9. python 写入excel 日期_详解:Python实现大数据收集至excel的思路大牛分享(建议收藏)...

    一.在工程目录中新建一个excel文件 二.使用python脚本程序将目标excel文件中的列头写入,本文省略该部分的code展示,可自行网上查询 三.以下code内容为:实现从接口获取到的数据值写入 ...

最新文章

  1. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(39)-在线人数统计探讨
  2. 使用matlab调用Oracle数据库
  3. RoHS、无铅制程、无卤 的基本介绍
  4. db2字符串定位_DB2/Oracle/SQL server判断某个字符串或单个字符在源字符串中出现的位置...
  5. 按键精灵post请求_手把手教你使用按键精灵post登陆网页
  6. jQuery WeUI动态获取省地市三级联动
  7. DroidCam---将手机转为电脑外接摄像头的软件(提供下载链接)
  8. 视频内容理解相关方法
  9. OceanBase架构浅析_OceanBase分布式数据库
  10. 软电话对接鼎信DWG无线网关
  11. h5锁屏提醒-锁横屏和锁竖屏
  12. 计算机查看流量记录,教你用路由器查看电脑数据流量使用情况的方法
  13. QT 无边窗口圆角实现
  14. 如何巧妙的防止网站被劫持
  15. 国内图书分类号 国际图书分类号查询
  16. 周立功: 我的25年嵌入式生涯——非常诚恳之谈
  17. 电力电子技术笔记-三相桥式
  18. 虚拟机下的Linux网络连接方法(NAT)
  19. Ubuntu ROS下遇到的问题记录
  20. android商城首页demo,FanZhengxi

热门文章

  1. sublime----------快捷键的记录
  2. idea 使用时的一些问题
  3. Web应用程序系统的多用户权限控制设计及实现-总述【1】
  4. MyBatis 入门到精通(一) 了解MyBatis获取SqlSession
  5. STL 源代码分析 算法 stl_algo.h -- includes
  6. android mysql代码_LitePal——Android数据库框架完整使用手册(示例代码)
  7. python用来自动修改pdf_python实现从pdf文件中提取文本,并自动翻译的方法
  8. php动态网页设计制作作业成品
  9. redis zset转set 反序列化失败_关于Redis中的五种数据结构,要知其然知其所以然...
  10. css3弧形跑道效果_【Tableau 图表】你是不是真的需要一个跑道图呢?