(8)MATLAB瑞利衰落信道仿真1

news2024/11/29 22:54:34

文章目录

  • 一、瑞利随机变量及其概率密度函数
  • 二、仿真代码
  • 三、仿真结果
  • 四、仿真代码的几点补充说明
  • 其他


一、瑞利随机变量及其概率密度函数

在无线通信中,如果信道中存在大量非视距路径而不存在视距路径信号分量,此时,无线信道可以由一个复高斯随机变量W1+jW2表示,其中W1和W2是均值为0,方差为σ2的独立同分布的高斯随机变量。令X表示复高斯随机变量W1+jW2的幅度,有:

在这里插入图片描述

则X是一个瑞利随机变量,此时的小尺度衰落称为瑞利衰落,其包络可由瑞利分布概率密度函数(Probability Density Function,PDF)来描述。其PDF为:

在这里插入图片描述

关于高斯随机变量及其概率密度函数,可参考《MATLAB生成高斯随机变量及其概率密度函数估计》。
下面给出瑞利随机变量的MATLAB建模,并计算出其PDF的估计值。


二、仿真代码

代码如下:

clc
close all
clear all
%% 比较瑞利衰落的估计值和理论值
N = 100000;                                     %10万个samples
x = randn(1, N);
y = randn(1, N);
r = sqrt(0.5*(x.^2 + y.^2));                    % 生成瑞利随机变量
step = 0.1; 
range = 0:step:3;                               %31个数
h = hist(r, range);                             % 直方图
fr_approx = h/(step*sum(h));                    % 仿真值

% 理论值
fr = (range/0.5).*exp(-range.^2);               % 瑞利随机变量概率密度函数

figure()
plot(range, fr_approx,'ro', range, fr,'b','LineWidth',1.5);
legend('仿真值','理论值');
grid on;
title('瑞利随机变量的概率密度');
xlabel('x');
ylabel('f(x)');

%% 瑞利随机变量的分贝值
rdb = 20*log10(r);                             % 幅度值转换为dB形式
figure();
plot(rdb);
title('瑞利随机变量的分贝值');
xlim([0 1e3]);
grid on;
xlabel('samples');
ylabel('amplitude/dB');

三、仿真结果

PDF如下:
在这里插入图片描述

瑞利随机变量如下:
在这里插入图片描述


四、仿真代码的几点补充说明

(1)在生成瑞利随机变量时,设置sigma方=0.5表示高斯分布的方差为0.5,设置为0.5是为了使得瑞利分布的方差=2*sigma方=1。

(2)瑞利分布的方差=2*sigma方=1,则对于瑞利分布而言,有sigma方=0.5,所以在画瑞利分布PDF时,取sigma方=0.5。

(3)hist用法。[counts,centers] = hist(x,xbins) ,该函数完成,基于向量x中的元素创建直方图条形图。x中的元素有序划分入x轴上介于x的最小值和最大值间的nbins(标量)所指定数量的bin中。hist将bin显示为矩形,这样每个矩形的高度就表示bin中的元素数量。如果 xbins 是一个包含等间距值的向量,则 hist 将使用这些值作为直方图中心。返回值counts是一个行向量,指示每个bin中的元素数目。返回值centers也是一个行向量,指示x轴上每个bin中心的位置。

(4)另外,需注意概率和概率密度的区别。

其他

瑞利衰落信道建模,见:
(9)MATLAB瑞利衰落信道仿真2

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2188984.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

深入浅出,从源码搞清Bean的加载过程

