深入探究升余弦滚降滤波器及其在通信系统中的应用
创作时间:
作者:
@小白创作中心
深入探究升余弦滚降滤波器及其在通信系统中的应用
引用
CSDN
1.
https://m.blog.csdn.net/qq_16763641/article/details/144927570
升余弦滚降滤波器是通信系统中常用的一种滤波器,主要用于脉冲成形和匹配滤波。本文将深入探讨升余弦滚降滤波器的原理及其在MATLAB中的实现方法。
一、rcosdesign函数设计升余弦脉冲或平方根升余弦脉冲
可以使用MATLAB函数rcosdesign
来生成升余弦脉冲或平方根升余弦脉冲。
b = rcosdesign(beta,span,sps)
beta
:滚降因子span
:滤波器跨越的符号数sps
:每个符号的采样点数
当shape
设置为"sqrt"
时,返回平方根升余弦滤波器;当shape
设置为"normal"
时,返回升余弦FIR滤波器。
a) 平方根升余弦脉冲
假设符号周期为1秒(Ts=1),beta=0.25,span=6,sps=9,shape="sqrt":
Ts = 1; % 码元周期
L = 9; % 每个符号周期包含9个样本
r = 0.25; % 滚降系数
t = -3:Ts/L:3; % 时间向量
pt = rcosdesign(r,6,L,'sqrt'); % 返回一个平方根升余弦滤波器。跨越6个符号
b) 升余弦脉冲
将rcosdesign(r,6,L,'sqrt')
中的sqrt
改为rcosdesign(r,6,L,'normal')
:
c) 根据函数表达式编写MATLAB
升余弦滚降滤波器的函数为:
% 平方根升余弦滚降函数
hr1=sin(pi*t/Ts)./(pi*t/Ts);
hr2=cos(alpha*pi*t/Ts)./(1-(2*alpha*t/Ts).^2);
hr=hr1.*hr2;
HR=abs(t2f(hr));
GT=sqrt(HR);
GR=GT;
function X=t2f(x)
global dt N
H=fft(x);
X=[H(N/2+1:N),H(1:N/2)]*dt;
end
二、脉冲调制的无符号间干扰(ISI)
脉冲调制时,需脉冲整形(插入0进行上采样)后与升余弦滚降滤波器卷积能实现无符号间干扰(ISI)。
a) 脉冲波形成
生成一个升余弦脉冲:
Ts = 1; % symbol duration
L = 9;
span = 6;
r = 0.25; % Roll-off factor
t_step = Ts/L;
pt = rcosdesign(r,span,L,'normal');
b) 单极到双极(幅度调制)
当nth信息为1时,设置αn=1,当nth信息为0时,设置αn=-1:
Ns = 2;%2个bit需要传输
data_bit =[0 1];
amp_modulated = 2*data_bit-1; % 0 => -1, 1 => 1
c) 脉冲调制
将信息每两个bit之间插入8个(L-1)个0:
impulse_modulated = [];
for n = 1:Ns
num_zeros =L-1;%延迟8bit,因为单个符号范围的采样个数为9
delta_signal = [amp_modulated(n) zeros(1, num_zeros)];
impulse_modulated = [impulse_modulated delta_signal];
end
d) 脉冲整形(传递滤波)
将脉冲调制(插入0)的信号与成型滤波器卷积:
tx_signal = conv(impulse_modulated, pt);
三、经过升余弦滚降滤波器后的眼图
使用升余弦滤波器绘制眼图的部分关键代码如下:
t_step = Ts/L;%相邻采样点之间的间隔
Ns = 1000;%Ns为总信息bit数量
pt = rcosdesign(r,span,L,'normal');
figure
for k = 1:floor(Ns/3) % k是三个连续符号部分的索引。Ns为总信息bit数量
tmp = tx_signal( ((k-1)*3*L + 1) : k*3*L ); %第k个连续的符号部分(波形)。
plot(t_step*(0:(3*L-1)), tmp);
axis([0 3 min(tx_signal) max(tx_signal)]);
grid on;
hold on
% pause % 需要按下一个键继续绘图,或者您可以选择common out“暂停”,以一键查看最终结果。
end
四、匹配滤波
匹配滤波器使滤波器输出的信噪比在某一特定时刻达到最大。在通信系统中,根升余弦滤波器(RRC)常用于发送和接收滤波器,来进行匹配滤波。
clear;
close all;clc;
R=0.3; % roll-off factor
delay=4; % the group delay of the filter
sps=16; % oversampling factor
sym=[-3,1,-1,-3,3]; % symbol
len_x=length(sym);
xx=zeros(1,(len_x+2*delay)*sps);
for ii=delay+1:len_x+delay
xx((ii-1)*sps+1)=sym(ii-delay); % oversampling
end
h_rrc=rcosdesign(R,2*delay,sps,'sqrt'); % RRC filter
send=conv(xx,h_rrc); % filter with RRC at the transmitter
send=send(delay*sps+1:end-delay*sps); % remove the delay
recv=conv(send,h_rrc); % filter with RRC at the receiver
recv=recv(delay*sps+1:end-delay*sps); % remove the delay
从图 1可以看出,滤波后波形在最佳采样点处的值并不等于采样点的值。而经过接收端匹配滤波后,波形在最佳采样点处的值正好是发送符号的幅度值,这说明经过匹配滤波后ISI得到缓解。
本文原文来自CSDN
热门推荐
购房过程中有哪些最常见的纠纷与解决办法
医院医疗诊断证明书:定义、种类、出具程序及法律效力
创业者必读的四本实战好书推荐
魔术主场击溃活塞,班切罗缺阵依旧无碍胜局
熊猫小镇设计规划:融合自然与文化的完美典范
奉新县农民工维权律师咨询记录及案例分析
清理手机内存的方法与步骤指南
克苏鲁文化的深层解读与构建中式克苏鲁故事的探索
身边的儿童科学小实验:火山喷发实验【火山喷发原理实验】
蛇入十二生肖的深厚背景与神秘象征
苹果自带浏览器怎么清理缓存文件方法
近代中国建筑师庄俊及其建筑代表作品
心灵的绿洲:在忙碌生活中寻找情感治愈的五个秘诀
铝基板散热设计规范及应用案例
乘着地铁逛青岛 | “含青量”满满,打卡《南来北往》取景地
如何正确选择聚类算法
马斯克的第一性原理给我们的启示
古代中国为何将火星命名为“荧惑星”
东阳光股票下跌的原因与分析
难怪郭襄终身不愿再见张三丰,你看郭襄把什么给了他,他羞于启齿
闪耀中国的年轻力量!破局需要勇气,夺冠背后的辛勤与默契
如何从失败中获得成长?
医生解答:肥胖人群一个月减重五六斤是否合理
常见的耳朵整形手术
申请法院调取证据的质证需要什么条件
合法解决吵架的技巧:避免冲突升级
破窗器原理:如何在紧急情况下砸碎玻璃逃生?
什么是多式联运?多式联运( MT)的类型详解
盗窃、侵占与诈骗:三种犯罪行为的区别及法律规定
个人养老金产品选择指南:三大类产品特点与选购建议