Mercurial > hg > qm-dsp
annotate dsp/tonal/TonalEstimator.h @ 30:a251fb0de594
* Make MFCC able to accept already-FFT'd input, and simplify API a bit
* Add log power value to MFCC, restore windowing, and avoid some heap allocs
* In HMM, bail out of iteration if loglik hits NaN
author | cannam |
---|---|
date | Fri, 18 Jan 2008 13:24:12 +0000 |
parents | d7116e3183f8 |
children | ba4076cb1be1 |
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 QM DSP Library |
cannam@0 | 5 |
cannam@0 | 6 Centre for Digital Music, Queen Mary, University of London. |
cannam@0 | 7 This file copyright 2006 Martin Gasser. |
cannam@0 | 8 All rights reserved. |
cannam@0 | 9 */ |
cannam@0 | 10 |
cannam@0 | 11 #ifndef _TONALESTIMATOR_ |
cannam@0 | 12 #define _TONALESTIMATOR_ |
cannam@0 | 13 |
cannam@0 | 14 |
cannam@0 | 15 #include <valarray> |
cannam@0 | 16 #include <numeric> |
cannam@0 | 17 #include <algorithm> |
cannam@0 | 18 #include <iostream> |
cannam@0 | 19 |
cannam@0 | 20 class ChromaVector : public std::valarray<double> |
cannam@0 | 21 { |
cannam@0 | 22 public: |
cannam@0 | 23 ChromaVector(size_t uSize = 12) : std::valarray<double>() |
cannam@0 | 24 { resize(uSize, 0.0f); } |
cannam@0 | 25 |
cannam@0 | 26 virtual ~ChromaVector() {}; |
cannam@0 | 27 |
cannam@0 | 28 void printDebug() |
cannam@0 | 29 { |
cannam@0 | 30 for (int i = 0; i < size(); i++) |
cannam@0 | 31 { |
cannam@0 | 32 std::cout << (*this)[i] << ";"; |
cannam@0 | 33 } |
cannam@0 | 34 |
cannam@0 | 35 std::cout << std::endl; |
cannam@0 | 36 } |
cannam@0 | 37 |
cannam@0 | 38 void normalizeL1() |
cannam@0 | 39 { |
cannam@0 | 40 // normalize the chroma vector (L1 norm) |
cannam@0 | 41 double dSum = 0.0; |
cannam@0 | 42 |
cannam@0 | 43 for (size_t i = 0; i < 12; (dSum += std::abs((*this)[i++]))); |
cannam@0 | 44 for (size_t i = 0; i < 12; dSum > 0.0000001?((*this)[i] /= dSum):(*this)[i]=0.0, i++); |
cannam@0 | 45 |
cannam@0 | 46 } |
cannam@0 | 47 |
cannam@0 | 48 }; |
cannam@0 | 49 |
cannam@0 | 50 class TCSVector : public std::valarray<double> |
cannam@0 | 51 { |
cannam@0 | 52 public: |
cannam@0 | 53 TCSVector() : std::valarray<double>() |
cannam@0 | 54 { resize(6, 0.0f); } |
cannam@0 | 55 |
cannam@0 | 56 virtual ~TCSVector() {}; |
cannam@0 | 57 |
cannam@0 | 58 void printDebug() |
cannam@0 | 59 { |
cannam@0 | 60 for (int i = 0; i < size(); i++) |
cannam@0 | 61 { |
cannam@0 | 62 std::cout << (*this)[i] << ";"; |
cannam@0 | 63 } |
cannam@0 | 64 |
cannam@0 | 65 std::cout << std::endl; |
cannam@0 | 66 } |
cannam@0 | 67 |
cannam@0 | 68 double magnitude() const |
cannam@0 | 69 { |
cannam@0 | 70 double dMag = 0.0; |
cannam@0 | 71 |
cannam@0 | 72 for (size_t i = 0; i < 6; i++) |
cannam@0 | 73 { |
cannam@0 | 74 dMag += std::pow((*this)[i], 2.0); |
cannam@0 | 75 } |
cannam@0 | 76 |
cannam@0 | 77 return std::sqrt(dMag); |
cannam@0 | 78 } |
cannam@0 | 79 |
cannam@0 | 80 }; |
cannam@0 | 81 |
cannam@0 | 82 |
cannam@0 | 83 |
cannam@0 | 84 class TonalEstimator |
cannam@0 | 85 { |
cannam@0 | 86 public: |
cannam@0 | 87 TonalEstimator(); |
cannam@0 | 88 virtual ~TonalEstimator(); |
cannam@0 | 89 TCSVector transform2TCS(const ChromaVector& rVector); |
cannam@0 | 90 protected: |
cannam@0 | 91 std::valarray< std::valarray<double> > m_Basis; |
cannam@0 | 92 }; |
cannam@0 | 93 |
cannam@0 | 94 #endif // _TONALESTIMATOR_ |