! Y/ [% T' q4 U; D2.3 控制模块 6 Y6 t. x2 H3 n7 d B ( g5 l- }$ X2 m9 h$ o+ N控制模块产生输入序列缓存模块的读写地址、使能信号以及滤波系数存储模块的读地址、使能信号,并对乘累加运算进行控制。; R! |' p0 e2 b; I( T+ f
9 w! u& u! @+ K' U$ S g$ j输入序列需要在缓存模块中反复移位输出进行运算,每256个时钟周期输入1个数,输入序列的写地址必须滞后读地址一个时钟周期,才能保证数据的连续、不丢失。这样新写入的数据不在固定的位置,就要求读地址也不是单纯的累加关系。以每个RAM块深度等于4为例研究读写地址的关系,如图4所示。 8 s. F5 Y/ D" o7 c
. U m' @$ u+ L' ^3 b7 }; m
整个控制模块的实现如图7所示。主计数器整体计数,每256个时钟周期,地址产生模块就把计数器的计数值整体加1,作为输人序列的读地址raddr输出,实现了图6所示的地址顺序。写地址waddr由读地址raddr经延时一个时钟周期获得。由于输入序列是按时间顺序输出的,故滤波系数只要从存储阵列中也相应地顺序输出就可以了,将主计数器的计数值直接引出作为滤波系数阵列的读地址h_addr。 + P9 D' {0 t c+ a; G; [