将wav音频格式字节数组转换为浮点数

ACS*_*ACS 5 java floating-point audio bytearray

我正在使用Java AudioInputStream读取.wav音频文件.音频文件是16位PCM签名,samplerate = 44100,framesize = 2,framelength = 114048.我设法以字节数组的形式获取音频数据但我我不确定我应该为这个字节数组分配多少大小,以便我可以将它转换为floatinf点值.我正在使用Goertzel算法进行一些音频操作,该算法接受浮点数组的输入,类似于"float [] x".下面是我正在使用的一些代码片段.提前致谢.

 try {
 AudioInputStream audioInputStream = AudioSystem.getAudioInputStream(fileIn);
  }

while ( numBytesRead != -1) {
numBytesRead = audioInputStream.read(audioBytes);

// Logic goes here
floatValue = byteArrayToFloat(audioBytes);
}
Run Code Online (Sandbox Code Playgroud)

rli*_*bby 10

音频文件是16位PCM签名,samplerate = 44100,framesize = 2,framelength = 114048.

我从上面假设您只有一个通道(2字节采样*1通道= 2字节帧).

第一步是将数据作为16位整数类型的序列,这是shortJava中的.

import java.nio.ByteBuffer;
import java.nio.ByteOrder;
import java.nio.ShortBuffer;

...

byte[] audioBytes = ...

ShortBuffer sbuf =
    ByteBuffer.wrap(audioBytes).order(ByteOrder.LITTLE_ENDIAN).asShortBuffer();
short[] audioShorts = new short[sbuf.capacity()];
sbuf.get(audioShorts);
Run Code Online (Sandbox Code Playgroud)

现在,如何将其转换为floats取决于下游函数如何表示音频.例如,如果他们期望浮点数> = -1且<= 1,那么您可以这样做:

float[] audioFloats = new float[audioShorts.length];
for (int i = 0; i < audioShorts.length; i++) {
    audioFloats[i] = ((float)audioShorts[i])/0x8000;
}
Run Code Online (Sandbox Code Playgroud)

不幸的是,有很多方法来表示音频.

  • 我是否正确地认为您的示例代码假设 AudioInputStream 是小端字节序?如果您不能依赖该假设,那么调用 .getFormat().isBigEndian() 是否安全,如果它返回 true,则改为传入 ByteOrder.BIG_ENDIAN ? (2认同)