常见分布在matlab的仿真实现方法

在 MATLAB 中进行不同概率分布的仿真,你可以使用内置的函数生成不同分布的随机数。以下是一些常见的分布及其仿真方法的示例。

1. 正态分布 (Normal Distribution)

使用 normrndrandn 函数生成正态分布随机数。

matlab 复制代码
mu = 0; % 均值
sigma = 1; % 标准差
n = 1000; % 样本数量

% 使用normrnd
data_normal = normrnd(mu, sigma, [1, n]);

% 或者使用randn生成标准正态分布 (均值0, 方差1),再进行缩放
data_normal = mu + sigma * randn(1, n);

% 绘制直方图
histogram(data_normal, 30);
title('Normal Distribution');

2. 学生 t 分布 (Student's t Distribution)

使用 trnd 函数生成 t 分布随机数。

matlab 复制代码
v = 5; % 自由度
n = 1000; % 样本数量

data_t = trnd(v, [1, n]);

% 绘制直方图
histogram(data_t, 30);
title('Student''s t Distribution');

3. 均匀分布 (Uniform Distribution)

使用 rand 函数生成均匀分布随机数。

matlab 复制代码
a = 0; % 下界
b = 10; % 上界
n = 1000; % 样本数量

data_uniform = (b-a) * rand(1, n) + a;

% 绘制直方图
histogram(data_uniform, 30);
title('Uniform Distribution');

4. 指数分布 (Exponential Distribution)

使用 exprnd 函数生成指数分布随机数。

matlab 复制代码
lambda = 2; % 速率参数 (λ)
n = 1000; % 样本数量

data_exp = exprnd(1/lambda, [1, n]);

% 绘制直方图
histogram(data_exp, 30);
title('Exponential Distribution');

5. 卡方分布 (Chi-Square Distribution)

使用 chi2rnd 函数生成卡方分布随机数。

matlab 复制代码
k = 4; % 自由度
n = 1000; % 样本数量

data_chi2 = chi2rnd(k, [1, n]);

% 绘制直方图
histogram(data_chi2, 30);
title('Chi-Square Distribution');

6. 伽马分布 (Gamma Distribution)

使用 gamrnd 函数生成伽马分布随机数。

matlab 复制代码
alpha = 2; % 形状参数
beta = 2; % 尺度参数
n = 1000; % 样本数量

data_gamma = gamrnd(alpha, beta, [1, n]);

% 绘制直方图
histogram(data_gamma, 30);
title('Gamma Distribution');

7. 泊松分布 (Poisson Distribution)

使用 poissrnd 函数生成泊松分布随机数。

matlab 复制代码
lambda = 3; % 均值
n = 1000; % 样本数量

data_poisson = poissrnd(lambda, [1, n]);

% 绘制直方图
histogram(data_poisson, 30);
title('Poisson Distribution');

8. 二项分布 (Binomial Distribution)

使用 binornd 函数生成二项分布随机数。

matlab 复制代码
p = 0.5; % 成功概率
N = 10; % 尝试次数
n = 1000; % 样本数量

data_binomial = binornd(N, p, [1, n]);

% 绘制直方图
histogram(data_binomial, 30);
title('Binomial Distribution');

9. Beta 分布 (Beta Distribution)

使用 betarnd 函数生成 Beta 分布随机数。

matlab 复制代码
alpha = 2; % 形状参数
beta = 5; % 形状参数
n = 1000; % 样本数量

data_beta = betarnd(alpha, beta, [1, n]);

% 绘制直方图
histogram(data_beta, 30);
title('Beta Distribution');

10. 绘制多个分布进行比较

如果你想在同一张图上比较不同分布的特性,可以使用 subplot 将多个直方图放在一起:

matlab 复制代码
figure;
subplot(2,2,1);
histogram(data_normal, 30);
title('Normal Distribution');

subplot(2,2,2);
histogram(data_t, 30);
title('Student''s t Distribution');

subplot(2,2,3);
histogram(data_uniform, 30);
title('Uniform Distribution');

subplot(2,2,4);
histogram(data_exp, 30);
title('Exponential Distribution');

总结

通过使用 MATLAB 中内置的概率分布函数,能够生成各种常见分布的数据,并对其进行可视化分析。这对于了解不同分布的特性及其应用非常有帮助。

相关推荐
一方热衷.1 小时前
YOLO26-Seg ONNXruntime C++/python推理
开发语言·c++·python
靓仔建3 小时前
Vue3导入组件出错does not provide an export named ‘user_setting‘ (at index.vue:180:10)
开发语言·前端·typescript
赶路人儿4 小时前
UTC时间和时间戳介绍
java·开发语言
6+h4 小时前
【java】基本数据类型与包装类:拆箱装箱机制
java·开发语言·python
未来之窗软件服务5 小时前
幽冥大陆(一百12)js打造json硬件管道——东方仙盟筑基期
开发语言·javascript·算法·json·仙盟创梦ide·东方仙盟·东方仙盟算法
人道领域5 小时前
苍穹外卖:菜品分页查询与删除功能(保姆级详解)
java·开发语言·数据库·后端·spring
EverestVIP5 小时前
c++前置声明的方式与说明
开发语言·c++
天远云服6 小时前
天远企业司法认证API对接实战:PHP构建B2B供应链合规防火墙
大数据·开发语言·后端·node.js·php
空空kkk7 小时前
Java基础——代理
java·开发语言
赵谨言7 小时前
基于YOLOv5的植物目标检测研究
大数据·开发语言·经验分享·python