【小白话通信】连续分布的产生

article/2025/9/17 4:29:24

由于篇幅有限,前一篇文章《离散分布的产生》中只讲述了用均匀分布产生离散分布的方法,那么本文接着讲如何利用均匀分布产生连续分布的方法。


连续分布

连续分布主要有以下几种:均匀分布 伽马分布 正态分布 贝塔分布 柯西分布 对数正态分布 双指数分布

产生各种连续分布的方法有很多,我把它分为两类:通用方法、特殊方法。特殊方法就是根据各个连续分布的特性而特有的方法。


通用方法

通用方法指的是对于各种连续分布理论上都适用的方法。下面只讲解分布函数法、舍取法这两种通用的方法。

分布函数法

概率积分变换定理
设随机变量 X 有连续累计分布函数F(x),令 U=F(X) ,则 U 服从(0,1)上的均匀分布。

由概率积分变换定理可知,如果知道一个连续分布函数的累计分布函数 F(x) ,则可以求得随机变量: X=F1(U) ,其中 U 服从01内的均匀分布。下面以指数分布来举例说明:
指数分布的累计分布函数 F(x) 可以表示为:

F(x)={1eλx,x00,x<0

由于 U=F(X) 服从 (0,1) 上的均匀分布,则随机变量: X=F1(U)=Ln(1U)λ 。因此只需要产生服从 (0,1) 上的均匀分布的 U ,就可以计算得到服从指数分布的随机变量X。

  • 指数分布 
%指数分布
%参数:到达率lambda
%mean=1/lamda,  var=1/lambda^2
clear all
close all
clc
lambda=1;%指数分布的产生lambda
n=10;%x的取值为0到无穷大,这里只取前n个%------------------------由内置函数直接给出-------------------------%%指数分布的产生,即事件发生的时间间隔x,x取值为0到正无穷
X=exprnd(1/lambda);%产生1均值为1/lamda的指数分布%指数分布的cdf
x=0:.1:n;
Fx=expcdf(x,1/lambda);
%figure
%plot(x,Fx,'-')
%title('指数分布的cdf')%指数分布的pdf
x=0:.1:n;
Px=exppdf(x,1/lambda);
figure
plot(x,Px,'r-')
hold on
title('指数分布的pdf')%-------------------------由均匀分布推导出(分布函数法)-------------------------%
N=1000;%样本点数
U=rand(1,N);%U服从均匀分布X2=-(log(1-U))/lambda;%X2服从指数分布,X2由分布函数法得到,对于不同的分布,分布函数不同,这里的表达式需作相应的改变!%下面的程序是绘制X2的概率密度函数pdf
Max=ceil(max(X2));
step=1;%步长
range=0:step:Max;for i=1:length(range)-1YY(i)=sum(range(i)<=X2&X2<=range(i+1))/N/step;%统计落在区间中的点数XX(i)=(range(i)+range(i+1))/2;
endplot(XX,YY,'bo')
hold on
title('指数分布的pdf')
legend('内置函数产生','分布函数法产生')

结果显示如下:(指数参数λ=1的情况)
这里写图片描述

分布函数法的局限性:由于该方法的关键就是求出分布函数的反函数,从而得到随机变量 X 关于均匀分布随机变量U的表达式。然而有些分布是不容易求得其反函数的,例如我们常见的正态分布,其分布函数需要用其概率密度函数表示如下:

F(x)=1σ2πxe(tu)22σ2dt

其中, u σ分布为均值和标准差。显然,当得知 F(x) 的取值时,也很难求得此时的 x 的值。因此,当出现上述问题时,我们可以采用舍去法。

舍去法

定理设随机变量Y,V的概率密度函数分布为 fY(y)fV(v) ,其中, fY(y)fV(v) 有相同的支撑集且

M=max{fY(y)/fV(v)}<+

按下列步骤可以生成随机变量 Y 服从概率密度为fY(y)的分布:
1. 生成独立的随机变量 U,V ,其中, U 服从0 1 的均匀分布,V服从概率密度函数为 fV(v) 的分布
2. 如果 U<1MfY(V)/fV(V) ,则令 Y=V ,否则返回到步骤1。

下面以用舍去法生成正态分布来具体说明:假设我们要用舍取法生成标准正态分布,标准正态分布的概率密度函数如下所示:
这里写图片描述

  • 确定 V 的分布
    由舍取法的步骤2可知,生成的正态分布变量Y的取值包含于随机变量 V 的取值中。因此,我们需要根据正态分布随机变量的取值范围,来选择V应该服从的分布!我们一般取 V 服从均匀分布(当然也可以取其他的分布,注意需要满足取值范围)。
    理论上,正态随机变量的取值在整个实数域中,因此V应该服从区间为实数域的均匀分布,显然这个均匀分布我们很难表示出来。但由上图可知,标准正态分布的取值基本在 5 5 之间,因此我们只需要使得V服从区间在 5 5 的均匀分布即可以很好的近似。

  • 确定M的大小
    在公式 M=max{fY(y)/fV(v)} 中, fV(v)=110 max{fY(y)}=fY(0)=12π 。因此 M=102π

在确定了 V 的分布以及M的大小之后,便可以根据定理中步骤2的判决方法来生成服从指定分布的随机变量 Y 。具体的程序实现如下:

%-------------------正态分布-----------------------%
%参数:均值mu,方差sigma2
%mean=mu,  var=sigma2
clear all
close all
clc
mu=0;
sigma2=1;
n=10;%x的取值为正负无穷大,
%-------------------由内置函数直接给出----------------%
%正态分布的产生X
X=normrnd(mu,sqrt(sigma2));%产生均值mu,方差sigma2的正态分布%正态分布的cdf
x=0:.1:n;
Fx=normcdf(x,mu,sqrt(sigma2));
% figure
% plot(x,Fx,'-')
% title('正态分布的cdf')%指数分布的pdf
x=-5:.1:5;
Px=normpdf(x,mu,sqrt(sigma2));
figure
plot(x,Px,'b-')
hold on%------由舍选法推导出--------%N=100;
A=-5;%A,B位均匀分布的取值区间
B=5;i=1;
while(i<=N)U=unifrnd(0,1);%服从(0,1)的均匀分布V=unifrnd(A,B);%服从(A,B)的均匀分布M=1/sqrt(2*pi)*(B-A);%计算得到Mif(U<1/M*1/sqrt(2*pi*sigma2)*exp(-(V-mu)^2/2/sigma2));%由定理得到的公式来生成随机变量X2X2(i)=V;%X2就是我们要生成的指定分布的随机变量i=i+1;end  
end%下面的程序是计算通过舍去法生成的正态分布X2的pdf
Max=ceil(max(X2));
step=1;
range=A:step:B;for i=1:length(range)-1YY(i)=sum(range(i)<=X2&X2<=range(i+1))/N/step;XX(i)=(range(i)+range(i+1))/2;
endplot(XX,YY,'ro')
hold on
title('正态分布的pdf')
legend('内部函数产生','舍取法产生')

结果显示如下:
这里写图片描述

注意:使用这种方法的时候必须使V服从合适的分布来保证 M<+ ,如若找不到这样的分布,则可以参考Markov Chain Monte Carlo(MCMC)方法。

特殊方法

上述的两种通用方法基本上可以用均匀分布产生大多数连续分布,不过由于每种分布有着各自的特性,因此也可以通过特殊的方法来生成。下面以生成标准正态分布(正态分布性质表明:任何正态分布都可以由标准正态分布转化得到)为例:

中心极限定理法

中心极限定理是概率论中的一组定理。中心极限定理说明,大量相互独立的随机变量,其均值的分布以正态分布为极限。这组定理是数理统计学和误差分析的理论基础,指出了大量随机变量之和近似服从正态分布的条件。(摘自维基百科)
我们由中心极限定理可知,多个独立同分布的随机变量的和服从正态分布,而关于这个正态分布的均值和方差的确定,我们可以依据林德伯格-列维定理:
林德伯格-列维(Lindeberg-Levy)定理
设随机变量 X1,X2,,Xn ,且具有有限的数学期望 E(Xi)=u,D(Xi)=σ2=0(i=1,2,,n) 。记 X¯=1ni=1nXi,Y=X¯uσ/n ,则 limnP(Y<z)=Φ(z) ,其中 Φ(z) 是标准正态分布的分布函数。

在程序实现中,我利用 10 个相互独立的服从区间 55 的均匀分布来生成标准正态分布 Y 。而由公式可知,区间01的均匀分布的均值为 u=5+52=0,σ2=(5(5))2/12=100/12 .因此我们需要生成的服从标准正态的随机变量的表达式为: Y=X¯0.5100/12/n 具体程序实现如下:

%-------------------正态分布-----------------------%
%参数:均值mu,方差sigma2
%mean=mu,  var=sigma2
clear all
close all
clc
mu=0;
sigma2=1;
n=10;%x的取值为正负无穷大,
%------------------由内置函数直接给出--------------%
%正态分布的产生X
X=normrnd(mu,sqrt(sigma2));%产生均值mu,方差sigma2的正态分布%正态分布的cdf
x=0:.1:n;
Fx=normcdf(x,mu,sqrt(sigma2));
% figure
% plot(x,Fx,'-')
% title('正态分布的cdf')%指数分布的pdf
x=-5:.1:5;
Px=normpdf(x,mu,sqrt(sigma2));
figure
plot(x,Px,'b-')
hold on
%-------------------由中心极限定理推导出---------------------%
N=1000;%样本点数
A=-5;%A,B位均匀分布的取值区间
B=5;for i=1:10
U(i,1:N)=unifrnd(A,B,1,N);%U存储10个独立的服从均匀分布的随机变量
end
meanX=mean(U);
X2=(meanX-(A+B)/2)/sqrt((B-A)^2/12)*sqrt(10);%由林德伯格-列维定理的公式知X2服从正态分布
mean(X2);%下面的程序是计算通过中心极限定理法生成的正态分布X2的pdf
Max=ceil(max(X2));
step=1;
range=A:step:B;for i=1:length(range)-1YY(i)=sum(range(i)<=X2&X2<=range(i+1))/N/step;XX(i)=(range(i)+range(i+1))/2;
endplot(XX,YY,'ro')
hold on
title('正态分布的pdf')
legend('内部函数产生','中心极限定理法产生')

显示结果如下:
这里写图片描述

Box-Muller法

基本思想:假设 U,V 是两个相互独立的且服从区间在 01 的均匀分布,并且随机变量 X,Y 的表达式如下:

X=2lnUcos(2πV),Y=2lnUsin(2πV)

X,Y 是相互独立的,并且服从标准正态分布。

具体的程序实现如下:

%-------------------正态分布-----------------------%
%参数:均值mu,方差sigma2
%mean=mu,  var=sigma2
clear all
close all
clc
mu=0;
sigma2=1;
n=10;%x的取值为正负无穷大,
%--------------------由内置函数直接给出----------------------%
%正态分布的产生X
X=normrnd(mu,sqrt(sigma2));%产生均值mu,方差sigma2的正态分布%正态分布的cdf
x=0:.1:n;
Fx=normcdf(x,mu,sqrt(sigma2));
% figure
% plot(x,Fx,'-')
% title('正态分布的cdf')%指数分布的pdf
x=-5:.1:5;
Px=normpdf(x,mu,sqrt(sigma2));
figure
plot(x,Px,'r-')
hold on%-----------------------Box-Muller法-----------------------%
N=1000;
U=rand(1,N);%U,V都是服从(0,1)的均匀分布
V=rand(1,N);
A=-5;
B=5;
R=sqrt(-2.*log(U));
theta=2*pi*V;X2=R.*cos(theta);
Y2=R.*sin(theta);%X,Y都是服从n(0,1)的正态分布%下面的程序是计算通过Box-Muller法生成的正态分布X的pdf
Max=ceil(max(X2));
step=1;
range=A:step:B;for i=1:length(range)-1YY(i)=sum(range(i)<=X2&X2<=range(i+1))/N/step;XX(i)=(range(i)+range(i+1))/2;
endplot(XX,YY,'bo')
hold on
title('正态分布的pdf')
legend('内部函数产生','Box-Muller法产生')

显示结果如下:
这里写图片描述

上面我们是以正态分布为例来讲述了特殊法的运用,主要是运用了正态分布与其他分布的关系:多个独立同分布的随机变量和服从正态分布;均匀分布与正态分布之间满足Box-Muller法中的关系。因此,当想要由一种分布生成另一种分布的时候,只需要知道它们之间的关系即可!

原文:http://blog.csdn.net/tengweitw/article/details/45599011

作者:nineheadedbird


http://chatgpt.dhexx.cn/article/J7MQSRAj.shtml

相关文章

论文变量分布图的绘制

论文变量分布图的绘制 在近红外变量选择的论文中&#xff0c;需要对选择的波段进行可视化&#xff0c;以下介绍两种变量分布图的绘制。MATLAB绘制点图 直接上代码 %数据输入&#xff0c;一行多列 load(cor1_huatu.mat) load(RSR1_huatu.mat) load(SSC1_huatu.mat) load(sopsr…

MATLAB一维数据分布情况(稳定程度))

