Mercurial > hg > svgui
comparison layer/Colour3DPlotExporter.cpp @ 1594:5aef3f53a425
Merge from branch sensible-delimited-data-strings
author | Chris Cannam |
---|---|
date | Mon, 06 Apr 2020 13:56:00 +0100 |
parents | 32171776fcc9 |
children |
comparison
equal
deleted
inserted
replaced
1592:1da52d5e6700 | 1594:5aef3f53a425 |
---|---|
43 m_sources.source = {}; | 43 m_sources.source = {}; |
44 m_sources.fft = {}; | 44 m_sources.fft = {}; |
45 m_sources.provider = nullptr; | 45 m_sources.provider = nullptr; |
46 } | 46 } |
47 | 47 |
48 QString | 48 QVector<QString> |
49 Colour3DPlotExporter::getDelimitedDataHeaderLine(QString delimiter, | 49 Colour3DPlotExporter::getStringExportHeaders(DataExportOptions opts) const |
50 DataExportOptions opts) const | |
51 { | 50 { |
52 auto model = | 51 auto model = |
53 ModelById::getAs<DenseThreeDimensionalModel>(m_sources.source); | 52 ModelById::getAs<DenseThreeDimensionalModel>(m_sources.source); |
54 | 53 |
55 auto layer = m_sources.verticalBinLayer; | 54 auto layer = m_sources.verticalBinLayer; |
72 | 71 |
73 nbins = layer->getIBinForY(provider, 0) - minbin + 1; | 72 nbins = layer->getIBinForY(provider, 0) - minbin + 1; |
74 if (minbin + nbins > sh) nbins = sh - minbin; | 73 if (minbin + nbins > sh) nbins = sh - minbin; |
75 } | 74 } |
76 | 75 |
77 QStringList list; | 76 QVector<QString> headers; |
78 | 77 |
79 if (opts & DataExportAlwaysIncludeTimestamp) { | 78 if (opts & DataExportAlwaysIncludeTimestamp) { |
80 if (opts & DataExportWriteTimeInFrames) { | 79 if (opts & DataExportWriteTimeInFrames) { |
81 list << "FRAME"; | 80 headers << "FRAME"; |
82 } else { | 81 } else { |
83 list << "TIME"; | 82 headers << "TIME"; |
84 } | 83 } |
85 } | 84 } |
86 | 85 |
87 if (m_params.binDisplay == BinDisplay::PeakFrequencies) { | 86 if (m_params.binDisplay == BinDisplay::PeakFrequencies) { |
88 for (int i = 0; i < nbins/4; ++i) { | 87 for (int i = 0; i < nbins/4; ++i) { |
89 list << QString("FREQ %1").arg(i+1) | 88 headers << QString("FREQ %1").arg(i+1) |
90 << QString("MAG %1").arg(i+1); | 89 << QString("MAG %1").arg(i+1); |
91 } | 90 } |
92 } else { | 91 } else { |
93 bool hasValues = model->hasBinValues(); | 92 bool hasValues = model->hasBinValues(); |
94 QString unit = (hasValues ? model->getBinValueUnit() : ""); | 93 QString unit = (hasValues ? model->getBinValueUnit() : ""); |
109 } else { | 108 } else { |
110 name = QString("BIN %1") | 109 name = QString("BIN %1") |
111 .arg(i+1); | 110 .arg(i+1); |
112 } | 111 } |
113 } | 112 } |
114 list << name; | 113 headers << name; |
115 } | 114 } |
116 } | 115 } |
117 | 116 |
118 return list.join(delimiter); | 117 return headers; |
119 } | 118 } |
120 | 119 |
121 QString | 120 QVector<QVector<QString>> |
122 Colour3DPlotExporter::toDelimitedDataString(QString delimiter, | 121 Colour3DPlotExporter::toStringExportRows(DataExportOptions opts, |
123 DataExportOptions opts, | 122 sv_frame_t startFrame, |
124 sv_frame_t startFrame, | 123 sv_frame_t duration) const |
125 sv_frame_t duration) const | |
126 { | 124 { |
127 QMutexLocker locker(&m_mutex); | 125 QMutexLocker locker(&m_mutex); |
128 | 126 |
129 BinDisplay binDisplay = m_params.binDisplay; | 127 BinDisplay binDisplay = m_params.binDisplay; |
130 | 128 |
159 if (minbin + nbins > sh) nbins = sh - minbin; | 157 if (minbin + nbins > sh) nbins = sh - minbin; |
160 } | 158 } |
161 | 159 |
162 int w = model->getWidth(); | 160 int w = model->getWidth(); |
163 | 161 |
164 QString s; | 162 QVector<QVector<QString>> rows; |
165 | 163 |
166 for (int i = 0; i < w; ++i) { | 164 for (int i = 0; i < w; ++i) { |
167 | 165 |
168 sv_frame_t fr = model->getStartFrame() + i * model->getResolution(); | 166 sv_frame_t fr = model->getStartFrame() + i * model->getResolution(); |
169 if (fr < startFrame || fr >= startFrame + duration) { | 167 if (fr < startFrame || fr >= startFrame + duration) { |
177 column.data() + minbin + nbins); | 175 column.data() + minbin + nbins); |
178 | 176 |
179 // The scale factor is always applied | 177 // The scale factor is always applied |
180 column = ColumnOp::applyGain(column, m_params.scaleFactor); | 178 column = ColumnOp::applyGain(column, m_params.scaleFactor); |
181 | 179 |
182 QStringList list; | 180 QVector<QString> row; |
183 | 181 |
184 if (opts & DataExportAlwaysIncludeTimestamp) { | 182 if (opts & DataExportAlwaysIncludeTimestamp) { |
185 if (opts & DataExportWriteTimeInFrames) { | 183 if (opts & DataExportWriteTimeInFrames) { |
186 list << QString("%1").arg(fr); | 184 row << QString("%1").arg(fr); |
187 } else { | 185 } else { |
188 list << RealTime::frame2RealTime(fr, model->getSampleRate()) | 186 row << RealTime::frame2RealTime(fr, model->getSampleRate()) |
189 .toString().c_str(); | 187 .toString().c_str(); |
190 } | 188 } |
191 } | 189 } |
192 | 190 |
193 if (binDisplay == BinDisplay::PeakFrequencies) { | 191 if (binDisplay == BinDisplay::PeakFrequencies) { |
214 } | 212 } |
215 | 213 |
216 double freq = p.second; | 214 double freq = p.second; |
217 double value = column[bin - minbin]; | 215 double value = column[bin - minbin]; |
218 | 216 |
219 list << QString("%1").arg(freq) << QString("%1").arg(value); | 217 row << QString("%1").arg(freq) << QString("%1").arg(value); |
220 } | 218 } |
221 | 219 |
222 } else { | 220 } else { |
223 | 221 |
224 if (binDisplay == BinDisplay::PeakBins) { | 222 if (binDisplay == BinDisplay::PeakBins) { |
225 column = ColumnOp::peakPick(column); | 223 column = ColumnOp::peakPick(column); |
226 } | 224 } |
227 | 225 |
228 for (auto value: column) { | 226 for (auto value: column) { |
229 list << QString("%1").arg(value); | 227 row << QString("%1").arg(value); |
230 } | 228 } |
231 } | 229 } |
232 | 230 |
233 if (!list.empty()) { | 231 if (!row.empty()) { |
234 s += list.join(delimiter) + "\n"; | 232 rows.push_back(row); |
235 } | 233 } |
236 } | 234 } |
237 | 235 |
238 return s; | 236 return rows; |
239 } | 237 } |
240 | 238 |