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 Paul Brossier's Aubio library.
|
cannam@0
|
5
|
cannam@0
|
6 Centre for Digital Music, Queen Mary, University of London.
|
cannam@0
|
7 This file copyright 2006 Chris Cannam.
|
cannam@0
|
8
|
cannam@0
|
9 This program is free software; you can redistribute it and/or
|
cannam@0
|
10 modify it under the terms of the GNU General Public License as
|
cannam@0
|
11 published by the Free Software Foundation; either version 2 of the
|
cannam@0
|
12 License, or (at your option) any later version. See the file
|
cannam@0
|
13 COPYING included with this distribution for more information.
|
cannam@0
|
14
|
cannam@0
|
15 */
|
cannam@0
|
16
|
cannam@0
|
17 #ifndef _NOTES_PLUGIN_H_
|
cannam@0
|
18 #define _NOTES_PLUGIN_H_
|
cannam@0
|
19
|
cannam@0
|
20 #include <vamp-sdk/Plugin.h>
|
cannam@0
|
21 #include <aubio/aubio.h>
|
cannam@0
|
22
|
cannam@0
|
23 #include <deque>
|
cannam@0
|
24
|
cannam@0
|
25 class Notes : public Vamp::Plugin
|
cannam@0
|
26 {
|
cannam@0
|
27 public:
|
cannam@0
|
28 Notes(float inputSampleRate);
|
cannam@0
|
29 virtual ~Notes();
|
cannam@0
|
30
|
cannam@0
|
31 bool initialise(size_t channels, size_t stepSize, size_t blockSize);
|
cannam@0
|
32 void reset();
|
cannam@0
|
33
|
cannam@0
|
34 InputDomain getInputDomain() const { return TimeDomain; }
|
cannam@0
|
35
|
cannam@0
|
36 std::string getName() const;
|
cannam@0
|
37 std::string getDescription() const;
|
cannam@0
|
38 std::string getMaker() const;
|
cannam@0
|
39 int getPluginVersion() const;
|
cannam@0
|
40 std::string getCopyright() const;
|
cannam@0
|
41
|
cannam@0
|
42 ParameterList getParameterDescriptors() const;
|
cannam@0
|
43 float getParameter(std::string) const;
|
cannam@0
|
44 void setParameter(std::string, float);
|
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(float **inputBuffers, Vamp::RealTime timestamp);
|
cannam@0
|
52
|
cannam@0
|
53 FeatureSet getRemainingFeatures();
|
cannam@0
|
54
|
cannam@0
|
55 protected:
|
cannam@0
|
56 fvec_t *m_ibuf;
|
cannam@0
|
57 cvec_t *m_fftgrain;
|
cannam@0
|
58 fvec_t *m_onset;
|
cannam@0
|
59 aubio_pvoc_t *m_pv;
|
cannam@0
|
60 aubio_pickpeak_t *m_peakpick;
|
cannam@0
|
61 aubio_onsetdetection_t *m_onsetdet;
|
cannam@0
|
62 aubio_onsetdetection_type m_onsettype;
|
cannam@0
|
63 aubio_pitchdetection_t *m_pitchdet;
|
cannam@0
|
64 aubio_pitchdetection_type m_pitchtype;
|
cannam@0
|
65 aubio_pitchdetection_mode m_pitchmode;
|
cannam@0
|
66 float m_threshold;
|
cannam@0
|
67 float m_silence;
|
cannam@0
|
68 size_t m_median;
|
cannam@0
|
69 size_t m_stepSize;
|
cannam@0
|
70 size_t m_blockSize;
|
cannam@0
|
71 size_t m_channelCount;
|
cannam@0
|
72 std::deque<float> m_notebuf;
|
cannam@0
|
73 size_t m_count;
|
cannam@0
|
74 Vamp::RealTime m_currentOnset;
|
cannam@0
|
75 Vamp::RealTime m_lastTimeStamp;
|
cannam@0
|
76 float m_currentLevel;
|
cannam@0
|
77 bool m_haveCurrent;
|
cannam@0
|
78
|
cannam@0
|
79 void pushNote(FeatureSet &, const Vamp::RealTime &);
|
cannam@0
|
80 };
|
cannam@0
|
81
|
cannam@0
|
82
|
cannam@0
|
83 #endif
|