Changeset 237f632 for src/fft.c


Ignore:
Timestamp:
Sep 29, 2006, 4:19:55 PM (18 years ago)
Author:
Paul Brossier <piem@altern.org>
Branches:
feature/autosink, feature/cnn, feature/cnn_org, feature/constantq, feature/crepe, feature/crepe_org, feature/pitchshift, feature/pydocstrings, feature/timestretch, fix/ffmpeg5, master, pitchshift, sampler, timestretch, yinfft+
Children:
3b3ec6c
Parents:
be929a5
Message:

use replacement if complex.h not found
use replacement if complex.h not found

File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/fft.c

    rbe929a5 r237f632  
    2929#define fftw_plan_dft_r2c_1d    fftwf_plan_dft_r2c_1d
    3030#define fftw_plan_dft_c2r_1d    fftwf_plan_dft_c2r_1d
     31#define fftw_plan_r2r_1d      fftwf_plan_r2r_1d
    3132#define fftw_plan               fftwf_plan
    3233#define fftw_destroy_plan       fftwf_destroy_plan
     
    4748};
    4849
     50static void aubio_fft_getspectrum(fft_data_t * spectrum, smpl_t *norm, smpl_t * phas, uint_t size);
     51
    4952aubio_fft_t * new_aubio_fft(uint_t size) {
    5053        aubio_fft_t * s = AUBIO_NEW(aubio_fft_t);
     
    5457        s->specdata = (fft_data_t*)fftw_malloc(sizeof(fft_data_t)*size);
    5558        /* create plans */
     59#ifdef HAVE_COMPLEX_H
    5660        s->pfw = fftw_plan_dft_r2c_1d(size, s->in,  s->specdata, FFTW_ESTIMATE);
    5761        s->pbw = fftw_plan_dft_c2r_1d(size, s->specdata, s->out, FFTW_ESTIMATE);
     62#else
     63        s->pfw = fftw_plan_r2r_1d(size, s->in,  s->specdata, FFTW_R2HC, FFTW_ESTIMATE);
     64        s->pbw = fftw_plan_r2r_1d(size, s->specdata, s->out, FFTW_HC2R, FFTW_ESTIMATE);
     65#endif
    5866        return s;
    5967}
     
    8997}
    9098
     99#ifdef HAVE_COMPLEX_H
    91100
    92101void aubio_fft_getnorm(smpl_t * norm, fft_data_t * spectrum, uint_t size) {
    93102        uint_t i;
    94         for (i=0;i<size;i++) norm[i] = ABSC(spectrum[i]);
     103        for (i=0;i<size/2+1;i++) norm[i] = ABSC(spectrum[i]);
     104        //for (i=0;i<size/2+1;i++) AUBIO_DBG("%f\n", norm[i]);
    95105}
    96106
    97107void aubio_fft_getphas(smpl_t * phas, fft_data_t * spectrum, uint_t size) {
    98108        uint_t i;
    99         for (i=0;i<size;i++) phas[i] = ARGC(spectrum[i]);
     109        for (i=0;i<size/2+1;i++) phas[i] = ARGC(spectrum[i]);
     110        //for (i=0;i<size/2+1;i++) AUBIO_DBG("%f\n", phas[i]);
    100111}
    101112
     113void aubio_fft_getspectrum(fft_data_t * spectrum, smpl_t *norm, smpl_t * phas, uint_t size) {
     114  uint_t j;
     115  for (j=0; j<size/2+1; j++) {
     116    spectrum[j]  = CEXPC(I*phas[j]);
     117    spectrum[j] *= norm[j];
     118  }
     119}
     120
     121#else
     122
     123void aubio_fft_getnorm(smpl_t * norm, fft_data_t * spectrum, uint_t size) {
     124        uint_t i;
     125  norm[0] = -spectrum[0];
     126        for (i=1;i<size/2+1;i++) norm[i] = SQRT(SQR(spectrum[i]) + SQR(spectrum[size-i]));
     127        //for (i=0;i<size/2+1;i++) AUBIO_DBG("%f\n", norm[i]);
     128}
     129
     130void aubio_fft_getphas(smpl_t * phas, fft_data_t * spectrum, uint_t size) {
     131        uint_t i;
     132  phas[0] = PI;
     133        for (i=1;i<size/2+1;i++) phas[i] = atan2f(spectrum[size-i] , spectrum[i]);
     134        //for (i=0;i<size/2+1;i++) AUBIO_DBG("%f\n", phas[i]);
     135}
     136
     137void aubio_fft_getspectrum(fft_data_t * spectrum, smpl_t *norm, smpl_t * phas, uint_t size) {
     138  uint_t j;
     139  for (j=0; j<size/2+1; j++) {
     140    spectrum[j]       = norm[j]*COS(phas[j]);
     141  }
     142  for (j=1; j<size/2+1; j++) {
     143    spectrum[size-j]  = norm[j]*SIN(phas[j]);
     144  }
     145}
     146
     147#endif
    102148
    103149/* new interface aubio_mfft */
     
    128174                aubio_fft_do (fft->fft,in->data[i],fft->spec[i],fft->winsize);
    129175                /* put norm and phase into fftgrain */
    130                 aubio_fft_getnorm(fftgrain->norm[i], fft->spec[i], fft->winsize/2+1);
    131                 aubio_fft_getphas(fftgrain->phas[i], fft->spec[i], fft->winsize/2+1);
     176                aubio_fft_getnorm(fftgrain->norm[i], fft->spec[i], fft->winsize);
     177                aubio_fft_getphas(fftgrain->phas[i], fft->spec[i], fft->winsize);
    132178        }
    133179}
     
    135181/* execute inverse fourier transform */
    136182void aubio_mfft_rdo(aubio_mfft_t * fft,cvec_t * fftgrain, fvec_t * out){
    137         uint_t i=0,j;
     183        uint_t i=0;
    138184        for (i=0; i < fft->channels; i++) {
    139                 for (j=0; j<fft->winsize/2+1; j++) {
    140                         fft->spec[i][j]  = CEXPC(I*aubio_unwrap2pi(fftgrain->phas[i][j]));
    141                         fft->spec[i][j] *= fftgrain->norm[i][j];
    142                 }
     185                aubio_fft_getspectrum(fft->spec[i],fftgrain->norm[i],fftgrain->phas[i],fft->winsize);
    143186                aubio_fft_rdo(fft->fft,fft->spec[i],out->data[i],fft->winsize);
    144187        }
Note: See TracChangeset for help on using the changeset viewer.