Mercurial > hg > svgui
diff layer/SpectrumLayer.cpp @ 1385:37e9d6a1e00c spectrogramparam
Retrieve only the values already determined to be peaks
author | Chris Cannam |
---|---|
date | Thu, 08 Nov 2018 12:55:36 +0000 |
parents | 2df1af7ac752 |
children | fc3d89f88690 |
line wrap: on
line diff
--- a/layer/SpectrumLayer.cpp Thu Nov 08 11:12:04 2018 +0000 +++ b/layer/SpectrumLayer.cpp Thu Nov 08 12:55:36 2018 +0000 @@ -679,14 +679,6 @@ getBiasCurve(curve); int cs = int(curve.size()); - std::vector<double> values; - - for (int bin = 0; bin < fft->getHeight(); ++bin) { - double value = m_sliceableModel->getValueAt(col, bin); - if (bin < cs) value *= curve[bin]; - values.push_back(value); - } - for (FFTModel::PeakSet::iterator i = peaks.begin(); i != peaks.end(); ++i) { @@ -694,14 +686,16 @@ // cerr << "bin = " << bin << ", thresh = " << thresh << ", value = " << fft->getMagnitudeAt(col, bin) << endl; - if (!fft->isOverThreshold(col, bin, float(thresh))) continue; + double value = fft->getValueAt(col, bin); + if (value < thresh) continue; + if (bin < cs) value *= curve[bin]; double freq = i->second; - int x = int(lrint(getXForFrequency(v, freq))); - + double norm = 0.f; - (void)getYForValue(v, values[bin], norm); // don't need return value, need norm + // don't need return value, need norm: + (void)getYForValue(v, value, norm); paint.setPen(mapper.map(norm)); paint.drawLine(x, 0, x, v->getPaintHeight() - scaleHeight - 1);