嵌入式 ADPCM压缩算法

本文介绍了ADPCM(Adaptive Differential Pulse Code Modulation)压缩算法,这是一种用于声音波形数据的有损压缩技术,能将16bit声音数据压缩至4bit,压缩比为1:4。ADPCM算法简单,适用于低空间需求和高音质场景。文中详细阐述了ADPCM的压缩和解压缩过程,并提供了相关附表。
摘要由CSDN通过智能技术生成
ADPCM(Adaptive Differential Pulse Code Modulation),是一种针对 16bits(或8bits或者更高) 声音波形数据的一种有损压缩算法,它将声音流中每次采样的 16bit 数据以 4bit 存储,所以压缩比1:4. 而且压缩/解压缩算法非常简单,所以是一种低空间消耗,高质量高效率声音获得的好途径。保存声音的数据文件后缀名为 .AUD的大多用ADPCM 压缩。
  ADPCM主要是针对连续的波形数据的,保存的是波形的变化情况,以达到描述整个波形的目的,由于它的编码和解码的过程却很简洁,列在后面,相信大家能够看懂。
  8bits采样的声音人耳是可以勉强接受的,而 16bit 采样的声音可以算是高音质了。ADPCM 算法却可以将每次采样得到的16bit 数据压缩到 4bit。需要注意的是,如果要压缩/解压缩得是立体声信号,采样时,声音信号是放在一起的,需要将两个声道分别处理。
ADPCM 压缩过程
  首先我们认为声音信号都是从零开始的,那么需要初始化两个变量
    int index=0,prev_sample=0;
  下面的循环将依次处理声音数据流,注意其中的 getnextsample() 应该得到一个 16bit 的采样数据,而outputdata() 可以将计算出来的数据保存起来,程序中用到的 step_table[],index_adjust[]附在后面:
    int index=0,prev_sample:=0;
    while (还有数据要处理)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值