2015-08-20 13 views
0

Использование ответа на эту ссылку: Spectrogram C++ library Я написали код для расчета спектрограммы синусоидального сигнала: 1-Создал синусоидальный сигнал. 2- Я применил окно Ханна. 3 б/у FFTW. 4- Рассчитанная логарифмическая величина частотных коэффициентов. Вот сценарий:Построение спектрограммы

#include <stdlib.h> 
#include <stdio.h> 
#include <time.h> 
#include <fftw3.h> 
#include <iostream> 
#include <cmath> 

using namespace std; 

int main(void) 
{ 
    int i; 
    double y; 
    int N=256; 
    double Fs=30000;//sampling frequency 
    double T=1/Fs;//sample time 
    double f=5000;//frequency 
    double *in; 
    fftw_complex *out; 
    double t[N-1];//time vector 
    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; 
     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); 

    printf ("\n"); 
    printf (" Input Data:\n"); 
    printf ("\n"); 

    for (i = 0; i < N; i++) 
    { 
     printf (" %4d %12f\n", i, in[i]); 
    } 

    fftw_execute (plan_forward); 

    printf ("\n"); 
    printf (" log magnitude of frequency domain components :\n"); 
    printf ("\n"); 

    for (i = 0; i < N; i++) 
    { 
     cout << log(sqrt(out[i][0]*out[i][0]+ out[i][1]*out[i][1])) ; 

    } 
    fftw_destroy_plan (plan_forward); 
    fftw_free (in); 
    fftw_free (out); 
    return 0; 
} 

Вопрос заключается в том, как я должен действовать дальше? Какую библиотеку я должен использовать для построения спектрограммы? Какие-либо предложения? Благодарю.

ответ

0

Если вы хотите остаться с C++ и разумно кросс-платформенный, вы можете рассмотреть Qt в качестве пользовательского интерфейса и либо QWT или QCustomPlot ар научных участков виджет

Ссылки

http://sourceforge.net/projects/qwt/

http://www.qcustomplot.com/