matthiasm@32
|
1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
|
matthiasm@32
|
2
|
matthiasm@32
|
3 /*
|
matthiasm@32
|
4 pYIN - A fundamental frequency estimator for monophonic audio
|
matthiasm@32
|
5 Centre for Digital Music, Queen Mary, University of London.
|
matthiasm@32
|
6
|
matthiasm@32
|
7 This program is free software; you can redistribute it and/or
|
matthiasm@32
|
8 modify it under the terms of the GNU General Public License as
|
matthiasm@32
|
9 published by the Free Software Foundation; either version 2 of the
|
matthiasm@32
|
10 License, or (at your option) any later version. See the file
|
matthiasm@32
|
11 COLocalCandidatePYING included with this distribution for more information.
|
matthiasm@32
|
12 */
|
matthiasm@32
|
13
|
matthiasm@32
|
14 #ifndef _LOCALCANDIDATEPYIN_H_
|
matthiasm@32
|
15 #define _LOCALCANDIDATEPYIN_H_
|
matthiasm@32
|
16
|
matthiasm@32
|
17 #include <vamp-sdk/Plugin.h>
|
matthiasm@32
|
18
|
matthiasm@32
|
19 #include "Yin.h"
|
matthiasm@32
|
20
|
Chris@136
|
21 class YinUtil;
|
Chris@136
|
22
|
matthiasm@32
|
23 class LocalCandidatePYIN : public Vamp::Plugin
|
matthiasm@32
|
24 {
|
matthiasm@32
|
25 public:
|
matthiasm@32
|
26 LocalCandidatePYIN(float inputSampleRate);
|
matthiasm@32
|
27 virtual ~LocalCandidatePYIN();
|
matthiasm@32
|
28
|
matthiasm@32
|
29 std::string getIdentifier() const;
|
matthiasm@32
|
30 std::string getName() const;
|
matthiasm@32
|
31 std::string getDescription() const;
|
matthiasm@32
|
32 std::string getMaker() const;
|
matthiasm@32
|
33 int getPluginVersion() const;
|
matthiasm@32
|
34 std::string getCopyright() const;
|
matthiasm@32
|
35
|
matthiasm@32
|
36 InputDomain getInputDomain() const;
|
matthiasm@32
|
37 size_t getPreferredBlockSize() const;
|
matthiasm@32
|
38 size_t getPreferredStepSize() const;
|
matthiasm@32
|
39 size_t getMinChannelCount() const;
|
matthiasm@32
|
40 size_t getMaxChannelCount() const;
|
matthiasm@32
|
41
|
matthiasm@32
|
42 ParameterList getParameterDescriptors() const;
|
matthiasm@32
|
43 float getParameter(std::string identifier) const;
|
matthiasm@32
|
44 void setParameter(std::string identifier, float value);
|
matthiasm@32
|
45
|
matthiasm@32
|
46 ProgramList getPrograms() const;
|
matthiasm@32
|
47 std::string getCurrentProgram() const;
|
matthiasm@32
|
48 void selectProgram(std::string name);
|
matthiasm@32
|
49
|
matthiasm@32
|
50 OutputList getOutputDescriptors() const;
|
matthiasm@32
|
51
|
matthiasm@32
|
52 bool initialise(size_t channels, size_t stepSize, size_t blockSize);
|
matthiasm@32
|
53 void reset();
|
matthiasm@32
|
54
|
matthiasm@32
|
55 FeatureSet process(const float *const *inputBuffers,
|
matthiasm@32
|
56 Vamp::RealTime timestamp);
|
matthiasm@32
|
57
|
matthiasm@32
|
58 FeatureSet getRemainingFeatures();
|
matthiasm@32
|
59
|
matthiasm@32
|
60 protected:
|
matthiasm@32
|
61 size_t m_channels;
|
matthiasm@32
|
62 size_t m_stepSize;
|
matthiasm@32
|
63 size_t m_blockSize;
|
matthiasm@32
|
64 float m_fmin;
|
matthiasm@32
|
65 float m_fmax;
|
matthiasm@32
|
66
|
matthiasm@32
|
67 mutable int m_oPitchTrackCandidates;
|
matthiasm@32
|
68
|
matthiasm@32
|
69 float m_threshDistr;
|
matthiasm@32
|
70 float m_outputUnvoiced;
|
matthiasm@70
|
71 float m_preciseTime;
|
matthiasm@46
|
72 vector<vector<pair<double, double> > > m_pitchProb;
|
matthiasm@32
|
73 vector<Vamp::RealTime> m_timestamp;
|
matthiasm@32
|
74 size_t m_nCandidate;
|
Chris@136
|
75
|
Chris@136
|
76 YinUtil *m_yinUtil;
|
matthiasm@32
|
77 };
|
matthiasm@32
|
78
|
matthiasm@32
|
79 #endif
|