hzosc.h 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /*
  2. Sekai - addons for the WORLD speech toolkit
  3. Copyright (C) 2016 Tobias Platen
  4. This program is free software: you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation, either version 3 of the License, or
  7. (at your option) any later version.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with this program. If not, see <http://www.gnu.org/licenses/>.
  14. */
  15. #ifndef SEKAI_HZOSC_H
  16. #define SEKAI_HZOSC_H
  17. #include <fftw3.h>
  18. #define N_OSC 100
  19. #define FFT_SIZE 2048
  20. class IFFTOsc {
  21. public:
  22. double phase[N_OSC];
  23. double amp[N_OSC];
  24. double frq[N_OSC];
  25. IFFTOsc();
  26. void processOneFrame();
  27. double output_buffer[FFT_SIZE / 2];
  28. int fs;
  29. private:
  30. float window[FFT_SIZE];
  31. fftw_complex *spectrum;
  32. double *waveform;
  33. fftw_plan inverse_c2r;
  34. double rover[FFT_SIZE / 2];
  35. };
  36. #endif