1、产生随机变量的组合法

将分布函数分解为若干个较简单的子分布函数的线性组合

其中是分布函数。

定理:若随机变量,即,并且,取;

证明的分布函数为

定理证毕。

根据此定义,我们可以给出产生随机数的组合和算法如下:

(1)产生一个正随机数使得

(2)在时,产生具有分布函数的随机变量x。

在该算法中,首先以概率选择子分布函数,然后取的随机数作为的随机数。

2、产生拉普拉斯分布随机数的方法

拉普拉斯分布的概率密度函数为

令拉普拉斯的均值为,方差为,,拉普拉斯分布也称为双指数分布。

根据上述的组合算法,产生拉普拉斯分布随机数的方法为

(1)产生均匀分布随机数,即

(2)计算

3、C语言代码实现

3.1 头文件laplace.h

#pragma once
#ifndef LAPLACE_H_
#define LAPLACE_H_/*
函数功能:    产生laplace分布的随机数
输入参数说明:
beta        拉普拉斯分布参数
seed        长整型指针变量, *seed 为伪随机数的种子
*/
double laplace_data(double beta, long int * seed);#endif // !LAPLACE_H_

3.2 函数文件laplace.c

#include "laplace.h"#include <stdint.h>
#include "string.h"
#include "stdio.h"
#include "uniform.h"
#include <math.h>/*
函数功能:    产生laplace分布的随机数
输入参数说明:
beta        拉普拉斯分布参数
seed        长整型指针变量, *seed 为伪随机数的种子
*/
double laplace_data(double beta, long int * seed)
{double u1,u2, x;u1 = uniform_data(0.0, 1.0, seed);u2 = uniform_data(0.0, 1.0, seed);if (u1 <= 0.5){x = -beta * log(1.0 - u2);}else{x = -beta * log(u2);}return x;
}

3.3 主程序main.c

#include <stdio.h>
#include <string.h>
#include "uniform.h"
#include "laplace.h"int main()
{// 产生50个指数分布的随机数int i, j;long int s;double x, beta;beta = 2.0;  s = 13579;for (i = 0; i < 10; i++){for (j = 0; j < 5; j++){x = laplace_data(beta,  &s);printf("%13.7f",x);}printf("\n");}   getchar();      // 此行代码是为了保持输出窗口,按任意按键关闭弹窗return 0;
}

程序中uniform.h和uniform.c的代码见文章

产生(a,b)区间上均匀分布的随机数 C语言实现_jk99528878769的博客-CSDN博客使用C语言实现 在设定区间内产生一个均匀分布的随机数https://blog.csdn.net/jk99528878769/article/details/124435414?spm=1001.2014.3001.5502

3.4  运行输出结果

产生拉普拉斯分布随机数--C语言实现相关推荐

  1. matlab中表示拉普拉斯分布_拉普拉斯分布的随机数

    一.功能 产生拉普拉斯分布的随机数. 二.方法简介 1.产生随机变量的组合法 将分布函数\(F(x)\)分解为若干个较为简单的子分布函数的线性组合 \[F(x)=\sum_{i=1}^{K}p_{i} ...

  2. 【源码】产生拉普拉斯分布的随机数

    本代码是一个提供具有拉普拉斯(双指数)分布随机数生成的Matlab函数,类似于内置的Matlab函数"rand"和"randn". The present co ...

  3. 随机游动Metropolis算法拟合标准拉普拉斯分布

    1. 题目分析 使用随机游动的Metropolis抽样方法产生标准拉普拉斯分布的随机数,其中使用正态分布产生增量,比较由提议分布不同方差生成的链的差异,并比较每个链的接收概率. 2. 代码展示 我们首 ...

  4. 产生正态分布(高斯分布)随机数 C语言实现

    正态分布的概率密度函数如下 通常使用表示均值为,方差为 产生正太分布的方法如下: 设为(0,1)上n个相互独立的均匀分布的随机数,由于,. 根据中心极限定理可知,当n趋向于无穷时 的分布近似于正态分布 ...

  5. 生成特定分布随机数的方法:Python seed() 函数numpy scikit-learn随机数据生成

    描述 seed() 方法改变随机数生成器的种子,可以在调用其他随机模块函数之前调用此函数.. 语法 以下是 seed() 方法的语法: import random random.seed ( [x] ...

  6. 生成特定分布随机数的方法

    生成随机数是程序设计里常见的需求.一般的编程语言都会自带一个随机数生成函数,用于生成服从均匀分布的随机数.不过有时需要生成服从其它分布的随机数,例如高斯分布或指数分布等.有些编程语言已经有比较完善的实 ...

  7. matlab中表示拉普拉斯分布_神奇的正态分布

    在统计学中有各种各样的分布,称为统计分布,例如有离散型的伯努利分布.二项分布.超几何分布.几何分布.负二项分布.泊松分布,有连续型的均匀分布.指数分布.t分布.卡方分布.F分布.正态分布等等,其中正态 ...

  8. 混合拉普拉斯分布(LMM)推导及实现

    作者:桂. 时间:2017-03-21  07:25:17 链接:http://www.cnblogs.com/xingshansi/p/6592599.html 声明:欢迎被转载,不过记得注明出处哦 ...

  9. 拉普拉斯分布和拉普拉斯变换有什么区别

    拉普拉斯分布和拉普拉斯变换是两个不同的概念. 拉普拉斯分布是一种特殊的概率分布,它是单峰的非对称分布,广泛应用于负面事件的概率分布,例如负极限分布. 拉普拉斯变换则是一种数学变换,它是一种常用于图像处 ...

最新文章

  1. ctf 文件头crc错误_[CTF隐写]png中CRC检验错误的分析
  2. 这人说的有意思,哈 哈
  3. 计算机一级b考试理论知识,全国计算机等级考试一级b知识点
  4. 当C++爬山壁纸——C++山寨版
  5. delete后加 limit是个好习惯么 ?
  6. 思维模型篇:数据分析必知必会的两个原则
  7. 一走进书房的QuickDove
  8. 通过伙伴系统申请内核内存的函数有哪些?
  9. 前置递增运算符(JS)
  10. 使用Thread包装类进行多线程操作
  11. 【原译】一个可定制的WPF任务对话框
  12. mars java安卓视频教程下载_mars老师[Android开发视频教学].01_18 文件下载 源码
  13. 【OpenGL ES】EGL简介
  14. Android 4.3 隐藏功能 App Ops 分析
  15. 推荐系统中的pointwise和pairwise区别
  16. 腾讯云tcp认证资料考点包含哪些知识?
  17. 声音均衡器怎么调好听_均衡器怎么调能达到最佳效果(十段均衡器最佳效果图)...
  18. pygame制作飞机大战1——规划
  19. 手部IK,自制动画,蒙太奇——开门手臂自动弯曲、靠墙手自动扶墙
  20. 超好用的java反编译工具(Java Decompiler)

热门文章

  1. bootstrap 图片居中,bootstrap如何设置居中
  2. word文字居中怎么设置
  3. mysql子查询删除
  4. Mongoose模块
  5. nodejs入门教程之CommonJs学习(二)
  6. Spark Core项目实战(1) | 准备数据与计算Top10 热门品类(附完整项目代码及注释)
  7. 《Python 计算机视觉编程》学习笔记(七)
  8. 挂耳式蓝牙耳机哪家的好用,盘点五款知名挂耳式蓝牙耳机
  9. 技校上机电还是计算机专业好,上技校是学机电一体化好还是学计算机应用好
  10. 电子书包windows-android网络影院操作步骤