• 易迪拓培训,专注于微波、射频、天线设计工程师的培养
首页 > 无线通信 > 技术文章 > 语音编解码算法G.723.1在DSP上的优化

语音编解码算法G.723.1在DSP上的优化

录入:edatop.com     点击:

  (1)编写连接命令文件.cmd

明确了系统的程序和数据映射地址后,编写连接器命令文件将部分调用次数较多的函数、堆栈段、数据段放入内存:cmd文件内容如下:

一L\evmdm642_echocfg.cmd //连接CCS提供的连接命令文件

SECTIONS

{

.tahles>SDRAM

.cinit>ISRAM //将变量初值表放入内存

. far >SDRAM

.const>ISRAM //将常数段放入内存

.pinit>SDRAM

. tin >SDRAM

.text>SDRAM

.test >ISRAM

}

一levmdm642bsl.lib //连接库文件

一levmdm642_edma_aic23.164 //连接驱动程序的库文件

一lc6xlx_edma_mcasp.J64 //连接串口McASP的库文件

其中.test是笔者在C程序内用#pragma CODE_SECTION或DATA_SECTION自定义的段。

(2)高速缓冲寄存器Cache的使用

Cache即高速缓存,是位于CPU和片内存储器之间的规模小速度快的存储器。Cache的工作原理是保存CPU中最常用的数据。当Cache中保存着CPU要读写的数据时,CPU直接访问Cache。由于Cache的速度与CPU相当,CPU能在零等待状态下迅速地实现数据存取。只有在Cache中不舍有CPU所需的数据时CPU才去访问片内存储器。因此Cache的有效利用对整个程序速度的提高有着举足轻重的作用。在主函数中加入以下代码,使Cache使能:

CACHE_clean (CACHE_L2ALL,0,0}; //清除Cache内原有内容

CACHE_setL2Mode (CACHE_64KCACHE); //设置Cache的大小为64K

CACHE_enableCaching (CACHE_EMIFA_CE00); //Cache使能

添加以上代玛后,测试速度由原来的20帧/s提高到了400帧/s。提高了将近20倍。

5 结束语

本文详缁分绍了G.723.1标准的DSP代码优化工作,重点描述了代码优化的方法和本课题的创新点.对于算法中的一些函数提出了独创性改写方法。基于线性汇编的优化以及Cache的有效利用使本课题的工作取得了显著成果,在没有降低音质的情况下,实现了DSP的语音实时编解码。

本文作者创新点:在对G.723.1的优化中,针对TMS320DM 642 DSP系列芯片提出了一些有价值的新方法。例如:编写连接命令文件.cmd和高速缓冲寄存器Cache的使用。这些创新点在不同程度上提高了代码的优化速度和执行效率,在语音编解码的DSP实时实现中起到了关键性作用。

作者:王伟 黄俊恒 来源:微计算机信息

上一篇:全业务运营与IMS网络管理
下一篇:基片集成波导多层转换器的设计与仿真

手机天线设计培训教程详情>>

手机天线设计培训教程 国内最全面、系统、专业的手机天线设计培训课程,没有之一;是您学习手机天线设计的最佳选择...【More..

射频和天线工程师培训课程详情>>

  网站地图