文档介绍:
一个实际的应用系统中,总存在各种干扰。数字滤波器在语音信号处理、信号频谱估计、信号去噪、无线通信中的数字变频以及图像信号等各种信号处理中都有广泛的应用,数字滤波器也是使用最为广泛的信号处理算法之一。
在本设计中,使用MATLAB模拟产生合成信号,S进行滤波。设定模拟信号的采样频率为48000Hz,。设计一个FIR低通滤波器,其参数为:
滤波器名称: FIR低通滤波器
采样频率: Fs=48000Hz
通带截止频率: 15000Hz
阻带截止频率: 16000Hz
通带最大衰减:
阻带最少衰减: 80dB
滤波器系数: 由MATLAB根据前述参数求得。
总体设计方案流程图
图1 总体设计方案
主要内容和步骤
滤波器原理
对于一个FIR滤波器系统,它的冲击响应总是又限长的,其系统函数可记为:
其中是FIR的滤波器的阶数,为延时结,为端口信号函数。
最基本的FIR滤波器可用下式表示:
其中输入采样序列,是滤波器系数,是滤波器的阶数表示滤波器的输出序列,也可以用卷积来表示输出序列与、的关系,如下:
操作步骤
(1)打开FDATOOL,根据滤波要求设置滤波器类型、通带截止频率、指定阶数、采样频率等。指定完设计参数后单击按钮Design Filter,生成滤波器系数。
(2)把生成的滤波器系数传到目标DSP。选择菜单Targets->Export to poser Studio(tm)IDE,打开Export to C Header File对话框,选择C header file,指定变量名(滤波器阶数和系数向量),输出数据类型可选浮点型或32 b,16 b整型等,根据自己安装选择目标板板号和处理器号,单击OK,保存该头文件,需指定文件名()和路径(保存在c:\ti\myprojects\fir工程中)。
(3)S汇编程序,删掉数据前的所有文字,,第二行加coeff .word,,比且把每行的最后的逗号去掉。
(4)编译汇编程序,如果有错误,按错误进行修改;没错误,则往下执行。
(5)加载初始化DATA数据。运行程序,查看输入输出波形,修改相应参数进行调试
第4章详细设计
在本实验中使用MATLAB模拟产生信号,观察滤波前的时域波形和频域波形。MATLAB仿真后,使用得到的滤波器参数,进行DSP编程,在DSP中实现带通滤波,S的频谱分析功能,查看DSP的滤波效果。
MATLAB程序流程图
第5章实验过程
汇编语言实验步骤与内容
Error! No bookmark name 实现FIR ,其总体过程为在DSP 中编写处理程序,在MATLAB中利用滤波器设计、分析工具( FDATOOL) ,根据指定的滤波器性能快速设计一个FIR ,S 中,头文件中MATLAB 辅助DSP 实现FIR 数字滤波器含滤波器阶数和系数数组,在MATLAB中调试、运行DSP 程序并显示、分析处理后的数据。使用该方法,便于采用汇编语言来实现程序。头文件名不变,当MATLAB中设计的滤波器系数改变时,相应头文件中系数也改变,方便了程序调试、仿真。
(1)在MATLAB中先编写程序,查看待滤波和已滤波的信号的时域和频域波形,。
待滤波信号的频域图
利用FDA TOOL 设计FIR 滤波器的参数,。
FIR滤波器的参数
打开Export,把Numerator改为B,。
Export设置
已滤波的信号的时域和频域波形,。
已滤波信号频域波形图
MATLAB滤波器设计工具在完成FIR设计后,,在Export as中选择16bit符号整数输出,然后单击OK按钮。 C语言头文件。将系数稍作修改,调整后拷贝到程序的系数初始化空间即可。
MATLAB输出数值转换图
(2)在CCS中编写汇编语言程序,进行调试,实现带通滤波的功能。在CCS IDE ,。另外根据板上的存储器配置方式,,,进行编译、链接,生成可执