千家信息网

基于FPGA的多级CIC滤波器如何实现四倍抽取一

发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,基于FPGA的多级CIC滤波器如何实现四倍抽取一,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。在实现多级CIC滤波器前我
千家信息网最后更新 2025年12月02日基于FPGA的多级CIC滤波器如何实现四倍抽取一

基于FPGA的多级CIC滤波器如何实现四倍抽取一,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

在实现多级CIC滤波器前我们先来了解滑动平均滤波器、微分器、积分器以及梳状滤波器原理。CIC滤波器在通信信号处理中有着重要的应用。

1滑动平均滤波器

图1 8权值滑动平均滤波器结构

滑动平均滤波器(Moving Average Filter)的所有权值系数均为1,实现对信号的平滑作用,具有低通特性。

Matlab :

close all

clear all

clc

%set system parameter

fs = 1000; %The frequency of the local oscillator signal

Fs = 44100; %sampling frequency

N = 24; %Quantitative bits

L = 8192;

%Generating an input signal

t =0:1/Fs:(1/Fs)*(L-1); %Generating the time series of sampling frequencies

sc =sin(2*pi*fs*t); %a sinusoidal input signal that produces a random starting phase

%滑动平均滤波器

b =[1,1,1,1,1,1,1,1];

a =1;

sf=filter(b,a,sc).*(1/8);

图2 滑动平均滤波器的幅频特征

2 微分器

图3 微分器结构

微分器有1和-1两个权值系数的滤波器,该滤波器具有简单的高通幅频响应特性。

y(k) = x(k)-x(k-1)

Matlab :

close all

clear all

clc

%set system parameter

fs = 1000; %The frequency of the local oscillator signal

Fs = 44100; %sampling frequency

N = 24; %Quantitative bits

L = 8192;

%Generating an input signal

t =0:1/Fs:(1/Fs)*(L-1); %Generating the time series of sampling frequencies

sc =sin(2*pi*fs*t); %a sinusoidal input signal that produces a random starting phase

%微分滤波器

b =[1,-1];

a =1;

sf=filter(b,a,sc);

图4 微分器幅频响应特征

3 积分器


图5 数字积分器结构

数字积分器是只有一个系数的IIR滤波器该滤波器具有低通的滤波器的幅频响应特性。

q(k)=p(k) +q(k-1)

Matlab :

close all

clear all

clc

%set system parameter

fs = 1000; %The frequency of the local oscillator signal

Fs = 44100; %sampling frequency

N = 24; %Quantitative bits

L = 8192;

%Generating an input signal

t =0:1/Fs:(1/Fs)*(L-1); %Generating the time series of sampling frequencies

sc =sin(2*pi*fs*t); %a sinusoidal input signal that produces a random starting phase

%积分滤波器

b =1;

a =[1,-1];

sf=filter(b,a,sc);

图6 积分器幅频响应特征

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。

0