Bitte beachten Sie die Edits in der Antwort unter dieser Frage.Plotten Frequenzspektrum mit C++
Ich habe ein Skript geschrieben, um das Frequenzspektrum eines Sinussignals mit C++ zu zeichnen. Hier sind die Schritte
- Anwendung Hanning Fenster
- Nehmen FFT fftw3 Bibliothek
Ich habe drei Graphen: Signal, Signal, wenn auf Hanning-Funktion multipliziert wird, und das Frequenzspektrum. Das Frequenzspektrum sieht falsch aus. Es sollte eine Spitze bei 50 Hz haben. Jeder Vorschlag wäre willkommen. Hier ist der Code:
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
#include <fftw3.h>
#include <iostream>
#include <cmath>
#include <fstream>
using namespace std;
int main()
{
int i;
double y;
int N=50;
double Fs=1000;//sampling frequency
double T=1/Fs;//sample time
double f=50;//frequency
double *in;
fftw_complex *out;
double t[N];//time vector
double ff[N];
fftw_plan plan_forward;
in = (double*) fftw_malloc(sizeof(double) * N);
out = (fftw_complex*) fftw_malloc(sizeof(fftw_complex) * N);
for (int i=0; i< N;i++)
{
t[i]=i*T;
ff[i]=1/t[i];
in[i] =0.7 *sin(2*M_PI*f*t[i]);// generate sine waveform
double multiplier = 0.5 * (1 - cos(2*M_PI*i/(N-1)));//Hanning Window
in[i] = multiplier * in[i];
}
plan_forward = fftw_plan_dft_r2c_1d (N, in, out, FFTW_ESTIMATE);
fftw_execute (plan_forward);
double v[N];
for (int i = 0; i < N; i++)
{
v[i]=20*log(sqrt(out[i][0]*out[i][0]+ out[i][1]*out[i][1])/N/2);//Here I have calculated the y axis of the spectrum in dB
}
fstream myfile;
myfile.open("example2.txt",fstream::out);
myfile << "plot '-' using 1:2" << std::endl;
for(i = 0; i < N; ++i)
{
myfile << ff[i]<< " " << v[i]<< std::endl;
}
myfile.close();
fftw_destroy_plan (plan_forward);
fftw_free (in);
fftw_free (out);
return 0;
}
Ich muss hinzufügen, dass ich die Graphen aufgetragen haben mit gnuplot nach Erhalt der Ergebnisse in example2.txt einsetzen. Also sollte ff [i] vs v [i] mir das Frequenzspektrum geben.
Hier sind die Plots: Frequenzspektrum und Sinuszeitfenster jeweils:
Sie könnten dies auch am Signal Processing Stack Exchange – 7VoltCrayon
OK fragen. Ich habe es einfach gemacht ... danke – Jack