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

MATLAB使用眼图分析QPSK通信系统接收端匹配滤波后的信号

文章目录

  • 前言
  • 一、MATLAB仿真代码
  • 二、仿真结果


前言

本文完成以下内容:
(1)建立一个QPSK传输系统,并引入EsNo=20dB(SNR=0dB)的噪声,接收端对带噪信号进行匹配滤波。
(2)分别画出成形滤波器输出信号的实部波形和匹配滤波器输出信号的实部波形。
(3)分别画出成形滤波器输出信号的2D彩色眼图,和匹配滤波器输出信号的2D彩色眼图,2D彩色眼图中,颜色强度与给定时间输入信号幅度的概率密度函数(PDF)成比例。


一、MATLAB仿真代码

代码如下:

clc
clear all
close all
%% Create a QPSK transmission system
% Initialize system parameters
Fs = 10000;
Rs = 100;
nSamps = Fs/Rs;
rollOff = 0.5;
M = 4;

% comm.QPSKModulator System object
hMod = comm.QPSKModulator;

% Square root raised cosine filters
filtSpec = fdesign.pulseshaping(nSamps,'Square root raised cosine',...
    'Nsym,Beta',6,rollOff);
hTxFlt = design(filtSpec); hTxFlt.PersistentMemory = true;
hRxFlt = copy(hTxFlt); hTxFlt.Numerator = hTxFlt.Numerator*nSamps;

% Generate modulated and pulse shaped signal
msgLen = 1000;
msgData = randi([0 M-1],msgLen,1);
msgSymbols = step(hMod, msgData);
msgTx = hTxFlt.filter(upsample(msgSymbols, nSamps));

% Create an comm.AWGNChannel System object
EsNo = 20;
SNR = EsNo - 10*log10(nSamps);
hChan = comm.AWGNChannel('NoiseMethod', 'Signal to noise ratio (SNR)',...
  'SNR', SNR);
hChan.SignalPower = (msgTx' * msgTx)/ length(msgTx);

% Modulated signal through AWGN channel
msgRx = step(hChan, msgTx);

% Matched filtering
msgRxMf = hRxFlt.filter(msgRx);

%% Plot the Tx filtered in-phase signal and the Nf filtered in-phase signal
t = 0:1/Fs:50/Rs-1/Fs;
idx = round(t*Fs+1);
figure(); 
subplot(211)
plot(t, real(msgTx(idx)));
title('Modulated, filtered in-phase signal');
xlabel('Time (sec)');
ylabel('Amplitude');
grid on;

subplot(212)
plot(t, real(msgRxMf(idx)));
title(['Modulated, filtered noisy in-phase signal, Es/No = ' ...
       num2str(EsNo) ' dB']);  
xlabel('Time (sec)');
ylabel('Amplitude');
grid on;

%% eye diagram
% Create an eye diagram object
eyeObj = commscope.eyediagram(...
    'SamplingFrequency', Fs, ...
    'SamplesPerSymbol', nSamps, ...
    'SymbolsPerTrace', 2, ...
    'MinimumAmplitude', -1.5, ...
    'MaximumAmplitude', 1.5, ...
    'OperationMode', 'Complex Signal', ...
    'PlotType', '2D Color', ...
    'PlotTimeOffset', 0);

eyeObjN = copy(eyeObj);

% Update the first eye diagram object with the transmitted signal
eyeObj.update(msgTx);

% Update the second eye diagram object with the received signal
eyeObjN.update(msgRxMf);

二、仿真结果

代码运行结果画图如下:

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述



http://www.kler.cn/news/331374.html

相关文章:

  • windows 11 LTSC 26100.1742 官方简体中文版
  • 免杀对抗—GOC#反VT沙盒资源分离混淆加密
  • 【Flutter】- 基础语法
  • 【go入门】常量
  • Leetcode 11.乘最多水的容器(字节,快手面试题)
  • 探索Spring Boot:实现“衣依”服装电商平台
  • 【Java序列化】使用Java 自带的Serializer进行对象序列化和反序列化
  • 2024年OpenAI DevDay发布实时 API、提示缓存等新功能
  • 软考系统分析师知识点一:绪论
  • Ubuntu20.04如何安装Microsoft Edge浏览器?
  • Linux云计算 |【第四阶段】RDBMS1-DAY5
  • ATLAS/ICESat-2 L3B 每 3 个月网格动态海洋地形图 V001
  • 算法【Java】—— 递归
  • centos环境安装JDK详细教程
  • 在Docker中运行微服务注册中心Eureka
  • 复习HTML(进阶)
  • eNSP网络配置指南:IP设置、DNS、Telnet、DHCP与路由表管理
  • 1.2.2 计算机网络的分层结构(下)
  • 【转载翻译】消息队列 - ActiveMQ、RabbitMQ、Kafka、ZeroMQ
  • 玄派玄机星16N:240Hz高刷战场,185W性能怪兽来袭