加星座图的16QAM代码 编写MATLAB程序仿真QAM及相干解调。   (2) 观察I、Q两路基带信号的特征及与输入NRZ码的关系。   (3) 观察I、Q调制解调过程中各信号的变化。  (4) 观察星座图在不同噪声环境下的变化。

时间: 2024-03-10 18:45:42 浏览: 25
对于第一个问题,以下是MATLAB代码实现16QAM调制和解调: ```matlab % 16QAM调制解调示例 clear all; close all; clc; % 参数设置 N = 10000; % 仿真的码元数 M = 16; % 星座点数 k = log2(M); % 每个符号的比特数 EbNo = 10; % 信噪比,单位:dB EsNo = EbNo + 10*log10(k); % 符号信噪比 n = 1/sqrt(10^(EsNo/10)); % 噪声标准差 alpha = 0.5; % 光滑滤波器系数 Fs = 100; % 采样率,单位:MHz Fc = 10; % 载波频率,单位:MHz % 生成随机比特流 bits = randi([0 1],N,k); % 16QAM调制 data = bi2de(bits,'left-msb'); txSig = qammod(data,M,'gray'); % I路和Q路信号 I = real(txSig); Q = imag(txSig); % 加载星座图 constellation = qammod(0:M-1,M,'gray'); % 生成加性高斯白噪声 noise = n*randn(1,N); % 16QAM解调 % I路解调 rxSigI = I.*cos(2*pi*Fc*(0:N-1)/Fs) + noise.*cos(2*pi*Fc*(0:N-1)/Fs); % Q路解调 rxSigQ = -Q.*sin(2*pi*Fc*(0:N-1)/Fs) + noise.*sin(2*pi*Fc*(0:N-1)/Fs); % I路滤波 I_filtered = conv(rxSigI,fliplr([alpha 1-alpha])); I_filtered = I_filtered(length(alpha):end-length(alpha)+1); % Q路滤波 Q_filtered = conv(rxSigQ,fliplr([alpha 1-alpha])); Q_filtered = Q_filtered(length(alpha):end-length(alpha)+1); % 16QAM解调器输出 rxSig = I_filtered + 1i*Q_filtered; rxData = qamdemod(rxSig,M,'gray'); rxBits = de2bi(rxData,'left-msb'); % 绘制星座图 figure; plot(constellation,'r.','MarkerSize',20); hold on; plot(rxSig,'b.','MarkerSize',10); hold off; axis square; legend('星座图','解调信号'); title(['16QAM星座图,信噪比:',num2str(EsNo),'dB']); % 绘制I路和Q路信号 figure; subplot(2,1,1); plot(I); hold on; plot(I_filtered,'r','LineWidth',2); hold off; xlabel('码元'); ylabel('幅值'); legend('调制信号','解调信号'); title(['I路信号,信噪比:',num2str(EsNo),'dB']); subplot(2,1,2); plot(Q); hold on; plot(Q_filtered,'r','LineWidth',2); hold off; xlabel('码元'); ylabel('幅值'); legend('调制信号','解调信号'); title(['Q路信号,信噪比:',num2str(EsNo),'dB']); ``` 上面的代码中,我们首先生成随机比特流,然后将其转换为16QAM调制信号。接着,我们将16QAM信号拆分为I路和Q路信号,并加上高斯白噪声。通过乘以和除以载波信号,我们可以将I路和Q路信号分别解调。然后,我们将解调的I路和Q路信号分别通过光滑滤波器进行滤波,最终得到解调后的16QAM信号。最后,我们绘制星座图、I路和Q路信号的波形图。 对于第二个问题,我们可以观察I路和Q路信号的波形图,可以看到它们的波形与输入的NRZ码有关。在16QAM调制中,每个符号由4个比特表示,因此I路和Q路信号都是由NRZ码变换而来的。例如,当NRZ码为00时,对应的16QAM符号为1+j,因此I路信号的波形为正半周期,Q路信号的波形为正半周期;当NRZ码为01时,对应的16QAM符号为3+j,因此I路信号的波形为正半周期,Q路信号的波形为负半周期,以此类推。 对于第三个问题,我们可以观察I路和Q路信号的波形图,可以看到它们在解调过程中发生了变化。在16QAM解调中,我们首先将接收信号分别乘以和除以载波信号,得到I路和Q路信号。然后,我们对I路和Q路信号进行光滑滤波,得到解调后的16QAM信号。可以看到,解调后的信号波形比接收到的信号波形更加平滑,同时也消除了高斯白噪声对信号的影响。 对于第四个问题,我们可以通过改变噪声标准差的值,观察星座图在不同噪声环境下的变化。下面给出相应的代码: ```matlab % 绘制星座图和误码率曲线 clear all; close all; clc; % 参数设置 N = 10000; % 仿真的码元数 M = 16; % 星座点数 k = log2(M); % 每个符号的比特数 EbNo = 0:2:20; % 信噪比,单位:dB EsNo = EbNo + 10*log10(k); % 符号信噪比 alpha = 0.5; % 光滑滤波器系数 Fs = 100; % 采样率,单位:MHz Fc = 10; % 载波频率,单位:MHz % 生成随机比特流 bits = randi([0 1],N,k); % 加载星座图 constellation = qammod(0:M-1,M,'gray'); % 绘制星座图和误码率曲线 figure; for i = 1:length(EbNo) % 计算噪声标准差 n = 1/sqrt(10^(EsNo(i)/10)); % 16QAM调制 data = bi2de(bits,'left-msb'); txSig = qammod(data,M,'gray'); % I路和Q路信号 I = real(txSig); Q = imag(txSig); % 生成加性高斯白噪声 noise = n*randn(1,N); % 16QAM解调 % I路解调 rxSigI = I.*cos(2*pi*Fc*(0:N-1)/Fs) + noise.*cos(2*pi*Fc*(0:N-1)/Fs); % Q路解调 rxSigQ = -Q.*sin(2*pi*Fc*(0:N-1)/Fs) + noise.*sin(2*pi*Fc*(0:N-1)/Fs); % I路滤波 I_filtered = conv(rxSigI,fliplr([alpha 1-alpha])); I_filtered = I_filtered(length(alpha):end-length(alpha)+1); % Q路滤波 Q_filtered = conv(rxSigQ,fliplr([alpha 1-alpha])); Q_filtered = Q_filtered(length(alpha):end-length(alpha)+1); % 16QAM解调器输出 rxSig = I_filtered + 1i*Q_filtered; rxData = qamdemod(rxSig,M,'gray'); % 统计误码率 err(i) = sum(rxData~=data)/N; % 绘制星座图 subplot(2,5,i); plot(constellation,'r.','MarkerSize',20); hold on; plot(rxSig,'b.','MarkerSize',10); hold off; axis square; legend('星座图','解调信号'); title(['信噪比:',num2str(EsNo(i)),'dB']); end % 绘制误码率曲线 figure; semilogy(EbNo,err,'b-o','LineWidth',2,'MarkerSize',10); grid on; xlabel('信噪比(dB)'); ylabel('误码率'); title('16QAM误码率曲线'); ``` 上面的代码中,我们将噪声标准差n作为一个变量,在不同的信噪比下计算误码率和绘制星座图。可以看到,在噪声标准差较小的情况下,星座图较为清晰;而在噪声标准差较大的情况下,星座图变得模糊,误码率也随之增加。

