annotate plugins/XTractPlugin.h @ 1:d9b43f698a44

* Update for libxtract SVN. Almost all of these changes were provided by Jamie Bullock.
author cannam
date Wed, 14 Feb 2007 16:16:13 +0000
parents 298dc5b79772
children c2305fa8e01f
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@1 21 #include <xtract/libxtract.h>
cannam@0 22
cannam@0 23 class XTractPlugin : public Vamp::Plugin
cannam@0 24 {
cannam@0 25 public:
cannam@0 26 XTractPlugin(unsigned int xtFeature, float inputSampleRate);
cannam@0 27 virtual ~XTractPlugin();
cannam@0 28
cannam@0 29 bool initialise(size_t channels, size_t stepSize, size_t blockSize);
cannam@0 30 void reset();
cannam@0 31
cannam@0 32 InputDomain getInputDomain() const;
cannam@0 33
cannam@0 34 std::string getName() const;
cannam@0 35 std::string getDescription() const;
cannam@0 36 std::string getMaker() const;
cannam@0 37 int getPluginVersion() const;
cannam@0 38 std::string getCopyright() const;
cannam@0 39
cannam@0 40 ParameterList getParameterDescriptors() const;
cannam@0 41 float getParameter(std::string) const;
cannam@0 42 void setParameter(std::string, float);
cannam@0 43
cannam@0 44 size_t getMinChannelCount() const;
cannam@0 45 size_t getMaxChannelCount() const;
cannam@0 46
cannam@0 47 size_t getPreferredStepSize() const;
cannam@0 48 size_t getPreferredBlockSize() const;
cannam@0 49
cannam@0 50 OutputList getOutputDescriptors() const;
cannam@0 51
cannam@0 52 FeatureSet process(const float *const *inputBuffers,
cannam@0 53 Vamp::RealTime timestamp);
cannam@0 54
cannam@0 55 FeatureSet getRemainingFeatures();
cannam@0 56
cannam@0 57 protected:
cannam@0 58 bool needPeakThreshold() const;
cannam@1 59 bool needHarmonicThreshold() const;
cannam@1 60 bool needRolloffThreshold() const;
cannam@0 61
cannam@0 62 mutable OutputList m_outputDescriptors;
cannam@0 63 void setupOutputDescriptors() const;
cannam@0 64
cannam@1 65 bool processSPF0(const float *data);
cannam@0 66
cannam@0 67 const unsigned int m_xtFeature;
cannam@0 68 size_t m_channels;
cannam@0 69 size_t m_stepSize;
cannam@0 70 size_t m_blockSize;
cannam@0 71
cannam@0 72 float *m_resultBuffer;
cannam@0 73
cannam@1 74 float m_peakThreshold;
cannam@1 75 float m_rolloffThreshold;
cannam@1 76 float m_harmonicThreshold;
cannam@0 77
cannam@0 78 float m_minFreq;
cannam@0 79 float m_maxFreq;
cannam@0 80
cannam@0 81 size_t m_coeffCount;
cannam@0 82 float **m_mfccFilters;
cannam@0 83 int m_mfccStyle;
cannam@0 84
cannam@0 85 int *m_barkBandLimits;
cannam@0 86
cannam@1 87 static xtract_function_descriptor_t *m_xtDescriptors;
cannam@1 88 static int m_xtDescRefCount;
cannam@1 89 xtract_function_descriptor_t *xtDescriptor() {
cannam@1 90 return &m_xtDescriptors[m_xtFeature];
cannam@1 91 }
cannam@1 92 const xtract_function_descriptor_t *xtDescriptor() const {
cannam@1 93 return &m_xtDescriptors[m_xtFeature];
cannam@1 94 }
cannam@1 95
cannam@0 96 size_t m_outputBinCount;
cannam@0 97 bool m_initialised;
cannam@0 98 };
cannam@0 99
cannam@0 100
cannam@0 101 #endif