产生指数分布的随机数 C语言实现

一、产生随机变量的逆变换方法

定理:设F(x)是任一连续的分布函数,如果u\sim U(0,1),且\eta=F^{-1}(u)那么\eta\sim F(x).

证明 由于u\sim U(0,1),则有

P(\eta \leqslant x ) = P(F^{-1}(u) \leqslant x) = P(u \leqslant F(x)) = F(x)

所以\eta \sim F(x)

此定理给出了从均匀分布随机数到给定分布F(x)的随机数的变换,根据该变换可以生分布函数为F(x)的随机数x,其算法可以用下列两个步骤实现:

 (1)产生均匀分布的随机数u,即u \sim U(0,1)

(2)计算x=F^{-1}(x)

 

二、产生指数随机分布随机数的方法

指数分布的概率密度函数为

f(x)=\left\{\begin{matrix} \frac{1}{\beta}e^{- \frac{x}{\beta}} & x \geqslant 0\\ 0 & other \end{matrix}\right.

其分布函数为

F(x)=\left\{\begin{matrix} 1- e^{- \frac{x}{\beta}} & x \ge 0 \\ 0 & other \end{matrix}\right.

指数分布的均值为\beta,方差为\beta ^2

根据上述的逆变换法,产生指数分布随机数的方法为

(1)产生均匀分布的随机数u,即u \sim U(0,1)

(2)计算x = -\beta ln (u)

 

1、exponent.h 文件

#pragma once
#ifndef EXPONENT_H_
#define EXPONENT_H_

/*
函数功能:	产生指数分布的随机数
输入参数说明:
beta		指数分布的均值
seed	    长整型指针变量, *seed 为伪随机数的种子
*/
double exponent_data(double beta,  long int * seed);

#endif // !EXPONENT_H_

2、exponent.c文件

#include "exponent.h"

#include <stdint.h>
#include "string.h"
#include "stdio.h"
#include "uniform.h"
#include <math.h>


/*
函数功能:	产生指数分布的随机数
输入参数说明:
beta		指数分布的均值
seed	    长整型指针变量, *seed 为伪随机数的种子
*/
double exponent_data(double beta, long int * seed)
{
	double u, x;
	u =  uniform_data(0.0, 1.0, seed);
	x = -beta * log(u);
	return x;
}

3、主程序main.c

#include <stdio.h>
#include <string.h>
#include "uniform.h"
#include "exponent.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 = exponent_data(beta,  &s);
			printf("%13.7f",x);
		}
		printf("\n");
	}	
	getchar();		// 此行代码是为了保持输出窗口,按任意按键关闭弹窗
	return 0;
}

4、代码运行结果

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jk99528878769

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值