两种随机数生成方法——反函数法和舍选法

2023-05-16

两种随机数生成方法——反函数法和舍选法

我们知道,对于均匀分布的随机数,我们可以使用随机数生成器类似的方法生成均匀分布的随机数。包括线性同余发生器,FSR发生器等。对于非均匀分布的随机数,对于连续型随机变量,如果我们知道该分布的密度函数,则可以使用反函数法和舍选法生成随机数。

反函数法生成随机数

反函数法生成随机数的原理如下:
在这里插入图片描述
具体步骤如下:
1.使用随机数发生器等方法生成均匀分布随机数
2.求解Fx的反函数
3.带入生成的均匀分布随机数,则生成分布函数为Fx的随机数
例:生成柯西分布随机数
柯西分布分布函数是
F ( x ) = 1 2 + 1 π a r c t a n ( x ) F(x) = \frac{1}{2}+\frac{1}{{\pi}}arctan(x) F(x)=21+π1arctan(x)

n = 1e5
x = runif(n)
res = tan(pi*(x-1/2))

反函数法缺点:一些函数的反函数表示不出来,此时反函数法就无法使用。

舍选法生成随机数

舍选法的原理:
在这里插入图片描述
解释:使用一个简单区域包含目标区区域,然后在这个简单区域上使用均匀分布生成随机数,再对随机数进行判断,是否落在目标区域内。
例子:使用舍选法生成正态分布随机数
目标密度: p ( x ) = ( 2 π ) − 1 / 2 e x p ( − x 2 2 ) p(x) = (2{\pi})^{-1/2}exp(-\frac{x^2}{2}) p(x)=(2π)1/2exp(2x2)
试投密度:
f ( x ) = 1 π ( 1 + x 2 ) f(x) = \frac{1}{{\pi(1+x^2)}} f(x)=π(1+x2)1

#3
c = 2
z = rep(NA,1e3);
i = 1
while(i<=1e3){
  x_old = runif(1)
  x_new = tan(pi*(x_old-1/2))
  u = runif(1)
  p = ((2*pi)^(-1/2))*exp(-(x_new^2)/2)
  g = 1/2+(1/pi)*atan(x_new)
  if(u<=p/(c*g)){
    z[i] = x_new;
    i = i+1
  }
}
z
hist(z,prob = T,ylim=c(0,1))

在这里插入图片描述
其中,c的最优值是
在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

