annotate vamp-sdk/PluginHostAdapter.h @ 173:a6981e5dafe5

* make a start on the summarising adapter
author cannam
date Mon, 04 Aug 2008 16:13:14 +0000
parents 6683f99107cf
children
rev   line source
cannam@1 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
cannam@1 2
cannam@1 3 /*
cannam@1 4 Vamp
cannam@1 5
cannam@1 6 An API for audio analysis and feature extraction plugins.
cannam@1 7
cannam@1 8 Centre for Digital Music, Queen Mary, University of London.
cannam@1 9 Copyright 2006 Chris Cannam.
cannam@1 10
cannam@1 11 Permission is hereby granted, free of charge, to any person
cannam@1 12 obtaining a copy of this software and associated documentation
cannam@1 13 files (the "Software"), to deal in the Software without
cannam@1 14 restriction, including without limitation the rights to use, copy,
cannam@1 15 modify, merge, publish, distribute, sublicense, and/or sell copies
cannam@1 16 of the Software, and to permit persons to whom the Software is
cannam@1 17 furnished to do so, subject to the following conditions:
cannam@1 18
cannam@1 19 The above copyright notice and this permission notice shall be
cannam@1 20 included in all copies or substantial portions of the Software.
cannam@1 21
cannam@1 22 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
cannam@1 23 EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
cannam@1 24 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
cannam@6 25 NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
cannam@1 26 ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
cannam@1 27 CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
cannam@1 28 WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
cannam@1 29
cannam@1 30 Except as contained in this notice, the names of the Centre for
cannam@1 31 Digital Music; Queen Mary, University of London; and Chris Cannam
cannam@1 32 shall not be used in advertising or otherwise to promote the sale,
cannam@1 33 use or other dealings in this Software without prior written
cannam@1 34 authorization.
cannam@1 35 */
cannam@1 36
cannam@5 37 #ifndef _VAMP_PLUGIN_HOST_ADAPTER_H_
cannam@5 38 #define _VAMP_PLUGIN_HOST_ADAPTER_H_
cannam@1 39
cannam@10 40 #include <vamp/vamp.h>
cannam@64 41 #include <vamp-sdk/Plugin.h>
cannam@1 42
cannam@32 43 #include <vector>
cannam@32 44
cannam@1 45 namespace Vamp {
cannam@1 46
cannam@53 47 /**
cannam@76 48 * \class PluginHostAdapter PluginHostAdapter.h <vamp-sdk/PluginHostAdapter.h>
cannam@76 49 *
cannam@53 50 * PluginHostAdapter is a wrapper class that a Vamp host can use to
cannam@53 51 * make the C-language VampPluginDescriptor object appear as a C++
cannam@53 52 * Vamp::Plugin object.
cannam@53 53 *
cannam@53 54 * The Vamp API is defined in vamp/vamp.h as a C API. The C++ objects
cannam@53 55 * used for convenience by plugins and hosts actually communicate
cannam@53 56 * using the C low-level API, but the details of this communication
cannam@53 57 * are handled seamlessly by the Vamp SDK implementation provided the
cannam@53 58 * plugin and host use the proper C++ wrapper objects.
cannam@53 59 *
cannam@53 60 * See also PluginAdapter, the plugin-side wrapper that makes a C++
cannam@53 61 * plugin object available using the C query API.
cannam@53 62 */
cannam@53 63
cannam@1 64 class PluginHostAdapter : public Plugin
cannam@1 65 {
cannam@1 66 public:
cannam@1 67 PluginHostAdapter(const VampPluginDescriptor *descriptor,
cannam@1 68 float inputSampleRate);
cannam@1 69 virtual ~PluginHostAdapter();
cannam@32 70
cannam@32 71 static std::vector<std::string> getPluginPath();
cannam@1 72
cannam@1 73 bool initialise(size_t channels, size_t stepSize, size_t blockSize);
cannam@1 74 void reset();
cannam@1 75
cannam@1 76 InputDomain getInputDomain() const;
cannam@1 77
cannam@50 78 unsigned int getVampApiVersion() const;
cannam@49 79 std::string getIdentifier() const;
cannam@1 80 std::string getName() const;
cannam@1 81 std::string getDescription() const;
cannam@1 82 std::string getMaker() const;
cannam@1 83 int getPluginVersion() const;
cannam@1 84 std::string getCopyright() const;
cannam@1 85
cannam@1 86 ParameterList getParameterDescriptors() const;
cannam@1 87 float getParameter(std::string) const;
cannam@1 88 void setParameter(std::string, float);
cannam@1 89
cannam@1 90 ProgramList getPrograms() const;
cannam@1 91 std::string getCurrentProgram() const;
cannam@1 92 void selectProgram(std::string);
cannam@1 93
cannam@1 94 size_t getPreferredStepSize() const;
cannam@1 95 size_t getPreferredBlockSize() const;
cannam@1 96
cannam@26 97 size_t getMinChannelCount() const;
cannam@26 98 size_t getMaxChannelCount() const;
cannam@26 99
cannam@1 100 OutputList getOutputDescriptors() const;
cannam@1 101
cannam@47 102 FeatureSet process(const float *const *inputBuffers, RealTime timestamp);
cannam@1 103
cannam@1 104 FeatureSet getRemainingFeatures();
cannam@1 105
cannam@1 106 protected:
cannam@12 107 void convertFeatures(VampFeatureList *, FeatureSet &);
cannam@1 108
cannam@1 109 const VampPluginDescriptor *m_descriptor;
cannam@1 110 VampPluginHandle m_handle;
cannam@1 111 };
cannam@1 112
cannam@1 113 }
cannam@1 114
cannam@1 115 #endif
cannam@1 116
cannam@1 117