(19)MATLAB使用Nakagami 分布对象生成Nakagami-m分布

文章目录


前言

MATLAB在R2013a版本中开始引入Nakagami分布对象,可以用来生成Nakagami随机变量。下面给出一个使用实例,用于生成服从Nakagami 分布的随机变量。


一、生成Nakagami分布随机变量的MATLAB代码

1.仿真代码

代码如下:

c 复制代码
clc
close all
clear all
%% 使用MATLAB函数makedist生成Nakagami分布
% Nakagami 分布的参数
m = 1;                                  % 形状参数
Omega = 2;                              % 尺度参数

% 使用 makedist 创建 Nakagami 分布对象
NakagamiDist = makedist('Nakagami', 'm', m, 'Omega', Omega);

% 生成随机变量
N = 10000;                              % 随机变量的数量
X = random(NakagamiDist, N, 1);         % 生成 N 个随机样本
figure(1)
histogram(X,nbins,'Normalization','pdf','DisplayStyle','bar');

%% nakagami分布的概率密度的理论值
% Nakagami分布的参数
m = 1;
Omega = 2;

% nakagami分布的概率密度的理论表达式
x = 0.01:0.01:3;
f = (2*m.^m./(gamma(m).*Omega^m)) .* x.^(2*m-1) .* exp(-m*x.^2./Omega);
figure()
plot(x,f,'LineWidth',1.5)
title('Nakagami分布的概率密度')
legend('概率密度函数的估计值','概率密度函数的理论值')

2.运行结果

二、传输信号经过衰落信道

与瑞利衰落和莱斯衰落一样,得到服从Nakagami分布的随机序列后,与传输信号相乘即可得到原信号的Nakagami衰落版本:

rx = tx .* X;


相关推荐
山语山几秒前
JavaScript进行数据可视化:D3.js入门
开发语言·javascript·信息可视化
hei_ya15 分钟前
python 进程和线程
开发语言·python
颜淡慕潇19 分钟前
【JDK17 | 10】Java 17 深入剖析:模式匹配(Pattern Matching)
java·开发语言·jdk·jdk17
计时开始不睡觉20 分钟前
【Java】并发编程基础 —— 进程、线程、并行与并发及相关方法示例
java·开发语言
lgily-122521 分钟前
Java新特性
java·开发语言·后端
删除没备份的痛21 分钟前
python3的语法
linux·开发语言·python
冲冲冲(ಡωಡ)22 分钟前
65 切面AOP
java·开发语言·数据库
会唱歌的小黄李26 分钟前
【C语言】字符函数和字符串函数
c语言·开发语言
景天科技苑37 分钟前
【Golang】Go语言Seeker接口与文件断点续传实战
开发语言·后端·golang·断点续传·seeker接口·go语言断点续传·偏移量
今天吃饺子38 分钟前
高被引算法GOA优化VMD,结合Transformer-SVM的轴承诊断,保姆级教程!
人工智能·深度学习·算法·支持向量机·transformer