Saya sedang mengerjakan proyek Android di mana saya menggunakan FFT untuk memproses data akselerometer dan saya memiliki masalah dalam memahami cara kerja hal-hal ini. Saya menggunakan perpustakaan jTransform oleh Piotr Wendykier dengan cara berikut:
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);
}
hasilnya adalah array dengan data berikut .
Saya memiliki masalah dengan menafsirkan data keluaran..Data berasal dari interval panjang 10 detik, dan frekuensi pengambilan sampel adalah 50Hz..Saat mengambil gambar, saya menggerakkan ponsel ke atas dan ke bawah setiap 3/4 detik di tangan saya, jadi mungkin saja bahwa titik ekstrim sekitar nilai x 16 dapat menjadi periode komponen sinyal terkuat? Saya perlu mendapatkan frekuensi komponen terkuat dalam sinyal..