Mercurial > hg > pyin
annotate MonoNoteHMM.h @ 164:a7d9c6142f8f tip
Added tag v1.2 for changeset 4a97f7638ffd
author | Chris Cannam |
---|---|
date | Thu, 06 Feb 2020 15:02:47 +0000 |
parents | 3faac48d491d |
children |
rev | line source |
---|---|
matthiasm@0 | 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ |
Chris@9 | 2 |
matthiasm@0 | 3 /* |
Chris@9 | 4 pYIN - A fundamental frequency estimator for monophonic audio |
Chris@9 | 5 Centre for Digital Music, Queen Mary, University of London. |
Chris@9 | 6 |
Chris@9 | 7 This program is free software; you can redistribute it and/or |
Chris@9 | 8 modify it under the terms of the GNU General Public License as |
Chris@9 | 9 published by the Free Software Foundation; either version 2 of the |
Chris@9 | 10 License, or (at your option) any later version. See the file |
Chris@9 | 11 COPYING included with this distribution for more information. |
matthiasm@0 | 12 */ |
matthiasm@0 | 13 |
matthiasm@0 | 14 #ifndef _MONONOTEHMM_H_ |
matthiasm@0 | 15 #define _MONONOTEHMM_H_ |
matthiasm@0 | 16 |
matthiasm@0 | 17 #include "MonoNoteParameters.h" |
matthiasm@0 | 18 #include "SparseHMM.h" |
matthiasm@0 | 19 |
matthiasm@0 | 20 #include <boost/math/distributions.hpp> |
matthiasm@0 | 21 |
matthiasm@0 | 22 #include <vector> |
matthiasm@0 | 23 #include <cstdio> |
matthiasm@0 | 24 |
matthiasm@0 | 25 using std::vector; |
matthiasm@0 | 26 |
matthiasm@0 | 27 class MonoNoteHMM : public SparseHMM |
matthiasm@0 | 28 { |
matthiasm@0 | 29 public: |
mail@132 | 30 MonoNoteHMM(int fixedLag); |
Chris@156 | 31 std::vector<double> calculateObsProb(const vector<pair<double, double> > &); |
mail@133 | 32 |
matthiasm@0 | 33 double getMidiPitch(size_t index); |
matthiasm@0 | 34 double getFrequency(size_t index); |
matthiasm@0 | 35 void build(); |
matthiasm@0 | 36 MonoNoteParameters par; |
matthiasm@0 | 37 vector<boost::math::normal> pitchDistr; |
matthiasm@0 | 38 }; |
matthiasm@0 | 39 |
matthiasm@0 | 40 #endif |