MATLAB一维数据分布情况&#xff08;稳定程度&#xff09; 一、具体实现二、测试三、其他 by HPC_ZY 搞研究的小伙伴们&#xff0c;经常需要对实验结果进行分析&#xff0c;获取实验的稳定性等。这里提供一个小函数&#xff0c;能对一维数据&#xff08;实验结果&#xff09;进…

Python数据科学numpy的运算、分布函数和矩阵

本文介绍numpy的常用运算、统计分布函数和矩阵的基础用法 numpy的一元多元运算&#xff0c;给我们做数据处理分析做基础&#xff0c;忘记的时候可以查看文档&#xff0c;常用的理解记忆就行。以下代码演示前提均以import numpy as np为前提 1. 一元运算&#xff1a; 运算函数…

IEEE802.11信道PDP与频谱分布

%实现IEEE802.11信道仿真&#xff0c;画出IEEE802.11信道的PDP曲线与频谱图 clear,clf scale 1e-9;%纳秒量级 Ts 50*scale;%采样时间间隔&#xff0c;50ns t_rms25*scale;%RMS时延扩展&#xff0c;25ns num_ch10000;%信道数 N128;%FFT长度 PDPIEEE802_11_model(t_rms,Ts);%调…

计算二维离散随机变量的联合概率分布

