annotate data/model/SparseOneDimensionalModel.h @ 282:d9319859a4cf tip

(none)
author benoitrigolleau
date Fri, 31 Oct 2008 11:00:24 +0000
parents fc9323a41f5a
children
rev   line source
lbajardsilogic@0 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
lbajardsilogic@0 2
lbajardsilogic@0 3 /*
lbajardsilogic@0 4 Sonic Visualiser
lbajardsilogic@0 5 An audio file viewer and annotation editor.
lbajardsilogic@0 6 Centre for Digital Music, Queen Mary, University of London.
lbajardsilogic@0 7 This file copyright 2006 Chris Cannam.
lbajardsilogic@0 8
lbajardsilogic@0 9 This program is free software; you can redistribute it and/or
lbajardsilogic@0 10 modify it under the terms of the GNU General Public License as
lbajardsilogic@0 11 published by the Free Software Foundation; either version 2 of the
lbajardsilogic@0 12 License, or (at your option) any later version. See the file
lbajardsilogic@0 13 COPYING included with this distribution for more information.
lbajardsilogic@0 14 */
lbajardsilogic@0 15
lbajardsilogic@0 16 #ifndef _SPARSE_ONE_DIMENSIONAL_MODEL_H_
lbajardsilogic@0 17 #define _SPARSE_ONE_DIMENSIONAL_MODEL_H_
lbajardsilogic@0 18
lbajardsilogic@0 19 #include "SparseModel.h"
lbajardsilogic@0 20 #include "base/PlayParameterRepository.h"
lbajardsilogic@0 21 #include "base/RealTime.h"
lbajardsilogic@0 22
lbajardsilogic@0 23 struct OneDimensionalPoint
lbajardsilogic@0 24 {
lbajardsilogic@0 25 public:
lbajardsilogic@0 26 OneDimensionalPoint(long _frame) : frame(_frame) { }
lbajardsilogic@0 27 OneDimensionalPoint(long _frame, QString _label) : frame(_frame), label(_label) { }
lbajardsilogic@0 28
lbajardsilogic@0 29 int getDimensions() const { return 1; }
lbajardsilogic@0 30
lbajardsilogic@0 31 long frame;
lbajardsilogic@0 32 QString label;
lbajardsilogic@0 33
lbajardsilogic@0 34 QString toXmlString(QString indent = "",
lbajardsilogic@0 35 QString extraAttributes = "") const
lbajardsilogic@0 36 {
lbajardsilogic@0 37 return QString("%1<point frame=\"%2\" label=\"%3\" %4/>\n")
lbajardsilogic@0 38 .arg(indent).arg(frame).arg(label).arg(extraAttributes);
lbajardsilogic@0 39 }
lbajardsilogic@0 40
lbajardsilogic@0 41 QString toDelimitedDataString(QString delimiter, size_t sampleRate) const
lbajardsilogic@0 42 {
lbajardsilogic@0 43 QStringList list;
lbajardsilogic@0 44 list << RealTime::frame2RealTime(frame, sampleRate).toString().c_str();
lbajardsilogic@0 45 list << label;
lbajardsilogic@0 46 return list.join(delimiter);
lbajardsilogic@0 47 }
lbajardsilogic@0 48
lbajardsilogic@0 49 struct Comparator {
lbajardsilogic@0 50 bool operator()(const OneDimensionalPoint &p1,
lbajardsilogic@0 51 const OneDimensionalPoint &p2) const {
lbajardsilogic@0 52 if (p1.frame != p2.frame) return p1.frame < p2.frame;
lbajardsilogic@0 53 return p1.label < p2.label;
lbajardsilogic@0 54 }
lbajardsilogic@0 55 };
lbajardsilogic@0 56
lbajardsilogic@0 57 struct OrderComparator {
lbajardsilogic@0 58 bool operator()(const OneDimensionalPoint &p1,
lbajardsilogic@0 59 const OneDimensionalPoint &p2) const {
lbajardsilogic@0 60 return p1.frame < p2.frame;
lbajardsilogic@0 61 }
lbajardsilogic@0 62 };
lbajardsilogic@0 63 };
lbajardsilogic@0 64
lbajardsilogic@0 65
lbajardsilogic@0 66 class SparseOneDimensionalModel : public SparseModel<OneDimensionalPoint>
lbajardsilogic@0 67 {
lbajardsilogic@0 68 public:
lbajardsilogic@0 69 SparseOneDimensionalModel(size_t sampleRate, size_t resolution,
lbajardsilogic@0 70 bool notifyOnAdd = true) :
lbajardsilogic@0 71 SparseModel<OneDimensionalPoint>(sampleRate, resolution, notifyOnAdd)
lbajardsilogic@0 72 {
lbajardsilogic@0 73 PlayParameterRepository::getInstance()->addModel(this);
lbajardsilogic@0 74 }
lbajardsilogic@0 75
lbajardsilogic@0 76 int getIndexOf(const Point &point) {
lbajardsilogic@0 77 // slow
lbajardsilogic@0 78 int i = 0;
lbajardsilogic@0 79 Point::Comparator comparator;
lbajardsilogic@0 80 for (PointList::const_iterator j = m_points.begin();
lbajardsilogic@0 81 j != m_points.end(); ++j, ++i) {
lbajardsilogic@0 82 if (!comparator(*j, point) && !comparator(point, *j)) return i;
lbajardsilogic@0 83 }
lbajardsilogic@0 84 return -1;
lbajardsilogic@0 85 }
lbajardsilogic@0 86 };
lbajardsilogic@0 87
lbajardsilogic@0 88 #endif
lbajardsilogic@0 89
lbajardsilogic@0 90
lbajardsilogic@0 91