Mercurial > hg > svcore
comparison data/model/SparseModel.h @ 936:0c1d6de8f44b
Merge from branch warnfix_no_size_t
author | Chris Cannam |
---|---|
date | Wed, 18 Jun 2014 13:51:16 +0100 |
parents | df82da55e86a |
children | 9f526ddc6165 |
comparison
equal
deleted
inserted
replaced
917:49618f39ff09 | 936:0c1d6de8f44b |
---|---|
41 template <typename PointType> | 41 template <typename PointType> |
42 class SparseModel : public Model, | 42 class SparseModel : public Model, |
43 public TabularModel | 43 public TabularModel |
44 { | 44 { |
45 public: | 45 public: |
46 SparseModel(size_t sampleRate, size_t resolution, | 46 SparseModel(int sampleRate, int resolution, |
47 bool notifyOnAdd = true); | 47 bool notifyOnAdd = true); |
48 virtual ~SparseModel() { } | 48 virtual ~SparseModel() { } |
49 | 49 |
50 virtual bool isOK() const { return true; } | 50 virtual bool isOK() const { return true; } |
51 virtual size_t getStartFrame() const; | 51 virtual int getStartFrame() const; |
52 virtual size_t getEndFrame() const; | 52 virtual int getEndFrame() const; |
53 virtual size_t getSampleRate() const { return m_sampleRate; } | 53 virtual int getSampleRate() const { return m_sampleRate; } |
54 | 54 |
55 virtual Model *clone() const; | 55 virtual Model *clone() const; |
56 | 56 |
57 // Number of frames of the underlying sample rate that this model | 57 // Number of frames of the underlying sample rate that this model |
58 // is capable of resolving to. For example, if m_resolution == 10 | 58 // is capable of resolving to. For example, if m_resolution == 10 |
59 // then every point in this model will be at a multiple of 10 | 59 // then every point in this model will be at a multiple of 10 |
60 // sample frames and should be considered to cover a window ending | 60 // sample frames and should be considered to cover a window ending |
61 // 10 sample frames later. | 61 // 10 sample frames later. |
62 virtual size_t getResolution() const { | 62 virtual int getResolution() const { |
63 return m_resolution ? m_resolution : 1; | 63 return m_resolution ? m_resolution : 1; |
64 } | 64 } |
65 virtual void setResolution(size_t resolution); | 65 virtual void setResolution(int resolution); |
66 | 66 |
67 typedef PointType Point; | 67 typedef PointType Point; |
68 typedef std::multiset<PointType, | 68 typedef std::multiset<PointType, |
69 typename PointType::OrderComparator> PointList; | 69 typename PointType::OrderComparator> PointList; |
70 typedef typename PointList::iterator PointListIterator; | 70 typedef typename PointList::iterator PointListIterator; |
76 virtual bool isEmpty() const; | 76 virtual bool isEmpty() const; |
77 | 77 |
78 /** | 78 /** |
79 * Get the total number of points in the model. | 79 * Get the total number of points in the model. |
80 */ | 80 */ |
81 virtual size_t getPointCount() const; | 81 virtual int getPointCount() const; |
82 | 82 |
83 /** | 83 /** |
84 * Get all points. | 84 * Get all points. |
85 */ | 85 */ |
86 virtual const PointList &getPoints() const; | 86 virtual const PointList &getPoints() const; |
155 s += i->toDelimitedDataString(delimiter, m_sampleRate) + "\n"; | 155 s += i->toDelimitedDataString(delimiter, m_sampleRate) + "\n"; |
156 } | 156 } |
157 return s; | 157 return s; |
158 } | 158 } |
159 | 159 |
160 virtual QString toDelimitedDataString(QString delimiter, size_t f0, size_t f1) const | 160 virtual QString toDelimitedDataStringSubset(QString delimiter, int f0, int f1) const |
161 { | 161 { |
162 QString s; | 162 QString s; |
163 for (PointListConstIterator i = m_points.begin(); i != m_points.end(); ++i) { | 163 for (PointListConstIterator i = m_points.begin(); i != m_points.end(); ++i) { |
164 if (i->frame >= (long)f0 && i->frame < (long)f1) { | 164 if (i->frame >= (long)f0 && i->frame < (long)f1) { |
165 s += i->toDelimitedDataString(delimiter, m_sampleRate) + "\n"; | 165 s += i->toDelimitedDataString(delimiter, m_sampleRate) + "\n"; |
369 command->deletePoint(*i); | 369 command->deletePoint(*i); |
370 return command->finish(); | 370 return command->finish(); |
371 } | 371 } |
372 | 372 |
373 protected: | 373 protected: |
374 size_t m_sampleRate; | 374 int m_sampleRate; |
375 size_t m_resolution; | 375 int m_resolution; |
376 bool m_notifyOnAdd; | 376 bool m_notifyOnAdd; |
377 long m_sinceLastNotifyMin; | 377 long m_sinceLastNotifyMin; |
378 long m_sinceLastNotifyMax; | 378 long m_sinceLastNotifyMax; |
379 bool m_hasTextLabels; | 379 bool m_hasTextLabels; |
380 | 380 |
381 PointList m_points; | 381 PointList m_points; |
382 size_t m_pointCount; | 382 int m_pointCount; |
383 mutable QMutex m_mutex; | 383 mutable QMutex m_mutex; |
384 int m_completion; | 384 int m_completion; |
385 | 385 |
386 void getPointIterators(long frame, | 386 void getPointIterators(long frame, |
387 PointListIterator &startItr, | 387 PointListIterator &startItr, |
405 PointListIterator getPointListIteratorForRow(int row) | 405 PointListIterator getPointListIteratorForRow(int row) |
406 { | 406 { |
407 if (m_rows.empty()) rebuildRowVector(); | 407 if (m_rows.empty()) rebuildRowVector(); |
408 if (row < 0 || row + 1 > int(m_rows.size())) return m_points.end(); | 408 if (row < 0 || row + 1 > int(m_rows.size())) return m_points.end(); |
409 | 409 |
410 size_t frame = m_rows[row]; | 410 int frame = m_rows[row]; |
411 int indexAtFrame = 0; | 411 int indexAtFrame = 0; |
412 int ri = row; | 412 int ri = row; |
413 while (ri > 0 && m_rows[ri-1] == m_rows[row]) { --ri; ++indexAtFrame; } | 413 while (ri > 0 && m_rows[ri-1] == m_rows[row]) { --ri; ++indexAtFrame; } |
414 int initialIndexAtFrame = indexAtFrame; | 414 int initialIndexAtFrame = indexAtFrame; |
415 | 415 |
432 PointListConstIterator getPointListIteratorForRow(int row) const | 432 PointListConstIterator getPointListIteratorForRow(int row) const |
433 { | 433 { |
434 if (m_rows.empty()) rebuildRowVector(); | 434 if (m_rows.empty()) rebuildRowVector(); |
435 if (row < 0 || row + 1 > int(m_rows.size())) return m_points.end(); | 435 if (row < 0 || row + 1 > int(m_rows.size())) return m_points.end(); |
436 | 436 |
437 size_t frame = m_rows[row]; | 437 int frame = m_rows[row]; |
438 int indexAtFrame = 0; | 438 int indexAtFrame = 0; |
439 int ri = row; | 439 int ri = row; |
440 while (ri > 0 && m_rows[ri-1] == m_rows[row]) { --ri; ++indexAtFrame; } | 440 while (ri > 0 && m_rows[ri-1] == m_rows[row]) { --ri; ++indexAtFrame; } |
441 int initialIndexAtFrame = indexAtFrame; | 441 int initialIndexAtFrame = indexAtFrame; |
442 | 442 |
463 } | 463 } |
464 }; | 464 }; |
465 | 465 |
466 | 466 |
467 template <typename PointType> | 467 template <typename PointType> |
468 SparseModel<PointType>::SparseModel(size_t sampleRate, | 468 SparseModel<PointType>::SparseModel(int sampleRate, |
469 size_t resolution, | 469 int resolution, |
470 bool notifyOnAdd) : | 470 bool notifyOnAdd) : |
471 m_sampleRate(sampleRate), | 471 m_sampleRate(sampleRate), |
472 m_resolution(resolution), | 472 m_resolution(resolution), |
473 m_notifyOnAdd(notifyOnAdd), | 473 m_notifyOnAdd(notifyOnAdd), |
474 m_sinceLastNotifyMin(-1), | 474 m_sinceLastNotifyMin(-1), |
478 m_completion(100) | 478 m_completion(100) |
479 { | 479 { |
480 } | 480 } |
481 | 481 |
482 template <typename PointType> | 482 template <typename PointType> |
483 size_t | 483 int |
484 SparseModel<PointType>::getStartFrame() const | 484 SparseModel<PointType>::getStartFrame() const |
485 { | 485 { |
486 QMutexLocker locker(&m_mutex); | 486 QMutexLocker locker(&m_mutex); |
487 size_t f = 0; | 487 int f = 0; |
488 if (!m_points.empty()) { | 488 if (!m_points.empty()) { |
489 f = m_points.begin()->frame; | 489 f = m_points.begin()->frame; |
490 } | 490 } |
491 return f; | 491 return f; |
492 } | 492 } |
493 | 493 |
494 template <typename PointType> | 494 template <typename PointType> |
495 size_t | 495 int |
496 SparseModel<PointType>::getEndFrame() const | 496 SparseModel<PointType>::getEndFrame() const |
497 { | 497 { |
498 QMutexLocker locker(&m_mutex); | 498 QMutexLocker locker(&m_mutex); |
499 size_t f = 0; | 499 int f = 0; |
500 if (!m_points.empty()) { | 500 if (!m_points.empty()) { |
501 PointListConstIterator i(m_points.end()); | 501 PointListConstIterator i(m_points.end()); |
502 f = (--i)->frame; | 502 f = (--i)->frame; |
503 } | 503 } |
504 return f; | 504 return f; |
524 { | 524 { |
525 return m_pointCount == 0; | 525 return m_pointCount == 0; |
526 } | 526 } |
527 | 527 |
528 template <typename PointType> | 528 template <typename PointType> |
529 size_t | 529 int |
530 SparseModel<PointType>::getPointCount() const | 530 SparseModel<PointType>::getPointCount() const |
531 { | 531 { |
532 return m_pointCount; | 532 return m_pointCount; |
533 } | 533 } |
534 | 534 |
674 return rv; | 674 return rv; |
675 } | 675 } |
676 | 676 |
677 template <typename PointType> | 677 template <typename PointType> |
678 void | 678 void |
679 SparseModel<PointType>::setResolution(size_t resolution) | 679 SparseModel<PointType>::setResolution(int resolution) |
680 { | 680 { |
681 { | 681 { |
682 QMutexLocker locker(&m_mutex); | 682 QMutexLocker locker(&m_mutex); |
683 m_resolution = resolution; | 683 m_resolution = resolution; |
684 } | 684 } |
716 // notifyOnAdd as an option rather than a necessity (the | 716 // notifyOnAdd as an option rather than a necessity (the |
717 // alternative is to notify on setCompletion). | 717 // alternative is to notify on setCompletion). |
718 | 718 |
719 if (m_notifyOnAdd) { | 719 if (m_notifyOnAdd) { |
720 m_rows.clear(); //!!! inefficient | 720 m_rows.clear(); //!!! inefficient |
721 emit modelChanged(point.frame, point.frame + m_resolution); | 721 emit modelChangedWithin(point.frame, point.frame + m_resolution); |
722 } else { | 722 } else { |
723 if (m_sinceLastNotifyMin == -1 || | 723 if (m_sinceLastNotifyMin == -1 || |
724 point.frame < m_sinceLastNotifyMin) { | 724 point.frame < m_sinceLastNotifyMin) { |
725 m_sinceLastNotifyMin = point.frame; | 725 m_sinceLastNotifyMin = point.frame; |
726 } | 726 } |
751 } | 751 } |
752 } | 752 } |
753 // std::cout << "SparseOneDimensionalModel: emit modelChanged(" | 753 // std::cout << "SparseOneDimensionalModel: emit modelChanged(" |
754 // << point.frame << ")" << std::endl; | 754 // << point.frame << ")" << std::endl; |
755 m_rows.clear(); //!!! inefficient | 755 m_rows.clear(); //!!! inefficient |
756 emit modelChanged(point.frame, point.frame + m_resolution); | 756 emit modelChangedWithin(point.frame, point.frame + m_resolution); |
757 } | 757 } |
758 | 758 |
759 template <typename PointType> | 759 template <typename PointType> |
760 void | 760 void |
761 SparseModel<PointType>::setCompletion(int completion, bool update) | 761 SparseModel<PointType>::setCompletion(int completion, bool update) |
779 | 779 |
780 if (update && | 780 if (update && |
781 m_sinceLastNotifyMin >= 0 && | 781 m_sinceLastNotifyMin >= 0 && |
782 m_sinceLastNotifyMax >= 0) { | 782 m_sinceLastNotifyMax >= 0) { |
783 m_rows.clear(); //!!! inefficient | 783 m_rows.clear(); //!!! inefficient |
784 emit modelChanged(m_sinceLastNotifyMin, m_sinceLastNotifyMax); | 784 emit modelChangedWithin(m_sinceLastNotifyMin, m_sinceLastNotifyMax); |
785 m_sinceLastNotifyMin = m_sinceLastNotifyMax = -1; | 785 m_sinceLastNotifyMin = m_sinceLastNotifyMax = -1; |
786 } else { | 786 } else { |
787 emit completionChanged(); | 787 emit completionChanged(); |
788 } | 788 } |
789 } else { | 789 } else { |