两种随机数生成方法——反函数法和舍选法 的相关文章

  • 嵌入式方向JD

    偏应用 xff1a 职位描述 xff1a 工作职责 负责业务部门嵌入式软件功能相关开发工作 xff0c 与其他同事合作完成项目交付 任职资格 1 本科及以上学历 xff1b 2 具备3 5年嵌入式行业软件开发经验 xff1b 3 熟练掌握C
  • VirtualBox虚拟机的迁移和快照问题

    查看原文 xff1a http www sijitao net 1616 html 前几天博主迁移了一台测试服务器上的virtualbox虚拟机 本来直接拷贝文件就可以解决的问题 xff0c 结果折腾了我一天 一开始 xff0c 我没注意这
  • 多轴飞行器无人机硬件技术细谈

    http www 52rd com S TXT 2015 3 TXT65233 HTM 多轴飞行器无人机硬件技术细谈 52RD com 2015年3月6日 电子工程专辑 参与 xff1a 2人 我来说两句 在今年CES上无人机成为了展会最大
  • android中onFinishInflate和onSizeChange()的调用时机

    1 onFinishInflate onFinishInflate是view加载完xml之后执行的方法 xff0c 相当于只是完成了布局的映射 xff0c 在这个方法里面是得不到控件的高宽的 xff0c 控件的高宽是必须在调用了onMeas
  • C++构造函数中冒号作用及explicit关键字

    构造函数中冒号作用 xff0c 类给成员变量赋值 xff0c 更适用于成员变量的常量const型 span class token keyword class span span class token class name myClass
  • IDEA(2022.2)搭建Servlet基本框架详细步骤

    文章目录 1 创建基本Web项目1 1 创建新项目1 2 生成Module1 3 设置Web框架1 4 新建导航页 2 配置Tomcat服务器2 1 设置Tomcat2 2 部署Tomcat启动服务2 3 测试Tomcat 3 实现Serv
  • 多径信道

    多径信道 多径信道的低通等效特征多径信道的统计特性时变行为的统计特性 在到达接收天线之前 xff0c 发送的信号遵循许多不同的路径 xff0c 并且这些路径的集合构成多径无线电传播信道 xff08 如图9 3 xff09 产生的信号强度将经
  • [VSCode] VSCode使用C++运行HelloWorld

    一 对于VS Code的介绍 首先需要明确的一点是VSCode并不是一个标准意义上的IDE Integrated Development Environment xff0c 集成开发环境 xff0c VSCode更像是一个功能强大的编辑器
  • 计算机组成.零件之间的通信.总线BUS

    总线干嘛的 xff1f 说白了就是用来传输数据的 xff0c 在计算机的各个部件之间 比如我主存里存的数据CPU要用 xff0c 需要一条线路传过去吧 xff0c CPU内部各个寄存器之间 寄存器与ALU CU与各个部件之间等等等等很多地方
  • 用linux也太爽了啊

    最近更换了公司 xff0c 换成了ubuntu系统进行开发 xff0c 我只能说比windows开发好用多了 xff0c 在windows需要各种工具 xff0c 然而linux的名林嗯行就解决了很多的问题 xff0c 从前windows下
  • 希望计算机专业学生都知道这些宝藏老师

    希望计算机专业学生都知道这些宝藏老师 IT服务圈儿 2022 12 04 17 30 发表于江苏 以下文章来源于程序员库森 xff0c 作者库森 程序员库森 阿里程序员 xff0c 专注分享编程学习 校招求职和大厂面试 IT服务圈儿 关注互
  • docker镜像push到仓库

    镜像可以很方便直接 push 到 docker 的公共仓库或阿里云仓库 1 上传至docker仓库 1 登录docker hub创建自己的仓库地址 xff1a https hub docker com repository create 创
  • 深度学习样本归一化到[0,1]还是[-1,1]

    一般 xff0c 我们需要对神经网络的输入样本进行归一化 xff0c 通常有多种选择 xff0c 比如归一化到 0 1 xff0c 或归一化到 1 1 这两种方法 xff0c 哪种归一化方法更好呢 xff1f 还是没有区别 现在的实验经验
  • ubuntu装机并设置远程连接

    step1 ubuntu16装系统的过程略过 step2 联网 step3 apt get更新 sudo apt get update step4 安装ssh 安装 openssh 服务 sudo apt get install opens
  • ros学习之串口通信(数据读取),并进行发布

    串口参数 波特率 9600 起始位 1 数据位 8 停止位 1 奇偶校验 无 例如超声波模组地址为0X01 则主机发送 0X55 0XAA 0X01 0X01 checksum checksum 61 帧头 43 用户地址 43 指令 am
  • 在Ubuntu上使用LVM对ROOT进行在线扩容

    前提 xff1a 在安装ubuntu的时候 xff0c 是使用LVM进行分区管理的 背景 xff1a 我在安装的时候 xff0c 选择了500G大小 xff0c 磁盘总大小1T xff0c 现在想扩成1T 扩容前 xff1a yang 64
  • realsense D435i双目IMU 数据集

    realsense D435i 双目IMU数据集 使用双目 43 IMU的数据双目内参双目IMU外参 使用双目 43 IMU的数据 双目内参 model type PINHOLE camera name camera image width
  • MobaXterm 登录出现 Network error :Connection timed out

    本来用SSH连接正在操作 xff0c 突然连接不好Linux xff0c 无法登陆 xff0c 出现Network error Connection timed out错误 还以为是自己哪里操作出错了 xff0c 打开本机 cmd命令窗口
  • 消息队列总结

    一 为什么需要无锁队列 xff1f 二 无锁队列是什么 xff1f 三 无锁队列是如何实现的 xff1f span class token keyword inline span span class token class name yq
  • 姿态传感器—MPU6050

    姿态传感器 MPU6050 简介寄存器数字运动处理器 DMP遇到的问题1 初始化是要水平放置 且 按照上电时的方位为基准 xff08 正点原子提供的例程 xff09 简介 MPU6050是一款六轴 xff08 三轴加速度 43 三轴角速度

随机推荐