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

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

创新互联公司专业为企业提供西夏网站建设、西夏做网站、西夏网站设计、西夏网站制作等企业网站建设、网页设计与制作、西夏企业网站模板建站服务,十余年西夏做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。

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

1滑动平均滤波器

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

图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);

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

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

2 微分器

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

图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);

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

图4 微分器幅频响应特征

3 积分器

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

 

图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);

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

图6 积分器幅频响应特征

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


新闻标题:基于FPGA的多级CIC滤波器如何实现四倍抽取一
文章路径:http://azwzsj.com/article/gdsshe.html