comparison data/model/AggregateWaveModel.cpp @ 1766:85b9b466a59f

Merge from branch by-id
author Chris Cannam
date Wed, 17 Jul 2019 14:24:51 +0100
parents 87b4c596c0ef
children dffc70996f54
comparison
equal deleted inserted replaced
1730:649ac57c5a2d 1766:85b9b466a59f
25 25
26 PowerOfSqrtTwoZoomConstraint 26 PowerOfSqrtTwoZoomConstraint
27 AggregateWaveModel::m_zoomConstraint; 27 AggregateWaveModel::m_zoomConstraint;
28 28
29 AggregateWaveModel::AggregateWaveModel(ChannelSpecList channelSpecs) : 29 AggregateWaveModel::AggregateWaveModel(ChannelSpecList channelSpecs) :
30 m_components(channelSpecs), 30 m_components(channelSpecs)
31 m_invalidated(false) 31 {
32 { 32 sv_samplerate_t overallRate = 0;
33 for (ChannelSpecList::const_iterator i = channelSpecs.begin(); 33
34 i != channelSpecs.end(); ++i) { 34 for (int channel = 0; in_range_for(m_components, channel); ++channel) {
35 35
36 connect(i->model, SIGNAL(aboutToBeDeleted()), 36 auto model = ModelById::getAs<RangeSummarisableTimeValueModel>
37 this, SLOT(componentModelAboutToBeDeleted())); 37 (m_components[channel].model);
38 38
39 if (i->model->getSampleRate() != 39 if (!model) {
40 channelSpecs.begin()->model->getSampleRate()) { 40 SVCERR << "AggregateWaveModel: WARNING: component for channel "
41 SVDEBUG << "AggregateWaveModel::AggregateWaveModel: WARNING: Component models do not all have the same sample rate" << endl; 41 << channel << " is not found or is of wrong model type"
42 break; 42 << endl;
43 continue;
44 }
45
46 sv_samplerate_t rate = model->getSampleRate();
47
48 if (!rate) {
49 SVCERR << "AggregateWaveModel: WARNING: component for channel "
50 << channel << " reports zero sample rate" << endl;
51
52 } else if (!overallRate) {
53
54 overallRate = rate;
55
56 } else if (rate != overallRate) {
57 SVCERR << "AggregateWaveModel: WARNING: component for channel "
58 << channel << " has different sample rate from earlier "
59 << "channels (has " << rate << ", expected " << overallRate
60 << ")" << endl;
43 } 61 }
44 } 62 }
45 } 63 }
46 64
47 AggregateWaveModel::~AggregateWaveModel() 65 AggregateWaveModel::~AggregateWaveModel()
48 { 66 {
49 SVDEBUG << "AggregateWaveModel::~AggregateWaveModel" << endl; 67 SVDEBUG << "AggregateWaveModel::~AggregateWaveModel" << endl;
50 }
51
52 void
53 AggregateWaveModel::componentModelAboutToBeDeleted()
54 {
55 SVDEBUG << "AggregateWaveModel::componentModelAboutToBeDeleted: invalidating"
56 << endl;
57 m_components.clear();
58 m_invalidated = true;
59 emit modelInvalidated();
60 } 68 }
61 69
62 bool 70 bool
63 AggregateWaveModel::isOK() const 71 AggregateWaveModel::isOK() const
64 { 72 {
65 if (m_invalidated || m_components.empty()) { 73 if (m_components.empty()) {
66 return false; 74 return false;
67 } 75 }
68 for (ChannelSpecList::const_iterator i = m_components.begin(); 76 for (const auto &c: m_components) {
69 i != m_components.end(); ++i) { 77 auto model = ModelById::get(c.model);
70 if (!i->model->isOK()) { 78 if (!model || !model->isOK()) {
71 return false; 79 return false;
72 } 80 }
73 } 81 }
74 return true; 82 return true;
75 } 83 }
78 AggregateWaveModel::isReady(int *completion) const 86 AggregateWaveModel::isReady(int *completion) const
79 { 87 {
80 if (completion) *completion = 100; 88 if (completion) *completion = 100;
81 89
82 bool ready = true; 90 bool ready = true;
83 for (ChannelSpecList::const_iterator i = m_components.begin(); 91 for (auto c: m_components) {
84 i != m_components.end(); ++i) {
85 int completionHere = 100; 92 int completionHere = 100;
86 if (!i->model->isReady(&completionHere)) { 93 auto model = ModelById::get(c.model);
94 if (!model) continue;
95 if (!model->isReady(&completionHere)) {
87 ready = false; 96 ready = false;
88 } 97 }
89 if (completion && completionHere < *completion) { 98 if (completion && completionHere < *completion) {
90 *completion = completionHere; 99 *completion = completionHere;
91 } 100 }
101 110
102 sv_frame_t 111 sv_frame_t
103 AggregateWaveModel::getFrameCount() const 112 AggregateWaveModel::getFrameCount() const
104 { 113 {
105 sv_frame_t count = 0; 114 sv_frame_t count = 0;
106 for (ChannelSpecList::const_iterator i = m_components.begin(); 115 for (auto c: m_components) {
107 i != m_components.end(); ++i) { 116 auto model = ModelById::get(c.model);
108 sv_frame_t thisCount = 117 if (!model) continue;
109 i->model->getEndFrame() - i->model->getStartFrame(); 118 sv_frame_t thisCount = model->getEndFrame() - model->getStartFrame();
110 if (thisCount > count) count = thisCount; 119 if (thisCount > count) count = thisCount;
111 } 120 }
112 return count; 121 return count;
113 } 122 }
114 123
119 } 128 }
120 129
121 sv_samplerate_t 130 sv_samplerate_t
122 AggregateWaveModel::getSampleRate() const 131 AggregateWaveModel::getSampleRate() const
123 { 132 {
124 if (m_invalidated || m_components.empty()) return 0; 133 if (m_components.empty()) return 0;
125 return m_components.begin()->model->getSampleRate(); 134 auto model = ModelById::get(m_components.begin()->model);
135 if (!model) return 0;
136 return model->getSampleRate();
126 } 137 }
127 138
128 floatvec_t 139 floatvec_t
129 AggregateWaveModel::getData(int channel, sv_frame_t start, sv_frame_t count) const 140 AggregateWaveModel::getData(int channel, sv_frame_t start, sv_frame_t count) const
130 { 141 {
131 if (m_invalidated || m_components.empty()) return {}; 142 if (m_components.empty()) return {};
132 143
133 int ch0 = channel, ch1 = channel; 144 int ch0 = channel, ch1 = channel;
134 if (channel == -1) { 145 if (channel == -1) {
135 ch0 = 0; 146 ch0 = 0;
136 ch1 = getChannelCount()-1; 147 ch1 = getChannelCount()-1;
148 } else if (!in_range_for(m_components, channel)) {
149 return {};
137 } 150 }
138 151
139 floatvec_t result(count, 0.f); 152 floatvec_t result(count, 0.f);
140 sv_frame_t longest = 0; 153 sv_frame_t longest = 0;
141 154
142 for (int c = ch0; c <= ch1; ++c) { 155 for (int c = ch0; c <= ch1; ++c) {
143 156
144 auto here = m_components[c].model->getData(m_components[c].channel, 157 auto model = ModelById::getAs<RangeSummarisableTimeValueModel>
145 start, count); 158 (m_components[c].model);
159 if (!model) continue;
160
161 auto here = model->getData(m_components[c].channel, start, count);
146 if (sv_frame_t(here.size()) > longest) { 162 if (sv_frame_t(here.size()) > longest) {
147 longest = sv_frame_t(here.size()); 163 longest = sv_frame_t(here.size());
148 } 164 }
149 for (sv_frame_t i = 0; in_range_for(here, i); ++i) { 165 for (sv_frame_t i = 0; in_range_for(here, i); ++i) {
150 result[i] += here[i]; 166 result[i] += here[i];
234 QString indent, 250 QString indent,
235 QString extraAttributes) const 251 QString extraAttributes) const
236 { 252 {
237 QStringList componentStrings; 253 QStringList componentStrings;
238 for (const auto &c: m_components) { 254 for (const auto &c: m_components) {
239 componentStrings.push_back(QString("%1").arg(c.model->getExportId())); 255 auto model = ModelById::get(c.model);
256 if (!model) continue;
257 componentStrings.push_back(QString("%1").arg(model->getExportId()));
240 } 258 }
241 Model::toXml(out, indent, 259 Model::toXml(out, indent,
242 QString("type=\"aggregatewave\" components=\"%1\" %2") 260 QString("type=\"aggregatewave\" components=\"%1\" %2")
243 .arg(componentStrings.join(",")) 261 .arg(componentStrings.join(","))
244 .arg(extraAttributes)); 262 .arg(extraAttributes));