#include <DenseThreeDimensionalModel.h>

Inheritance diagram for DenseThreeDimensionalModel:
Inheritance graph
Collaboration diagram for DenseThreeDimensionalModel:
Collaboration graph

Public Types

typedef ColumnOp::Column Column
 
typedef Id ModelId
 
typedef TypedId< ModelId
 
enum  { NO_ID = -1 }
 
typedef int ExportId
 
enum  { SortRole = Qt::UserRole }
 
enum  SortType { SortNumeric, SortAlphabetical }
 

Signals

void modelChanged (ModelId myId)
 Emitted when a model has been edited (or more data retrieved from cache, in the case of a cached model that generates slowly) More...
 
void modelChangedWithin (ModelId myId, sv_frame_t startFrame, sv_frame_t endFrame)
 Emitted when a model has been edited (or more data retrieved from cache, in the case of a cached model that generates slowly) More...
 
void completionChanged (ModelId myId)
 Emitted when some internal processing has advanced a stage, but the model has not changed externally. More...
 
void ready (ModelId myId)
 Emitted when internal processing is complete (i.e. More...
 
void alignmentCompletionChanged (ModelId myId)
 Emitted when the completion percentage changes for the calculation of this model's alignment model. More...
 

Public Member Functions

virtual int getResolution () const =0
 Return the number of sample frames covered by each column of bins. More...
 
virtual int getWidth () const =0
 Return the number of columns of bins in the model. More...
 
virtual int getHeight () const =0
 Return the number of bins in each column. More...
 
virtual float getMinimumLevel () const =0
 Return the minimum permissible value in each bin. More...
 
virtual float getMaximumLevel () const =0
 Return the maximum permissible value in each bin. More...
 
virtual Column getColumn (int column) const =0
 Get data from the given column of bin values. More...
 
virtual float getValueAt (int column, int n) const =0
 Get the single data point from the n'th bin of the given column. More...
 
virtual QString getBinName (int n) const =0
 Get the name of a given bin (i.e. More...
 
virtual bool hasBinValues () const
 Return true if the bins have values as well as names. More...
 
virtual float getBinValue (int n) const
 Return the value of bin n, if any. More...
 
virtual QString getBinValueUnit () const
 Obtain the name of the unit of the values returned from getBinValue(), if any. More...
 
virtual bool shouldUseLogValueScale () const =0
 Estimate whether a logarithmic scale might be appropriate for the value scale. More...
 
bool isLocalPeak (int x, int y)
 Utility function to query whether a given bin is greater than its (vertical) neighbours. More...
 
bool isOverThreshold (int x, int y, float threshold)
 Utility function to query whether a given bin is greater than a certain threshold. More...
 
QString getTypeName () const override
 Return the type of the model. More...
 
virtual int getCompletion () const override=0
 Return an estimated percentage value showing how far through any background operation used to calculate or load the model data the model thinks it is. More...
 
int getRowCount () const override
 Return the number of rows (items) in the model. More...
 
int getColumnCount () const override
 Return the number of columns (values/labels/etc per item). More...
 
bool isEditable () const override
 Return true if the model is user-editable, false otherwise. More...
 
CommandgetSetDataCommand (int, int, const QVariant &, int) override
 Return a command to set the value in the given cell, for the given role, to the contents of the supplied variant. More...
 
CommandgetInsertRowCommand (int) override
 Return a command to insert a new row before the row with the given index. More...
 
CommandgetRemoveRowCommand (int) override
 Return a command to delete the row with the given index. More...
 
QString getHeading (int column) const override
 Return the heading for a given column, e.g. More...
 
QVariant getData (int row, int column, int) const override
 Get the value in the given cell, for the given role. More...
 
bool isColumnTimeValue (int col) const override
 Return true if the column is the frame time of the item, or an alternative representation of it (i.e. More...
 
SortType getSortType (int) const override
 Return the sort type (numeric or alphabetical) for the column. More...
 
sv_frame_t getFrameForRow (int row) const override
 Return the frame time for the given row. More...
 
int getRowForFrame (sv_frame_t frame) const override
 Return the number of the first row whose frame time is not less than the given one. More...
 
virtual bool isOK () const =0
 Return true if the model was constructed successfully. More...
 
virtual sv_frame_t getStartFrame () const =0
 Return the first audio frame spanned by the model. More...
 
sv_frame_t getEndFrame () const
 Return the audio frame at the end of the model, i.e. More...
 
virtual sv_frame_t getTrueEndFrame () const =0
 Return the audio frame at the end of the model. More...
 
void extendEndFrame (sv_frame_t to)
 Extend the end of the model. More...
 
virtual sv_samplerate_t getSampleRate () const =0
 Return the frame rate in frames per second. More...
 
virtual sv_samplerate_t getNativeRate () const
 Return the frame rate of the underlying material, if the model itself has already been resampled. More...
 
virtual QString getTitle () const
 Return the "work title" of the model, if known. More...
 
virtual QString getMaker () const
 Return the "artist" or "maker" of the model, if known. More...
 
virtual QString getLocation () const
 Return the location of the data in this model (e.g. More...
 
virtual bool isSparse () const
 Return true if this is a sparse model. More...
 
virtual bool isReady (int *cp=nullptr) const
 Return true if the model has finished loading or calculating all its data, for a model that is capable of calculating in a background thread. More...
 
virtual const ZoomConstraintgetZoomConstraint () const
 If this model imposes a zoom constraint, i.e. More...
 
virtual ModelId getSourceModel () const
 If this model was derived from another, return the id of the model it was derived from. More...
 
virtual void setSourceModel (ModelId model)
 Set the source model for this model. More...
 
virtual void setAlignment (ModelId alignmentModel)
 Specify an alignment between this model's timeline and that of a reference model. More...
 
virtual const ModelId getAlignment () const
 Retrieve the alignment model for this model. More...
 
virtual const ModelId getAlignmentReference () const
 Return the reference model for the current alignment timeline, if any. More...
 
virtual sv_frame_t alignToReference (sv_frame_t frame) const
 Return the frame number of the reference model that corresponds to the given frame number in this model. More...
 
virtual sv_frame_t alignFromReference (sv_frame_t referenceFrame) const
 Return the frame number in this model that corresponds to the given frame number of the reference model. More...
 
virtual int getAlignmentCompletion () const
 Return the completion percentage for the alignment model: 100 if there is no alignment model or it has been entirely calculated, or less than 100 if it is still being calculated. More...
 
void setRDFTypeURI (QString uri)
 Set the event, feature, or signal type URI for the features contained in this model, according to the Audio Features RDF ontology. More...
 
QString getRDFTypeURI () const
 Retrieve the event, feature, or signal type URI for the features contained in this model, if previously set with setRDFTypeURI. More...
 
void toXml (QTextStream &stream, QString indent="", QString extraAttributes="") const override
 Stream this exportable object out to XML on a text stream. More...
 
virtual QVector< QString > getStringExportHeaders (DataExportOptions options) const =0
 Return a label for each column that would be written by toStringExportRows. More...
 
virtual QVector< QVector< QString > > toStringExportRows (DataExportOptions options, sv_frame_t startFrame, sv_frame_t duration) const =0
 Emit events starting within the given range as string rows ready for conversion to an e.g. More...
 
ExportId getExportId () const
 Return the numerical export identifier for this object. More...
 
virtual QString toXmlString (QString indent="", QString extraAttributes="") const
 Convert this exportable object to XML in a string. More...
 
virtual bool canPlay () const
 
virtual QString getDefaultPlayClipId () const
 
virtual bool getDefaultPlayAudible () const
 

Static Public Member Functions

static QString encodeEntities (QString)
 
static QString encodeColour (int r, int g, int b)
 

Protected Member Functions

 DenseThreeDimensionalModel ()
 
Id getId () const
 Return an id for this object. More...
 
int getUntypedId () const
 Return an id for this object. More...
 

Static Protected Member Functions

static QVariant adaptFrameForRole (sv_frame_t frame, sv_samplerate_t rate, int role)
 
static QVariant adaptValueForRole (float value, QString unit, int role)
 

Protected Attributes

QMutex m_mutex
 
ModelId m_sourceModel
 
ModelId m_alignmentModel
 
QString m_typeUri
 
std::atomic< sv_frame_tm_extendTo
 

Detailed Description

Definition at line 28 of file DenseThreeDimensionalModel.h.

Member Typedef Documentation

typedef Id Model::ModelId
inherited

Definition at line 59 of file Model.h.

typedef TypedId<Model > WithTypedId< Model >::Id
inherited

Definition at line 180 of file ById.h.

typedef int XmlExportable::ExportId
inherited

Definition at line 33 of file XmlExportable.h.

Member Enumeration Documentation

anonymous enum
inherited
Enumerator
NO_ID 

Definition at line 28 of file XmlExportable.h.

anonymous enum
inherited
Enumerator
SortRole 

Definition at line 57 of file TabularModel.h.

enum TabularModel::SortType
inherited
Enumerator
SortNumeric 
SortAlphabetical 

Definition at line 58 of file TabularModel.h.

Constructor & Destructor Documentation

DenseThreeDimensionalModel::DenseThreeDimensionalModel ( )
inlineprotected

Definition at line 184 of file DenseThreeDimensionalModel.h.

Member Function Documentation

virtual int DenseThreeDimensionalModel::getResolution ( ) const
pure virtual

Return the number of sample frames covered by each column of bins.

Implemented in FFTModel, BasicCompressedDenseThreeDimensionalModel, Dense3DModelPeakCache, and EditableDenseThreeDimensionalModel.

Referenced by getData(), getFrameForRow(), and getRowForFrame().

virtual int DenseThreeDimensionalModel::getWidth ( ) const
pure virtual

Return the number of columns of bins in the model.

Implemented in BasicCompressedDenseThreeDimensionalModel, Dense3DModelPeakCache, FFTModel, and EditableDenseThreeDimensionalModel.

Referenced by getRowCount().

virtual int DenseThreeDimensionalModel::getHeight ( ) const
pure virtual

Return the number of bins in each column.

Implemented in Dense3DModelPeakCache, BasicCompressedDenseThreeDimensionalModel, EditableDenseThreeDimensionalModel, and FFTModel.

Referenced by getColumnCount(), and isLocalPeak().

virtual float DenseThreeDimensionalModel::getMinimumLevel ( ) const
pure virtual

Return the minimum permissible value in each bin.

Implemented in BasicCompressedDenseThreeDimensionalModel, Dense3DModelPeakCache, FFTModel, and EditableDenseThreeDimensionalModel.

virtual float DenseThreeDimensionalModel::getMaximumLevel ( ) const
pure virtual

Return the maximum permissible value in each bin.

Implemented in BasicCompressedDenseThreeDimensionalModel, EditableDenseThreeDimensionalModel, Dense3DModelPeakCache, and FFTModel.

virtual Column DenseThreeDimensionalModel::getColumn ( int  column) const
pure virtual

Get data from the given column of bin values.

Implemented in BasicCompressedDenseThreeDimensionalModel, EditableDenseThreeDimensionalModel, Dense3DModelPeakCache, and FFTModel.

virtual float DenseThreeDimensionalModel::getValueAt ( int  column,
int  n 
) const
pure virtual

Get the single data point from the n'th bin of the given column.

Implemented in BasicCompressedDenseThreeDimensionalModel, EditableDenseThreeDimensionalModel, Dense3DModelPeakCache, and FFTModel.

Referenced by getData(), isLocalPeak(), and isOverThreshold().

virtual QString DenseThreeDimensionalModel::getBinName ( int  n) const
pure virtual

Get the name of a given bin (i.e.

a label to associate with that bin across all columns).

Implemented in BasicCompressedDenseThreeDimensionalModel, EditableDenseThreeDimensionalModel, Dense3DModelPeakCache, and FFTModel.

Referenced by getHeading().

virtual bool DenseThreeDimensionalModel::hasBinValues ( ) const
inlinevirtual

Return true if the bins have values as well as names.

If this returns true, getBinValue() may be used to retrieve the values.

Reimplemented in BasicCompressedDenseThreeDimensionalModel, EditableDenseThreeDimensionalModel, and FFTModel.

Definition at line 81 of file DenseThreeDimensionalModel.h.

virtual float DenseThreeDimensionalModel::getBinValue ( int  n) const
inlinevirtual

Return the value of bin n, if any.

This is a "vertical scale" value which does not vary from one column to the next. This is only meaningful if hasBinValues() returns true.

Reimplemented in BasicCompressedDenseThreeDimensionalModel, EditableDenseThreeDimensionalModel, and FFTModel.

Definition at line 88 of file DenseThreeDimensionalModel.h.

virtual QString DenseThreeDimensionalModel::getBinValueUnit ( ) const
inlinevirtual

Obtain the name of the unit of the values returned from getBinValue(), if any.

Reimplemented in BasicCompressedDenseThreeDimensionalModel, EditableDenseThreeDimensionalModel, and FFTModel.

Definition at line 94 of file DenseThreeDimensionalModel.h.

References shouldUseLogValueScale().

virtual bool DenseThreeDimensionalModel::shouldUseLogValueScale ( ) const
pure virtual

Estimate whether a logarithmic scale might be appropriate for the value scale.

Implemented in BasicCompressedDenseThreeDimensionalModel, EditableDenseThreeDimensionalModel, Dense3DModelPeakCache, and FFTModel.

Referenced by getBinValueUnit().

bool DenseThreeDimensionalModel::isLocalPeak ( int  x,
int  y 
)
inline

Utility function to query whether a given bin is greater than its (vertical) neighbours.

Definition at line 106 of file DenseThreeDimensionalModel.h.

References getHeight(), and getValueAt().

bool DenseThreeDimensionalModel::isOverThreshold ( int  x,
int  y,
float  threshold 
)
inline

Utility function to query whether a given bin is greater than a certain threshold.

Definition at line 117 of file DenseThreeDimensionalModel.h.

References getValueAt().

QString DenseThreeDimensionalModel::getTypeName ( ) const
inlineoverridevirtual

Return the type of the model.

For display purposes only.

Implements Model.

Reimplemented in EditableDenseThreeDimensionalModel, and FFTModel.

Definition at line 121 of file DenseThreeDimensionalModel.h.

References getCompletion().

virtual int DenseThreeDimensionalModel::getCompletion ( ) const
overridepure virtual

Return an estimated percentage value showing how far through any background operation used to calculate or load the model data the model thinks it is.

Must return 100 when the model is complete.

A model that carries out all its calculation from the constructor or accessor functions might return 0 if isOK() is false and 100 if isOK() is true. Other models may make the return value here depend on the internal completion status.

See also isReady().

Implements Model.

Implemented in Dense3DModelPeakCache, FFTModel, BasicCompressedDenseThreeDimensionalModel, and EditableDenseThreeDimensionalModel.

Referenced by getTypeName().

int DenseThreeDimensionalModel::getRowCount ( ) const
inlineoverridevirtual

Return the number of rows (items) in the model.

Implements TabularModel.

Definition at line 132 of file DenseThreeDimensionalModel.h.

References getWidth().

int DenseThreeDimensionalModel::getColumnCount ( ) const
inlineoverridevirtual

Return the number of columns (values/labels/etc per item).

Implements TabularModel.

Definition at line 133 of file DenseThreeDimensionalModel.h.

References getHeight().

bool DenseThreeDimensionalModel::isEditable ( ) const
inlineoverridevirtual

Return true if the model is user-editable, false otherwise.

Implements TabularModel.

Definition at line 135 of file DenseThreeDimensionalModel.h.

Command* DenseThreeDimensionalModel::getSetDataCommand ( int  row,
int  column,
const QVariant &  ,
int  role 
)
inlineoverridevirtual

Return a command to set the value in the given cell, for the given role, to the contents of the supplied variant.

If the model is not editable or the cell or value is out of range, return nullptr.

Implements TabularModel.

Definition at line 136 of file DenseThreeDimensionalModel.h.

Command* DenseThreeDimensionalModel::getInsertRowCommand ( int  beforeRow)
inlineoverridevirtual

Return a command to insert a new row before the row with the given index.

If the model is not editable or the index is out of range, return nullptr.

Implements TabularModel.

Definition at line 137 of file DenseThreeDimensionalModel.h.

Command* DenseThreeDimensionalModel::getRemoveRowCommand ( int  row)
inlineoverridevirtual

Return a command to delete the row with the given index.

If the model is not editable or the index is out of range, return nullptr.

Implements TabularModel.

Definition at line 138 of file DenseThreeDimensionalModel.h.

QString DenseThreeDimensionalModel::getHeading ( int  column) const
inlineoverridevirtual

Return the heading for a given column, e.g.

"Time" or "Value". These are shown directly to the user, so must be translated already.

Implements TabularModel.

Definition at line 140 of file DenseThreeDimensionalModel.h.

References getBinName().

QVariant DenseThreeDimensionalModel::getData ( int  row,
int  column,
int  role 
) const
inlineoverridevirtual

Get the value in the given cell, for the given role.

The role is actually a Qt::ItemDataRole.

Implements TabularModel.

Definition at line 154 of file DenseThreeDimensionalModel.h.

References RealTime::frame2RealTime(), getResolution(), Model::getSampleRate(), Model::getStartFrame(), getValueAt(), and RealTime::toText().

bool DenseThreeDimensionalModel::isColumnTimeValue ( int  col) const
inlineoverridevirtual

Return true if the column is the frame time of the item, or an alternative representation of it (i.e.

anything that has the same sort order). Duration is not a time value by this meaning.

Implements TabularModel.

Definition at line 169 of file DenseThreeDimensionalModel.h.

SortType DenseThreeDimensionalModel::getSortType ( int  col) const
inlineoverridevirtual

Return the sort type (numeric or alphabetical) for the column.

Implements TabularModel.

Definition at line 172 of file DenseThreeDimensionalModel.h.

References TabularModel::SortNumeric.

sv_frame_t DenseThreeDimensionalModel::getFrameForRow ( int  row) const
inlineoverridevirtual

Return the frame time for the given row.

Implements TabularModel.

Definition at line 176 of file DenseThreeDimensionalModel.h.

References getResolution(), and Model::getStartFrame().

int DenseThreeDimensionalModel::getRowForFrame ( sv_frame_t  frame) const
inlineoverridevirtual

Return the number of the first row whose frame time is not less than the given one.

If there is none, return getRowCount().

Implements TabularModel.

Definition at line 179 of file DenseThreeDimensionalModel.h.

References getResolution(), and Model::getStartFrame().

virtual bool Model::isOK ( ) const
pure virtualinherited
sv_frame_t Model::getEndFrame ( ) const
inlineinherited

Return the audio frame at the end of the model, i.e.

the final frame contained within the model plus 1 (rounded up to the model's "resolution" granularity, if more than 1). The end frame minus the start frame should yield the total duration in frames (as a multiple of the resolution) spanned by the model. This is broadly consistent with the definition of the end frame of a Selection object.

If the end has been extended by extendEndFrame() beyond the true end frame, return the extended end instead. This is usually the behaviour you want.

Definition at line 87 of file Model.h.

References Model::getTrueEndFrame(), and Model::m_extendTo.

Referenced by Model::alignFromReference(), ReadOnlyWaveFileModel::cacheFilled(), WaveformOversampler::getFixedRatioData(), SparseOneDimensionalModel::getNotes(), NoteModel::getNotes(), ReadOnlyWaveFileModel::isReady(), Model::toXml(), CSVFileWriter::write(), CSVStreamWriter::writeInChunks(), and WavFileWriter::writeModel().

virtual sv_frame_t Model::getTrueEndFrame ( ) const
pure virtualinherited
void Model::extendEndFrame ( sv_frame_t  to)
inlineinherited

Extend the end of the model.

If this is set to something beyond the true end of the data within the model, then getEndFrame() will return this value instead of the true end. (This is used by the Tony application.)

Definition at line 109 of file Model.h.

References Model::getSampleRate(), and Model::m_extendTo.

virtual sv_samplerate_t Model::getNativeRate ( ) const
inlinevirtualinherited

Return the frame rate of the underlying material, if the model itself has already been resampled.

Reimplemented in WritableWaveFileModel, ReadOnlyWaveFileModel, and WaveFileModel.

Definition at line 122 of file Model.h.

References Model::getLocation(), Model::getMaker(), Model::getSampleRate(), Model::getTitle(), and Model::getTypeName().

QString Model::getTitle ( ) const
virtualinherited

Return the "work title" of the model, if known.

Reimplemented in WritableWaveFileModel, ReadOnlyWaveFileModel, and WaveFileModel.

Definition at line 177 of file Model.cpp.

References TypedById< Item, Id >::get(), Model::m_mutex, and Model::m_sourceModel.

Referenced by Model::getNativeRate().

QString Model::getMaker ( ) const
virtualinherited

Return the "artist" or "maker" of the model, if known.

Reimplemented in WritableWaveFileModel, ReadOnlyWaveFileModel, and WaveFileModel.

Definition at line 186 of file Model.cpp.

References TypedById< Item, Id >::get(), Model::m_mutex, and Model::m_sourceModel.

Referenced by Model::getNativeRate().

QString Model::getLocation ( ) const
virtualinherited

Return the location of the data in this model (e.g.

source URL). This should not normally be returned for editable models that have been edited.

Reimplemented in WritableWaveFileModel, ReadOnlyWaveFileModel, and WaveFileModel.

Definition at line 195 of file Model.cpp.

References TypedById< Item, Id >::get(), Model::m_mutex, and Model::m_sourceModel.

Referenced by Model::getNativeRate().

virtual bool Model::isSparse ( ) const
inlinevirtualinherited

Return true if this is a sparse model.

Reimplemented in NoteModel, SparseTimeValueModel, BoxModel, RegionModel, SparseOneDimensionalModel, ImageModel, and TextModel.

Definition at line 149 of file Model.h.

Referenced by CSVFileWriter::writeSelection().

virtual bool Model::isReady ( int *  cp = nullptr) const
inlinevirtualinherited

Return true if the model has finished loading or calculating all its data, for a model that is capable of calculating in a background thread.

If "completion" is non-NULL, return through it an estimated percentage value showing how far through the background operation it thinks it is (for progress reporting). This should be identical to the value returned by getCompletion().

A model that carries out all its calculation from the constructor or accessor functions would typically return true (and completion == 100) as long as isOK() is true. Other models may make the return value here depend on the internal completion status.

See also getCompletion().

Reimplemented in ReadOnlyWaveFileModel, AlignmentModel, BasicCompressedDenseThreeDimensionalModel, AggregateWaveModel, and EditableDenseThreeDimensionalModel.

Definition at line 169 of file Model.h.

References Model::getCompletion(), and Model::isOK().

virtual const ZoomConstraint* Model::getZoomConstraint ( ) const
inlinevirtualinherited

If this model imposes a zoom constraint, i.e.

some limit to the set of resolutions at which its data can meaningfully be displayed, then return it.

Reimplemented in WritableWaveFileModel, ReadOnlyWaveFileModel, AggregateWaveModel, and AlignmentModel.

Definition at line 196 of file Model.h.

virtual ModelId Model::getSourceModel ( ) const
inlinevirtualinherited

If this model was derived from another, return the id of the model it was derived from.

The assumption is that the source model's alignment will also apply to this model, unless some other property (such as a specific alignment model set on this model) indicates otherwise.

Definition at line 207 of file Model.h.

References Model::alignFromReference(), Model::alignToReference(), Model::getAlignment(), Model::getAlignmentCompletion(), Model::getAlignmentReference(), Model::m_sourceModel, Model::setAlignment(), and Model::setSourceModel().

void Model::setSourceModel ( ModelId  model)
virtualinherited

Set the source model for this model.

Definition at line 31 of file Model.cpp.

References Model::alignmentCompletionChanged(), TypedById< Item, Id >::get(), Model::m_mutex, and Model::m_sourceModel.

Referenced by RDFImporterImpl::getDataModelsSparse(), and Model::getSourceModel().

void Model::setAlignment ( ModelId  alignmentModel)
virtualinherited

Specify an alignment between this model's timeline and that of a reference model.

The alignment model, of type AlignmentModel, records both the reference and the alignment.

Definition at line 45 of file Model.cpp.

References Model::alignmentModelCompletionChanged(), Model::completionChanged(), TypedById< Item, Id >::get(), Model::m_alignmentModel, Model::m_mutex, and SVDEBUG.

Referenced by Model::getSourceModel().

const ModelId Model::getAlignment ( ) const
virtualinherited

Retrieve the alignment model for this model.

This is not a generally useful function, as the alignment you really want may be performed by the source model instead. You should normally use getAlignmentReference, alignToReference and alignFromReference instead of this. The main intended application for this function is in streaming out alignments to the session file.

Definition at line 72 of file Model.cpp.

References Model::m_alignmentModel, and Model::m_mutex.

Referenced by Model::getSourceModel().

const ModelId Model::getAlignmentReference ( ) const
virtualinherited

Return the reference model for the current alignment timeline, if any.

Definition at line 79 of file Model.cpp.

References Model::m_alignmentModel, and Model::m_mutex.

Referenced by Model::getSourceModel().

sv_frame_t Model::alignToReference ( sv_frame_t  frame) const
virtualinherited

Return the frame number of the reference model that corresponds to the given frame number in this model.

Definition at line 88 of file Model.cpp.

References TypedById< Item, Id >::get(), Model::m_alignmentModel, Model::m_mutex, and Model::m_sourceModel.

Referenced by Model::getSourceModel().

sv_frame_t Model::alignFromReference ( sv_frame_t  referenceFrame) const
virtualinherited

Return the frame number in this model that corresponds to the given frame number of the reference model.

Definition at line 116 of file Model.cpp.

References TypedById< Item, Id >::get(), Model::getEndFrame(), Model::m_alignmentModel, Model::m_mutex, and Model::m_sourceModel.

Referenced by Model::getSourceModel().

int Model::getAlignmentCompletion ( ) const
virtualinherited

Return the completion percentage for the alignment model: 100 if there is no alignment model or it has been entirely calculated, or less than 100 if it is still being calculated.

Definition at line 141 of file Model.cpp.

References TypedById< Item, Id >::get(), Model::m_alignmentModel, Model::m_mutex, Model::m_sourceModel, and SVCERR.

Referenced by Model::getSourceModel().

void Model::setRDFTypeURI ( QString  uri)
inlineinherited

Set the event, feature, or signal type URI for the features contained in this model, according to the Audio Features RDF ontology.

Definition at line 264 of file Model.h.

References Model::m_typeUri.

Referenced by FeatureExtractionModelTransformer::getAdditionalModel(), and RDFImporterImpl::getDataModelsSparse().

QString Model::getRDFTypeURI ( ) const
inlineinherited

Retrieve the event, feature, or signal type URI for the features contained in this model, if previously set with setRDFTypeURI.

Definition at line 271 of file Model.h.

References Model::alignmentCompletionChanged(), Model::alignmentModelCompletionChanged(), Model::completionChanged(), Model::getStringExportHeaders(), Model::m_typeUri, Model::modelChanged(), Model::modelChangedWithin(), Model::ready(), Model::toStringExportRows(), and Model::toXml().

virtual QVector<QString> Model::getStringExportHeaders ( DataExportOptions  options) const
pure virtualinherited
virtual QVector<QVector<QString> > Model::toStringExportRows ( DataExportOptions  options,
sv_frame_t  startFrame,
sv_frame_t  duration 
) const
pure virtualinherited
void Model::completionChanged ( ModelId  myId)
signalinherited
void Model::ready ( ModelId  myId)
signalinherited

Emitted when internal processing is complete (i.e.

when isReady() would return true, with completion at 100).

Referenced by ReadOnlyWaveFileModel::cacheFilled(), Model::getRDFTypeURI(), AggregateWaveModel::isReady(), and ReadOnlyWaveFileModel::isReady().

void Model::alignmentCompletionChanged ( ModelId  myId)
signalinherited

Emitted when the completion percentage changes for the calculation of this model's alignment model.

(The ModelId provided is that of this model, not the alignment model.)

Referenced by Model::alignmentModelCompletionChanged(), Model::getRDFTypeURI(), and Model::setSourceModel().

Id WithTypedId< Model >::getId ( ) const
inlineprotectedinherited

Return an id for this object.

The id is a unique value for this object among all objects that implement WithId within this single run of the application.

Definition at line 193 of file ById.h.

References TypedId< T >::untyped.

Referenced by BoxModel::add(), RegionModel::add(), SparseTimeValueModel::add(), NoteModel::add(), Model::alignmentModelCompletionChanged(), ReadOnlyWaveFileModel::cacheFilled(), AggregateWaveModel::componentModelChanged(), WritableWaveFileModel::componentModelChanged(), AggregateWaveModel::componentModelChangedWithin(), WritableWaveFileModel::componentModelChangedWithin(), AggregateWaveModel::componentModelCompletionChanged(), ReadOnlyWaveFileModel::fillTimerTimedOut(), ImageModel::getInsertRowCommand(), TextModel::getInsertRowCommand(), SparseOneDimensionalModel::getInsertRowCommand(), RegionModel::getInsertRowCommand(), BoxModel::getInsertRowCommand(), SparseTimeValueModel::getInsertRowCommand(), NoteModel::getInsertRowCommand(), ImageModel::getRemoveRowCommand(), TextModel::getRemoveRowCommand(), SparseOneDimensionalModel::getRemoveRowCommand(), RegionModel::getRemoveRowCommand(), BoxModel::getRemoveRowCommand(), SparseTimeValueModel::getRemoveRowCommand(), NoteModel::getRemoveRowCommand(), ImageModel::getSetDataCommand(), TextModel::getSetDataCommand(), SparseOneDimensionalModel::getSetDataCommand(), RegionModel::getSetDataCommand(), BoxModel::getSetDataCommand(), SparseTimeValueModel::getSetDataCommand(), NoteModel::getSetDataCommand(), WritableWaveFileModel::init(), NoteModel::NoteModel(), AlignmentModel::pathSourceCompletionChanged(), ReadOnlyWaveFileModel::ReadOnlyWaveFileModel(), ImageModel::remove(), TextModel::remove(), SparseOneDimensionalModel::remove(), BoxModel::remove(), RegionModel::remove(), SparseTimeValueModel::remove(), NoteModel::remove(), EditableDenseThreeDimensionalModel::setBinName(), BasicCompressedDenseThreeDimensionalModel::setBinName(), EditableDenseThreeDimensionalModel::setBinNames(), BasicCompressedDenseThreeDimensionalModel::setBinNames(), EditableDenseThreeDimensionalModel::setColumn(), BasicCompressedDenseThreeDimensionalModel::setColumn(), EditableDenseThreeDimensionalModel::setCompletion(), BasicCompressedDenseThreeDimensionalModel::setCompletion(), AlignmentModel::setCompletion(), TextModel::setCompletion(), ImageModel::setCompletion(), SparseOneDimensionalModel::setCompletion(), BoxModel::setCompletion(), RegionModel::setCompletion(), SparseTimeValueModel::setCompletion(), NoteModel::setCompletion(), SparseOneDimensionalModel::SparseOneDimensionalModel(), SparseTimeValueModel::SparseTimeValueModel(), WritableWaveFileModel::writeComplete(), Model::~Model(), NoteModel::~NoteModel(), ReadOnlyWaveFileModel::~ReadOnlyWaveFileModel(), SparseOneDimensionalModel::~SparseOneDimensionalModel(), SparseTimeValueModel::~SparseTimeValueModel(), and WritableWaveFileModel::~WritableWaveFileModel().

int WithId::getUntypedId ( ) const
inlineprotectedinherited

Return an id for this object.

The id is a unique number for this object among all objects that implement WithId within this single run of the application.

Definition at line 168 of file ById.h.

int XmlExportable::getExportId ( ) const
inherited

Return the numerical export identifier for this object.

It's allocated the first time this is called, so objects on which this is never called do not get allocated one.

Definition at line 71 of file XmlExportable.cpp.

References XmlExportable::m_exportId, and mutex.

Referenced by EditableDenseThreeDimensionalModel::toXml(), BasicCompressedDenseThreeDimensionalModel::toXml(), EventSeries::toXml(), ImageModel::toXml(), TextModel::toXml(), Model::toXml(), SparseOneDimensionalModel::toXml(), RegionModel::toXml(), BoxModel::toXml(), SparseTimeValueModel::toXml(), NoteModel::toXml(), and XmlExportable::~XmlExportable().

QString XmlExportable::toXmlString ( QString  indent = "",
QString  extraAttributes = "" 
) const
virtualinherited

Convert this exportable object to XML in a string.

The default implementation calls toXml and returns the result as a string. Do not override this unless you really know what you're doing.

Definition at line 25 of file XmlExportable.cpp.

References XmlExportable::toXml().

Referenced by ModelTransformerFactory::getConfigurationForTransform(), RDFTransformFactoryImpl::getTransforms(), and XmlExportable::~XmlExportable().

QString XmlExportable::encodeColour ( int  r,
int  g,
int  b 
)
staticinherited

Definition at line 54 of file XmlExportable.cpp.

Referenced by XmlExportable::~XmlExportable().

virtual bool Playable::canPlay ( ) const
inlinevirtualinherited

Reimplemented in NoteModel, SparseTimeValueModel, SparseOneDimensionalModel, and DenseTimeValueModel.

Definition at line 26 of file Playable.h.

virtual QString Playable::getDefaultPlayClipId ( ) const
inlinevirtualinherited

Reimplemented in NoteModel, SparseOneDimensionalModel, and DenseTimeValueModel.

Definition at line 27 of file Playable.h.

Referenced by PlayParameterRepository::addPlayable().

virtual bool Playable::getDefaultPlayAudible ( ) const
inlinevirtualinherited

Reimplemented in SparseTimeValueModel.

Definition at line 28 of file Playable.h.

Referenced by PlayParameterRepository::addPlayable().

static QVariant TabularModel::adaptFrameForRole ( sv_frame_t  frame,
sv_samplerate_t  rate,
int  role 
)
inlinestaticprotectedinherited
static QVariant TabularModel::adaptValueForRole ( float  value,
QString  unit,
int  role 
)
inlinestaticprotectedinherited

Member Data Documentation

QString Model::m_typeUri
protectedinherited

Definition at line 340 of file Model.h.

Referenced by Model::getRDFTypeURI(), and Model::setRDFTypeURI().

std::atomic<sv_frame_t> Model::m_extendTo
protectedinherited

Definition at line 341 of file Model.h.

Referenced by Model::extendEndFrame(), and Model::getEndFrame().


The documentation for this class was generated from the following file: