annotate Spectrogram.h @ 13:7680cc4c0073
* Tidying - made length of array variables type size_t and for loops unsigned int, where index > 0.
* Window length parameter is now a dropdown box.
author |
Carl Bussey <c.bussey@se10.qmul.ac.uk> |
date |
Wed, 13 Aug 2014 14:18:00 +0100 |
parents |
09fb76606b2b |
children |
|
rev |
line source |
c@7
|
1 //
|
c@7
|
2 // Spectrogram.h
|
c@7
|
3 // Tempogram
|
c@7
|
4 //
|
c@7
|
5 // Created by Carl Bussey on 07/08/2014.
|
c@7
|
6 // Copyright (c) 2014 Carl Bussey. All rights reserved.
|
c@7
|
7 //
|
c@7
|
8
|
c@7
|
9 #ifndef __Tempogram__Spectrogram__
|
c@7
|
10 #define __Tempogram__Spectrogram__
|
c@7
|
11 #include <vector>
|
c@7
|
12 #include <vamp-sdk/FFT.h>
|
c@7
|
13 #include <cmath>
|
c@7
|
14
|
c@13
|
15 typedef std::vector <std::vector<float> > Spectrogram;
|
c@13
|
16 typedef std::vector <std::vector<float> > SpectrogramTransposed;
|
c@13
|
17
|
c@11
|
18 class SpectrogramProcessor{
|
c@13
|
19 size_t m_inputLength;
|
c@13
|
20 size_t m_windowLength;
|
c@13
|
21 size_t m_fftLength;
|
c@13
|
22 size_t m_hopSize;
|
c@13
|
23 size_t m_numberOfOutputBins;
|
c@13
|
24 double * m_pFftInput;
|
c@13
|
25 double * m_pFftOutputReal;
|
c@13
|
26 double * m_pFftOutputImag;
|
c@7
|
27
|
c@7
|
28 void initialise();
|
c@7
|
29 void cleanup();
|
c@7
|
30 public:
|
c@13
|
31 SpectrogramProcessor(const size_t &inputLength, const size_t &windowLength, const size_t &fftLength, const size_t &hopSize);
|
c@11
|
32 ~SpectrogramProcessor();
|
c@13
|
33
|
c@13
|
34 std::vector< std::vector<float> > process(const float * const pInput, const float * pWindow) const;
|
c@7
|
35 };
|
c@7
|
36
|
c@7
|
37 #endif /* defined(__Tempogram__Spectrogram__) */
|