Mercurial > hg > svcore
comparison data/model/FFTModel.h @ 936:0c1d6de8f44b
Merge from branch warnfix_no_size_t
author | Chris Cannam |
---|---|
date | Wed, 18 Jun 2014 13:51:16 +0100 |
parents | 59e7fe1b1003 |
children | cc27f35aa75c |
comparison
equal
deleted
inserted
replaced
917:49618f39ff09 | 936:0c1d6de8f44b |
---|---|
56 * number if possible, as that is likely to be requested first. | 56 * number if possible, as that is likely to be requested first. |
57 */ | 57 */ |
58 FFTModel(const DenseTimeValueModel *model, | 58 FFTModel(const DenseTimeValueModel *model, |
59 int channel, | 59 int channel, |
60 WindowType windowType, | 60 WindowType windowType, |
61 size_t windowSize, | 61 int windowSize, |
62 size_t windowIncrement, | 62 int windowIncrement, |
63 size_t fftSize, | 63 int fftSize, |
64 bool polar, | 64 bool polar, |
65 StorageAdviser::Criteria criteria = StorageAdviser::NoCriteria, | 65 StorageAdviser::Criteria criteria = StorageAdviser::NoCriteria, |
66 size_t fillFromColumn = 0); | 66 int fillFromColumn = 0); |
67 ~FFTModel(); | 67 ~FFTModel(); |
68 | 68 |
69 inline float getMagnitudeAt(size_t x, size_t y) { | 69 inline float getMagnitudeAt(int x, int y) { |
70 return m_server->getMagnitudeAt(x << m_xshift, y << m_yshift); | 70 return m_server->getMagnitudeAt(x << m_xshift, y << m_yshift); |
71 } | 71 } |
72 inline float getNormalizedMagnitudeAt(size_t x, size_t y) { | 72 inline float getNormalizedMagnitudeAt(int x, int y) { |
73 return m_server->getNormalizedMagnitudeAt(x << m_xshift, y << m_yshift); | 73 return m_server->getNormalizedMagnitudeAt(x << m_xshift, y << m_yshift); |
74 } | 74 } |
75 inline float getMaximumMagnitudeAt(size_t x) { | 75 inline float getMaximumMagnitudeAt(int x) { |
76 return m_server->getMaximumMagnitudeAt(x << m_xshift); | 76 return m_server->getMaximumMagnitudeAt(x << m_xshift); |
77 } | 77 } |
78 inline float getPhaseAt(size_t x, size_t y) { | 78 inline float getPhaseAt(int x, int y) { |
79 return m_server->getPhaseAt(x << m_xshift, y << m_yshift); | 79 return m_server->getPhaseAt(x << m_xshift, y << m_yshift); |
80 } | 80 } |
81 inline void getValuesAt(size_t x, size_t y, float &real, float &imaginary) { | 81 inline void getValuesAt(int x, int y, float &real, float &imaginary) { |
82 m_server->getValuesAt(x << m_xshift, y << m_yshift, real, imaginary); | 82 m_server->getValuesAt(x << m_xshift, y << m_yshift, real, imaginary); |
83 } | 83 } |
84 inline bool isColumnAvailable(size_t x) const { | 84 inline bool isColumnAvailable(int x) const { |
85 return m_server->isColumnReady(x << m_xshift); | 85 return m_server->isColumnReady(x << m_xshift); |
86 } | 86 } |
87 | 87 |
88 inline bool getMagnitudesAt(size_t x, float *values, size_t minbin = 0, size_t count = 0) { | 88 inline bool getMagnitudesAt(int x, float *values, int minbin = 0, int count = 0) { |
89 return m_server->getMagnitudesAt(x << m_xshift, values, minbin << m_yshift, count, getYRatio()); | 89 return m_server->getMagnitudesAt(x << m_xshift, values, minbin << m_yshift, count, getYRatio()); |
90 } | 90 } |
91 inline bool getNormalizedMagnitudesAt(size_t x, float *values, size_t minbin = 0, size_t count = 0) { | 91 inline bool getNormalizedMagnitudesAt(int x, float *values, int minbin = 0, int count = 0) { |
92 return m_server->getNormalizedMagnitudesAt(x << m_xshift, values, minbin << m_yshift, count, getYRatio()); | 92 return m_server->getNormalizedMagnitudesAt(x << m_xshift, values, minbin << m_yshift, count, getYRatio()); |
93 } | 93 } |
94 inline bool getPhasesAt(size_t x, float *values, size_t minbin = 0, size_t count = 0) { | 94 inline bool getPhasesAt(int x, float *values, int minbin = 0, int count = 0) { |
95 return m_server->getPhasesAt(x << m_xshift, values, minbin << m_yshift, count, getYRatio()); | 95 return m_server->getPhasesAt(x << m_xshift, values, minbin << m_yshift, count, getYRatio()); |
96 } | 96 } |
97 inline bool getValuesAt(size_t x, float *reals, float *imaginaries, size_t minbin = 0, size_t count = 0) { | 97 inline bool getValuesAt(int x, float *reals, float *imaginaries, int minbin = 0, int count = 0) { |
98 return m_server->getValuesAt(x << m_xshift, reals, imaginaries, minbin << m_yshift, count, getYRatio()); | 98 return m_server->getValuesAt(x << m_xshift, reals, imaginaries, minbin << m_yshift, count, getYRatio()); |
99 } | 99 } |
100 | 100 |
101 inline size_t getFillExtent() const { return m_server->getFillExtent(); } | 101 inline int getFillExtent() const { return m_server->getFillExtent(); } |
102 | 102 |
103 // DenseThreeDimensionalModel and Model methods: | 103 // DenseThreeDimensionalModel and Model methods: |
104 // | 104 // |
105 inline virtual size_t getWidth() const { | 105 inline virtual int getWidth() const { |
106 return m_server->getWidth() >> m_xshift; | 106 return m_server->getWidth() >> m_xshift; |
107 } | 107 } |
108 inline virtual size_t getHeight() const { | 108 inline virtual int getHeight() const { |
109 // If there is no y-shift, the server's height (based on its | 109 // If there is no y-shift, the server's height (based on its |
110 // fftsize/2 + 1) is correct. If there is a shift, then the | 110 // fftsize/2 + 1) is correct. If there is a shift, then the |
111 // server is using a larger fft size than we want, so we shift | 111 // server is using a larger fft size than we want, so we shift |
112 // it right as many times as necessary, but then we need to | 112 // it right as many times as necessary, but then we need to |
113 // re-add the "+1" part (because ((fftsize*2)/2 + 1) / 2 != | 113 // re-add the "+1" part (because ((fftsize*2)/2 + 1) / 2 != |
114 // fftsize/2 + 1). | 114 // fftsize/2 + 1). |
115 return (m_server->getHeight() >> m_yshift) + (m_yshift > 0 ? 1 : 0); | 115 return (m_server->getHeight() >> m_yshift) + (m_yshift > 0 ? 1 : 0); |
116 } | 116 } |
117 virtual float getValueAt(size_t x, size_t y) const { | 117 virtual float getValueAt(int x, int y) const { |
118 return const_cast<FFTModel *>(this)->getMagnitudeAt(x, y); | 118 return const_cast<FFTModel *>(this)->getMagnitudeAt(x, y); |
119 } | 119 } |
120 virtual bool isOK() const { | 120 virtual bool isOK() const { |
121 return m_server && m_server->getModel(); | 121 return m_server && m_server->getModel(); |
122 } | 122 } |
123 virtual size_t getStartFrame() const { | 123 virtual int getStartFrame() const { |
124 return 0; | 124 return 0; |
125 } | 125 } |
126 virtual size_t getEndFrame() const { | 126 virtual int getEndFrame() const { |
127 return getWidth() * getResolution() + getResolution(); | 127 return getWidth() * getResolution() + getResolution(); |
128 } | 128 } |
129 virtual size_t getSampleRate() const; | 129 virtual int getSampleRate() const; |
130 virtual size_t getResolution() const { | 130 virtual int getResolution() const { |
131 return m_server->getWindowIncrement() << m_xshift; | 131 return m_server->getWindowIncrement() << m_xshift; |
132 } | 132 } |
133 virtual size_t getYBinCount() const { | 133 virtual int getYBinCount() const { |
134 return getHeight(); | 134 return getHeight(); |
135 } | 135 } |
136 virtual float getMinimumLevel() const { | 136 virtual float getMinimumLevel() const { |
137 return 0.f; // Can't provide | 137 return 0.f; // Can't provide |
138 } | 138 } |
139 virtual float getMaximumLevel() const { | 139 virtual float getMaximumLevel() const { |
140 return 1.f; // Can't provide | 140 return 1.f; // Can't provide |
141 } | 141 } |
142 virtual Column getColumn(size_t x) const; | 142 virtual Column getColumn(int x) const; |
143 virtual QString getBinName(size_t n) const; | 143 virtual QString getBinName(int n) const; |
144 | 144 |
145 virtual bool shouldUseLogValueScale() const { | 145 virtual bool shouldUseLogValueScale() const { |
146 return true; // Although obviously it's up to the user... | 146 return true; // Although obviously it's up to the user... |
147 } | 147 } |
148 | 148 |
149 /** | 149 /** |
150 * Calculate an estimated frequency for a stable signal in this | 150 * Calculate an estimated frequency for a stable signal in this |
151 * bin, using phase unwrapping. This will be completely wrong if | 151 * bin, using phase unwrapping. This will be completely wrong if |
152 * the signal is not stable here. | 152 * the signal is not stable here. |
153 */ | 153 */ |
154 virtual bool estimateStableFrequency(size_t x, size_t y, float &frequency); | 154 virtual bool estimateStableFrequency(int x, int y, float &frequency); |
155 | 155 |
156 enum PeakPickType | 156 enum PeakPickType |
157 { | 157 { |
158 AllPeaks, /// Any bin exceeding its immediate neighbours | 158 AllPeaks, /// Any bin exceeding its immediate neighbours |
159 MajorPeaks, /// Peaks picked using sliding median window | 159 MajorPeaks, /// Peaks picked using sliding median window |
160 MajorPitchAdaptivePeaks /// Bigger window for higher frequencies | 160 MajorPitchAdaptivePeaks /// Bigger window for higher frequencies |
161 }; | 161 }; |
162 | 162 |
163 typedef std::set<size_t> PeakLocationSet; // bin | 163 typedef std::set<int> PeakLocationSet; // bin |
164 typedef std::map<size_t, float> PeakSet; // bin -> freq | 164 typedef std::map<int, float> PeakSet; // bin -> freq |
165 | 165 |
166 /** | 166 /** |
167 * Return locations of peak bins in the range [ymin,ymax]. If | 167 * Return locations of peak bins in the range [ymin,ymax]. If |
168 * ymax is zero, getHeight()-1 will be used. | 168 * ymax is zero, getHeight()-1 will be used. |
169 */ | 169 */ |
170 virtual PeakLocationSet getPeaks(PeakPickType type, size_t x, | 170 virtual PeakLocationSet getPeaks(PeakPickType type, int x, |
171 size_t ymin = 0, size_t ymax = 0); | 171 int ymin = 0, int ymax = 0); |
172 | 172 |
173 /** | 173 /** |
174 * Return locations and estimated stable frequencies of peak bins. | 174 * Return locations and estimated stable frequencies of peak bins. |
175 */ | 175 */ |
176 virtual PeakSet getPeakFrequencies(PeakPickType type, size_t x, | 176 virtual PeakSet getPeakFrequencies(PeakPickType type, int x, |
177 size_t ymin = 0, size_t ymax = 0); | 177 int ymin = 0, int ymax = 0); |
178 | 178 |
179 virtual int getCompletion() const { return m_server->getFillCompletion(); } | 179 virtual int getCompletion() const { return m_server->getFillCompletion(); } |
180 virtual QString getError() const { return m_server->getError(); } | 180 virtual QString getError() const { return m_server->getError(); } |
181 | 181 |
182 virtual Model *clone() const; | 182 virtual Model *clone() const; |
197 FFTDataServer *m_server; | 197 FFTDataServer *m_server; |
198 int m_xshift; | 198 int m_xshift; |
199 int m_yshift; | 199 int m_yshift; |
200 | 200 |
201 FFTDataServer *getServer(const DenseTimeValueModel *, | 201 FFTDataServer *getServer(const DenseTimeValueModel *, |
202 int, WindowType, size_t, size_t, size_t, | 202 int, WindowType, int, int, int, |
203 bool, StorageAdviser::Criteria, size_t); | 203 bool, StorageAdviser::Criteria, int); |
204 | 204 |
205 size_t getPeakPickWindowSize(PeakPickType type, size_t sampleRate, | 205 int getPeakPickWindowSize(PeakPickType type, int sampleRate, |
206 size_t bin, float &percentile) const; | 206 int bin, float &percentile) const; |
207 | 207 |
208 size_t getYRatio() { | 208 int getYRatio() { |
209 size_t ys = m_yshift; | 209 int ys = m_yshift; |
210 size_t r = 1; | 210 int r = 1; |
211 while (ys) { --ys; r <<= 1; } | 211 while (ys) { --ys; r <<= 1; } |
212 return r; | 212 return r; |
213 } | 213 } |
214 }; | 214 }; |
215 | 215 |