R语言【base】——.Random.seed(),RNGkind(),RNGversion(),set.seed():随机数生成器

2024-02-22 16:28

本文主要是介绍R语言【base】——.Random.seed(),RNGkind(),RNGversion(),set.seed():随机数生成器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Package base version 4.2.0


Description

.Random.seed是一个整数向量,包含R中生成随机数的随机数生成器(RNG)状态。它可以保存和恢复,但不应该被用户更改。

RNGkind是一个更友好的接口,用于查询或设置正在使用的RNG类型。

RNGversion在早期的R版本中可以用来设置随机生成器(为了再现性)。

set.seed 是设置随机数种子的推荐方法。


Usage

.Random.seed <- c(rng.kind, n1, n2, ...)RNGkind(kind = NULL, normal.kind = NULL, sample.kind = NULL)
RNGversion(vstr)
set.seed(seed, kind = NULL, normal.kind = NULL, sample.kind = NULL)

Arguments

参数【kind】:字符或NULL。如果kind是字符串,则将R的RNG设置为所需的类型。使用"default"返回R默认值。有关NULL的解释,请参阅“详细信息”。

参数【normal.kind】:字符串或NULL。如果是字符串,则设置为常见的构造器方式。使用"default"返回R默认值。NULL不做任何改变。

参数【sample.kind】:字符串或NULL。如果是字符串,则设置离散均匀生成方法(例如在sample中使用)。使用"default"返回R默认值。NULL不做任何改变。

参数【seed】:单个值,解释为整数或NULL(参见“详细信息”)。

参数【vstr】:包含版本号的字符串,例如“1.6.2”。如果vstr大于当前版本,则使用当前R版本的默认RNG配置。

参数【rng.kind】:上面kind的整数码为0:k。

参数【n1,n2,...】:整数。请参阅所需数量的详细信息(这取决于ring .kind)。


Details

目前可用的RNG种类如下。Kind部分匹配此列表。默认是“Mersenne-Twister”。

  • "Wichmann-Hill"
  • "Marsaglia-Multicarry"
  • "Super-Duper"
  • "Mersenne-Twister"
  • "Knuth-TAOCP-2002"
  • "Knuth-TAOCP"
  • "L'Ecuyer-CMRG"
  • "user-supplied"

normal.kind可为“Kinderman-Ramage”、“Buggy Kinderman-Ramage”(不适用set.seed)、“Ahrens-Dieter”、“Box-Muller”、“Inversion”(默认)或“user-supplied”。在1.7.0之前的版本中使用的Kinderman-Ramage生成器(现在称为“Buggy”)有几个近似错误,应该只用于复制旧结果。

“Box-Muller”生成器是有状态的,因为法线对是依次生成和返回的。当它被选中时(即使它是当前的普通生成器),当类型被改变时,状态将被重置。

sample.kind可以是“Rounding”或“Rejection”,或部分匹配这些。前者在3.6.0之前的版本中是默认的:它使样本在大种群中明显不均匀,并且应该只用于复制旧的结果。

set.seed使用单个整数参数来设置所需的任意数量的种子。它的目的是作为一种简单的方法,通过指定小的整数参数来获得完全不同的种子,也是一种为更复杂的方法(特别是“Mersenne-Twister”和“Knuth-TAOCP”)获得有效种子集的方法。我们不能保证不同的seed值会以不同的方式生成RNG,尽管任何例外情况都是非常罕见的。如果使用seed = NULL调用,它会重新初始化(参见' Note '),就好像没有设置种子一样。

使用kind = NULL,normal.kind = NULL或在RNGkind或set.seed中,sample.kind = NULL选择当前使用的生成器(如果工作空间已经恢复,包括在前一个会话中使用的生成器):如果没有使用生成器,它选择“default”。


Value

.Random.seed是一个整数向量,其第一个元素编码RNG和normal生成器的类型。最小的两位十进制数字为0 (k-1),其中k为可用rng数。百位代表普通发生器的类型(从0开始),万位代表离散均匀采样器的类型。

在底层的C中,.Random.seed[-1]是无符号的;因此在R .Random.seed[-1]可以是负数,因为用有符号整数表示无符号整数。

RNGkind返回在调用之前选择的RNG,正常和样本类型的三元素字符向量,如果参数不为NULL,则不可见。一个类型作为默认值启动会话,并通过调用RNGkind或通过设置. random来选择。在工作空间中播种。(注意:在r3.6.0之前,前两种类型以双元素字符向量的形式返回。)

RNGversion返回与RNGkind相同的关于特定R版本默认值的信息。

set.seed返回NULL,不可见。


Note

最初,没有种子;当需要时,将根据当前时间和进程ID创建一个新的。因此,默认情况下,不同的会话将给出不同的模拟结果。但是,如果恢复以前保存的工作空间,则可能会从以前的会话恢复种子。

