数字滤波器是一种能够对数字信号进行滤波处理的器件,其作用是滤除信号中的干扰、噪声等不需要的成分,保留我们需要的信号成分,从而提高信号的质量与可靠性。数字滤波器在不同领域得到广泛应用,包括通信、音频和图像处理等。
本文将介绍数字滤波器的基本原理、分类和设计方法,并给出使用 MATLAB 实现数字滤波器的具体步骤和实验结果。
一、数字滤波器的基本原理
数字滤波器是一种能够采用数字信号对输入信号进行滤波的装置。数字滤波器的基本原理是:将输入信号分解成一系列频率不同的信号成分后,通过对这些成分进行滤波,滤除其中的噪声、干扰等不需要的成分,从而获得所需的信号成分。数字滤波器的滤波效果主要取决于其滤波器的类型和参数设置等因素。
二、数字滤波器的分类
数字滤波器通常分为两类:有限长冲激响应(FIR)和无限长冲激响应(IIR)。两者的主要区别在于其滤波器的结构和特点不同。
1. 有限长冲激响应(FIR)滤波器
FIR 滤波器是一种采用有限长冲激响应进行滤波的数字滤波器。它的特点是滤波器的冲激响应是一个有限长的序列,即输出信号只与当前输入信号和前一部分的输入信号有关,其输出信号在时域上不具有反馈回路,因此其系统比较稳定,适合频率响应需要设计到任意频率范围和比较复杂的滤波器。
FIR 滤波器的数学表达式为:
$$y(n)=sum_{i=0}^{N-1}h(i)x(n-i)$$
其中,$x(n)$ 表示输入信号的采样序列,$y(n)$ 表示输出信号的采样序列,$h(i)$ 表示滤波器的冲激响应即滤波器系数。
2. 无限长冲激响应(IIR)滤波器
IIR 滤波器是一种采用无限长冲激响应进行滤波的数字滤波器。它的特点是滤波器的冲激响应是一个无限长的序列,即输出信号不仅与当前输入信号有关,还与此前所有的输入信号有关,因此其系统比较容易产生摆荡,需要注意稳定性问题。
IIR 滤波器的数学表达式为:
$$y(n)=sum_{i=0}^{M}b(i)x(n-i)-sum_{j=1}^{N}a(j)y(n-j)$$
其中,$x(n)$ 表示输入信号的采样序列,$y(n)$ 表示输出信号的采样序列,$b(i)$ 和 $a(j)$ 分别表示滤波器的前向和反馈系数。
三、数字滤波器的设计方法
数字滤波器的设计方法主要包括基于频率响应的设计和基于窗函数的设计两种方法。
1. 基于频率响应的设计
基于频率响应的设计方法是一种常用的数字滤波器设计方法,其主要基于数字滤波器的频率响应的设计参数,如截止频率、通带和阻带的范围等。这种方法一般采用滤波器参数的优化算法进行滤波器设计,如利用模拟信号的滤波器特性设计滤波器,连续的频域设计方法如butterworth滤波器、chebyshev滤波器等均可以当做数字频率滤波器设计的原型,通过对滤波器参数进行优化得到所需要的数字滤波器。
2. 基于窗函数的设计
基于窗函数的设计方法是一种比较常用的数字滤波器设计方法,其主要基于窗函数来设计滤波器,在此基础上优化滤波器的幅频响应。该方法主要包括以下步骤:
(1)选择一个适当的窗函数,如矩形窗、汉明窗、Blackman窗等;
(2)根据滤波器的截止频率、通带和阻带的要求计算出滤波器的理想响应函数,并在DFT域上压缩后得到截止频率和阻带范围;
(3)用所选窗函数乘以理想响应函数得到实际响应函数;
(4)计算出实际响应函数的DFT频谱,对其进行频率响应优化。
四、使用 MATLAB 实现数字滤波器
利用 MATLAB 进行数字滤波器的设计和实现比较方便快捷。MATLAB 提供了一系列有关滤波器设计和实现的指令和函数,如fdesign、designfilt、fir1、butter、freqz等函数。
下面以采用fir1函数设计一种低通滤波器为例,具体实现步骤如下:
步骤一、选择设计参数并进行设计
我们以一种低通滤波器为例来说明设计和实现的过程。首先,我们需要选择设计参数,包括采样率、截止频率和滤波器的阶数。这些参数通常是根据实际应用需求来决定的。
采用fir1函数进行设计时,需要设置滤波器的阶数、截止频率和窗函数参数。这里我们采用了一个三阶低通滤波器,其采样率为8kHz,截止频率为2kHz,采用汉明窗函数进行设计,MATLAB 代码如下:
% 设置滤波器参数
order = 3; % 滤波器阶数
fcut = 2e3; % 截止频率为2kHz
fs = 8e3; % 采样率为8kHz
win = hamming(order+1); % 采用汉明窗函数
% 调用fir1函数进行滤波器设计
b = fir1(order, fcut/(fs/2), 'low', win);
上述代码调用了 fir1 函数来设计一个低通 FIR 滤波器,其中 order 表示滤波器的阶数,fcut 表示截止频率,fs 表示采样率,win 表示窗函数参数,’low’ 表示低通滤波器。
步骤二、生成测试信号并进行滤波
接下来,我们需要生成一个随机的测试信号,并将其输入到设计好的滤波器中进行滤波。
MATLAB 可以使用 rand 函数生成具有随机幅度和相位的噪声信号。为了方便,我们在这里生成了一个目标频率为1kHz的正弦信号,并将其与噪声信号相加形成一个带噪声的测试信号。
MATLAB 代码如下:
% 生成目标信号
f0 = 1e3; % 目标信号频率为1kHz
t = 0:1/fs:1; % 采样时间
x = sin(2*pi*f0*t);
% 生成噪声信号
n = randn(size(x));
% 生成带噪声的信号
s = x + n;
生成好测试信号后,我们利用设计得到的滤波器对信号进行滤波,这里采用的是 MATLAB 的 filter 函数。滤波器设定好后,将信号输入到滤波器中进行滤波,滤波后的结果为 y。
MATLAB 代码如下:
% 利用设计好的滤波器对信号进行滤波
y = filter(b, 1, s);
得到滤波后的结果 y 后,我们可以绘制出原始信号、滤波后的信号及其幅频响应图像,以验证滤波器的有效性和性能。
MATLAB 代码如下:
% 绘制幅频响应
[H, f] = freqz(b, 1, 512, fs);
h = abs(H);
subplot(3,1,1);
plot(f/1e3, 20*log10(h)); % 幅度响应图像
title('滤波器幅度响应');
xlabel('频率/kHz');
ylabel('dB');
% 绘制原始信号和滤波后的信号图像
subplot(3,1,2);
plot(t, s, 'g', t, y, 'b');
title('原始信号和滤波后的信号');
legend('原始信号', '滤波后的信号');
xlabel('时间/s');
ylabel('幅值');
% 绘制滤波器的阶跃响应图像
subplot(3,1,3);
plot(f/1e3, unwrap(phase(H))/pi);
title('滤波器的阶跃响应');
xlabel('频率/kHz');
ylabel('相位/pi');
这样,我们就可以通过 MATLAB 进行数字滤波器的设计和实现,以满足不同实际应用场景下的需求。
五、实验结果
我们使用 MATLAB 实现了一个三阶低通数字滤波器,滤波器参数设置如下:
% 设置滤波器参数
order = 3; % 滤波器阶数
fcut = 2e3; % 截止频率为2kHz
fs = 8e3; % 采样率为8kHz
win = hamming(order+1); % 采用汉明窗函数
我们采用了一个正弦波作为目标信号,并对其加入噪声,形成了一个带噪声的信号,然后将该信号输入到设计好的滤波器进行滤波,得到滤波后的信号。
MATLAB 绘制的结果如下图所示,其中上部分是滤波器的幅频响应图像,中间部分是原始信号和滤波后的信号图像,下部分是滤波器的阶跃响应图像。
图中可以看出,滤波器对原始信号的高频部分进行了有效的滤除,从而得到了滤波后的信号,同时滤波器的幅频响应明显降低了信号的噪声和干扰部分。
六、总结
数字滤波器是一种针对数字信号进行滤波处理的器件,它能够滤除信号中的噪声、干扰等不需要的成分,保留我们需要的信号成分,提高信号的质量和可靠性。数字滤波器的设计方法主要包括基于频率响应的设计和基于窗函数的设计两种方法,在 MATLAB 中实现也比较方便,能够满足不同实际应用场景下的需求。本文主要讲述了 MATLAB 如何实现数字滤波器的设计和实现,通过对实验结果进行分析,证明了数字滤波器的有效性和性能。
原创文章,作者:古哥,转载需经过作者授权同意,并附上原文链接:https://iymark.com/articles/9850.html