Mercurial > hg > svcore
comparison data/model/EditableDenseThreeDimensionalModel.cpp @ 936:0c1d6de8f44b
Merge from branch warnfix_no_size_t
author | Chris Cannam |
---|---|
date | Wed, 18 Jun 2014 13:51:16 +0100 |
parents | df82da55e86a |
children | 24964a8b31e7 3be40cf40c49 |
comparison
equal
deleted
inserted
replaced
917:49618f39ff09 | 936:0c1d6de8f44b |
---|---|
27 #include <cmath> | 27 #include <cmath> |
28 #include <cassert> | 28 #include <cassert> |
29 | 29 |
30 #include "system/System.h" | 30 #include "system/System.h" |
31 | 31 |
32 EditableDenseThreeDimensionalModel::EditableDenseThreeDimensionalModel(size_t sampleRate, | 32 EditableDenseThreeDimensionalModel::EditableDenseThreeDimensionalModel(int sampleRate, |
33 size_t resolution, | 33 int resolution, |
34 size_t yBinCount, | 34 int yBinCount, |
35 CompressionType compression, | 35 CompressionType compression, |
36 bool notifyOnAdd) : | 36 bool notifyOnAdd) : |
37 m_startFrame(0), | 37 m_startFrame(0), |
38 m_sampleRate(sampleRate), | 38 m_sampleRate(sampleRate), |
39 m_resolution(resolution), | 39 m_resolution(resolution), |
53 EditableDenseThreeDimensionalModel::isOK() const | 53 EditableDenseThreeDimensionalModel::isOK() const |
54 { | 54 { |
55 return true; | 55 return true; |
56 } | 56 } |
57 | 57 |
58 size_t | 58 int |
59 EditableDenseThreeDimensionalModel::getSampleRate() const | 59 EditableDenseThreeDimensionalModel::getSampleRate() const |
60 { | 60 { |
61 return m_sampleRate; | 61 return m_sampleRate; |
62 } | 62 } |
63 | 63 |
64 size_t | 64 int |
65 EditableDenseThreeDimensionalModel::getStartFrame() const | 65 EditableDenseThreeDimensionalModel::getStartFrame() const |
66 { | 66 { |
67 return m_startFrame; | 67 return m_startFrame; |
68 } | 68 } |
69 | 69 |
70 void | 70 void |
71 EditableDenseThreeDimensionalModel::setStartFrame(size_t f) | 71 EditableDenseThreeDimensionalModel::setStartFrame(int f) |
72 { | 72 { |
73 m_startFrame = f; | 73 m_startFrame = f; |
74 } | 74 } |
75 | 75 |
76 size_t | 76 int |
77 EditableDenseThreeDimensionalModel::getEndFrame() const | 77 EditableDenseThreeDimensionalModel::getEndFrame() const |
78 { | 78 { |
79 return m_resolution * m_data.size() + (m_resolution - 1); | 79 return m_resolution * m_data.size() + (m_resolution - 1); |
80 } | 80 } |
81 | 81 |
90 | 90 |
91 model->m_minimum = m_minimum; | 91 model->m_minimum = m_minimum; |
92 model->m_maximum = m_maximum; | 92 model->m_maximum = m_maximum; |
93 model->m_haveExtents = m_haveExtents; | 93 model->m_haveExtents = m_haveExtents; |
94 | 94 |
95 for (size_t i = 0; i < m_data.size(); ++i) { | 95 for (int i = 0; i < m_data.size(); ++i) { |
96 model->setColumn(i, m_data.at(i)); | 96 model->setColumn(i, m_data.at(i)); |
97 } | 97 } |
98 | 98 |
99 return model; | 99 return model; |
100 } | 100 } |
101 | 101 |
102 size_t | 102 int |
103 EditableDenseThreeDimensionalModel::getResolution() const | 103 EditableDenseThreeDimensionalModel::getResolution() const |
104 { | 104 { |
105 return m_resolution; | 105 return m_resolution; |
106 } | 106 } |
107 | 107 |
108 void | 108 void |
109 EditableDenseThreeDimensionalModel::setResolution(size_t sz) | 109 EditableDenseThreeDimensionalModel::setResolution(int sz) |
110 { | 110 { |
111 m_resolution = sz; | 111 m_resolution = sz; |
112 } | 112 } |
113 | 113 |
114 size_t | 114 int |
115 EditableDenseThreeDimensionalModel::getWidth() const | 115 EditableDenseThreeDimensionalModel::getWidth() const |
116 { | 116 { |
117 return m_data.size(); | 117 return m_data.size(); |
118 } | 118 } |
119 | 119 |
120 size_t | 120 int |
121 EditableDenseThreeDimensionalModel::getHeight() const | 121 EditableDenseThreeDimensionalModel::getHeight() const |
122 { | 122 { |
123 return m_yBinCount; | 123 return m_yBinCount; |
124 } | 124 } |
125 | 125 |
126 void | 126 void |
127 EditableDenseThreeDimensionalModel::setHeight(size_t sz) | 127 EditableDenseThreeDimensionalModel::setHeight(int sz) |
128 { | 128 { |
129 m_yBinCount = sz; | 129 m_yBinCount = sz; |
130 } | 130 } |
131 | 131 |
132 float | 132 float |
152 { | 152 { |
153 m_maximum = level; | 153 m_maximum = level; |
154 } | 154 } |
155 | 155 |
156 EditableDenseThreeDimensionalModel::Column | 156 EditableDenseThreeDimensionalModel::Column |
157 EditableDenseThreeDimensionalModel::getColumn(size_t index) const | 157 EditableDenseThreeDimensionalModel::getColumn(int index) const |
158 { | 158 { |
159 QReadLocker locker(&m_lock); | 159 QReadLocker locker(&m_lock); |
160 if (index >= m_data.size()) return Column(); | 160 if (int(index) >= m_data.size()) return Column(); |
161 return expandAndRetrieve(index); | 161 return expandAndRetrieve(index); |
162 } | 162 } |
163 | 163 |
164 float | 164 float |
165 EditableDenseThreeDimensionalModel::getValueAt(size_t index, size_t n) const | 165 EditableDenseThreeDimensionalModel::getValueAt(int index, int n) const |
166 { | 166 { |
167 Column c = getColumn(index); | 167 Column c = getColumn(index); |
168 if (n < c.size()) return c.at(n); | 168 if (int(n) < c.size()) return c.at(n); |
169 return m_minimum; | 169 return m_minimum; |
170 } | 170 } |
171 | 171 |
172 //static int given = 0, stored = 0; | 172 //static int given = 0, stored = 0; |
173 | 173 |
174 void | 174 void |
175 EditableDenseThreeDimensionalModel::truncateAndStore(size_t index, | 175 EditableDenseThreeDimensionalModel::truncateAndStore(int index, |
176 const Column &values) | 176 const Column &values) |
177 { | 177 { |
178 assert(index < m_data.size()); | 178 assert(int(index) < m_data.size()); |
179 | 179 |
180 //cout << "truncateAndStore(" << index << ", " << values.size() << ")" << endl; | 180 //cout << "truncateAndStore(" << index << ", " << values.size() << ")" << endl; |
181 | 181 |
182 // The default case is to store the entire column at m_data[index] | 182 // The default case is to store the entire column at m_data[index] |
183 // and place 0 at m_trunc[index] to indicate that it has not been | 183 // and place 0 at m_trunc[index] to indicate that it has not been |
185 // tests works out. | 185 // tests works out. |
186 | 186 |
187 m_trunc[index] = 0; | 187 m_trunc[index] = 0; |
188 if (index == 0 || | 188 if (index == 0 || |
189 m_compression == NoCompression || | 189 m_compression == NoCompression || |
190 values.size() != m_yBinCount) { | 190 values.size() != int(m_yBinCount)) { |
191 // given += values.size(); | 191 // given += values.size(); |
192 // stored += values.size(); | 192 // stored += values.size(); |
193 m_data[index] = values; | 193 m_data[index] = values; |
194 return; | 194 return; |
195 } | 195 } |
281 m_data[index] = values; | 281 m_data[index] = values; |
282 return; | 282 return; |
283 } | 283 } |
284 | 284 |
285 EditableDenseThreeDimensionalModel::Column | 285 EditableDenseThreeDimensionalModel::Column |
286 EditableDenseThreeDimensionalModel::expandAndRetrieve(size_t index) const | 286 EditableDenseThreeDimensionalModel::expandAndRetrieve(int index) const |
287 { | 287 { |
288 // See comment above m_trunc declaration in header | 288 // See comment above m_trunc declaration in header |
289 | 289 |
290 assert(index < m_data.size()); | 290 assert(int(index) < m_data.size()); |
291 Column c = m_data.at(index); | 291 Column c = m_data.at(index); |
292 if (index == 0) { | 292 if (index == 0) { |
293 return c; | 293 return c; |
294 } | 294 } |
295 int trunc = (int)m_trunc[index]; | 295 int trunc = (int)m_trunc[index]; |
299 bool top = true; | 299 bool top = true; |
300 int tdist = trunc; | 300 int tdist = trunc; |
301 if (trunc < 0) { top = false; tdist = -trunc; } | 301 if (trunc < 0) { top = false; tdist = -trunc; } |
302 Column p = expandAndRetrieve(index - tdist); | 302 Column p = expandAndRetrieve(index - tdist); |
303 int psize = p.size(), csize = c.size(); | 303 int psize = p.size(), csize = c.size(); |
304 if (psize != m_yBinCount) { | 304 if (psize != int(m_yBinCount)) { |
305 cerr << "WARNING: EditableDenseThreeDimensionalModel::expandAndRetrieve: Trying to expand from incorrectly sized column" << endl; | 305 cerr << "WARNING: EditableDenseThreeDimensionalModel::expandAndRetrieve: Trying to expand from incorrectly sized column" << endl; |
306 } | 306 } |
307 if (top) { | 307 if (top) { |
308 for (int i = csize; i < psize; ++i) { | 308 for (int i = csize; i < psize; ++i) { |
309 c.push_back(p.at(i)); | 309 c.push_back(p.at(i)); |
324 } | 324 } |
325 return c; | 325 return c; |
326 } | 326 } |
327 | 327 |
328 void | 328 void |
329 EditableDenseThreeDimensionalModel::setColumn(size_t index, | 329 EditableDenseThreeDimensionalModel::setColumn(int index, |
330 const Column &values) | 330 const Column &values) |
331 { | 331 { |
332 QWriteLocker locker(&m_lock); | 332 QWriteLocker locker(&m_lock); |
333 | 333 |
334 while (index >= m_data.size()) { | 334 while (int(index) >= m_data.size()) { |
335 m_data.push_back(Column()); | 335 m_data.push_back(Column()); |
336 m_trunc.push_back(0); | 336 m_trunc.push_back(0); |
337 } | 337 } |
338 | 338 |
339 bool allChange = false; | 339 bool allChange = false; |
340 | 340 |
341 // if (values.size() > m_yBinCount) m_yBinCount = values.size(); | 341 // if (values.size() > m_yBinCount) m_yBinCount = values.size(); |
342 | 342 |
343 for (size_t i = 0; i < values.size(); ++i) { | 343 for (int i = 0; i < values.size(); ++i) { |
344 float value = values[i]; | 344 float value = values[i]; |
345 if (ISNAN(value) || ISINF(value)) { | 345 if (ISNAN(value) || ISINF(value)) { |
346 continue; | 346 continue; |
347 } | 347 } |
348 if (!m_haveExtents || value < m_minimum) { | 348 if (!m_haveExtents || value < m_minimum) { |
365 | 365 |
366 if (m_notifyOnAdd) { | 366 if (m_notifyOnAdd) { |
367 if (allChange) { | 367 if (allChange) { |
368 emit modelChanged(); | 368 emit modelChanged(); |
369 } else { | 369 } else { |
370 emit modelChanged(windowStart, windowStart + m_resolution); | 370 emit modelChangedWithin(windowStart, windowStart + m_resolution); |
371 } | 371 } |
372 } else { | 372 } else { |
373 if (allChange) { | 373 if (allChange) { |
374 m_sinceLastNotifyMin = -1; | 374 m_sinceLastNotifyMin = -1; |
375 m_sinceLastNotifyMax = -1; | 375 m_sinceLastNotifyMax = -1; |
386 } | 386 } |
387 } | 387 } |
388 } | 388 } |
389 | 389 |
390 QString | 390 QString |
391 EditableDenseThreeDimensionalModel::getBinName(size_t n) const | 391 EditableDenseThreeDimensionalModel::getBinName(int n) const |
392 { | 392 { |
393 if (m_binNames.size() > n) return m_binNames[n]; | 393 if ((int)m_binNames.size() > n) return m_binNames[n]; |
394 else return ""; | 394 else return ""; |
395 } | 395 } |
396 | 396 |
397 void | 397 void |
398 EditableDenseThreeDimensionalModel::setBinName(size_t n, QString name) | 398 EditableDenseThreeDimensionalModel::setBinName(int n, QString name) |
399 { | 399 { |
400 while (m_binNames.size() <= n) m_binNames.push_back(""); | 400 while ((int)m_binNames.size() <= n) m_binNames.push_back(""); |
401 m_binNames[n] = name; | 401 m_binNames[n] = name; |
402 emit modelChanged(); | 402 emit modelChanged(); |
403 } | 403 } |
404 | 404 |
405 void | 405 void |
414 { | 414 { |
415 return !m_binValues.empty(); | 415 return !m_binValues.empty(); |
416 } | 416 } |
417 | 417 |
418 float | 418 float |
419 EditableDenseThreeDimensionalModel::getBinValue(size_t n) const | 419 EditableDenseThreeDimensionalModel::getBinValue(int n) const |
420 { | 420 { |
421 if (n < m_binValues.size()) return m_binValues[n]; | 421 if (n < (int)m_binValues.size()) return m_binValues[n]; |
422 else return 0.f; | 422 else return 0.f; |
423 } | 423 } |
424 | 424 |
425 void | 425 void |
426 EditableDenseThreeDimensionalModel::setBinValues(std::vector<float> values) | 426 EditableDenseThreeDimensionalModel::setBinValues(std::vector<float> values) |
447 | 447 |
448 QVector<float> sample; | 448 QVector<float> sample; |
449 QVector<int> n; | 449 QVector<int> n; |
450 | 450 |
451 for (int i = 0; i < 10; ++i) { | 451 for (int i = 0; i < 10; ++i) { |
452 size_t index = i * 10; | 452 int index = i * 10; |
453 if (index < m_data.size()) { | 453 if (index < m_data.size()) { |
454 const Column &c = m_data.at(index); | 454 const Column &c = m_data.at(index); |
455 while (c.size() > sample.size()) { | 455 while (c.size() > sample.size()) { |
456 sample.push_back(0.f); | 456 sample.push_back(0.f); |
457 n.push_back(0); | 457 n.push_back(0); |
485 } else if (!m_notifyOnAdd) { | 485 } else if (!m_notifyOnAdd) { |
486 | 486 |
487 if (update && | 487 if (update && |
488 m_sinceLastNotifyMin >= 0 && | 488 m_sinceLastNotifyMin >= 0 && |
489 m_sinceLastNotifyMax >= 0) { | 489 m_sinceLastNotifyMax >= 0) { |
490 emit modelChanged(m_sinceLastNotifyMin, | 490 emit modelChangedWithin(m_sinceLastNotifyMin, |
491 m_sinceLastNotifyMax + m_resolution); | 491 m_sinceLastNotifyMax + m_resolution); |
492 m_sinceLastNotifyMin = m_sinceLastNotifyMax = -1; | 492 m_sinceLastNotifyMin = m_sinceLastNotifyMax = -1; |
493 } else { | 493 } else { |
494 emit completionChanged(); | 494 emit completionChanged(); |
495 } | 495 } |
496 } else { | 496 } else { |
502 QString | 502 QString |
503 EditableDenseThreeDimensionalModel::toDelimitedDataString(QString delimiter) const | 503 EditableDenseThreeDimensionalModel::toDelimitedDataString(QString delimiter) const |
504 { | 504 { |
505 QReadLocker locker(&m_lock); | 505 QReadLocker locker(&m_lock); |
506 QString s; | 506 QString s; |
507 for (size_t i = 0; i < m_data.size(); ++i) { | 507 for (int i = 0; i < m_data.size(); ++i) { |
508 QStringList list; | 508 QStringList list; |
509 for (size_t j = 0; j < m_data.at(i).size(); ++j) { | 509 for (int j = 0; j < m_data.at(i).size(); ++j) { |
510 list << QString("%1").arg(m_data.at(i).at(j)); | 510 list << QString("%1").arg(m_data.at(i).at(j)); |
511 } | 511 } |
512 s += list.join(delimiter) + "\n"; | 512 s += list.join(delimiter) + "\n"; |
513 } | 513 } |
514 return s; | 514 return s; |
515 } | 515 } |
516 | 516 |
517 QString | 517 QString |
518 EditableDenseThreeDimensionalModel::toDelimitedDataString(QString delimiter, size_t f0, size_t f1) const | 518 EditableDenseThreeDimensionalModel::toDelimitedDataStringSubset(QString delimiter, int f0, int f1) const |
519 { | 519 { |
520 QReadLocker locker(&m_lock); | 520 QReadLocker locker(&m_lock); |
521 QString s; | 521 QString s; |
522 for (size_t i = 0; i < m_data.size(); ++i) { | 522 for (int i = 0; i < m_data.size(); ++i) { |
523 size_t fr = m_startFrame + i * m_resolution; | 523 int fr = m_startFrame + i * m_resolution; |
524 if (fr >= f0 && fr < f1) { | 524 if (fr >= int(f0) && fr < int(f1)) { |
525 QStringList list; | 525 QStringList list; |
526 for (size_t j = 0; j < m_data.at(i).size(); ++j) { | 526 for (int j = 0; j < m_data.at(i).size(); ++j) { |
527 list << QString("%1").arg(m_data.at(i).at(j)); | 527 list << QString("%1").arg(m_data.at(i).at(j)); |
528 } | 528 } |
529 s += list.join(delimiter) + "\n"; | 529 s += list.join(delimiter) + "\n"; |
530 } | 530 } |
531 } | 531 } |
556 | 556 |
557 out << indent; | 557 out << indent; |
558 out << QString("<dataset id=\"%1\" dimensions=\"3\" separator=\" \">\n") | 558 out << QString("<dataset id=\"%1\" dimensions=\"3\" separator=\" \">\n") |
559 .arg(getObjectExportId(&m_data)); | 559 .arg(getObjectExportId(&m_data)); |
560 | 560 |
561 for (size_t i = 0; i < m_binNames.size(); ++i) { | 561 for (int i = 0; i < (int)m_binNames.size(); ++i) { |
562 if (m_binNames[i] != "") { | 562 if (m_binNames[i] != "") { |
563 out << indent + " "; | 563 out << indent + " "; |
564 out << QString("<bin number=\"%1\" name=\"%2\"/>\n") | 564 out << QString("<bin number=\"%1\" name=\"%2\"/>\n") |
565 .arg(i).arg(m_binNames[i]); | 565 .arg(i).arg(m_binNames[i]); |
566 } | 566 } |
567 } | 567 } |
568 | 568 |
569 for (size_t i = 0; i < m_data.size(); ++i) { | 569 for (int i = 0; i < (int)m_data.size(); ++i) { |
570 out << indent + " "; | 570 out << indent + " "; |
571 out << QString("<row n=\"%1\">").arg(i); | 571 out << QString("<row n=\"%1\">").arg(i); |
572 for (size_t j = 0; j < m_data.at(i).size(); ++j) { | 572 for (int j = 0; j < (int)m_data.at(i).size(); ++j) { |
573 if (j > 0) out << " "; | 573 if (j > 0) out << " "; |
574 out << m_data.at(i).at(j); | 574 out << m_data.at(i).at(j); |
575 } | 575 } |
576 out << QString("</row>\n"); | 576 out << QString("</row>\n"); |
577 out.flush(); | 577 out.flush(); |