Mercurial > hg > svcore
view data/model/DenseTimeValueModel.h @ 335:02d2ad95ea52 spectrogram-cache-rejig
* Get storage advice for each cache in an FFT data server. Allows us to be
more confident about the actual memory situation and cut over from memory
to disc part way through an FFT calculation if necessary. StorageAdviser
is now a bit too optimistic though (it's too keen to allocate large numbers
of small blocks in memory).
author | Chris Cannam |
---|---|
date | Tue, 13 Nov 2007 13:54:10 +0000 |
parents | 5877d68815c7 |
children | 700cd3350391 6f6ab834449d |
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ /* Sonic Visualiser An audio file viewer and annotation editor. Centre for Digital Music, Queen Mary, University of London. This file copyright 2006 Chris Cannam. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. See the file COPYING included with this distribution for more information. */ #ifndef _DENSE_TIME_VALUE_MODEL_H_ #define _DENSE_TIME_VALUE_MODEL_H_ #include <QObject> #include "Model.h" /** * Base class for models containing dense two-dimensional data (value * against time). For example, audio waveform data. */ class DenseTimeValueModel : public Model { Q_OBJECT public: DenseTimeValueModel(); /** * Return the minimum possible value found in this model type. * (That is, the minimum that would be valid, not the minimum * actually found in a particular model). */ virtual float getValueMinimum() const = 0; /** * Return the minimum possible value found in this model type. * (That is, the minimum that would be valid, not the minimum * actually found in a particular model). */ virtual float getValueMaximum() const = 0; /** * Return the number of distinct channels for this model. */ virtual size_t getChannelCount() const = 0; /** * Get the specified set of samples from the given channel of the * model in single-precision floating-point format. Return the * number of samples actually retrieved. * If the channel is given as -1, mix all available channels and * return the result. */ virtual size_t getData(int channel, size_t start, size_t count, float *buffer) const = 0; /** * Get the specified set of samples from the given channel of the * model in double-precision floating-point format. Return the * number of samples actually retrieved. * If the channel is given as -1, mix all available channels and * return the result. */ virtual size_t getData(int channel, size_t start, size_t count, double *buffer) const = 0; }; #endif