annotate data/model/EditableDenseThreeDimensionalModel.h @ 1651:7a56bb85030f single-point

Introduce deferred notifier, + start converting sparse time-value model (perhaps we should rename it too)
author Chris Cannam
date Mon, 18 Mar 2019 14:17:20 +0000
parents ad5f892c0c4d
children 0d89abd631ac
rev   line source
Chris@152 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@152 2
Chris@152 3 /*
Chris@152 4 Sonic Visualiser
Chris@152 5 An audio file viewer and annotation editor.
Chris@152 6 Centre for Digital Music, Queen Mary, University of London.
Chris@202 7 This file copyright 2006 Chris Cannam and QMUL.
Chris@152 8
Chris@152 9 This program is free software; you can redistribute it and/or
Chris@152 10 modify it under the terms of the GNU General Public License as
Chris@152 11 published by the Free Software Foundation; either version 2 of the
Chris@152 12 License, or (at your option) any later version. See the file
Chris@152 13 COPYING included with this distribution for more information.
Chris@152 14 */
Chris@152 15
Chris@1581 16 #ifndef SV_EDITABLE_DENSE_THREE_DIMENSIONAL_MODEL_H
Chris@1581 17 #define SV_EDITABLE_DENSE_THREE_DIMENSIONAL_MODEL_H
Chris@152 18
Chris@152 19 #include "DenseThreeDimensionalModel.h"
Chris@152 20
Chris@536 21 #include <QReadWriteLock>
Chris@536 22
Chris@533 23 #include <vector>
Chris@533 24
Chris@152 25 class EditableDenseThreeDimensionalModel : public DenseThreeDimensionalModel
Chris@152 26 {
Chris@152 27 Q_OBJECT
Chris@152 28
Chris@152 29 public:
Chris@535 30
Chris@535 31 // EditableDenseThreeDimensionalModel supports a basic compression
Chris@535 32 // method that reduces the size of multirate data (e.g. wavelet
Chris@535 33 // transform outputs) that are stored as plain 3d grids by about
Chris@535 34 // 60% or thereabouts. However, it can only be used for models
Chris@535 35 // whose columns are set in order from 0 and never subsequently
Chris@535 36 // changed. If the model is going to be actually edited, it must
Chris@535 37 // have NoCompression.
Chris@535 38
Chris@535 39 enum CompressionType
Chris@535 40 {
Chris@535 41 NoCompression,
Chris@535 42 BasicMultirateCompression
Chris@535 43 };
Chris@535 44
Chris@1040 45 EditableDenseThreeDimensionalModel(sv_samplerate_t sampleRate,
Chris@1429 46 int resolution,
Chris@1429 47 int height,
Chris@535 48 CompressionType compression,
Chris@1429 49 bool notifyOnAdd = true);
Chris@152 50
Chris@1580 51 bool isOK() const override;
Chris@152 52
Chris@1580 53 sv_samplerate_t getSampleRate() const override;
Chris@1580 54 sv_frame_t getStartFrame() const override;
Chris@1580 55 sv_frame_t getEndFrame() const override;
Chris@152 56
Chris@152 57 /**
Chris@611 58 * Set the frame offset of the first column.
Chris@611 59 */
Chris@1038 60 virtual void setStartFrame(sv_frame_t);
Chris@611 61
Chris@611 62 /**
Chris@152 63 * Return the number of sample frames covered by each set of bins.
Chris@152 64 */
Chris@1580 65 int getResolution() const override;
Chris@152 66
Chris@152 67 /**
Chris@152 68 * Set the number of sample frames covered by each set of bins.
Chris@152 69 */
Chris@929 70 virtual void setResolution(int sz);
Chris@152 71
Chris@152 72 /**
Chris@182 73 * Return the number of columns.
Chris@182 74 */
Chris@1580 75 int getWidth() const override;
Chris@182 76
Chris@182 77 /**
Chris@1252 78 * Return the number of bins in each column.
Chris@152 79 */
Chris@1580 80 int getHeight() const override;
Chris@152 81
Chris@152 82 /**
Chris@1252 83 * Set the number of bins in each column.
Chris@1252 84 *
Chris@1252 85 * You can set (via setColumn) a vector of any length as a column,
Chris@1252 86 * but any column being retrieved will be resized to this height
Chris@1252 87 * (or the height that was supplied to the constructor, if this is
Chris@1252 88 * never called) on retrieval. That is, the model owner determines
Chris@1252 89 * the height of the model at a single stroke; the columns
Chris@1252 90 * themselves don't have any effect on the height of the model.
Chris@152 91 */
Chris@929 92 virtual void setHeight(int sz);
Chris@152 93
Chris@152 94 /**
Chris@152 95 * Return the minimum value of the value in each bin.
Chris@152 96 */
Chris@1580 97 float getMinimumLevel() const override;
Chris@152 98
Chris@152 99 /**
Chris@152 100 * Set the minimum value of the value in a bin.
Chris@152 101 */
Chris@152 102 virtual void setMinimumLevel(float sz);
Chris@152 103
Chris@152 104 /**
Chris@152 105 * Return the maximum value of the value in each bin.
Chris@152 106 */
Chris@1580 107 float getMaximumLevel() const override;
Chris@152 108
Chris@152 109 /**
Chris@152 110 * Set the maximum value of the value in a bin.
Chris@152 111 */
Chris@152 112 virtual void setMaximumLevel(float sz);
Chris@152 113
Chris@182 114 /**
Chris@182 115 * Get the set of bin values at the given column.
Chris@152 116 */
Chris@1580 117 Column getColumn(int x) const override;
Chris@152 118
Chris@152 119 /**
Chris@182 120 * Get a single value, from the n'th bin of the given column.
Chris@152 121 */
Chris@1580 122 float getValueAt(int x, int n) const override;
Chris@152 123
Chris@152 124 /**
Chris@182 125 * Set the entire set of bin values at the given column.
Chris@152 126 */
Chris@929 127 virtual void setColumn(int x, const Column &values);
Chris@152 128
Chris@881 129 /**
Chris@881 130 * Return the name of bin n. This is a single label per bin that
Chris@881 131 * does not vary from one column to the next.
Chris@881 132 */
Chris@1580 133 QString getBinName(int n) const override;
Chris@881 134
Chris@881 135 /**
Chris@881 136 * Set the name of bin n.
Chris@881 137 */
Chris@929 138 virtual void setBinName(int n, QString);
Chris@881 139
Chris@881 140 /**
Chris@881 141 * Set the names of all bins.
Chris@881 142 */
Chris@152 143 virtual void setBinNames(std::vector<QString> names);
Chris@152 144
Chris@881 145 /**
Chris@886 146 * Return true if the bins have values as well as names. (The
Chris@886 147 * values may have been derived from the names, e.g. by parsing
Chris@886 148 * numbers from them.) If this returns true, getBinValue() may be
Chris@886 149 * used to retrieve the values.
Chris@886 150 */
Chris@1580 151 bool hasBinValues() const override;
Chris@886 152
Chris@886 153 /**
Chris@886 154 * Return the value of bin n, if any. This is a "vertical scale"
Chris@886 155 * value which does not vary from one column to the next. This is
Chris@886 156 * only meaningful if hasBinValues() returns true.
Chris@886 157 */
Chris@1580 158 float getBinValue(int n) const override;
Chris@886 159
Chris@886 160 /**
Chris@886 161 * Set the values of all bins (separate from their labels). These
Chris@886 162 * are "vertical scale" values which do not vary from one column
Chris@886 163 * to the next.
Chris@886 164 */
Chris@886 165 virtual void setBinValues(std::vector<float> values);
Chris@886 166
Chris@886 167 /**
Chris@886 168 * Obtain the name of the unit of the values returned from
Chris@886 169 * getBinValue(), if any.
Chris@886 170 */
Chris@1580 171 QString getBinValueUnit() const override;
Chris@886 172
Chris@886 173 /**
Chris@886 174 * Set the name of the unit of the values return from
Chris@886 175 * getBinValue() if any.
Chris@886 176 */
Chris@886 177 virtual void setBinValueUnit(QString unit);
Chris@886 178
Chris@886 179 /**
Chris@881 180 * Return true if the distribution of values in the bins is such
Chris@881 181 * as to suggest a log scale (mapping to colour etc) may be better
Chris@881 182 * than a linear one.
Chris@881 183 */
Chris@1580 184 bool shouldUseLogValueScale() const override;
Chris@478 185
Chris@333 186 virtual void setCompletion(int completion, bool update = true);
Chris@1580 187 int getCompletion() const override { return m_completion; }
Chris@152 188
Chris@1580 189 QString getTypeName() const override { return tr("Editable Dense 3-D"); }
Chris@345 190
Chris@1580 191 QString toDelimitedDataString(QString delimiter) const override;
Chris@1580 192 QString toDelimitedDataStringSubset(QString delimiter, sv_frame_t f0, sv_frame_t f1) const override;
Chris@318 193
Chris@1580 194 void toXml(QTextStream &out,
Chris@152 195 QString indent = "",
Chris@1580 196 QString extraAttributes = "") const override;
Chris@152 197
Chris@152 198 protected:
Chris@1154 199 typedef std::vector<Column> ValueMatrix;
Chris@152 200 ValueMatrix m_data;
Chris@152 201
Chris@535 202 // m_trunc is used for simple compression. If at least the top N
Chris@535 203 // elements of column x (for N = some proportion of the column
Chris@535 204 // height) are equal to those of an earlier column x', then
Chris@535 205 // m_trunc[x] will contain x-x' and column x will be truncated so
Chris@535 206 // as to remove the duplicate elements. If the equal elements are
Chris@535 207 // at the bottom, then m_trunc[x] will contain x'-x (a negative
Chris@535 208 // value). If m_trunc[x] is 0 then the whole of column x is
Chris@535 209 // stored.
Chris@535 210 std::vector<signed char> m_trunc;
Chris@929 211 void truncateAndStore(int index, const Column & values);
Chris@929 212 Column expandAndRetrieve(int index) const;
Chris@1252 213 Column rightHeight(const Column &c) const;
Chris@534 214
Chris@152 215 std::vector<QString> m_binNames;
Chris@886 216 std::vector<float> m_binValues;
Chris@886 217 QString m_binValueUnit;
Chris@152 218
Chris@1038 219 sv_frame_t m_startFrame;
Chris@1040 220 sv_samplerate_t m_sampleRate;
Chris@929 221 int m_resolution;
Chris@929 222 int m_yBinCount;
Chris@535 223 CompressionType m_compression;
Chris@152 224 float m_minimum;
Chris@152 225 float m_maximum;
Chris@256 226 bool m_haveExtents;
Chris@152 227 bool m_notifyOnAdd;
Chris@1110 228 sv_frame_t m_sinceLastNotifyMin;
Chris@1110 229 sv_frame_t m_sinceLastNotifyMax;
Chris@152 230 int m_completion;
Chris@152 231
Chris@536 232 mutable QReadWriteLock m_lock;
Chris@152 233 };
Chris@152 234
Chris@152 235 #endif