annotate plugins/XTractPlugin.h @ 0:298dc5b79772

* Initial import
author cannam
date Fri, 08 Dec 2006 17:29:27 +0000
parents
children d9b43f698a44
rev   line source
cannam@0 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
cannam@0 2
cannam@0 3 /*
cannam@0 4 Vamp feature extraction plugins using Jamie Bullock's
cannam@0 5 libxtract audio feature extraction library.
cannam@0 6
cannam@0 7 Centre for Digital Music, Queen Mary, University of London.
cannam@0 8 This file copyright 2006 Queen Mary, University of London.
cannam@0 9
cannam@0 10 This program is free software; you can redistribute it and/or
cannam@0 11 modify it under the terms of the GNU General Public License as
cannam@0 12 published by the Free Software Foundation; either version 2 of the
cannam@0 13 License, or (at your option) any later version. See the file
cannam@0 14 COPYING included with this distribution for more information.
cannam@0 15 */
cannam@0 16
cannam@0 17 #ifndef _XTRACT_PLUGIN_H_
cannam@0 18 #define _XTRACT_PLUGIN_H_
cannam@0 19
cannam@0 20 #include <vamp-sdk/Plugin.h>
cannam@0 21
cannam@0 22 class XTractPlugin : public Vamp::Plugin
cannam@0 23 {
cannam@0 24 public:
cannam@0 25 XTractPlugin(unsigned int xtFeature, float inputSampleRate);
cannam@0 26 virtual ~XTractPlugin();
cannam@0 27
cannam@0 28 bool initialise(size_t channels, size_t stepSize, size_t blockSize);
cannam@0 29 void reset();
cannam@0 30
cannam@0 31 InputDomain getInputDomain() const;
cannam@0 32
cannam@0 33 std::string getName() const;
cannam@0 34 std::string getDescription() const;
cannam@0 35 std::string getMaker() const;
cannam@0 36 int getPluginVersion() const;
cannam@0 37 std::string getCopyright() const;
cannam@0 38
cannam@0 39 ParameterList getParameterDescriptors() const;
cannam@0 40 float getParameter(std::string) const;
cannam@0 41 void setParameter(std::string, float);
cannam@0 42
cannam@0 43 size_t getMinChannelCount() const;
cannam@0 44 size_t getMaxChannelCount() const;
cannam@0 45
cannam@0 46 size_t getPreferredStepSize() const;
cannam@0 47 size_t getPreferredBlockSize() const;
cannam@0 48
cannam@0 49 OutputList getOutputDescriptors() const;
cannam@0 50
cannam@0 51 FeatureSet process(const float *const *inputBuffers,
cannam@0 52 Vamp::RealTime timestamp);
cannam@0 53
cannam@0 54 FeatureSet getRemainingFeatures();
cannam@0 55
cannam@0 56 protected:
cannam@0 57 enum XTractInputType {
cannam@0 58 TimeDomainAudio,
cannam@0 59 MagnitudeSpectrum,
cannam@0 60 SpectralPeaks,
cannam@0 61 SpectralPeaksPlusF0,
cannam@0 62 HarmonicSpectrum,
cannam@0 63 BarkCoefficients,
cannam@0 64 CustomInputType
cannam@0 65 };
cannam@0 66 XTractInputType getXTractInputType() const;
cannam@0 67 bool needPeakThreshold() const;
cannam@0 68
cannam@0 69 mutable OutputList m_outputDescriptors;
cannam@0 70 void setupOutputDescriptors() const;
cannam@0 71
cannam@0 72 bool processSPF0(float *data);
cannam@0 73
cannam@0 74 const unsigned int m_xtFeature;
cannam@0 75 size_t m_channels;
cannam@0 76 size_t m_stepSize;
cannam@0 77 size_t m_blockSize;
cannam@0 78
cannam@0 79 float *m_resultBuffer;
cannam@0 80
cannam@0 81 float m_threshold;
cannam@0 82
cannam@0 83 float m_minFreq;
cannam@0 84 float m_maxFreq;
cannam@0 85
cannam@0 86 size_t m_coeffCount;
cannam@0 87 float **m_mfccFilters;
cannam@0 88 int m_mfccStyle;
cannam@0 89
cannam@0 90 int *m_barkBandLimits;
cannam@0 91
cannam@0 92 size_t m_outputBinCount;
cannam@0 93 bool m_initialised;
cannam@0 94 };
cannam@0 95
cannam@0 96
cannam@0 97 #endif