comparison data/model/SparseTimeValueModel.h @ 1450:a12fd0456f0c streaming-csv-writer

Merge from default branch
author Chris Cannam
date Tue, 17 Apr 2018 10:35:42 +0100
parents 48e9f538e6e9
children c01cbe41aeb5
comparison
equal deleted inserted replaced
1449:deabf9fd3d28 1450:a12fd0456f0c
29 struct TimeValuePoint 29 struct TimeValuePoint
30 { 30 {
31 public: 31 public:
32 TimeValuePoint(sv_frame_t _frame) : frame(_frame), value(0.0f) { } 32 TimeValuePoint(sv_frame_t _frame) : frame(_frame), value(0.0f) { }
33 TimeValuePoint(sv_frame_t _frame, float _value, QString _label) : 33 TimeValuePoint(sv_frame_t _frame, float _value, QString _label) :
34 frame(_frame), value(_value), label(_label) { } 34 frame(_frame), value(_value), label(_label) { }
35 35
36 int getDimensions() const { return 2; } 36 int getDimensions() const { return 2; }
37 37
38 sv_frame_t frame; 38 sv_frame_t frame;
39 float value; 39 float value;
43 43
44 void toXml(QTextStream &stream, QString indent = "", 44 void toXml(QTextStream &stream, QString indent = "",
45 QString extraAttributes = "") const 45 QString extraAttributes = "") const
46 { 46 {
47 stream << QString("%1<point frame=\"%2\" value=\"%3\" label=\"%4\" %5/>\n") 47 stream << QString("%1<point frame=\"%2\" value=\"%3\" label=\"%4\" %5/>\n")
48 .arg(indent).arg(frame).arg(value).arg(XmlExportable::encodeEntities(label)) 48 .arg(indent).arg(frame).arg(value).arg(XmlExportable::encodeEntities(label))
49 .arg(extraAttributes); 49 .arg(extraAttributes);
50 } 50 }
51 51
52 QString toDelimitedDataString(QString delimiter, DataExportOptions, sv_samplerate_t sampleRate) const 52 QString toDelimitedDataString(QString delimiter, DataExportOptions, sv_samplerate_t sampleRate) const
53 { 53 {
57 if (label != "") list << label; 57 if (label != "") list << label;
58 return list.join(delimiter); 58 return list.join(delimiter);
59 } 59 }
60 60
61 struct Comparator { 61 struct Comparator {
62 bool operator()(const TimeValuePoint &p1, 62 bool operator()(const TimeValuePoint &p1,
63 const TimeValuePoint &p2) const { 63 const TimeValuePoint &p2) const {
64 if (p1.frame != p2.frame) return p1.frame < p2.frame; 64 if (p1.frame != p2.frame) return p1.frame < p2.frame;
65 if (p1.value != p2.value) return p1.value < p2.value; 65 if (p1.value != p2.value) return p1.value < p2.value;
66 return p1.label < p2.label; 66 return p1.label < p2.label;
67 } 67 }
68 }; 68 };
69 69
70 struct OrderComparator { 70 struct OrderComparator {
71 bool operator()(const TimeValuePoint &p1, 71 bool operator()(const TimeValuePoint &p1,
72 const TimeValuePoint &p2) const { 72 const TimeValuePoint &p2) const {
73 return p1.frame < p2.frame; 73 return p1.frame < p2.frame;
74 } 74 }
75 }; 75 };
76 }; 76 };
77 77
78 78
79 class SparseTimeValueModel : public SparseValueModel<TimeValuePoint> 79 class SparseTimeValueModel : public SparseValueModel<TimeValuePoint>
80 { 80 {
81 Q_OBJECT 81 Q_OBJECT
82 82
83 public: 83 public:
84 SparseTimeValueModel(sv_samplerate_t sampleRate, int resolution, 84 SparseTimeValueModel(sv_samplerate_t sampleRate, int resolution,
85 bool notifyOnAdd = true) : 85 bool notifyOnAdd = true) :
86 SparseValueModel<TimeValuePoint>(sampleRate, resolution, 86 SparseValueModel<TimeValuePoint>(sampleRate, resolution,
87 notifyOnAdd) 87 notifyOnAdd)
88 { 88 {
89 // Model is playable, but may not sound (if units not Hz or 89 // Model is playable, but may not sound (if units not Hz or
90 // range unsuitable) 90 // range unsuitable)
91 PlayParameterRepository::getInstance()->addPlayable(this); 91 PlayParameterRepository::getInstance()->addPlayable(this);
92 } 92 }
93 93
94 SparseTimeValueModel(sv_samplerate_t sampleRate, int resolution, 94 SparseTimeValueModel(sv_samplerate_t sampleRate, int resolution,
95 float valueMinimum, float valueMaximum, 95 float valueMinimum, float valueMaximum,
96 bool notifyOnAdd = true) : 96 bool notifyOnAdd = true) :
97 SparseValueModel<TimeValuePoint>(sampleRate, resolution, 97 SparseValueModel<TimeValuePoint>(sampleRate, resolution,
98 valueMinimum, valueMaximum, 98 valueMinimum, valueMaximum,
99 notifyOnAdd) 99 notifyOnAdd)
100 { 100 {
101 // Model is playable, but may not sound (if units not Hz or 101 // Model is playable, but may not sound (if units not Hz or
102 // range unsuitable) 102 // range unsuitable)
103 PlayParameterRepository::getInstance()->addPlayable(this); 103 PlayParameterRepository::getInstance()->addPlayable(this);
104 } 104 }
105 105
106 virtual ~SparseTimeValueModel() 106 virtual ~SparseTimeValueModel()
107 { 107 {
108 PlayParameterRepository::getInstance()->removePlayable(this); 108 PlayParameterRepository::getInstance()->removePlayable(this);
109 } 109 }
110 110
111 QString getTypeName() const { return tr("Sparse Time-Value"); } 111 QString getTypeName() const { return tr("Sparse Time-Value"); }
112 112
113 virtual bool canPlay() const { return true; } 113 virtual bool canPlay() const { return true; }