numpy1.1.7版本后随机数新的生成方法总结

2024-08-22 17:58

本文主要是介绍numpy1.1.7版本后随机数新的生成方法总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

      • 一、简介
      • 二、Generator
        • 1、常用函数
        • 2、示例
          • 2.1 产生随机整数
          • 2.2 产生随机数
          • 2.3 在已有的一维数组里面挑选随机数
        • 3、seed
      • 三、RandomState
      • 四、使用体验

一、简介

最近在看numpy官网的时候,发现1.17版本对随机数做了部分改动。官网地址:Random sampling (numpy.random)

改动如下:
在这里插入图片描述
numpy新版本保持了RandomState的兼容,新的Generator相比于RandomState能力更强大。

在这里插入图片描述
所以有时候我们去网上找博客,不一定能获得最新的内容。

二、Generator

官网地址:Random Generator

我一开始去官网找的时候,也是再三确认,有新的方法了

1、常用函数

Generator常用的产生随机数的函数如下:
在这里插入图片描述

2、示例

常用的是前三个,我们一个一个说过去。

2.1 产生随机整数
random.Generator.integers(low, high=None, size=None, dtype=np.int64, endpoint=False)

参数:

  • low:int or array-like of ints,确定随机数的下限,必须给出;如果high没有指定,假如参数是low=3,那么就把3赋值给high,随机数在[0,3)里面选;如果只有一个参数,且给出的时候没有指定给哪low还是high,则默认给high,并且此时low默认为0;
  • high:int or array-like of ints, optional,确定随机数的上限;
  • size:int or tuple of ints, optional,确定返回的矩阵大小,可以是一维,也可以是多维;
  • dtype:dtype, optional,确定整数类型;
  • endpoint:bool, optional,确定上下限是否包含high,默认是不包含;

示例:

>>> import numpy as np
#初始化Generator
>>> rng=np.random.default_rng()
>>> rng.integers(low=-2,high=2,size=(2,3),endpoint=True)
array([[ 1,  0,  0],[ 1,  2, -1]])
>>> rng.integers(low=3,size=5)
array([0, 1, 2, 0, 0])
>>> rng.integers(3,size=(2,3))
array([[2, 0, 1],[1, 1, 2]])
>>> rng.integers(low=3)
0
>>> rng.integers(low=3)
2
#high是数组的情况,返回值是一个有不同上限的1*3的矩阵,
>>> rng.integers(1,[3,5,10])
array([1, 2, 8])
#low是数组的情况,指定下限
>>> rng.integers([3,5,10],11)
array([ 3, 10, 10])
>>> 
2.2 产生随机数
random.Generator.random(size=None, dtype=np.float64, out=None)

参数比较少,size和dtype不再赘述,out用于指定存放结果的数组。random只能产生[0,1)之间的随机数,其它范围的得利用加减乘除等运算得到想要的结果了。

比如,想要[a,b)之间的随机数,可以如下操作:

(b - a) * random() + a

示例:

#产生[0,1)之间的随机数
>>> rng.random(size=4)
array([0.98110911, 0.18213644, 0.41812857, 0.19352714])
#产生[0,5)之间的随机数
>>> 5*rng.random(size=4)
array([1.07804164, 3.67840157, 3.8162768 , 2.13327948])
>>> 
2.3 在已有的一维数组里面挑选随机数
random.Generator.choice(a, size=None, replace=True, p=None, axis=0, shuffle=True)

参数如下:

  • a:{array_like, int},如果是数组(不仅限于一维数组),就在数组元素里面选;如果是int整数,就在np.arange(a)产生的数组里面选;
  • replace:bool, optional,是不是有放回采样,即产生的数组里面是不是有重复值;True表示有重复值,False表示没有重复值;
  • p:1-D array_like, optional,a中每个值被选上的可能性;如果没有给出,默认是均匀分布;
  • asix:int, optional,这个主要是针对a的,如果a是多维数组,选定在哪个维度上选取元素,假如a是2*4矩阵,axis=0表示每一行作为被挑选的元素;axis=1表示每一列作为被挑选的元素;
  • shuffle:bool, optional,如果是无放回抽样,是否打乱顺序。

示例:

>>> rng.choice(25,size=(2,4),replace=True)
array([[ 0, 11, 18, 11],[ 3, 18, 20, 22]])
>>> rng.choice(25,size=(2,4),replace=False)
array([[ 1, 14,  7, 23],[20,  9,  6, 19]])
>>> 

关于概率p,之前在一篇博客中,看到过这么一个应用,用choice实现了类似轮盘赌的效果,在遗传算法里面需要根据适应度选择交叉和变异的双亲节点,轮盘赌就是想实现适应度越高,被选上的可能性越大,choice函数中的p参数刚好符合。

简单实例:

>>> fitness=rng.random(size=6)
#适应度
>>> fitness
array([0.31172348, 0.21873388, 0.38370583, 0.29026004, 0.39245999,0.33158675])
>>> p=fitness/fitness.sum()
>>> p
array([0.1616429 , 0.11342354, 0.19896904, 0.15051312, 0.20350848,0.17194292])
>>> result=rng.choice(a=6,size=4,replace=False)
#result保存的是下标
>>> result
array([2, 4, 5, 3])
>>> 
3、seed

和RandomState一样,seed是用于产生相同的随机数,在Generator中需要实例化的时候就指定,暂时还没遇到这种情境下的应用。

代码:

>>> rng=np.random.default_rng(seed=10)
>>> rng.random()
0.9560017096289753
>>> rng=np.random.default_rng(seed=10)
>>> rng.random()
0.9560017096289753
>>> 

三、RandomState

这是RandomState和Generator两个类下的常用函数对比

在这里插入图片描述
RandomState官网介绍:Legacy Random Generation

这是常用的几个函数:
在这里插入图片描述
用法与Generator这个类差不多,要是觉得英文的不想看,也可以看看这篇博客Python的numpy库中rand(),randn(),randint(),random_integers()等random系函数的使用

四、使用体验

Generator函数更少,个人更喜欢新版的,反正都支持,看个人习惯。

这篇关于numpy1.1.7版本后随机数新的生成方法总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1096988

相关文章

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端