基于TMS320VC5509_DSP的语音信号的FIR滤波器课程设计报告书.doc_第1页
基于TMS320VC5509_DSP的语音信号的FIR滤波器课程设计报告书.doc_第2页
基于TMS320VC5509_DSP的语音信号的FIR滤波器课程设计报告书.doc_第3页
基于TMS320VC5509_DSP的语音信号的FIR滤波器课程设计报告书.doc_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

dsp原理与应用 课程设计报告书课题名称基于tms320vc5509 dsp的语音信号的fir滤波器姓 名学 号 院、系、部专 业指导教师 毕业设计(论文)原创性声明和使用授权说明原创性声明本人郑重承诺:所呈交的毕业设计(论文),是我个人在指导教师的指导下进行的研究工作及取得的成果。尽我所知,除文中特别加以标注和致谢的地方外,不包含其他人或组织已经发表或公布过的研究成果,也不包含我为获得 及其它教育机构的学位或学历而使用过的材料。对本研究提供过帮助和做出过贡献的个人或集体,均已在文中作了明确的说明并表示了谢意。作 者 签 名: 日 期: 指导教师签名: 日期: 使用授权说明本人完全了解 大学关于收集、保存、使用毕业设计(论文)的规定,即:按照学校要求提交毕业设计(论文)的印刷本和电子版本;学校有权保存毕业设计(论文)的印刷本和电子版,并提供目录检索与阅览服务;学校可以采用影印、缩印、数字化或其它复制手段保存论文;在不以赢利为目的前提下,学校可以公布论文的部分或全部内容。作者签名: 日 期: 学位论文原创性声明本人郑重声明:所呈交的论文是本人在导师的指导下独立进行研究所取得的研究成果。除了文中特别加以标注引用的内容外,本论文不包含任何其他个人或集体已经发表或撰写的成果作品。对本文的研究做出重要贡献的个人和集体,均已在文中以明确方式标明。本人完全意识到本声明的法律后果由本人承担。作者签名: 日期: 年 月 日学位论文版权使用授权书本学位论文作者完全了解学校有关保留、使用学位论文的规定,同意学校保留并向国家有关部门或机构送交论文的复印件和电子版,允许论文被查阅和借阅。本人授权 大学可以将本学位论文的全部或部分内容编入有关数据库进行检索,可以采用影印、缩印或扫描等复制手段保存和汇编本学位论文。涉密论文按学校规定处理。作者签名:日期: 年 月 日导师签名: 日期: 年 月 日指导教师评阅书指导教师评价:一、撰写(设计)过程1、学生在论文(设计)过程中的治学态度、工作精神 优 良 中 及格 不及格2、学生掌握专业知识、技能的扎实程度 优 良 中 及格 不及格3、学生综合运用所学知识和专业技能分析和解决问题的能力 优 良 中 及格 不及格4、研究方法的科学性;技术线路的可行性;设计方案的合理性 优 良 中 及格 不及格5、完成毕业论文(设计)期间的出勤情况 优 良 中 及格 不及格二、论文(设计)质量1、论文(设计)的整体结构是否符合撰写规范? 优 良 中 及格 不及格2、是否完成指定的论文(设计)任务(包括装订及附件)? 优 良 中 及格 不及格三、论文(设计)水平1、论文(设计)的理论意义或对解决实际问题的指导意义 优 良 中 及格 不及格2、论文的观念是否有新意?设计是否有创意? 优 良 中 及格 不及格3、论文(设计说明书)所体现的整体水平 优 良 中 及格 不及格建议成绩: 优 良 中 及格 不及格(在所选等级前的内画“”)指导教师: (签名) 单位: (盖章)年 月 日评阅教师评阅书评阅教师评价:一、论文(设计)质量1、论文(设计)的整体结构是否符合撰写规范? 优 良 中 及格 不及格2、是否完成指定的论文(设计)任务(包括装订及附件)? 优 良 中 及格 不及格二、论文(设计)水平1、论文(设计)的理论意义或对解决实际问题的指导意义 优 良 中 及格 不及格2、论文的观念是否有新意?设计是否有创意? 优 良 中 及格 不及格3、论文(设计说明书)所体现的整体水平 优 良 中 及格 不及格建议成绩: 优 良 中 及格 不及格(在所选等级前的内画“”)评阅教师: (签名) 单位: (盖章)年 月 日教研室(或答辩小组)及教学系意见教研室(或答辩小组)评价:一、答辩过程1、毕业论文(设计)的基本要点和见解的叙述情况 优 良 中 及格 不及格2、对答辩问题的反应、理解、表达情况 优 良 中 及格 不及格3、学生答辩过程中的精神状态 优 良 中 及格 不及格二、论文(设计)质量1、论文(设计)的整体结构是否符合撰写规范? 优 良 中 及格 不及格2、是否完成指定的论文(设计)任务(包括装订及附件)? 优 良 中 及格 不及格三、论文(设计)水平1、论文(设计)的理论意义或对解决实际问题的指导意义 优 良 中 及格 不及格2、论文的观念是否有新意?设计是否有创意? 优 良 中 及格 不及格3、论文(设计说明书)所体现的整体水平 优 良 中 及格 不及格评定成绩: 优 良 中 及格 不及格(在所选等级前的内画“”)教研室主任(或答辩小组组长): (签名)年 月 日教学系意见:系主任: (签名)年 月 日基于tms320vc5509 dsp的语音信号的fir滤波器设计一、实践的目的和要求 1.熟悉icetek-vc5509-a板上语音codec芯片tlv320aic23的设计和程序控制原理。2.熟悉fir滤波器工作原理及编程。3.掌握使用ti的算法库dsplib提高程序运行效率的方法。4.学习使用ccs图形观察窗口观察和分析语音波形及其频谱。二、实践原理: 在数字信号处理中,滤波占有极其重要的地位。数字滤波是语音处理、图像处理、模式识别、频谱分析等应用中的基本处理算法。用dsp芯片实现数字滤波除了具有稳定性好、精确度高、不受环境影响等优点外,还具有灵活性好等特点。 vc5509引脚图过渡带宽度=阻带边缘频宽-通带边缘频率采样频率:f1=通带边缘频率+(过渡带宽度)/2理想低通滤波器脉冲响应:h1n=sin(n1)/n/根据要求,选择布莱克曼窗,窗函数长度为:n=5.98fs/过渡带宽度选择n=30wn=0.42+0.5cos(2n/30)+0.8cos(4n/24)滤波器脉冲响应为:hn=h1nwn|n|12根据上面计算,各式算出hn,然后将脉冲响应值移位为因果序列。完成的滤波器的差分方程为:yn=-0.001xn-2-0.002xn-3-0.002xn-4+0.01xn-5-0.009xn-6-0.018xn-7-0.049xn-8-0.02xn-9+0.11xn-10+0.28xn-11+0.64xn-12+0.28xn-13-0.11xn-14-0.02xn-15+0.049xn-16-0.018xn-17-0.009xn-18+0.01n-19-0.002xn-20-0.002xn-21+0.001xn-22开始初始化:emif、cpu频率、aic23调用aic23_mixer子程序处理音频数据输入/输出开始初始化语音缓冲区和工作变量等待mcbsp通道0传送结束读取语音数据保存于左声道缓冲区调用fir2计算fir滤波输出滤波结果保存于右声道缓冲区原声音送左声道,滤波结果送右声道,输出到mcbsp0三、实践步骤1.首先自己参照指导书完语音信号的fir滤波实验,认真阅读实验中的源程序,深刻理解语音信号fir滤波的原理及具体实现方法,包括含噪语音信号的读取,滤波后信号的输出,语音编解码器的设置(aic23),重点理解fir滤波器的实现(循环寻找的实现)2.语音采集的采集与分析 (1)录制语音,并命名为“e”,保存在相应的位置(桌面)。(2)用matlab对原始语音信号进行分析,画出它的时域波形和频谱。程序如下:fs=22050;x,fs,nbits=wavread(c:documents and settingsowner桌面e);t=0:1/22050:(length(x)-1)/22050;sound(x,fs) ; %对加载的语音信号进行回放figure(1)plot(x) %做原始语音信号的时域图形title(原始语音信号);xlabel(time n);ylabel(fuzhi n);figure(2)freqz(x) %绘制原始语音信号的频率响应图title(频率响应图)n=length(x); %求出语音信号的长度y1=fft(x,n) ; %傅里叶变换y2=fftshift(y1); %对频谱图进行平移f=0:fs/n:fs*(n-1)/n; %得出频点figure(3) subplot(2,1,1);plot(abs(y2) %做原始语音信号的fft频谱图title(原始语音信号fft频谱)subplot(2,1,2);plot(f,abs(y2); %绘制原始语音信号的频谱图title(原始语音信号频谱)%加噪声k=1:1:n; %定义k 值,噪声与原始语音长度一致c1=100000*sin(2*pi*5000*k); %噪声信号的函数z=x+c1; %噪音与原始信号叠加wavwrite(z,8000,16,c:documents and settingsowner桌面e2); %得到含噪语音s=length(c1);y3=fft(z,s); %对叠加信号进行频谱变换y4=fftshift(y3); %对频谱图平移f=0:fs/s:fs*(s-1)/s; %得出频点figure(4)plot(z) %做原始语音信号的时域图形title(加噪语音信号);xlabel(time n);ylabel(fuzhi n);figure(5)plot(f,abs(y4); %绘出加噪语音频谱图axis(0 8000 0 100);title(含噪语音信号的频谱);figure(6)subplot(2,1,1);plot(f,abs(y2) %做原始语音信号的fft频谱图title(原始语音信号fft频谱)subplot(2,1,2);plot(f,abs(y4) %做加噪语音信号的fft频谱图title(加噪语音信号频谱) 原始语音信号 加噪语音信号 原始语音信号fft频谱 含噪语音信号频谱 原始语音信号fft频谱 频率响应图3. 设计一定参数的滤波器使用fir2函数设计一个31阶低通滤波器,信号的采样频率为8000hz,滤波器的通带截止频率为2900hz,阻带截止频率为3300hz。在函数中,其截止频率均用归一化频率表示。归一化频率的计算方法:f=实际频率/(采样频率/2),则将截止频率归一化后的截止频率值为0.725、0.825用fir2函数实现的格式:f = 0 0.725 0.825 1 ; m = 1 1 0 0 ; b=fir2(30,f,m);b= -0.0005,0.0004,0.0003,-0.0018,0.0039,-0.0045,0.0009,0.0086,-0.0210,0.0279,-0.0173,-0.0191,0.0793,-0.1486,0.2043,0.7744,0.2043,-0.1486,0.0793,-0.0191,-0.0173,0.0279,-0.0210,0.0086,0.0009,-0.0045,0.0039,-0.0018,0.0003,0.0004,-0.0005audio滤波程序如下:#include myapp.h#include icetek-vc5509-edu.h#include scancode.h#include #define firnumber 31#define signal1f 2900#define signal2f 3300#define samplef 8000#define pi 3.1415926float inputwave();float fir();float fhnfirnumber=-0.0005,0.0004,0.0003,-0.0018,0.0039,-0.0045,0.0009,0.0086,-0.0210,0.0279,-0.0173,-0.0191,0.0793,-0.1486,0.2043,0.7744,0.2043,-0.1486,0.0793,-0.0191,-0.0173,0.0279,-0.0210,0.0086,0.0009,-0.0045,0.0039,-0.0018,0.0003,0.0004,-0.0005;float fxnfirnumber= 0.0 ;float finput,foutput;float fsignal1,fsignal2;float fstepsignal1,fstepsignal2;float f2pi;int i;float fin256,fout256;int nin,nout;main()nin=0; nout=0;f2pi=2*pi;fsignal1=0.0;fsignal2=pi*0.1;fstepsignal1=2*pi/30;fstepsignal2=2*pi*1.4;while ( 1 )finput=inputwave();finnin=finput;nin+; nin%=256;foutput=fir();foutnout=foutput;nout+;/* break point */if ( nout=256 )nout=0;float inputwave()for ( i=firnumber-1;i0;i- )fxni=fxni-1;fxn0=sin(double)fsignal1)+cos(double)fsignal2)/6.0;fsignal1+=fstepsignal1; if ( fsignal1=f2pi )fsignal1-=f2pi;fsignal2+=fstepsignal2;if ( fsignal2=f2pi )fsignal2-=f2pi;return(fxn0);float fir()float fsum;fsum=0;for ( i=0;i spcr1, 0); write(pmcbsp0 - spcr2, 0); / config frame parameters (32 bit, single phase, no delay) write(pmcbsp0 - xcr1, xwdlen1_32); write(pmcbsp0 - xcr2, xphase_single | xdatdly_0); write(pmcbsp0 - rcr1, rwdlen1_32); write(pmcbsp0 - rcr2, rphase_single | rdatdly_0); / disable int frame generation and enable slave w/ext frame signals on fsx / frame sync is active high, data clocked on rising edge of clkx write(pmcbsp0 - pcr, pcr_clkxp); / bring transmitter and receiver out of reset setmask(pmcbsp0 - spcr2, spcr2_xrst); setmask(pmcbsp0 - spcr1, spcr1_rrst); void aic23_init() i2c_init(); / reset the aic23 and turn on all power aic23_write(aic23_reset_reg, 0); aic23_write(aic23_power_down_ctl, 0); aic23_write(aic23_analog_audio_ctl, anapctl_dac | anapctl_insel);/ 使用麦克风音源 aic23_write(aic23_digital_audio_ctl, 0); / turn on volume for line inputs aic23_write(aic23_lt_line_ctl,0x000); aic23_write(aic23_rt_line_ctl,0x000); / configure the aic23 for master mode, 44.1khz stereo, 16 bit samples / use 12mhz usb clock aic23_write(aic23_digital_if_format, digif_fmt_ms | digif_fmt_iwl_16 | digif_fmt_for_dsp); aic23_write(aic23_sample_rate_ctl, src_sr_44 | src_bosr | src_mo); / turn on headphone volume and digital interface aic23_write(aic23_lt_hp_ctl, 0x07f); / 0x79 for speakers aic23_write(aic23_rt_hp_ctl, 0x07f); aic23_write(aic23_dig_if_activate, digifact_act); / set mcbsp0 to be transmit slave mcbsp0_initslave();void aic23_disable() pc55xx_mcsp pmcbsp0 = (pc55xx_mcsp)c55xx_msp0_addr; i2c_disable(); / put the mcbsp in reset write(pmcbsp0 - spcr1, 0); write(pmcbsp0 - spcr2, 0);#define autiodataleft 0x0d000#define autiodataright 0x17000int *paudioleft,*paudioright;int www=0; void aic23_mixer() pc55xx_mcsp pmcbsp0 = (pc55xx_mcsp)c55xx_msp0_addr; int left, right; int *pl,*pr,naudiocount; int i;paudioleft=pl=(int *)autiodataleft;paudioright=pr=(int *)autiodataright;naudiocount=0; for ( i=0;inx;i+) xi=0; for ( i=0;i spcr2, spcr2_xrdy);/ 等待数据传输完成 (*pl)=left = read(pmcbsp0 - ddr1);/ 读入左声道数据 right = read(pmcbsp0 - ddr2);/ 读入右声道数据 xnx-1=left/16;/ 防止滤波时数据溢出 fir2(x, h, r, db, nx, nh);/ 调用滤波程序计算当前输出(*pr)=rnx-1;/ 数组r的最后一个单元为当前输出 write(pmcbsp0 - dxr1, left);/ 将原始数据送左声道输出 /write(pmcbsp0 - dxr1, rnx-1);/ 将原始数据送左声道输出 write(pmcbsp0 - dxr2, rnx-1);/ 将经过滤波后数据送右声道输出 naudiocount+; pl+; pr+;/ 循环使用缓冲区 if ( naudiocount=1024 ) naudiocount=0;/ break point pl=paudioleft; pr=paudioright; for ( i=0;inx-1;i+ )/ 重新调整输入序列(供fir2使用) xi=xi+1; 语音信号fir滤波: 状态1状态2四 、心得体会通过一星期的课程设计,我了解了fir滤波器的原理和实验的内容以及需要注意的地方,了解了基本的过程。通过硬件和软件的链接完成本次实验。进一步认识了ccstudio软件的使用,了解了各种窗函数对滤波器特性的影响。这一学期的理论知识学习,加上这次课程设计,我对dsp这门学科有了更为深刻的了解,掌握了dsp的硬件操作、软件分析和编程技巧。对以后的实际工作的应用提供了有力的基础。总之,只有大量的实践才能更深层次的了解这类软件,熟练的运用其功能。对数字信号的处理功能,硬软件相结合,语音的压缩、去噪和编码等等方面都有了很深的了解。相信本次课程设计,无论是对我以后的学习,还是工作等方面都有一个很大的帮助。因此,本次课程设计我受益匪浅。参考文献:1.教 材:自编教材,dsp原理实验及课程设计指导书2.参考书:dsp技术的发展与应用,彭启琮编著,高等教育出版社,2002年第1版dsp控制器原理及应用,宁改娣、杨拴科编著,科学出版社,2002年第1版。学位论文原创性声明 本人郑重声明:所呈交的学位论文,是本人在导师的指导下进行的研究工作所取得的成果。尽我所知,除文中已经特别注明引用的内容和致谢的地方外,本论文不包含任何其他个人或集体已经发表或撰写过的研究成果。对本文的研究做出重要贡献的个人和集体,均已在文中以明确方式注明并表示感谢。本人完全意识到本声明的法律结果由本人承担。学位论文作者(本人签名): 年 月 日学位论文出版授权书本人及导师完全同意中国博士学位论文全文数据库出版章程、中国优秀硕士学位论文全文数据库出版章程(以下简称“章程”),愿意将本人的学位论文提交“中国学术期刊(光盘版)电子杂志社”在中国博士学位论文全文数据库、中国优秀硕士学位论文全文数据库中全文发表和以电子、网络形式公开出版,并同意编入cnki中国知识资源总库,在中国博硕士学位论文评价数据库中使用和在互联网上传播,同意按“章程”规定享受相关权益。论文密级:公开保密(_年_月至_年_月)(保密的学位论文在解密后应遵守此协议)作者签名:_ 导师签名:_年_月_日 _年_月_日独 创 声 明本人郑重声明:所呈交的毕业设计(论文),是本人在指导老师的指导下,独立进行研究工作所取得的成果,成果不存在知识产权争议。尽我所知,除文中已经注明引用的内容外,本设计(论文)不含任何其他个人或集体已经发表或撰写过的作品成果。对本文的研究做出重要贡献的个人和集体均已在文中以明确方式标明。本声明的法律后果由本人承担。作者签名: 二一年九月二十日毕业设计(论文)使用授权声明本人完全了解滨州学院关于收集、保存、使用毕业设计(论文)的规定。本人愿意按照学校要求提交学位论文的印刷本和电子版,同意学校保存学位论文的印刷本和电子版,或采用影印、数字化或其它复制手段保存设计(论文);同意学校在不以营利为目的的前提下,建立目录检索与阅览服务系统,公布设计(论文)的部分或全部内容,允许他人依法合理使用。(保密论文在解密后遵守此规定)作者签名: 二一年九月二十日致 谢时间飞逝,大学的学习生活很快就要过去,在这四年的学习生活中,收获了很多,而这些成绩的取得是和一直关心帮助我的人分不开的。首先非常感谢学校开设这个课题,为本人日

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论