Ответ 1
Сначала вам нужно убедиться, что полученный результат правильно преобразован в float/double. Я не уверен, как работает короткая [] версия, но версия byte [] возвращает только исходную байтовую версию. Этот массив байтов затем должен быть правильно преобразован в число с плавающей запятой. Код для преобразования должен выглядеть примерно так:
double[] micBufferData = new double[<insert-proper-size>];
final int bytesPerSample = 2; // As it is 16bit PCM
final double amplification = 100.0; // choose a number as you like
for (int index = 0, floatIndex = 0; index < bytesRecorded - bytesPerSample + 1; index += bytesPerSample, floatIndex++) {
double sample = 0;
for (int b = 0; b < bytesPerSample; b++) {
int v = bufferData[index + b];
if (b < bytesPerSample - 1 || bytesPerSample == 1) {
v &= 0xFF;
}
sample += v << (b * 8);
}
double sample32 = amplification * (sample / 32768.0);
micBufferData[floatIndex] = sample32;
}
Затем вы используете micBufferData [] для создания сложного массива ввода.
Как только вы получите результаты, используйте значения комплексных чисел в результатах. Большая часть величин должна быть близка к нулю, кроме частот, которые имеют фактические значения.
Вам нужна частота дискретизации, чтобы преобразовать индексы массива в такие величины к частотам:
private double ComputeFrequency(int arrayIndex) {
return ((1.0 * sampleRate) / (1.0 * fftOutWindowSize)) * arrayIndex;
}