I implemented the following algorithm to convert PCM 16 bit audio data to 8 bit:
if(encoding == AudioFormat.ENCODING_PCM_8BIT){
int len = data.length;
data1 = new byte[len/2];
int tempint;
for (int k = 0, i=1; i < len; i+=2, k++) {
tempint = ((int)data[i]) ^ 0x00000080;
data1[k] = (byte)tempint;
}
data=null;
}
where data is byte[]
. After running this code, the output contains a lot of noise
and suggest me that I'm doing something wrong here. What should I do besides dropping the lower byte?
[EDIT]: modified the code:
if(encoding == AudioFormat.ENCODING_PCM_8BIT){
int len = data.length;
data1 = new byte[len/2];
for (int i = 0; i < len/2; i++) {
data1[i] = data[i*2+1];
}
}
the input/output looks like:
Original data(counter:0) = 4
Original data(counter:1) = -1
Original data(counter:2) = 75
Original data(counter:3) = -1
Original data(counter:4) = 16
Original data(counter:5) = -1
Original data(counter:6) = 44
Original data(counter:7) = -1
Original data(counter:8) = 7
Original data(counter:9) = -1
Original data(counter:10) = 22
Original data(counter:11) = -1
Original data(counter:12) = 22
Original data(counter:13) = -1
Original data(counter:14) = 12
Original data(counter:15) = -1
Output data:(counter:0) = -1
Output data:(counter:1) = -1
Output data:(counter:2) = -1
Output data:(counter:3) = -1
Output data:(counter:4) = -1
Output data:(counter:5) = -1
Output data:(counter:6) = -1
Output data:(counter:7) = -1
Output data:(counter:8) = -1
Output data:(counter:9) = -1
Output data:(counter:10) = -1
Output data:(counter:11) = -1
Output data:(counter:12) = -1
Output data:(counter:13) = -1
Output data:(counter:14) = -1
Output data:(counter:15) = -1
It does not matter if I drop first or second byte, the noise still remain. Here I dropped first byte(instead of second)
The following algorithm has considerably reduced the amount of noise, but can't get rid of it completely:
if(encoding == AudioFormat.ENCODING_PCM_8BIT){
ShortBuffer intBuf = ByteBuffer.wrap(data).order(ByteOrder.LITTLE_ENDIAN).asShortBuffer();
short[] samples16Bit = new short[intBuf.remaining()];
intBuf.get(samples16Bit);
data1 = new byte[samples16Bit.length];
for (int i = 0; i < samples16Bit.length; i++) {
data1[i] = (byte)((samples16Bit[i] / 256)+128);
}
}