|
- /*
- ZynAddSubFX - a software synthesizer
-
- FFTwrapper.h - A wrapper for Fast Fourier Transforms
- Copyright (C) 2002-2005 Nasca Octavian Paul
- Author: Nasca Octavian Paul
-
- This program is free software; you can redistribute it and/or modify
- it under the terms of version 2 of the GNU General Public License
- as published by the Free Software Foundation.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License (version 2 or later) for more details.
-
- You should have received a copy of the GNU General Public License (version 2)
- along with this program; if not, write to the Free Software Foundation,
- Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-
- */
-
- #ifndef FFT_WRAPPER_H
- #define FFT_WRAPPER_H
- #include <fftw3.h>
- #include <complex>
- #include "../globals.h"
-
- /**A wrapper for the FFTW library (Fast Fourier Transforms)*/
- class FFTwrapper
- {
- public:
- /**Constructor
- * @param fftsize The size of samples to be fed to fftw*/
- FFTwrapper(int fftsize_);
- /**Destructor*/
- ~FFTwrapper();
- /**Convert Samples to Frequencies using Fourier Transform
- * @param smps Pointer to Samples to be converted; has length fftsize_
- * @param freqs Structure FFTFREQS which stores the frequencies*/
- void smps2freqs(const float *smps, fft_t *freqs);
- void freqs2smps(const fft_t *freqs, float *smps);
- private:
- int fftsize;
- fftw_real *time;
- fftw_complex *fft;
- fftw_plan planfftw, planfftw_inv;
- };
-
- /*
- * The "std::polar" template has no clear definition for the range of
- * the input parameters, and some C++ standard library implementations
- * don't accept negative amplitude among others. Define our own
- * FFTpolar template, which works like we expect it to.
- */
- template<class _Tp>
- std::complex<_Tp>
- FFTpolar(const _Tp& __rho, const _Tp& __theta = _Tp(0))
- {
- _Tp __x = __rho * cos(__theta);
- if (isnan(__x))
- __x = 0;
- _Tp __y = __rho * sin(__theta);
- if (isnan(__y))
- __y = 0;
- return std::complex<_Tp>(__x, __y);
- }
-
- void FFT_cleanup();
- #endif
|