C实现wav采样率转换的算法

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

其中c为传入的采样率数据
需要将上面转换的数据进行字节转换,公式如下:
第一个字节c&0xFF
第二个字节c>>8
将第一字节与第二字节依次写入新生成的文件.
六、对源文件与目标文件进行循环操作,只到源文件末尾。
}
fwrite(&data2[0], sizeof(short), 160, fout);
mData2Size+=2*160;
}
Wave格式音频文件采样率转换
一、此转换方法为文件转换方式,需要对现在的文件分析的基础上生成新的音频文件。
for(j=0;j<160;j++)
{
data[m+j]=data[m]+k*j;
}
}
for(i=0; i<MAX_SIZE; i+=441)
{
data2[i/441]=data[i];
while(mDataSize>0)
{
fread(&data2[0], 2, 441, fin);
mDataSize=mDataSize-2*441;
二、方法占用时间比较多,但速度在允许范围之内
三、分析文件与写入新文件的时候是按字节操作
四、本方法转换生成的新文件的精度只能为16位,如果需要其他的精度,需要另外进行精度转换。
操作流程:
一、分析源文件的头结构,取得源文件的采样率、声道数、数据长度、数据流量等参数。
二、根据文件头结构生成新文件的头结构,确定各项参数,其中采样率由用户自行指定。
C实现wav采样率转换的算法
直接取它们的最小公倍数,先取441个点,然后往中间插160个,再由原来的441个点每两个点之间的斜率取出插进去的点的值,最后每441个点取一个,取出来的点就是了。
可这样的精度太差了。想问下大家,有没有更好的算法.
用c实现的循环:
三、根据源文件的采样率与声道数确定转换的循环次数。
四、对源文件的语音数据进行获取与转换,转换公式:
(((itmp <<8)+itmp)-32768) << 16
其中,itmp为取得的双字节数据。
五、将转换后的数据传给需要写入的文件,再次进行转换,公式如下:
1、c = (((c + 0x80000000) >> 16) & 0xFFFF) ^ 0x8000;
for(i=0; i<MAX_SIZE; i+=160)
{
data[i]=data2[i/160];
}
for(m=0;m<MAX_SIZE;m+=160)
{
k=(data[m+160]-data[m])/160;
相关文档
最新文档