FIR滤波器根据输入数据速率的不同可分为串行结构、半并行结构和全并行结构。串行结构的FIR滤波器是将并行数据串行输入,所需的DSP资源较少,但是数据吞吐率较低;而全并行结构的FIR滤波器数据是并行输入,滤波系数的个数就决定了所需DSP资源的个数,资源耗用较多,但是吞吐率可以做到很大。在大多数应用中,如无线数字中频处理,所需数据吞吐率一般都较高,因此采用的是全并行结构的FIR滤波器。

  全并行FIR滤波器根据实现结构不同可分为:直接型(Transverse)、转置型(Transpose)和脉动型(Systolic),这一节主要讲解直接型FIR滤波器设计。

  (一)直接型

  直接型FIR滤波器在上一节中也有介绍,如图1所示,数据x(n)移入并寄存,如果有11个抽头,因此直接型FIR滤波器需要11个乘加模块。

  

  图1

  FPGA实现时,直接采用上图中结构,不对中间数据寄存,则关键路径是x(n)h(0)+x(n-1)h(1)…x(n-N+1)h(N-1),以阶数10的FIR滤波器为例,如下为抽头系数:

  coe_0 = -1241

  coe_1 = -650

  coe_2 = 1300

  coe_3 = 4739

  coe_4 = 8126

  coe_5 = 9544

  coe_6 = 8126

  coe_7 = 4739

  coe_8 = 1300

  coe_9 = -650

  coe_10 = -1241

  数据输入时打了一拍,输出时打了一拍。综合后结果如下:

  Number of Slice Registers: 2

  Number of Slice LUTs: 19

  Number of DSP48E1s: 11

  关键路径中数据路径延时报告如图2所示,数据路径延时包括乘法器延时Tdspcko PCOUT AREG MULT (3.001ns)+ 10个级联加法器延时Tdspdo PCIN PCOUT(1.219),数据路径延时总共15.017ns,因此fmax最大不过66.273MHz。可以发现综合器自动将乘法器和加法器在 DSP48E1中实现。

  

  图2

  加法树实现:

  直接型FIR滤波器的一般实现方法关键路径中有较多级的加法器,所有加法器延时累加后导致关键路径延时较大,对整个FIR滤波器的性能造成了很大影响。为了解决加法器延时累加的问题,可采用加法树结构,如图3所示为采用了加法数的直接型FIR滤波器结构,这种层次化的树型结构,使加法器逻辑由级联结构转化成并行结构,这样整个路径的延时减小。

  

  图3

  流水线实现:

  虽然直接型FIR滤波器采用加法树结构后优化了关键路径,但是时序还是不够理想,因为关键路径上至少有一个乘法器和一个加法器的延时,如果想竟可能的优化时序,可以分隔乘法器和加法器逻辑,中间加一级寄存器,即采用流水线实现。

  那如何有效地分割逻辑呢?可以在图3中加法树结构的基础上分割,在原先的关键路径上,乘法器延时3.001ns,加法器延时1.219ns,因此可以将逻辑分割成如下**:

  第1级:乘法器

  第2级:2级加法器

  第3级:3个数累加即2级加法器

  如图4所示为流水线实现的FIR滤波器,逻辑分割后的关键路径是乘法器那一级,理论分析得到的延时只有3.001ns,如果时钟约束到250MHz可满足时序要求。

  

  图4

  实际得到综合结果如下:

  Number of Slice Registers: 105

  Number of Slice LUTs: 124

  Number of DSP48E1s: 11

  Minimum period: 3.037ns{1} (Maximum frequency: 329.272MHz)

  fmax能达到329.272MHz,延时基本与预期的差不多,FIR滤波器能达到这样的性能基本能满足大多数应用了。

  线性相位FIR滤波器:

  FIR滤波器有一特征:线性相位,直接表现在抽头系数上,抽头系数为偶对称或者奇对称,在这节实例中,系数是偶对称的,即 h(0)=h(10),h(1)=h(9),h(2)=h(8),h(3)=h(7),h(4)=h(6),直接型FIR结构优化后如图5所示,输入数据在与系数相乘之前,因系数对称,可以先将相同系数对应的数据进行预加操作,然后再与系数相乘,如此做法的好处是是乘法器资源减少了近一半,此例中DSP资源由原先需要11个到现在只需6个。而且,在Xilinx FPGA中的DSP48E1资源专门为线性相位FIR滤波器应用提供了预加pre-adder结构,即预加和乘法都可以在1个DSP48E1中完成,这样大大缩短了数据路径的延时,有利于时序收敛。

  

  图5

  实际得到综合结果如下:

  Number of Slice Registers: 184

  Number of Slice LUTs: 173

  Number of DSP48E1s: 6

  Minimum period: 2.854ns{1} (Maximum frequency: 350.385MHz)

  fmax能达到350.385MHz,由于采用了加法树结构,避免了加法器级联延时,并且分了3级流水线实现。关键路径数据延时报告如图6所示,路径是从 DSP48E1输出端到dout_d,但是光从代码中看DSP48E1端到dout_d中间应该还有一级加法器的寄存,原来这个加法器采用了 DSP48E1中的累加器实现了。

  

  图6

