我签署了存储在SInt16缓冲区中的单声道16位PCM音频样本,我试图将它们转换为存储在UInt8缓冲区中的无符号单声道8位PCM样本。我写了以下基本工作代码:
for (int i=0; i < numSamples; i++) {
SInt8 tempSigned8Bit = signed16BitBuffer[i]/127; // In 2 passes
unsigned8BitBuffer[i] = tempSigned8Bit + 127; // for clarity
}
但是,我可以听到所产生音频中最大振幅的削波,或者至少是我对失真发生位置的印象。这是重新量化的工件还是我需要包含某种类型的钳位,如此问题中描述的类似转换但没有任何符号转换:
不必要进行逐位优化,但我当然不会对它们说不。
答案 0 :(得分:8)
对于较大的值,这将失败,因为您需要除以256而不是127.此外,偏移量需要为128,而不是127.
for (int i = 0; i < numSamples; i++) {
SInt8 tempSigned8Bit = signed16BitBuffer[i] / 256;
unsigned8BitBuffer[i] = tempSigned8Bit + 128;
}
+/-满刻度和零的转换如下所示:
Signed Divide Add
16 bit by 256 128
sample
32767 -> 127 -> 255 ; Full scale +
0 -> 0 -> 128 ; 0
-32768 -> -128 -> 0 ; Full scale -