CIC滤波器基本原理

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

image-20201002173656346

可以将其分解为两部分:

image-20201002173729012

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

image-20201002173755692

CIC滤波器有三个参数:

R:抽取倍数

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

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

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

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

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

频响如下:

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(:))

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

image-20210207155034229

cic matlab,Matlab中CIC滤波器的应用相关推荐

  1. matlab 级联cic,Matlab中CIC滤波器的应用

    CIC滤波器基本原理 CIC(积分梳状级联)滤波器是工程上经常用的滤波器,因为CIC滤波器不需要乘法,CIC滤波器往往在级联抽取滤波器的第一级和级联插值滤波器的最后一级.这一节我们以CIC抽取滤波器为 ...

  2. 【MATLAB教程案例1】通信系统中成形滤波器原理的MATLAB设计实现

    FPGA教程目录 MATLAB教程目录 -------------------------------------------------------------------------------- ...

  3. MATLAB中FIR滤波器的时延溢出问题详解:线性相位对信号造成的时延溢出及其消除方法,以及fir1等函数的使用

    1.问题由来: 前段时间在对用MATLAB处理试验数据时,需要对多路信号进行滤波后做同步,在这个过程中使用MATLAB中自带的 fir1 函数以及Filter Designer工具箱(FDATool) ...

  4. 用matlab画多普勒加宽线性函数,MTD雷达中多普勒滤波器组的设计与实现

    合肥工业大学理学院电子科学与技术2006届毕业论文集 目 录 中文摘要1 英文摘要2 1 引言3 1.1 研究背景及意义3 1.2 国内外研究现状4 1.3 本设计的指导思想和主要工作4 2 动目标检 ...

  5. matlab中SG滤波器的说明

    matlab中SG滤波器的说明 项目需要最近在进行光谱预处理方面研究,看了很多论文,发现其中涉及到的方法也就那么几种,比如SG filter.MSC.SNV等等.今天对SG filter 进行了学习, ...

  6. MATLAB中用FDATool设计滤波器及使用

    from: http://blog.sina.com.cn/s/blog_3e4367660100nyz1.html 1. 在Matlab中键入fdatool运行Filter Design and A ...

  7. 【Matlab】扩展卡尔曼滤波器原理及仿真(初学者入门专用)

    文章目录 0.引言及友情链接 1.场景预设 2.扩展卡尔曼滤波器 3.仿真及效果 0.引言及友情链接 \qquad卡尔曼滤波器(Kalman Filter, KF)是传感器融合(Sensor Fusi ...

  8. matlab中基于十字形窗口的滤波算法,#215;字形滤波窗口在Matlab自适应中值滤波算法中的应用 - 21ic中国电子网...

    由于种种原因,图像在生成.传输.变换等过程中往往会受到各种噪声的污染,从而导致图像质量退化.噪声信号的滤波是图像处理的基本任务之一,主要有线性滤波和非线性滤波两种方法.线性滤波方法一般具有低通特性,而 ...

  9. matlab函数 无限冲激响应滤波器,MATLAB代码 有限冲激响应(FIR)滤波器和无限冲激响应(IIR)滤波器...

    MATLAB有限冲激响应(FIR)滤波器和无限冲激响应(IIR)滤波器设计 附MATLAB代码 摘要 文章设计了一个数字信号处理仿真实验,产生一个信号,其频率成分为f1和f2,并对其进行理想采样,采样 ...

最新文章

  1. 利用SqlHelper.cs实现Web程序对数据库的增、删、改等操作
  2. Python基础day03 作业解析【5道 字符串题、3道 列表题、2道 元组题】
  3. 一个简单的方式搞定密码的加盐哈希与验证
  4. 理解C# 4 dynamic(1) - var, object, dynamic的区别以及dynamic的使用
  5. 他们守护非洲大象犀牛,马云守护他们
  6. 一个C++工程内存泄漏问题的排查及重现工程
  7. 使用Python写的第一个网络爬虫程序
  8. 国际音标的HTML实体对照表
  9. python-pip : Depends: python-setuptools (= 0.6c1) 问题
  10. Multisim的学习记录(一)
  11. windows 2000 密钥
  12. IDEA连接web网页
  13. 【软件测试理论】(六) 白盒测试方法论说明
  14. C4D中使用Redshift渲染器翻转贴图
  15. LabVIEW如何实现高性能串口助手-附代码
  16. dashboard与coredns服务启动发生ContainerCreating的对应方法
  17. 温度滞回程序C语言,间隙式粘滞阻尼器温度变化对滞回性能影响的研究
  18. vfio概述(vfio/iommu/device passthrough)
  19. [附源码]Python计算机毕业设计SSM基于Web课堂签到管理系统(程序+LW)
  20. DS1302实时时钟及实验【时序定义、数据读写】

热门文章

  1. python自动剪视频_用python进行视频剪辑
  2. SqlPlus访问oracle
  3. 图片怎么压缩到100k以下?
  4. CAD专用卸载工具,完美彻底卸载清除干净cad各种残留注册表和文件。
  5. 怎么重新编译CE5.6?
  6. DSPE-PEG-VAP/DCDX/LyP-1/M2pep/GLP-1/HP2/FNB/CPPs/CGKRKb 磷脂-聚乙二醇-多肽
  7. 33种语言的中文名称、本地名称、英文名称
  8. RELATION:基于结构的从头药物设计的深度生成模型
  9. 固态硬盘:NVME 命令队列 SQ/CQ 的奥秘
  10. openwrt自动启动脚本