直接型FIR滤波器的fpga实现相关推荐

  1. 转置型FIR滤波器的fpga实现

    这一节主要讲解一下转置型FIR滤波器实现. FIR滤波器的单位冲激响应h(n)可以表示为如下式: 对应转置型结构的FIR滤波器,如图1所示,抽头系数与上一节中讲解直接型FIR滤波器的实例相同,滤波器阶 ...

  2. (多图) 基于并行流水线结构的可重配FIR滤波器的FPGA实现

    1 并行流水结构FIR的原理 在用FPGA或专用集成电路实现数字信号处理算法时,计算速度和芯片面积是两个相互制约的主要问题.实际应用FIR滤波器时,要获得良好的滤波效果,滤波器的阶数可能会显著增加,有 ...

  3. 基于FPGA的FIR滤波器的实现(5)— 并行结构FIR滤波器的FPGA代码实现

    书接上回 三.并行结构的FPGA实现 设计实例 1.matlab参数与数据 2.使用Verilog编写并行结构的FIR滤波器 3.使用matlab将产生的程序进行仿真验证 三.并行结构的FPGA实现 ...

  4. 【DA算法】基于DA算法的FIR滤波器的FPGA实现

    1.软件版本 quartusii 2.本算法理论知识 DA算法的主要特点是,巧妙地利用查找表将固定系数的MAC运算转化为查表操作,其运算速度不随系数和输入数据位数的增加而降低,而且相对直接实现乘法器而 ...

  5. fir fpga 不同截止频率_【通信篇】带你认识FIR滤波器

    一 .滤波器介绍 滤波器是一种用来减少,消除干扰的电器部件,有对特定频率的频点或该频点以外的频率信号进行有效滤除,从而实现消除干扰.获取特定频率信号的功能.数字滤波器相比模拟滤波器,有着更高的精度.信 ...

  6. FIR数字滤波器的FPGA实现(一)-FIR滤波器基本原理

    (一)FIR数字滤波器的FPGA实现-FIR滤波器基本原理 文章目录 (一)FIR数字滤波器的FPGA实现-FIR滤波器基本原理 1 FIR滤波器基本原理 1.1 FIR滤波器的结构及设计 1.1.1 ...

  7. FIR数字滤波器的FPGA实现(二)-串行FIR滤波器设计(1)

    (二)FIR数字滤波器的FPGA实现-串行FIR滤波器设计 文章目录 (二)FIR数字滤波器的FPGA实现-串行FIR滤波器设计 0 串行FIR滤波器基本原理 1 基于移位寄存器的串行 FIR 滤波器 ...

  8. FIR数字滤波器的FPGA实现(三)-并行FIR滤波器设计

    (三)FIR数字滤波器的FPGA实现-并行FIR滤波器设计 文章目录 (三)FIR数字滤波器的FPGA实现-并行FIR滤波器设计 0 并行FIR滤波器基本原理 1 基于直接型结构的全并行 FIR 滤波 ...

  9. FIR数字滤波器的FPGA实现(二)-串行FIR滤波器设计(2)

    (二)FIR数字滤波器的FPGA实现-串行FIR滤波器设计 文章目录 (二)FIR数字滤波器的FPGA实现-串行FIR滤波器设计 0 串行FIR滤波器基本原理 1 基于移位寄存器的串行 FIR 滤波器 ...

最新文章

  1. oracle 数据库中(创建、解锁、授权、删除)用户
  2. 思科路由器怎么安装?
  3. Elasticsearch搜索引擎之缓存:Request Cache、Query Cache、Fielddata Cache
  4. rem和em学习笔记及CSS预处理
  5. 监控行业应用解决方案
  6. java的简单工厂模式_java设计模式之简单工厂模式
  7. android二分查找法简书,【PYTHON】二分查找算法
  8. 07-狄克斯特拉算法
  9. C++ 学习之旅(3)——头文件Header
  10. BZOJ1013球形空间产生器sphere 高斯消元
  11. 算法训练 s01串java_试题 算法训练 s01串
  12. 输入月份自动生成excel考勤表,周末高亮,内容可以勾选
  13. Linux安装中文输入法(Google拼音输入法)
  14. Java学多久可以接项目_自学Java,多久可以找到工作?
  15. 2021普华集团数字经济年度盛典在三亚盛大举行
  16. 防沉迷与身份证系统挂钩 网游要实名认证
  17. ssm电商背景下精品茶网站的设计与实现毕业设计-附源码191732
  18. winform数独C#的数独游戏
  19. Navicat Premium12安装_破解(亲测成功)时间:2019年7月29日
  20. 晋城联通dns服务器位置,山西联通dns服务器地址

热门文章

  1. 磁棒 锰锌铁氧体高频磁条22x5x3mm,作为天线性能测试
  2. 卓老师 ,k车模能自制吗?
  3. TD321DCAN 隔离CAN总线驱动器
  4. centos 7 文档服务器,centos 7 web服务器
  5. html调用相机相册案例,Ionic 相册、相机调用
  6. linux mysql innodb_MySQL innoDB 存储引擎学习篇
  7. Linux 系统编程总结 (未完待续)
  8. java arraylist 序列化_无法序列化/反序列化ArrayList
  9. php get 传循环出来的参数_PHP性能优化小技巧
  10. matlab 求解黄金分割率