网站大量收购闲置独家精品文档,联系QQ:2885784924

音频编码(PCM-ADPCM,WAVE文件).pdfVIP

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

⾳⾳频频编编码码((PCM,ADPCM,,WAVE⽂⽂件件))

ADPCM⽂件解码详解

⼀、搞了⼏天终于搞定这个ADPCM解码了,之前找了很多的资料,⼤描述的都是千篇⼀律,但是基本上都没有说到细节上,让我也⾛了不少弯路,其实主要在细节,⽹上给

的算法是正确的,但是直接运⽤根本就不⾏,噪⾳很⼤。这⼀点让我⼀直很头疼,最后还是看了英⽂资料,才得到解答,还是⽼外的原始资料好。

⼆、给个英⽂参考⽹址吧

这两个讲的很详细,请仔细阅读!通过阅读我发现细节在与adpcm格式的wav⽂件的block的特点,每⼀个block包含header和data两部分,

Typedefstruct{

shortsample0;//block中第⼀个采样值(未压缩)

BTEindex;//上⼀个block最后⼀个index,第⼀个block的index=0;

BTEreserved;//尚未使⽤

}MonoBlockHeader

关键是我们要抓住每⼀个block的header⾥⾯的信息,即sample0,运算的时候注意运⽤!

三、还是给个代码吧,多的也不说了!

1、adpcm.c⽂件代码

#includeadpcm.h

/*IntelADPCMstepvariationtable*/

staticintindexTable[16]={

-1,-1,-1,-1,2,4,6,8,

-1,-1,-1,-1,2,4,6,8,

};

staticintstepsizeTable[89]={

7,8,9,10,11,12,13,14,16,17,

19,21,23,25,28,31,34,37,41,45,

50,55,60,66,73,80,88,97,107,118,

130,143,157,173,190,209,230,253,279,307,

337,371,408,449,494,544,598,658,724,796,

876,963,1060,1166,1282,1411,1552,1707,1878,2066,

2272,2499,2749,3024,3327,3660,4026,4428,4871,5358,

5894,6484,7132,7845,8630,9493,10442,11487,12635,13899,

15289,16818,18500,20350,22385,24623,27086,29794,32767

};

voidadpcm_decoder(char*inbuff,char*outbuff,intlen_of_in,structadpcm_state*state)

{

inti=0,j=0;

chartmp_data;

structadpcm_state*tmp_state=state;

longstep;/*Quantizerstepsize*/

signedlongpredsample;/*OutputofADPCMpredictor*/

signedlongdiffq;/*Dequantizedpredicteddifference*/

intindex;/*Indexintostepsizetable*/

intSamp;

unsignedcharSampH,SampL;

unsignedcharinCode;

/*Restorepreviousvaluesofpredictedsampleandquantizerstep

sizeindex

*/

predsample=state-valprev;

index=state-index;

for(i=0;ilen_of_in*2;i++)

{

tmp_data=inbuff[i/2];

if(i%2)

inCode=(tmp_data0xf0)4;

else

inCode=tmp_data0x0f;

step=stepsizeTable[index];

文档评论(0)

jiangwen666 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档