.Random.seed保存用于均匀随机数生成器的种子集,至少用于系统生成器。它并不一定保存其他生成器的状态,特别是不保存Box-Muller正常生成器的状态。如果稍后要重现工作,请调用set.seed(最好为kind和normal.kind设置明确的值),而不是设置 . Random.seed。

.Random.seed对象只在用户的工作空间中查找。

不要依赖rng低阶位的随机性。大多数提供的统一生成器返回32位整数值,这些值被转换为双精度,因此它们最多取一个2的32次方个不同的值和长时间运行将返回重复的值(wichman - hill是例外,它们都给出至少30个不同的位)。

这篇关于R语言【base】——.Random.seed(),RNGkind(),RNGversion(),set.seed():随机数生成器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

大语言模型(LLMs)能够进行推理和规划吗?

大语言模型(LLMs),基本上是经过强化训练的 n-gram 模型,它们在网络规模的语言语料库(实际上,可以说是我们文明的知识库)上进行了训练,展现出了一种超乎预期的语言行为,引发了我们的广泛关注。从训练和操作的角度来看,LLMs 可以被认为是一种巨大的、非真实的记忆库,相当于为我们所有人提供了一个外部的系统 1(见图 1)。然而,它们表面上的多功能性让许多研究者好奇,这些模型是否也能在通常需要系

人工和AI大语言模型成本对比 ai语音模型

这里既有AI,又有生活大道理,无数渺小的思考填满了一生。 上一专题搭建了一套GMM-HMM系统,来识别连续0123456789的英文语音。 但若不是仅针对数字,而是所有普通词汇,可能达到十几万个词,解码过程将非常复杂,识别结果组合太多,识别结果不会理想。因此只有声学模型是完全不够的,需要引入语言模型来约束识别结果。让“今天天气很好”的概率高于“今天天汽很好”的概率,得到声学模型概率高,又符合表达

C语言 将“China”译成密码

将“China”译成密码,密码规律是:用原来的字母后面的第4个字母代替原来的字母。例如,字母“A”后面的第4个字母是“E”,用“E”代替“A”。因此,“China”应译为“Glmre”。编译程序用付赋初值的方法使c1,c2,c3,c4,c5这五个变量的值分别为“C”,“h”,“i”,“n”,“a”,经过运算,使c1,c2,c3,c4,c5分别变成“G”,“l”,“m”,“r”,“e”。分别用put

C语言入门系列:探秘二级指针与多级指针的奇妙世界

文章目录 一,指针的回忆杀1,指针的概念2,指针的声明和赋值3,指针的使用3.1 直接给指针变量赋值3.2 通过*运算符读写指针指向的内存3.2.1 读3.2.2 写 二,二级指针详解1,定义2,示例说明3,二级指针与一级指针、普通变量的关系3.1,与一级指针的关系3.2,与普通变量的关系,示例说明 4,二级指针的常见用途5,二级指针扩展到多级指针 小结 C语言的学习之旅中,二级

【LinuxC语言】select轮询

文章目录 前言select函数详解selectfd_set类型一个小问题select函数使用步骤改进服务器代码select服务器示例代码 总结 前言 在Linux C语言编程中,我们经常需要处理多个I/O操作。然而,如果我们为每个I/O操作创建一个线程,那么当I/O操作数量增加时,线程管理将变得复杂且效率低下。这就是我们需要select轮询的地方。select是一种高效的I/

拓扑排序——C语言

拓扑排序(Topological Sorting)是一种用于有向无环图(DAG)的排序算法,其输出是图中所有顶点的线性排序,使得对于每条有向边 (u, v),顶点 u 在 v 之前出现。拓扑排序确定了项目网络图中的起始事件和终止事件,也就是顶点的执行顺序。         因为是有向无环图,所以拓扑排序的作用其实就是把先发生的排序在前面,后发生的排序到后面。 例如现在我们有一个

OC和 C语言中的const

const与宏对比 1.都是在其他的地方不可以改变 2.一个地方改了其他的地方都会改变。 而且宏定义的缺陷是, 是它会不断的开辟临时变量的存储空间 使用const的话 是都去使用同一的一份空间,使用同一个对象。 加const 之后变量还是全局的,只不过变为全局常量。 如果此时改变量不想被被类外面访问的话,可以加上static关键字, 3.下次想要定义一些宏的时候分

[分布式网络通讯框架]----Zookeeper客户端基本操作----ls、get、create、set、delete

Zookeeper数据结构 zk客户端常用命令 进入客户端 在bin目录下输入./zkCli.sh 查看根目录下数据ls / 注意:要查看哪一个节点,必须把路径写全 查看节点数据信息 get /第一行代码数据,没有的话表示没有数据 创建节点create /sl 20 /sl为节点的路径,20为节点的数据 注意,不能跨越创建,也就是说,创建sl2的时候,必须确保sl