相关推荐

最新推荐

recommend-type

qam及常见调制信号的星座图

qam的星座图,详细描绘qam以及其他调制解调的矢量星座图 方便人们一眼看出,各种调制的不同之处
recommend-type

通信与网络中的基于FPGA的16QAM调制器设计与实现

0 引言 为了满足现代通信系统对传输速率和带宽提出的新...1 16QAM调制原理 一般情况下,正交振幅调制的表达式为: 在式(1)的两个相互正交的载波分量中,每个载波被一组离散的振幅{Am}、{Bm}所调制,故称这
recommend-type

QPSK、8PSK、16PSK以及16QAM调制下的信道容量曲线

现在有一个二维M元信号集合,及信号的二维矢量表示。每一个信号波形都可以由完备的两个归一化正交函数的线性组合表示。现每一个都用使用复数表示。在高斯信道中二维的M进制调制的容量公式可以看成二进制情况的直接...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

用Spring boot和vue写一个登录注册界面

好的,这是一个比较常见的技术问题,我可以为您提供一些参考资料和思路。首先,您可以使用Spring Boot作为后端框架来处理用户认证和注册的逻辑,比如使用Spring Security实现用户登录认证。同时,您还需要设计相应的数据模型和数据库表结构来存储用户信息。在前端方面,您可以使用Vue.js作为框架来构建登录注册页面,使用Axios来发起API请求并和后端进行交互。当然,在实现过程中,还需要考虑一些具体细节,比如数据校验、安全性和用户体验等方面。希望这些信息能够帮助到您。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

MATLAB柱状图在数据分析中的作用:从可视化到洞察

![MATLAB柱状图在数据分析中的作用:从可视化到洞察](https://img-blog.csdnimg.cn/img_convert/1a36558cefc0339f7836cca7680c0aef.png) # 1. MATLAB柱状图概述** 柱状图是一种广泛用于数据可视化的图表类型,它使用垂直条形来表示数据中不同类别或组别的值。在MATLAB中,柱状图通过`bar`函数创建,该函数接受数据向量或矩阵作为输入,并生成相应的高度条形。 柱状图的优点在于其简单性和易于理解性。它们可以快速有效地传达数据分布和组别之间的比较。此外,MATLAB提供了广泛的定制选项,允许用户调整条形颜色、