Mercurial > hg > svcore
comparison data/model/FFTModel.cpp @ 1221:a1b97df9962e 3.0-integration
Merge from branch msvc2015_64
author | Chris Cannam |
---|---|
date | Thu, 20 Oct 2016 11:16:22 +0100 |
parents | 6b847a59d908 |
children | d8d6d01505ed |
comparison
equal
deleted
inserted
replaced
1215:f50ded4b951c | 1221:a1b97df9962e |
---|---|
21 | 21 |
22 #include <algorithm> | 22 #include <algorithm> |
23 | 23 |
24 #include <cassert> | 24 #include <cassert> |
25 #include <deque> | 25 #include <deque> |
26 | |
27 #ifndef __GNUC__ | |
28 #include <alloca.h> | |
29 #endif | |
30 | 26 |
31 using namespace std; | 27 using namespace std; |
32 | 28 |
33 FFTModel::FFTModel(const DenseTimeValueModel *model, | 29 FFTModel::FFTModel(const DenseTimeValueModel *model, |
34 int channel, | 30 int channel, |
358 int minbin = ymin; | 354 int minbin = ymin; |
359 if (minbin > 0) minbin = minbin - 1; | 355 if (minbin > 0) minbin = minbin - 1; |
360 int maxbin = ymax; | 356 int maxbin = ymax; |
361 if (maxbin < getHeight() - 1) maxbin = maxbin + 1; | 357 if (maxbin < getHeight() - 1) maxbin = maxbin + 1; |
362 const int n = maxbin - minbin + 1; | 358 const int n = maxbin - minbin + 1; |
363 #ifdef __GNUC__ | 359 float *values = new float[n]; |
364 float values[n]; | |
365 #else | |
366 float *values = (float *)alloca(n * sizeof(float)); | |
367 #endif | |
368 getMagnitudesAt(x, values, minbin, maxbin - minbin + 1); | 360 getMagnitudesAt(x, values, minbin, maxbin - minbin + 1); |
369 for (int bin = ymin; bin <= ymax; ++bin) { | 361 for (int bin = ymin; bin <= ymax; ++bin) { |
370 if (bin == minbin || bin == maxbin) continue; | 362 if (bin == minbin || bin == maxbin) continue; |
371 if (values[bin - minbin] > values[bin - minbin - 1] && | 363 if (values[bin - minbin] > values[bin - minbin - 1] && |
372 values[bin - minbin] > values[bin - minbin + 1]) { | 364 values[bin - minbin] > values[bin - minbin + 1]) { |
373 peaks.insert(bin); | 365 peaks.insert(bin); |
374 } | 366 } |
375 } | 367 } |
368 delete[] values; | |
376 return peaks; | 369 return peaks; |
377 } | 370 } |
378 | 371 |
379 Column values = getColumn(x); | 372 Column values = getColumn(x); |
380 int nv = int(values.size()); | 373 int nv = int(values.size()); |