一. 定义 Joint probability distribution: 给定至少两个随机变量X,Y,…, 它们的联合概率分布(Joint probability distribution)指的是每一个随机变量的值落入特定范围或者离散点集合内的概率. 对于只有两个随机变量的情况, 称为二元分布(bivariate distribution). 联合概率…

matlab 分布拟合,曲线拟合和分布拟合 - MATLAB Simulink Example - MathWorks 中国

在曲线拟合与分布拟合之间进行选择 曲线拟合和分布拟合是不同类型的数据分析。 当您要将某个响应变量建模为预测变量的函数时,请使用曲线拟合。 当您要为单一变量的概率分布建模时,请使用分布拟合。 曲线拟合 在以下试验数据中,预测变量为 time,即服用药物之后的时间。响应…

MATLAB如何画数据分布曲线,Matlab绘制累积分布函数(CDF)

CDF示例代码&#xff1a; cdf.mfunction [xTime,yPercentage]cdf(initValue,step,endValue,sample); xTime[]; yPercentage[]; totalNumlength(sample); for iinitValue:step:endValue templength(find(sample<i))/totalNum; xTime[xTime,i]; yPercentage[yPercentage,temp]…

【得物技术】如何测试概率性事件 - 二项分布置信区间

前言 &#xfeff; 日常开发测试可能会遇到这样一种情况&#xff0c;有一个接口或方法概率触发&#xff0c;那么需要多少次抽样&#xff0c;落在一个什么区间内&#xff0c;才能断定是否按照设定概率进行呢&#xff1f; &#xfeff; 本文将以二项分布作为研究手段&#xf…

