如何在两个不同的音频样本之间找到比例?

时间:2017-06-01 14:43:11

标签: python ios audio avfoundation signal-processing

我打算制作一个分析音频样本的通用应用程序。当我说'通用'时,我的意思是任何技术(Javascript,C,Java等)都可以使用它。 基本上我在iOS上使用Apple的AVFoundation制作了一个应用程序,它实时接收长度为512(bufferSize = 512)的麦克风样本。 在Python我使用PyAudio做了同样的事情,但不幸的是我收到了非常不同的值...

查看样本:

t_object

更多信息:

https://pastebin.com/jrM2VWXR

Python代码:

https://gist.github.com/denisb411/7c6f601175e8bb9f735d8aa43a0db340

在这两种情况下,我都使用同一台计算机。

我如何找到一种方法'转换'(不知道这是否是正确的词)它们的规模相同?

如果我不清楚这个问题,请通知我。

1 个答案:

答案 0 :(得分:0)

音频样本通常在16或24位上量化。但是这些样本可以采用的值范围有不同的约定:

  • 如果你要对8位进行量化,样本通常会被存储为无符号字节,范围从0到255
  • 如果你要对16位进行量化,样本通常会被存储为2的补码有符号整数,范围从-32768到32767
  • 如果要对24位进行量化,则样本通常会存储为无符号整数

基本上,当您决定存储样本时,您有两个参数:

  • 已签名或未签名
  • int或float

每个都有其优点和缺点。例如,存储在[-1,1]范围内的浮点数中的优点是,两个样本的乘积将始终在[-1,1]的相同范围内......

因此,要回答您的问题,您只需要更改打开 PyAudio 流的格式。目前,您使用format=pyaudio.paInt16。尝试更改它pyaudio.paFloat32,您应该获得与iOS实现相同的数据。