当前位置: 首页 > news >正文

(10)MATLAB莱斯(Rician)衰落信道仿真1

文章目录

  • 前言
  • 一、莱斯分布随机变量
  • 二、仿真代码与结果
    • 1.仿真代码
    • 2.仿真结果画图
  • 后续


前言

首先给出莱斯衰落信道模型,引入了莱斯因子K,并给出莱斯分布的概率密度函数公式。然后导出莱斯分布随机变量的仿真表示式,建立MATLAB仿真代码,并根据莱斯衰落变量估计得到其PDF。


一、莱斯分布随机变量

与瑞利衰落不同,当无线信道中存在一个直射路径信号分量时,接收信号的包络将不再服从瑞利分布,而是服从莱斯分布,此时的小尺度衰落称为莱斯衰落。莱斯衰落时刻i的衰落幅度ri可以表示为:

式1

其中β是直射路径分量的幅度,而xi和yi是服从均值为0、方差为σ^2的平稳高斯随机过程的样本。直射路径信号能量与散射路径信号能量的比值定义了所谓的Rician因子K,其表达式为

式2

莱斯信道的概率密度函数为:

式3

其中I0[.]是第一类零阶修正贝塞尔函数。

已知Rician分布的均方值为 2σ^2(K + 1),其中 σ^2是组成莱斯分布的高斯噪声过程的方差。另外,为了使信号功率和信噪比(SNR)一致,通常需要将莱斯分布的均方值设置为1,即 E{r^2} = 1。在满足E{r^2} = 1的条件下,式(1)可以写成以下形式:

式4

式中,xi和yi是具有方差σ^2=1的零均值平稳高斯随机过程的样本。
接下来,将根据式(4)给出生成莱斯衰落随机变量的MATLAB代码,并根据随机变量计算出其PDF的估计值。

高斯分布随机变量仿真可以参考:
(3)MATLAB生成高斯随机变量及其概率密度函数估计

二、仿真代码与结果

生成莱斯衰落随机变量的MATLAB代码,并根据随机变量计算出其PDF的估计值。

1.仿真代码

莱斯分布随机变量MATLAB代码如下:

clc
close all
clear all
%% 生成莱斯分布随机变量
Kdb = 1;                      % 莱斯因子K,分贝值
N = 100000;% 生成莱斯分布随机变量
K = 10^(Kdb/10);              % 分贝值转换成线性值
const = 1/(2*(K+1));
x = randn(1,N);               % 高斯分布随机变量
y = randn(1,N);
r = sqrt(const*((x+sqrt(2*K)).^2 + y.^2));% 莱斯随机变量的分贝值
rdb = 20*log10(r);
figure()
plot(rdb)
xlim([0 1e3]);
title('莱斯分布随机变量的分贝值');
grid on;
xlabel('samples');
ylabel('amplitude/dB');%% 莱斯分布的pdf
bins_number = 30;
[elements_number,x] = hist(abs(r),bins_number);
pdfx = elements_number./N./(mean(diff(x)));% 画图
figure()
plot(x,pdfx,'-*','LineWidth',1.5)
title('莱斯分布的概率密度函数')
grid on
xlabel('x');
ylabel('pdfx');

2.仿真结果画图

仿真代码运行结果画图如下:
(1)莱斯分布随机变量

在这里插入图片描述

(2)莱斯分布随机变量概率密度估计值

在这里插入图片描述


后续

下一篇文章将会给出莱斯衰落信道的建模方法与MATLAB代码。

http://www.lryc.cn/news/454431.html

相关文章:

  • 什么是重卡充电桩?
  • 模拟实现消息队列(基于SpringBoot实现)
  • C语言:预编译过程的剖析
  • 算法——单调栈
  • LeetCode讲解篇之695. 岛屿的最大面积
  • 招联2025校招内推倒计时
  • vite学习教程01、vite构建vue2
  • 强化学习部分代码的注释分析
  • ctf.bugku-备份是个好习惯
  • C++面试速通宝典——14
  • k8s的简介和部署
  • Thingsboard 网关实战 modbus通信 rpc下发控制指令
  • 基于pytorch的手写数字识别
  • MySQL 实验 7:索引的操作
  • 为Floorp浏览器添加搜索引擎及搜索栏相关设置. 2024-10-05
  • 如何设置WSL Ubuntu在Windows开机时自动启动
  • 使用TensorBoard可视化模型
  • 《深度学习》OpenCV 图像拼接 原理、参数解析、案例实现
  • Hive数仓操作(三)
  • TDSQL-C电商可视化,重塑电商决策新纪元
  • 翔云 OCR:发票识别与验真
  • HTML ASCII:Web 开发中的字符编码基础
  • Meta 首个多模态大模型一键启动!首个多针刺绣数据集上线,含超 30k 张图片
  • 阿里云ECS服务器仿真
  • 如何为树莓派安装操作系统,以及远程操控树莓派的两种方法,无线操控和插网线操控
  • 【最新华为OD机试E卷-支持在线评测】简单的自动曝光(100分)多语言题解-(Python/C/JavaScript/Java/Cpp)
  • 每日一练:等差数列划分
  • Kotlin真·全平台——Kotlin Compose Multiplatform Mobile(kotlin跨平台方案、KMP、KMM)
  • unity 默认渲染管线材质球的材质通道,材质球的材质通道
  • PostgreSQL升级:使用pg_upgrade进行大版本(16.3)升级(17.0)