1、有限长单位冲激响应滤波器,是数字信号处理系统中最基本的元件,它可以在保证任意幅频特性的同时具有严格的线性相频特性,同时其单位抽样响应是有限长的,因而滤波器是稳定的系统。因此,FIR滤波器在通信、图像处理、模式识别等领域都有着广泛的应用。TMS320C5402(简称C5402)提供了2个支持高速、全双工、带缓冲、多种数据格式等优点的多通道缓冲串行口McBSP。MCBSP分为数据通路和控制通路。通信数据通过McBSP的数据发送(DX)引脚发送,通过数据接收(DR)引脚接收。时钟和帧同步控制信息通过CLKX、CLKR、FSX和FSR给出。C54xx通过16位宽可访问控制寄存器经外部外设总线与McBS
2、P通信。CPU或MDA控制器从数据接收寄存器(DRR1,2)中读取接收待的数据,并把要发送的数据写到数据发送寄存器(DXR1,2)中;然后,写到DXR1,2中的数据通过发送移位寄存器(XSR1,2)从引脚移出。类似地,引脚上的接收数据被移入到接收移位寄存器(RSR1,2),并被复制到接收缓冲接存器(RBR1,2)中;然后,(RBR1,2)被复制到DRR1,2,则CPU或DMA控制器即可通过(DRR1,2)获得接收数据。这样,便可实现同时移动内部和外部帧同步脉冲有效表示传输的开始。 本次课设就是用DSP的多通道缓冲串行口接收数据,在通过FIR滤波后,输出出去。二、方案设计与论证C语言编程产生滤波
3、器模拟输入4KHz方波信号;设计一个FIR滤波器,经FIR滤波后得到4KHz的正弦波信号。FIR滤波器的DSP编程采用分别采用线性缓冲区法和循环缓冲区法。由实验箱信号发生器产生4KHz的模拟方波信号,然后进行AD转换,采样频率为32KHz,对采样数字信号进行数字滤波得到4KHz的正弦波信号,存放在内存单元中观察这些数据的波形,并通过串口DAC转换后输出,在示波器上观察输出信号。三、单元程序设计与参数计算3.1设计一个FIR低通滤波器,通带边界频率为6500Hz,通带波纹小于1dB;阻带边界频率为2000Hz,阻带衰减大于40dB;采样频率为32000Hz。FIR滤波器的设计可以用MATLAB窗
4、函数法进行,例如选择Hamming窗,其程序为:b=fir1(16,6500/32000*2);在DSP汇编语言中,不能直接输入十进制小数,在MATLAB中进行如下转换: h= round(b*215); 则将系数转换为Q15的定点小数形式,为h = -74 81 367 75 -1303 -1581 2510 9645 13330 9645 2510 -1581 -1303 75 367 81 -743.2用C语言实现C语言编程产生滤波器模拟输入4KHz方波信号或者三角波信号。程序如下:方案一:#include math.hstdlib.hvoid main()int i;int value
5、 = 1;int f256;FILE *fp;if(fp=fopen(iiirin.inc,wt)=NULL) printf(cant open file! n); return; for(i = 0;i 256; i+) if(i % 8 = 0) value *= -1; fi = value; fprintf(fp, .word %1dn,(long)(fi*32768/2);fclose(fp); 方案二:int i,k;int j;double f256;iirin.incfor (j=0;j=15;j+)for (i=0;ii+) m=0 n=7 k=i+16*j; if ( i%16 ROM1 PAGE 0 .data :INTRAM1 PAGE 1FIR_COEF:INTRAM2 PAGE 1FIR_BFR :INTRAM3 PAGE 13.4应用线性缓冲区法编程实现FIR滤波器 .mmregs .global start .def start,_c_int00 KS .set 256 COFF_FIR .sect COFF_FIR .wo
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1