Я работаю над проектом Android, где использую БПФ для обработки данных акселерометра, и у меня возникают проблемы с пониманием того, как эти вещи на самом деле работают.
Я использую библиотеку jTransform Петра Вендикера следующим образом:
int length = vectors.length;
float[] input = new float[length*2];
for(int i=0;i<length;i++){
input[i]=vectors[i];
}
FloatFFT_1D fftlib = new FloatFFT_1D(length);
fftlib.complexForward(input);
float outputData[] = new float[(input.length+1)/2];
if(input.length%2==0){
for(int i = 0; i < length/2; i++){
outputData[i]= (float) Math.sqrt((Math.pow(input[2*i],2))+(Math.pow(input[2*(i)+1], 2)));
}
}else{
for(int i = 0; i < length/2+1; i++){
outputData[i]= (float) Math.sqrt((Math.pow(input[2*i],2))+(Math.pow(input[2*i+1], 2)));
}
}
List<Float> output = new ArrayList<Float>();
for (float f : outputData) {
output.add(f);
}
результат - массив со следующими данными .
У меня проблема с интерпретацией выходных данных. Данные взяты с 10-секундного интервала, а частота дискретизации составляет 50 Гц. Во время захвата я перемещал телефон вверх и вниз примерно на 3/4 секунды в моей руке, возможно ли, чтобы экстремум, составляющий около 16 значений x, мог быть периодом самого сильного компонента сигнала?
Мне нужно получить частоту самого сильного компонента в сигнале ..