深入浅出,从源码搞清Bean的加载过程 前言 Bean的加载过程算是面试中的老生常谈了,今天我们就来从源码层面深入去了解一下Spring中是如何进行Bean的加载的 Spring 先看示例代码: public static void main(String[] args) {ApplicationCon…

微服务之间的相互调用的几种常见实现方式对比

目录 微服务之间的相互调用的几种实现方式 一、HTTP HTTP/RESTful API调用工作原理 二、RPC 设计理念与实现方式 协议与传输层 RPC远程调用工作原理 应用场景与性能考量 特点 三、Feign 设计理念与实现方式 协议与传输层 Feign调用的基本流程 Feign调用的工作原理…

算法训练营打卡Day19

目录 1.二叉搜索树的最近公共祖先 2.二叉树中的插入操作 3.删除二叉搜索树中的节点 题目1、二叉搜索树的最近公共祖先 力扣题目链接(opens new window) 给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有…

温度转换-C语言

1.问题: 输入一个华氏温度,要求输出摄氏温度。公式为 c5(F-32)/9,取位2小数。 2.解答: scanf("%lf",&f);或者scanf("%f",&f);如果你前面定义的f是用double类型的话,就应该用%lf格式&…

deploy thingsboard

ThingsBoard部署 平台:windows10,idea2022,postgres15 maven仓库 进入thingsboard源码下载目录: 主要执行以下两个命令: mvn编译: mvn clean install -Dmaven.test.skiptrue编译报错时: 清除java进程 t…

计算机毕业设计 玩具租赁系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍:✌从事软件开发10年之余,专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ 🍅文末获取源码联系🍅 👇🏻 精…

UART通信—基于江科大源码基础进行的改进和解析

我就不讲理论了,CSDN上大佬属实多,我就只讲代码了,串口的基本理论,大家去看其他大佬写的吧 一、源文件的组成 1、包含的头文件 stm32f10x.h 是STM32F10x系列微控制器的标准外设库(Standard Peripheral Library&…

C语言基础(7)之操作符(1)(详解)

目录 1. 各种操作符介绍 1.1 操作符汇总表 2. 移位操作符 2.1 移位操作符知识拓展 —— 原码、反码、补码 2.2 移位操作符讲解 2.2.1 右移操作符 ( >> ) 2.2.2 左移操作符 ( << ) 3. 位操作符 3.1 & (按位与) 3.2 | (按位或) 3.3 ^ (按位异或) 3.4…

【AI学习】Mamba学习(二):线性注意力

上一篇《Mamba学习&#xff08;一&#xff09;&#xff1a;总体架构》提到&#xff0c;Transformer 模型的主要缺点是&#xff1a;自注意力机制的计算量会随着上下文长度的增加呈平方级增长。所以&#xff0c;许多次二次时间架构&#xff08;指一个函数或算法的增长速度小于二次…

C++ 多态:重塑编程效率与灵活性

目录 多态的概念 多态的定义及实现 多态的构成条件 虚函数 虚函数的重写 虚函数重写的两个例外&#xff1a; 1. 协变(基类与派生类虚函数返回值类型不同) 2. 析构函数的重写(基类与派生类析构函数的名字不同&#xff09; 析构函数要不要定义成虚函数&#xff1f;&…

绝对值得收藏!分享7款ai写作论文免费一键生成网站

在当前的学术研究和写作过程中&#xff0c;AI写作工具已经成为了许多研究者和学生的重要助手。这些工具不仅能够提高写作效率&#xff0c;还能帮助生成高质量的论文内容。以下是七款免费的AI写作论文生成器&#xff0c;其中特别推荐千笔-AIPassPaper。 1.千笔-AIPassPaper 千…

信号处理: Block Pending Handler 与 SIGKILL/SIGSTOP 实验

1. 信号处理机制的 “三张表” kill -l &#xff1a;前 31 个信号为系统标准信号。 block pending handler 三张表保存在每个进程的进程控制块 —— pcb 中&#xff0c;它们分别对应了某一信号的阻塞状态、待处理状态以及处理方式。 block &#xff1a;通过 sigset_t 类型实现&…

YOLO11改进 | 检测头 | 融合渐进特征金字塔的检测头【AFPN3】

秋招面试专栏推荐 &#xff1a;深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转 &#x1f4a1;&#x1f4a1;&#x1f4a1;本专栏所有程序均经过测试&#xff0c;可成功执行&#x1f4a1;&#x1f4a1;&#x1f4a1; 本文介绍了一个渐进特征金字塔网络&…

关于 S7 - 1200 通过存储卡进行程序更新

西门子S7-1200系列PLC可以通过存储卡进行程序的更新&#xff0c;固件版本的升级以及程序数据的存储多项功能。本例进行程序更新的操作。 存储卡的订货号以及存储容量 一&#xff1b;如何插入存储卡 在CPU断电下&#xff0c;将CPU上挡板向下掀开&#xff0c;可以看到右上角有一…

ai写作论文会被检测吗?分享市面上7款自动写论文网站

近年来&#xff0c;随着人工智能技术的飞速发展&#xff0c;AI写作工具在学术界引起了广泛关注。然而&#xff0c;这些工具的使用也引发了关于学术诚信和检测机制的讨论。根据多所高校的声明&#xff0c;为了应对AI代写论文的现象&#xff0c;许多高校已经开始引入论文检测工具…

Python入门:深入了解__init__.py 文件(如何实现动态导入子模块)

文章目录 📖 介绍 📖🏡 演示环境 🏡📒 文章内容 📒📝 `__init__.py` 的作用示例:📝 如何编写 `__init__.py`1. 空的 `__init__.py`2. 导入子模块3. 初始化代码4. 动态导入子模块📝 编写 `__init__.py` 的技巧和注意事项⚓️ 相关链接 ⚓️📖 介绍 📖 在…

01:(寄存器开发)点亮一个LED灯

寄存器开发 1、单片机的简介1.1、什么是单片机1.2、F1系列内核和芯片的系统架构1.3、存储器映像1.4、什么是寄存器 2、寄存器开发模板工程3、使用寄存器点亮一个LED4、代码改进15、代码改进2 本教程使用的是STM32F103C8T6最小系统板&#xff0c;教程来源B站up“嵌入式那些事”。…

前缀和(6)_和可被k整除的子数组_蓝桥杯

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 前缀和(6)_和可被k整除的子数组 收录于专栏【经典算法练习】 本专栏旨在分享学习算法的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 …

kubeadm部署k8s

1.1 安装Docker [rootk8s-all ~]# wget -O /etc/yum.repos.d/docker-ce.repo https://mirrors.huaweicloud.com/docker-ce/linux/centos/docker-ce.repo [rootk8s-all ~]# sed -i sdownload.docker.commirrors.huaweicloud.com/docker-ce /etc/yum.repos.d/docker-ce.repo [ro…