python画累积分布图_python累积分布图

在与@EOL进行了决定性的讨论之后,我想使用随机高斯样本作为摘要发布我的解决方案(左上角): import numpy as np import matplotlib.pyplot as plt from math import ceil, floor, sqrt def pdf(x, mu=0, sigma=1): """ Calculates the normal distributions p…

2021-10-24 我的第五次java作业:二项分布和双骰子赌博问题

我的第五次java作业 题目&#xff1a; 二项分布是n次独立试验中成功次数k的离散概率分布&#xff0c;其中每次试验成功的概率为p。利用Java Math类中提供的数学函数&#xff0c;给出二项分布X~B(n, p, k)的实现代码并进行测试。例如&#xff0c;当用户给定n20, p0.1, k5的概率…

记一次使用Cobar踩到的坑

起因 起因是因为日志里经常报出锁等待超时的错误&#xff0c;并且这个是环环相扣的&#xff0c;一个锁等待会直接引发另外的锁等待&#xff0c;所以危害非常严重&#xff0c;影响非常深远。寻找原因发现是C3P0报出了DEADLOCK&#xff0c;如下图所示&#xff1a; 分析 可以…

Cobar介绍及配置

原文地址为&#xff1a; Cobar介绍及配置 from&#xff1a;http://code.alibabatech.com/wiki/display/cobar/Home Skip to end of metadata Page restrictions applyAttachments:1Added by kimi Lv, last edited by 邱 硕 on 十月 18, 2012 (view change) Comment: Go to st…

用cobar搭建分布式数据库

周末针对最新的项目需求进行cobar的搭建并针对实际状况做了demo演示 一、需求 1、大数据量&#xff0c;邮件发送记录需要记录&#xff0c;一年可能累计4亿的数据 2、需要按照邮箱进行邮件发送明细的查询以及发送记录的查询 二、问题 1、单库分表分区已经解决不了存储以及查…

用cobar搭建分布式数据库 .

周末针对最新的项目需求进行cobar的搭建并针对实际状况做了demo演示 一、需求 1、大数据量&#xff0c;邮件发送记录需要记录&#xff0c;一年可能累计4亿的数据 2、需要按照邮箱进行邮件发送明细的查询以及发送记录的查询 二、问题 1、单库分表分区已经解决不了存储以及查…

开源的分布式数据库中间件系统Mycat和阿里巴巴Cobar的对比

mycat 不得不说的缘分 原创 2016年04月15日 15:48:17 27834 1&#xff0c;愕然回首&#xff0c;它在灯火阑珊处 关于mysql集群中间件&#xff0c;以前写在应用程序里面&#xff0c;由开发人员实现&#xff0c;在配置文件里面写多个数据源&#xff0c;写库一个数据源&#xff0…

分布式数据中间件TDDL、Amoeba、Cobar、MyCAT架构比较

框架比较 TDDL Amoeba Cobar MyCat 点评 TDDL不同于其它几款产品&#xff0c;并非独立的中间件&#xff0c;只能算作中间层&#xff0c;是以Jar包方式提供给应用调用。属于JDBC Shard的思想&#xff0c;网上也有很多其它类似产品。 另外&#xff0c;网上有关于TDDL的图&#x…

TDDL、Amoeba、Cobar、MyCAT架构比较

布式数据库中间件TDDL、Amoeba、Cobar、MyCAT架构比较分 比较了业界流行的MySQL分布式数据库中间件&#xff0c;关于每个产品的介绍&#xff0c;网上的资料比较多&#xff0c;本文只是对几款产品的架构进行比较&#xff0c;从中可以看出中间件发展和演进路线 框架比较 TDDL Am…

Cobar使用文档(可用作MySQL大型集群解决方案)

转&#xff1a;http://blog.csdn.net/shagoo/article/details/8191346 最近好不容易抽空研究了下Cobar&#xff0c;感觉这个产品确实很不错&#xff08;在文档方面比Amoeba强多了&#xff09;&#xff0c;特此推荐给大家。Cobar是阿里巴巴研发的关系型数据的分布式处理系统&am…

Cobar的架构与实践

Cobar是提供分布式数据库服务的中间件&#xff0c;是阿里巴巴B2B前台应用访问数据库的统一入口。本文讲述的就是Cobar的架构演变与应用实践。 2008年&#xff0c;阿里巴巴B2B成立了平台技术部&#xff0c;为各个业务部门的产品提供底层的基础平台。这些平台涵盖Web框架、消息…

alibaba的COBAR真是强大.

最近好不容易抽空研究了下Cobar&#xff0c;感觉这个产品确实很不错&#xff08;在文档方面比Amoeba强多了&#xff09;&#xff0c;特此推荐给大家。Cobar是阿里巴巴研发的关系型数据的分布式处理系统&#xff0c;该产品成功替代了原先基于Oracle的数据存储方案&#xff0c;目…