采样率的转换


一、高变低

    例如16k转换为8k,就是将16k降为8k,也就是每采集的16k两次数据变为1次,采用两个数据求平均除以2

二、低变高

  例如 8k变为16k升频。将8k的每个数据变为两个,也就是后一个数据减去前一个数据除以2,加上前一个数据

/*  @breaf   用于pcm音频采集率的转换
	@param   bit[in],输入文件和输出文件的采样位数
	@param   sourcefile[in],源文件名
	@param   sou_rate[in],源文件的采集率
	@param   disfile[out],目标文件名
	@param   dis_rate[in],目标文件的采集率
	@return  0成功,-1出错
	*/
void pcm_rate_trans(int bit,char * sourcefile,int sou_rate,char *disfile,int dis_rate )
	{
		FILE *fp_sou;
		FILE *fp_dis;
		fopen_s(&fp_sou, sourcefile, "rb+");
		fopen_s(&fp_dis,disfile, "wb+");
		if (fp_sou==NULL|| fp_dis==NULL)
		{
			printf("error open!\n");
		}
		int rate_len = sou_rate / dis_rate;
				//减小采样率
				if (rate_len > 0)
				{
					short tempRead = 0;
					short tempSum = 0;
					int flag = 0;

					while (!feof(fp_sou))
					{
						
						if (fread(&tempRead, bit/8, 1, fp_sou) > 0)
						{
							tempSum = tempSum + tempRead; // 求和
							flag++;
							if (flag == rate_len)              
							{
								flag = 0;
								tempSum = tempSum / rate_len;   
								fwrite(&tempSum,bit/8, 1, fp_dis);
								tempSum = 0;
							}
						}
					}
				}
				//增大采样率
				else
				{
					rate_len = dis_rate/ sou_rate ;
					int tempRead1;
					int tempRead2;
					int tempSum;
					int tempWrite;
					int flag;
					while (!feof(fp_sou))
					{
						
						if (fread(&tempRead1,bit/8, 1, fp_sou) >0&& fread(&tempRead2, bit / 8, 1, fp_sou) >0)
						{
						//	tempSum = *((short *)&tempRead +1)-*(short *)&tempRead;//波距离
							tempSum = tempRead2 - tempRead1;
							flag = rate_len;
							tempWrite =tempRead1;
							do
							{
								tempWrite += tempSum / rate_len;
								fwrite(&tempWrite, bit/8, 1, fp_dis);
							} while (--flag!=0);
							fseek(fp_sou, -1L*bit/8, SEEK_CUR);
						}
					}

				}
		fclose(fp_sou);
		fclose(fp_dis);
	}

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: PCM采样率转换是指将一个PCM音频信号的采样率从一种频率转换为另一种频率的过程。在C语言中,可以使用一些库或算法来实现这个功能。 常见的一种方法是使用插值算法,如线性插值方法。该方法的基本思想是根据已有的采样点,在两个相邻的采样点之间进行插值来生成新的采样点。具体步骤如下: 1. 计算原始音频信号的采样点之间的时间间隔,即每个采样点的时间间隔为1/原始采样率。 2. 根据目标采样率,计算目标音频信号的采样点之间的时间间隔。 3. 根据目标采样率和目标采样间隔,计算目标采样点的个数。 4. 在目标采样点的时间范围内,使用线性插值方法计算目标采样点的数值。对于每个目标采样点,找到其对应的原始采样点,并根据采样点之间的时间间隔进行线性插值计算。 5. 将生成的目标采样点保存为新的音频文件或直接在内存中使用。 此外,还有一些其他的采样率转换算法可供选择,如重采样算法、多相滤波器算法等。不同算法的性能和复杂度各有差异,可以根据具体的项目需求和性能要求选择适合的算法进行实现。 总之,通过使用适当的算法,可以在C语言中实现PCM采样率转换,以满足不同采样率的音频处理需求。 ### 回答2: PCM采样率转换是一种将数字音频信号从一种采样率转换为另一种采样率的过程。在C语言中,可以使用一些库函数来实现这个功能。 一种常用的方法是使用SoX库(Sound eXchange)来进行采样率转换。SoX是一个用于音频处理的开源库,它提供了许多功能强大的音频处理函数,包括采样率转换。 首先,我们需要在C程序中引入SoX库的头文件,并链接SoX库。 然后,我们可以使用SoX库中的函数来实现采样率转换。例如,可以使用sox_open_read函数打开输入音频文件,并使用sox_open_write函数创建输出音频文件。然后,使用sox_format_read函数读取输入音频文件的信息,并使用sox_format_signalinfo函数修改输出音频文件的采样率信息。 接下来,可以使用sox_create_effects_chain函数创建一个SoX效果链,在效果链中添加一个采样率转换效果。可以使用sox_effect_options函数设置采样率转换的参数。 最后,使用sox_flow_effects函数将输入音频文件的数据流经过效果链,写入到输出音频文件中。使用sox_delete_effects_chain函数删除效果链,并分别使用sox_close函数关闭输入和输出音频文件。 需要注意的是,这只是其中一种实现采样率转换的方法,还有其他的方法可以选择,如使用libresample库、libsamplerate库等。 总之,在C语言中实现PCM采样率转换,可以使用一些音频处理库或函数来实现。以上是使用SoX库的一种可能的方式。根据具体情况和需求,可以选择合适的方法来进行采样率转换

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值