IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> C语言实现 产生正态分布(高斯分布)随机数 -> 正文阅读

[C++知识库]C语言实现 产生正态分布(高斯分布)随机数

正态分布的概率密度函数如下

f(x) = \frac{1}{\sqrt{2\pi} \sigma }*e^{-(y-\mu)^2/2{\sigma}^2}

通常使用N(\mu,{\sigma}^2)表示均值为\mu,方差为\sigma^2

产生正太分布的方法如下:

r_{1},r_{2},...r_{n}为(0,1)上n个相互独立的均匀分布的随机数,由于E(r_{i})=\frac{1}{2},D(r_i)=\frac{1}{12}.

根据中心极限定理可知,当n趋向于无穷时

x=\sqrt{\frac{12}{n}}(\sum_{r=1}^{n}r_{i}-\frac{n}{2})

的分布近似于正态分布N(0,1),通常取n=12,

最后通过变换y=\mu+\sigma x,便可以得到均值为\mu,方差为\sigma^2的正太分布随机数。

C语言程序代码如下:

1、guass.h头文件代码

#pragma once
#ifndef GUASS_H_
#define GUASS_H_

/*
函数功能:	产生正太分布随机数
输入参数说明:
mean		给定均值
sigma		给定方差
seed	长整型指针变量, *seed 为伪随机数的种子
*/
double guass_data(double mean, double sigma, long int * seed);


#endif

2、guass.c文件

#include "guass.h"

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

/*
函数功能:	产生正太分布随机数
输入参数说明:
mean		给定均值
sigma		给定方差
seed	长整型指针变量, *seed 为伪随机数的种子
*/
double guass_data(double mean, double sigma, long int * seed)
{
	int i;
	double x, y;

	for (x=0, i = 0; i < 12; i++)
	{
		x += uniform_data(0.0,1.0,seed);
	}
	x = x - 6;
	y = mean + x * sigma;
	return y;
}

3、主程序Main.代码

#include <stdio.h>
#include <string.h>
#include "uniform.h"
#include "guass.h"

int main()
{
	// 产生50个0-1之间的随机数
	
	int i, j;
	long int s;

	double x, mean, sigma;
	mean = 0.0; sigma = 1.0; s = 13579;

	for (i = 0; i < 10; i++)
	{
		for (j = 0; j < 5; j++)
		{
			x = guass_data(mean, sigma, &s);
			printf("%13.7f",x);
		}
		printf("\n");
	}
	
	getchar();		// 此行代码是为了保持输出窗口,按任意按键关闭弹窗
	return 0;
}

4、程序运行结果

注:程序中包含的头文件 uniform.h和函数文件uniform.c 见文章产生(a,b)区间上均匀分布的随机数 C语言实现_jk99528878769的博客-CSDN博客使用C语言实现 在设定区间内产生一个均匀分布的随机数https://blog.csdn.net/jk99528878769/article/details/124435414?spm=1001.2014.3001.5501

matlab 验证结果

待添加。。。

?

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-29 11:55:13  更:2022-04-29 11:55:33 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/20 21:41:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码