找回密码
 注册
关于网站域名变更的通知
查看: 471|回复: 1
打印 上一主题 下一主题

怎么设计基于FPGA的高阶音频均衡滤波器?

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-6-30 17:13 | 只看该作者 |只看大图 回帖奖励 |正序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
音频均衡器作为高品质音响不可或缺的关键附属调节设备,在音效调整修饰方面起着至关重要的作用。一般音频均衡器有数字和模拟两种实现方法,模拟方法用有源和无源滤波器组实现,受器件温度等特性的影响,难以达到较高的可靠性和一致性,且成本较高。
7 ?4 C' w, E6 B0 F
# k: @; r4 w' P! e/ C3 u. L" I  X; |数字实现方法采用数字滤波器,具有较高的灵活性和可靠性。常用的数字滤波器有IIR和FIR两种。IIR滤波器结构简单,所需的存储空间小,但其相位是非线性;FIR滤波器是线性相位滤波器,这对高品质音效处理是必要的。本文通过在FPGA内设计了1 024阶FIR滤波器实现数字均衡滤波,通过系数的重载实现多种频率响应的均衡特性。$ {3 K. G; Y$ ~/ N# E
1 总体概述9 Y, @& ~& W% Q. f! g0 _3 B

" ]) [1 ?5 R1 Y/ ]2 W$ `+ d文中设计的FIR音频均衡滤波器采用多相滤波结构,用时间换取空间,节省FPGA内部资源,以达到在固定资源下的最大阶数。实现结构框图如图1所示。
! ]/ b2 i* t: Z2 k, P6 } 5 G, h' \! T" }% V
输入序列以及滤波系数分别存储在缓存阵列中,在时钟同步下由控制模块通过生成相应的读写地址及使能信号,使其按照一定次序输出到乘累加模块进行运算,并输出最终结果。系数可通过外部输入重载,以实现不同的均衡特性。EP1C3系列FPGA共有13个M4K块,每个为256 ×18位,取数据和系数的位宽为16位。为了充分利用有限资源,并考虑处理速度及音频信号速率要求,取每个缓存子模块的存储深度为256,即将乘累加模块复用256次,每256个系统时钟周期运算一个采样点数据,输出一个滤波结果。每个缓存子模块占用一个M4K块,连续4个子模块串联,就可实现256 x4=1 024阶的要求,再考虑系数占用的空间,总共消耗8个M4K块。这也是在有限资源下能实现的最高阶数。
) L. b$ R+ c- V1 @# L2 各模块实现
' Y) ]7 \& L( R. W% H
9 X8 g# x2 |& p( M- o( Q0 ]2.1 输入序列缓存模块
: a% T/ }3 v, [4 c7 R
' Y8 A* J% j1 \) T4 a8 y& g* |$ G( g输入序列缓冲模块采用双口RAM模块实现,将4个级联使用,如图2所示。4个子块使用相同的读写地址及使能信号,采样数据从第一个子块输入,第一个子块的数据输出端与下一级子块的输入端直接相连,依次类推。每个缓存子块的数据y1~y4都输出给乘累加模块进行运算。3 q4 a) i0 K$ d, @" C

  {# q: D) Q% T该模块的关键是读写地址的控制,写地址waddr必须滞后读地址raddr一个时钟周期,这样子块当前输出数据会在下个时钟写入下一个子块的相应单元。256个周期后,子块的数据整体移到下一个子块。/ c% X+ t2 H+ r# P
, y8 c- K$ s) Y. x4 q6 d# p* s
2.2 滤波器系数存储模块& R5 {6 O. n0 k/ e9 Y4 }. @

  @" n! i5 Q1 _7 A0 j3 G$ f# u- m滤波器系数存储模块和输入序列缓存模块相对应,采用双口RAM模块实现,共有4个256深度的双口RAM模块,如图3所示。
! \) ?2 L7 G" | 1 z; B8 d! r* g* I( C
4个子块使用相同的输入数据线,通过系数写地址的译码,生成各子块的写使能’wen1~wen4和写地址h_addr,控制输入的系数按照顺序依次存入到RAM中。系数的读地址h_addr由控制模块生成,4个子块共用一个读地址,输出与数据相对应的系数h1~h4到乘累加模块,进行乘累加运算。
1 b; M, g: s/ N  [: c
& `; F7 }6 A( c2.3 控制模块
' ?4 j8 v$ j% |9 `' V! u: b
5 J5 d9 W1 P% [$ U控制模块产生输入序列缓存模块的读写地址、使能信号以及滤波系数存储模块的读地址、使能信号,并对乘累加运算进行控制。
) c4 `+ w1 e! D6 {; \; P1 D4 ~* D7 Y6 n; }0 P; B$ j! Y& C( Z) m# u
输入序列需要在缓存模块中反复移位输出进行运算,每256个时钟周期输入1个数,输入序列的写地址必须滞后读地址一个时钟周期,才能保证数据的连续、不丢失。这样新写入的数据不在固定的位置,就要求读地址也不是单纯的累加关系。以每个RAM块深度等于4为例研究读写地址的关系,如图4所示。
" z' ~- ]. G" K. x2 E , o* @( |) D, Y: E
可见此时输入序列的读地址顺序如图5所示。, i2 d* i) ]; M0 [

! O9 \( u& t0 Z# Y; s# a由此类推可得实际输入序列缓存模块的读地址如图6所示。
6 Y3 f& K- x3 e1 W  R, \' s
* J1 n( Y1 L2 j整个控制模块的实现如图7所示。主计数器整体计数,每256个时钟周期,地址产生模块就把计数器的计数值整体加1,作为输人序列的读地址raddr输出,实现了图6所示的地址顺序。写地址waddr由读地址raddr经延时一个时钟周期获得。由于输入序列是按时间顺序输出的,故滤波系数只要从存储阵列中也相应地顺序输出就可以了,将主计数器的计数值直接引出作为滤波系数阵列的读地址h_addr。3 [. f+ Z$ c" U  u4 c
) t& z( R* O- Z
主计数器的输出经过译码电路后,输出数据的低速采样时钟sa_clk,用来同步输入序列。还输出输入序列的写使能wren,每256个时钟周期使能一次,写一次数据。  u; T0 _( t) ~8 r  O, Q- m
  u; |: h( {# v# D+ d7 T
2.4 乘累加模块
6 c9 Z, x. o2 W) Z0 K4 Z1 D! g' n7 w2 B) ?) ?$ r) T/ {, f% k
乘累加模块负责将输入的数据和系数进行乘累加运算,每256个时钟周期输出一个滤波结果。其实现框图如图8所示。
# C3 ?+ ~1 X+ s 3 Q4 t: _2 p4 G4 T
输入序列缓存模块输出的数据y1~y4和滤波器系数存储阵列输出的相应系数h1~h4在该模块进行乘累加运算。每256个时钟周期,计算完1个采样点数据的4个部分y1’~y4’,由锁存器锁存,经两级流水线加法器后得到最终滤波结果y,然后将累加器清零,开始准备下个采样点数据的计算。其中,锁存器的锁存时钟及乘累加器的清零信号都由输入序列的写使能wren经过相应的延时处理后得到。9 b: l$ Z1 u& n! g  s& J0 F- \% M
3 仿真结果' ]5 b8 ]1 Y- w* ]! B5 y/ Y9 _

1 C# {* R9 P5 P4 d对设计的均衡滤波器进行综合编译,编译报告如图9所示。) B+ ?1 L& z1 t$ \" O- S
' g3 T4 L7 W8 _. s- N
可见该1 024阶FIR均衡滤波器在EP1C3系列FPGA内得以实现,仅占用其约70%的逻辑资源和约50%的存储空间。为了验证该设计功能,将滤波器系数利用存储器初始化文件进行初始化,存储的系数如图10所示。
" w6 o# ?8 a9 j, d , i& D# Q, ^  }' H
为了直观验证,输入序列x取为δ序列,即x中只有1个数据为1,其它为0。根据滤波器及卷积的相关知识,输出结果y=x*h=δ*h=h,即为滤波器系数。仿真结果如图11所示。! z$ t$ M: ?3 e& e( \. f3 @
! Z8 g9 h9 `) e4 I! g' Y! `5 l
输入序列x只有1个采样时钟周期为数据1,其它全为0,fout为输出的滤波结果。可见结果为-1~-16的重复数据,与图10所示的滤波器系数一致,滤波器工作正常。
& T9 i2 T% q4 t: ?, X- b4 b% V4 结束语6 P6 f1 l8 i) J$ r# K1 }! Q. M1 P3 D

* o# k+ J& d3 D. _! @/ {" t( e利用EP1C3约70%的逻辑单元及约50%的存储空间,设计了1024阶FIR数字滤波器,并通过重载系数,可实现多种频率响应的均衡特性,实现了简易数字均衡滤波器的功能,达到了设计目标。
* m% h* d5 T  O$ ]

该用户从未签到

2#
发表于 2020-6-30 17:38 | 只看该作者
为了充分利用有限资源,并考虑处理速度及音频信号速率要求,取每个缓存子模块的存储深度为256,即将乘累加模块复用256次,每256个系统时钟周期运算一个采样点数据,输出一个滤波结果
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-11-25 00:21 , Processed in 0.187500 second(s), 27 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表