cic matlab,Matlab中CIC滤波器的应用

CIC滤波器基本原理

CIC(积分梳状级联)滤波器是工程上经常用的滤波器,因为CIC滤波器不需要乘法,CIC滤波器往往在级联抽取滤波器的第一级和级联插值滤波器的最后一级。这一节我们以CIC抽取滤波器为例来讲CIC滤波器的使用方法,CIC滤波器的数学模式为:

2fb6d94fdb4e0aca98f4c23935cce6e3.png

image-20201002173656346

可以将其分解为两部分:

3d74223c7207c939aa9437175ff85089.png

image-20201002173729012

其中第一级是积分器,就是做累加;第二级是级联梳状滤波器。

c18a90aa8bf13de1b2b31c6f1c550585.png

image-20201002173755692

CIC滤波器有三个参数:

R:抽取倍数

M:差分延迟,在工程中一般取1或者2

N:滤波器级数,一级CIC的阻带有13.46dB的衰减,N级就是有13.46*N dB的衰减。

若R=8,M=1,N=5,那么CIC滤波器的频响如下所示:

00ad28d1b60d8fbd80fdb62f0505e8db.png

image-20201002192819206

Matlab中CIC滤波器的使用

在Matlab中,有两个函数可以生成CIC滤波器。我们以CIC抽取滤波器为例,一个是fdesign.decimator,第二个是dsp.CICDecimator。下面我们分别来看这两个函数的使用方法。

生成滤波器模型

首先来看如何用fdesign.decimator生成一个CIC滤波器和其补偿滤波器,并查看CIC滤波器、补偿滤波器、级联滤波器的频响。下面代码中hcic即为构造的CIC滤波器,抽取倍数为4,差分延时为1;cic_comp为CIC补偿滤波器;其中Ap表示通带衰减,Astp表示阻带衰减。

Fs = 1; % sample rateR = 4; % decimator factorD = 1; % differential delayFp = 0.05; % pass bandFstp = 0.075; % stop bandAp = 0.1; % attenuation in pass bandAstp = 60; % attenuation in stop bandhcic = design(fdesign.decimator(R,'cic',D, Fp, Astp, Fs),'SystemObject',true);cic_comp = design(fdesign.ciccomp(hcic.DifferentialDelay, ...hcic.NumSections,Fp,Fstp,Ap,Astp,Fs/R), 'SystemObject',true);fvtool(hcic,cic_comp,...cascade(hcic,cic_comp),'ShowReference','off','Fs',[Fs Fs/R Fs])legend('CIC Decimator','CIC Compensator','Resulting Cascade Filter');

62ff6cc83ee083a8c6662c44dfddfe73.png

image-20210207151607757

dsp.CICDecimator的用法也非常类似,我们可以直接指定阶数;CIC补偿滤波器也直接使用dsp.CICCompensationDecimator函数来设计;

Fs = 1; % sample rateR = 4; % decimator factorD = 1; % differential delayN = 5; % number of stageFp = 0.05; % pass bandFstp = 0.075; % stop bandAp = 0.1; % attenuation in pass bandAstp = 60; % attenuation in stop bandCICDecim = dsp.CICDecimator(R, D, N);CICCompDecim = dsp.CICCompensationDecimator(CICDecim, ...'DecimationFactor',2,'PassbandFrequency',Fp, ...'StopbandFrequency',Fstp,'SampleRate',Fs/R);fvtool(CICDecim,CICCompDecim,...cascade(CICDecim,CICCompDecim),'ShowReference','off','Fs',[Fs Fs/R Fs])legend('CIC Decimator','CIC Compensator','Resulting Cascade Filter');

频响如下:

66b8dc5f6b1048d770b6fc68713eb3cf.png

image-20210207161734382

滤波操作

如果要用上面生成的CIC模型来完成滤波操作,可以用dsp.SignalSource函数,该函数用于生成信号源,函数的第一个参数是原信号,第二个参数是每帧的点数。(至于为什么要分成不同的帧本人也不是很清楚,只是按照Mathworks提供的例程来完成)

下面的例子中,我们要完成的是对输入的1024点的信号进行抽4的CIC滤波,在dsp.SignalSource中我们指定一帧为64个点,因此总共有1024/64=16帧,在抽4之后,每帧的长度就是64/4=16;所以定义的y是一个16x16的矩阵,其中每一行为一帧的滤波结果,将16行拼接起来,就是输出的1024/4=256点的结果。

dsp.CICDecimator和fdesign.decimator的滤波的方法是一样的:

F0 = Fs/40;N = 1024;t = (0:N-1)'; % length: 1024x = fi(sin(2*pi*F0/Fs*t),true,16,15);SamplesPerFrame = 64;src = dsp.SignalSource(x,SamplesPerFrame);y = zeros(N/SamplesPerFrame,SamplesPerFrame/R);for ii = 1:length(x)/SamplesPerFramey(ii,:) = hcic(src());%y(ii,:) = CICDecim(src());endyy = y.';figure;plot(yy(:))

滤波后的时域结果如下所示:

d53dccac12fa4bfde7284d59f53d8bdd.png

image-20210207155034229

  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值