comparison data/model/EditableDenseThreeDimensionalModel.cpp @ 1450:a12fd0456f0c streaming-csv-writer

Merge from default branch
author Chris Cannam
date Tue, 17 Apr 2018 10:35:42 +0100
parents 48e9f538e6e9
children f97d64b8674f
comparison
equal deleted inserted replaced
1449:deabf9fd3d28 1450:a12fd0456f0c
319 const Column &values) 319 const Column &values)
320 { 320 {
321 QWriteLocker locker(&m_lock); 321 QWriteLocker locker(&m_lock);
322 322
323 while (index >= int(m_data.size())) { 323 while (index >= int(m_data.size())) {
324 m_data.push_back(Column()); 324 m_data.push_back(Column());
325 m_trunc.push_back(0); 325 m_trunc.push_back(0);
326 } 326 }
327 327
328 bool allChange = false; 328 bool allChange = false;
329 329
330 for (int i = 0; in_range_for(values, i); ++i) { 330 for (int i = 0; in_range_for(values, i); ++i) {
331 float value = values[i]; 331 float value = values[i];
332 if (ISNAN(value) || ISINF(value)) { 332 if (ISNAN(value) || ISINF(value)) {
333 continue; 333 continue;
334 } 334 }
335 if (!m_haveExtents || value < m_minimum) { 335 if (!m_haveExtents || value < m_minimum) {
336 m_minimum = value; 336 m_minimum = value;
337 allChange = true; 337 allChange = true;
338 } 338 }
339 if (!m_haveExtents || value > m_maximum) { 339 if (!m_haveExtents || value > m_maximum) {
340 m_maximum = value; 340 m_maximum = value;
341 allChange = true; 341 allChange = true;
342 } 342 }
343 m_haveExtents = true; 343 m_haveExtents = true;
344 } 344 }
345 345
346 truncateAndStore(index, values); 346 truncateAndStore(index, values);
347 347
349 349
350 sv_frame_t windowStart = index; 350 sv_frame_t windowStart = index;
351 windowStart *= m_resolution; 351 windowStart *= m_resolution;
352 352
353 if (m_notifyOnAdd) { 353 if (m_notifyOnAdd) {
354 if (allChange) { 354 if (allChange) {
355 emit modelChanged(); 355 emit modelChanged();
356 } else { 356 } else {
357 emit modelChangedWithin(windowStart, windowStart + m_resolution); 357 emit modelChangedWithin(windowStart, windowStart + m_resolution);
358 } 358 }
359 } else { 359 } else {
360 if (allChange) { 360 if (allChange) {
361 m_sinceLastNotifyMin = -1; 361 m_sinceLastNotifyMin = -1;
362 m_sinceLastNotifyMax = -1; 362 m_sinceLastNotifyMax = -1;
363 emit modelChanged(); 363 emit modelChanged();
364 } else { 364 } else {
365 if (m_sinceLastNotifyMin == -1 || 365 if (m_sinceLastNotifyMin == -1 ||
366 windowStart < m_sinceLastNotifyMin) { 366 windowStart < m_sinceLastNotifyMin) {
367 m_sinceLastNotifyMin = windowStart; 367 m_sinceLastNotifyMin = windowStart;
368 } 368 }
369 if (m_sinceLastNotifyMax == -1 || 369 if (m_sinceLastNotifyMax == -1 ||
370 windowStart > m_sinceLastNotifyMax) { 370 windowStart > m_sinceLastNotifyMax) {
371 m_sinceLastNotifyMax = windowStart; 371 m_sinceLastNotifyMax = windowStart;
372 } 372 }
373 } 373 }
374 } 374 }
375 } 375 }
376 376
377 QString 377 QString
378 EditableDenseThreeDimensionalModel::getBinName(int n) const 378 EditableDenseThreeDimensionalModel::getBinName(int n) const
460 460
461 void 461 void
462 EditableDenseThreeDimensionalModel::setCompletion(int completion, bool update) 462 EditableDenseThreeDimensionalModel::setCompletion(int completion, bool update)
463 { 463 {
464 if (m_completion != completion) { 464 if (m_completion != completion) {
465 m_completion = completion; 465 m_completion = completion;
466 466
467 if (completion == 100) { 467 if (completion == 100) {
468 468
469 m_notifyOnAdd = true; // henceforth 469 m_notifyOnAdd = true; // henceforth
470 emit modelChanged(); 470 emit modelChanged();
471 471
472 } else if (!m_notifyOnAdd) { 472 } else if (!m_notifyOnAdd) {
473 473
474 if (update && 474 if (update &&
475 m_sinceLastNotifyMin >= 0 && 475 m_sinceLastNotifyMin >= 0 &&
476 m_sinceLastNotifyMax >= 0) { 476 m_sinceLastNotifyMax >= 0) {
477 emit modelChangedWithin(m_sinceLastNotifyMin, 477 emit modelChangedWithin(m_sinceLastNotifyMin,
478 m_sinceLastNotifyMax + m_resolution); 478 m_sinceLastNotifyMax + m_resolution);
479 m_sinceLastNotifyMin = m_sinceLastNotifyMax = -1; 479 m_sinceLastNotifyMin = m_sinceLastNotifyMax = -1;
480 } else { 480 } else {
481 emit completionChanged(); 481 emit completionChanged();
482 } 482 }
483 } else { 483 } else {
484 emit completionChanged(); 484 emit completionChanged();
485 } 485 }
486 } 486 }
487 } 487 }
488 488
489 QString 489 QString
490 EditableDenseThreeDimensionalModel::toDelimitedDataString(QString delimiter) const 490 EditableDenseThreeDimensionalModel::toDelimitedDataString(QString delimiter) const
491 { 491 {
492 QReadLocker locker(&m_lock); 492 QReadLocker locker(&m_lock);
493 QString s; 493 QString s;
494 for (int i = 0; in_range_for(m_data, i); ++i) { 494 for (int i = 0; in_range_for(m_data, i); ++i) {
495 QStringList list; 495 QStringList list;
496 for (int j = 0; in_range_for(m_data.at(i), j); ++j) { 496 for (int j = 0; in_range_for(m_data.at(i), j); ++j) {
497 list << QString("%1").arg(m_data.at(i).at(j)); 497 list << QString("%1").arg(m_data.at(i).at(j));
498 } 498 }
499 s += list.join(delimiter) + "\n"; 499 s += list.join(delimiter) + "\n";
500 } 500 }
501 return s; 501 return s;
529 // For historical reasons we read and write "resolution" as "windowSize" 529 // For historical reasons we read and write "resolution" as "windowSize"
530 530
531 SVDEBUG << "EditableDenseThreeDimensionalModel::toXml" << endl; 531 SVDEBUG << "EditableDenseThreeDimensionalModel::toXml" << endl;
532 532
533 Model::toXml 533 Model::toXml
534 (out, indent, 534 (out, indent,
535 QString("type=\"dense\" dimensions=\"3\" windowSize=\"%1\" yBinCount=\"%2\" minimum=\"%3\" maximum=\"%4\" dataset=\"%5\" startFrame=\"%6\" %7") 535 QString("type=\"dense\" dimensions=\"3\" windowSize=\"%1\" yBinCount=\"%2\" minimum=\"%3\" maximum=\"%4\" dataset=\"%5\" startFrame=\"%6\" %7")
536 .arg(m_resolution) 536 .arg(m_resolution)
537 .arg(m_yBinCount) 537 .arg(m_yBinCount)
538 .arg(m_minimum) 538 .arg(m_minimum)
539 .arg(m_maximum) 539 .arg(m_maximum)
540 .arg(getObjectExportId(&m_data)) 540 .arg(getObjectExportId(&m_data))
541 .arg(m_startFrame) 541 .arg(m_startFrame)
542 .arg(extraAttributes)); 542 .arg(extraAttributes));
543 543
544 out << indent; 544 out << indent;
545 out << QString("<dataset id=\"%1\" dimensions=\"3\" separator=\" \">\n") 545 out << QString("<dataset id=\"%1\" dimensions=\"3\" separator=\" \">\n")
546 .arg(getObjectExportId(&m_data)); 546 .arg(getObjectExportId(&m_data));
547 547
548 for (int i = 0; i < (int)m_binNames.size(); ++i) { 548 for (int i = 0; i < (int)m_binNames.size(); ++i) {
549 if (m_binNames[i] != "") { 549 if (m_binNames[i] != "") {
550 out << indent + " "; 550 out << indent + " ";
551 out << QString("<bin number=\"%1\" name=\"%2\"/>\n") 551 out << QString("<bin number=\"%1\" name=\"%2\"/>\n")
552 .arg(i).arg(m_binNames[i]); 552 .arg(i).arg(m_binNames[i]);
553 } 553 }
554 } 554 }
555 555
556 for (int i = 0; i < (int)m_data.size(); ++i) { 556 for (int i = 0; i < (int)m_data.size(); ++i) {
557 out << indent + " "; 557 out << indent + " ";
558 out << QString("<row n=\"%1\">").arg(i); 558 out << QString("<row n=\"%1\">").arg(i);
559 for (int j = 0; j < (int)m_data.at(i).size(); ++j) { 559 for (int j = 0; j < (int)m_data.at(i).size(); ++j) {
560 if (j > 0) out << " "; 560 if (j > 0) out << " ";
561 out << m_data.at(i).at(j); 561 out << m_data.at(i).at(j);
562 } 562 }
563 out << QString("</row>\n"); 563 out << QString("</row>\n");
564 out.flush(); 564 out.flush();
565 } 565 }
566 566
567 out << indent + "</dataset>\n"; 567 out << indent + "</dataset>\n";
568 } 568 }