r语言在线编译器w3c,R语言生成随机数实例讲解

1.概述

作为一种语言进行统计分析,R有一个随机数生成各种统计分布功能的综合性图书馆。R语言可以针对不同的分布,生成该分布下的随机数。其中,有许多常用的个分布可以直接调用。本文简单介绍生成常用分布随机数的方法,并介绍如何生成给定概率密度分布下的随机数。

2.常用分布的随机数

在R中各种概率函数都有统一的形式,即一套统一的 前缀+分布函数名:

d 表示密度函数(density);

p 表示分布函数(生成相应分布的累积概率密度函数);

q 表示分位数函数,能够返回特定分布的分位数(quantile);

r 表示随机函数,生成特定分布的随机数(random)。

e49c89b898bb982cf7d87f966d781a46.png

2.1各种分布的随机数生存函数:

rnorm(n, mean=0, sd=1) #正态分布

rexp(n, rate=1) #指数

rgamma(n, shape, rate=1, scale=1/rate) #r 分布

rpois(n, lambda) #泊松

rt(n, df, ncp) #t 分布

rf(n, df1, df2, ncp) #f 分布

rchisq(n, df, ncp=0) #卡方分布

rbinom(n, size, prob) #二项分布

rweibull(n, shape, scale=1) #weibull 分布

rbata(n, shape1, shape2) #bata 分布runif(n,min=0,max=1) #均匀分布

2.2以二项分布为例,实现上述各类函数:

dbinom(x, size, prob, log = FALSE)# 可用于计算二项分布的概率。

pbinom(q, size, prob, lower.tail = TRUE, log.p = FALSE)#二项分布的分布函数值

qbinom(p, size, prob, lower.tail = TRUE, log.p = FALSE)#生成二项分布的特定分位数

rbinom(n, size, prob)#生成二项分布的随机数

二项分布随机数

二项分布是指n次独立重复伯努利试验成功的次数的分布,每次伯努利试验的结果只有两个,成功和失败,记成功的概率为p。生成二项分布随机数的函数是:rbinom() 。句法是:rbinom(n,size,prob)。n表示生成的随机数数量,size表示进行伯努利试验的次数,prob表示一次贝努力试验成功的概率。

#例:产生100个n为10,20,50,概率p为0.25的二项分布随机数:

par(mfrow=c(1,3))

p=0.25

for( n in c(10,20,50)) {

x=rbinom(100,n,p)

hist(x,prob=T,main=paste("n =",n))

xvals=0:n

points(xvals,dbinom(xvals,n,p),type="h",lwd=3)

}

par(mfrow=c(1,1))

d3505e3de4d4f49165eac9121d196690.png

3.离散随机变量的生成3.1逆变换法

假设我们希望生成一个离散型随机变量X,它有密度

5949390ea73ce83ce7e8e6f0ec00af70.png

我们首先可以生成一个均匀分布的随机数,使得:

b5aa6a59fc3f96b731ea96c8a08caaa6.png

75c5f6e9fc7183753a53e4c17889bd03.png

9b38dda090c560c350b5b9ffee68a596.png

8de4295eb7a04eacb27ef2b297061fc9.png

48f5512520cbe737c30b765bfaeb963e.png

#代码实现如下:
p1

p2

p3

p4

disRand

u

if(u

if(u

if(u

x

return(x)

}

3.2二项随机变量的生成

09acb7ece15b7be066cf7ab199700353.png

c127ddc60504c931f97dfa4c709f4571.png

b621c02f91a744660e3aa9ae833f94a8.png

Example:假设要生成1000个服从b(100,0.6)的随机数

p

n

c

i

pp

f

binomialRandomeV

u

f

while(u>=f){

pp

f

i

}

return(i)

}

sapply(c(1:1000),binomialRandomeV)

到此这篇关于R语言生成随机数实例讲解的文章就介绍到这了,更多相关R语言生成随机数内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

时间: 2021-03-15

  • 2
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值