使用FIR滤波器实现音频滤波实验指南汇编.docVIP

使用FIR滤波器实现音频滤波实验指南汇编.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
使用FIR滤波器实现音频滤波实验指南汇编

DSP Builder入门与使用FIR滤波器实现音频滤波 --DSP Builder应用实例 主要内容 1. 设计要求 2. Audio ADC/DAC配置 3. FIR滤波器的设计 4. Quartus II工程对DSP Builder模块的调用 一、设计要求 (1) 原始音乐(夹带2KHz的啸叫声)由电脑的媒体播放器播放后,经音频线连到Cyclone II EP2C70 DSP Development Board(以下简称DSP开发板)的LINE IN音频输入口,DSP开发板上音频codec对模拟音频进行采样得到数字化音频; (2) 在DSP开发平台上设计FIR滤波器滤除原始音乐中的单音啸叫得到较理想的音乐,并通过DSP开发板上音频codec进行DAC转换,通过耳机收听音乐效果。 二、Audio ADC/DAC配置 主要步骤: (1) 在DE2_default工程上修改 (2) 从Bypass模式切换到DAC模式 第一步:修改I2C_AV_Config.v 在修改工程之前,下载原来的程序,用计算机播放器播放音乐并连到DE2的LINEIN输入端,用耳机可以听到效果。但是这个声音并没有经过ADC和DAC,因此并需进行修改,否则无法测试滤波器的效果。 修改方法: A_PATH_CTRL : LUT_DATA = 16h08F8; 将8改为0 SAMPLE_CTRL : LUT_DATA = 16h1002; 将2改为0 改完后结果如下图所示: 图1 修改I2C_AV_Config.v 此时编译工程,将不能再听到LINEIN输入的音乐,说明修改生效了。 第二步:Step 2: 修改AUDIO_DAC.v (1)增加两个输入fir_in_data和fir_out_data,前者为fir滤波器的输入数据,也是ADC采样后的数据,后者是fir滤波器滤波后的数据。 具体代码为: input [DATA_WIDTH-1:0] fir_out_data; input [DATA_WIDTH-1:0] fir_in_data; 图2 增加两个输入 (2)fir_in_data为ADC采样后的输出,现将其连入。 图3 将FLASH_Out改为fir_in_data 第三步:Step 3: 修改DE2_Default.v 主要内容 (1) 将ADC采集的数据进行串并转换得到并行数据 (2) 将并行数据送给fir_in_data (3) ADC采集后的数据是双通道的,只需将左声道或右声道送给fir_in_data (1)串并转换 将以下代码加入到系统顶层文件DE2_Default.v //////////////////////////////added by sunshine (begin) reg [3:0] count_ADC_l=0; reg [3:0] count_ADC_r=0; reg [15:0] fir_in_data_l=0; reg [15:0] fir_in_data_r=0; reg [15:0] ADC_data_l=0; reg [15:0] ADC_data_r=0; wire [15:0] fir_out_data; ///// ADC data serial to pararrel always @(posedge AUD_BCLK) begin if(AUD_ADCLRCK) begin ADC_data_l[~count_ADC_l[3:0]]=AUD_ADCDAT; count_ADC_l = count_ADC_l+1; if(count_ADC_l==15) begin fir_in_data_r=ADC_data_r; count_ADC_r=0; end end else begin ADC_data_r[~count_ADC_r[3:0]]=AUD_ADCDAT; count_ADC_r = count_ADC_r+1; if(count_ADC_r==15) begin fir_in_data_l=ADC_data_l; count_ADC_l=0; end end end //////////////////////////////added by sunshine (end) 图4 串并转换 (2)AUDIO_DAC重新连接 AUDIO_DAC增加了两个输入fir_in_data和fir_out_data(已在第二步完成) 将串并转换的数据送给fir_in_data,如下图所示 图5 重新对Audio_

文档评论(0)

过各自的生活 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档