annotate src/MatchVampPlugin.h @ 98:bdd8158d401f adaptive_diagonals

Add feature distance and feature magnitude outputs (for experiments)
author Chris Cannam
date Thu, 27 Nov 2014 18:01:36 +0000
parents b9aa663a607b
children 184e6ab734ce
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 plugin using the MATCH audio alignment
cannam@0 5 algorithm.
cannam@0 6
cannam@0 7 Centre for Digital Music, Queen Mary, University of London.
cannam@0 8 This file copyright 2007 Simon Dixon, Chris Cannam and QMUL.
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 _MATCH_VAMP_PLUGIN_H_
cannam@0 18 #define _MATCH_VAMP_PLUGIN_H_
cannam@0 19
cannam@0 20 #include <vamp-sdk/Plugin.h>
cannam@0 21
cannam@0 22 #ifdef _WIN32
cannam@0 23 #include <windows.h>
cannam@0 24 #else
cannam@0 25 #include <pthread.h>
cannam@0 26 #endif
cannam@0 27
Chris@17 28 #include "Matcher.h"
Chris@38 29 #include "FeatureExtractor.h"
Chris@17 30
Chris@74 31 class MatchFeatureFeeder;
cannam@0 32
cannam@0 33 class MatchVampPlugin : public Vamp::Plugin
cannam@0 34 {
cannam@0 35 public:
cannam@0 36 MatchVampPlugin(float inputSampleRate);
cannam@0 37 virtual ~MatchVampPlugin();
cannam@0 38
cannam@0 39 bool initialise(size_t channels, size_t stepSize, size_t blockSize);
cannam@0 40 void reset();
cannam@0 41
cannam@0 42 InputDomain getInputDomain() const { return FrequencyDomain; }
cannam@0 43
cannam@0 44 size_t getPreferredStepSize() const;
cannam@0 45 size_t getPreferredBlockSize() const;
cannam@0 46
cannam@0 47 size_t getMinChannelCount() const { return 2; }
cannam@0 48 size_t getMaxChannelCount() const { return 2; }
cannam@0 49
cannam@0 50 std::string getIdentifier() const;
cannam@0 51 std::string getName() const;
cannam@0 52 std::string getDescription() const;
cannam@0 53 std::string getMaker() const;
cannam@0 54 int getPluginVersion() const;
cannam@0 55 std::string getCopyright() const;
cannam@0 56
cannam@0 57 ParameterList getParameterDescriptors() const;
cannam@0 58 float getParameter(std::string) const;
cannam@0 59 void setParameter(std::string, float);
cannam@0 60
cannam@0 61 OutputList getOutputDescriptors() const;
cannam@0 62
cannam@0 63 FeatureSet process(const float *const *inputBuffers,
cannam@0 64 Vamp::RealTime timestamp);
cannam@0 65
cannam@0 66 FeatureSet getRemainingFeatures();
cannam@0 67
cannam@0 68 protected:
Chris@17 69 void createMatchers();
Chris@74 70 bool aboveThreshold(const float *);
Chris@16 71
Chris@74 72 Matcher *m_pm1;
Chris@74 73 Matcher *m_pm2;
Chris@74 74 FeatureExtractor *m_fe1;
Chris@74 75 FeatureExtractor *m_fe2;
Chris@74 76 MatchFeatureFeeder *m_feeder;
Chris@16 77
Chris@10 78 Vamp::RealTime m_startTime;
Chris@15 79 int m_stepSize;
Chris@15 80 float m_stepTime;
Chris@15 81 int m_blockSize;
cannam@0 82 bool m_serialise;
cannam@0 83 bool m_begin;
cannam@0 84 bool m_locked;
Chris@32 85 bool m_smooth;
cannam@0 86
Chris@74 87 int m_frameNo;
Chris@74 88 int m_lastFrameIn1;
Chris@74 89 int m_lastFrameIn2;
Chris@74 90
Chris@17 91 Matcher::Parameters m_params;
Chris@17 92 Matcher::Parameters m_defaultParams;
Chris@17 93
Chris@38 94 FeatureExtractor::Parameters m_feParams;
Chris@38 95 FeatureExtractor::Parameters m_defaultFeParams;
Chris@38 96
Chris@16 97 mutable int m_pathOutNo;
Chris@16 98 mutable int m_abOutNo;
Chris@16 99 mutable int m_baOutNo;
Chris@16 100 mutable int m_abDivOutNo;
Chris@16 101 mutable int m_abRatioOutNo;
Chris@16 102 mutable int m_aFeaturesOutNo;
Chris@16 103 mutable int m_bFeaturesOutNo;
Chris@98 104 mutable int m_distOutNo;
Chris@98 105 mutable int m_featureMagOutNo;
Chris@16 106
cannam@0 107 #ifdef _WIN32
cannam@0 108 static HANDLE m_serialisingMutex;
cannam@0 109 #else
cannam@0 110 static pthread_mutex_t m_serialisingMutex;
cannam@0 111 #endif
cannam@0 112
cannam@0 113 static bool m_serialisingMutexInitialised;
cannam@0 114 };
cannam@0 115
cannam@0 116
cannam@0 117 #endif