Mercurial > hg > silvet
view src/Silvet.h @ 35:461d94ed3816
More on EM
author | Chris Cannam |
---|---|
date | Fri, 04 Apr 2014 14:38:40 +0100 |
parents | 7d81407a2fd8 |
children | 5164bccf3064 |
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ /* Silvet A Vamp plugin for note transcription. Centre for Digital Music, Queen Mary University of London. 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 SILVET_H #define SILVET_H #include <vamp-sdk/Plugin.h> #include <vector> #include <string> #include "maths/MedianFilter.h" using std::string; using std::vector; class Resampler; class CQInterpolated; class Silvet : public Vamp::Plugin { public: Silvet(float inputSampleRate); virtual ~Silvet(); string getIdentifier() const; string getName() const; string getDescription() const; string getMaker() const; int getPluginVersion() const; string getCopyright() const; InputDomain getInputDomain() const; size_t getPreferredBlockSize() const; size_t getPreferredStepSize() const; size_t getMinChannelCount() const; size_t getMaxChannelCount() const; ParameterList getParameterDescriptors() const; float getParameter(string identifier) const; void setParameter(string identifier, float value); ProgramList getPrograms() const; string getCurrentProgram() const; void selectProgram(string name); OutputList getOutputDescriptors() const; bool initialise(size_t channels, size_t stepSize, size_t blockSize); void reset(); FeatureSet process(const float *const *inputBuffers, Vamp::RealTime timestamp); FeatureSet getRemainingFeatures(); protected: Resampler *m_resampler; CQInterpolated *m_cq; typedef vector<vector<double> > Grid; vector<MedianFilter<double> *> m_filterA; vector<MedianFilter<double> *> m_filterB; Grid preProcess(const Grid &); FeatureSet transcribe(const Grid &); int m_blockSize; int m_columnCount; int m_reducedColumnCount; mutable int m_notesOutputNo; mutable int m_cqOutputNo; }; #endif