annotate dsp/tonal/ChangeDetectionFunction.h @ 0:d7116e3183f8

* Queen Mary C++ DSP library
author cannam
date Wed, 05 Apr 2006 17:35:59 +0000
parents
children 980b1a3b9cbe
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 _CHANGEDETECTIONFUNCTION_
cannam@0 12 #define _CHANGEDETECTIONFUNCTION_
cannam@0 13
cannam@0 14 #define DEBUG_CHANGE_DETECTION_FUNCTION 1
cannam@0 15
cannam@0 16 #include "TCSgram.h"
cannam@0 17
cannam@0 18 #include <valarray>
cannam@0 19 using std::valarray;
cannam@0 20
cannam@0 21 typedef valarray<double> ChangeDistance;
cannam@0 22
cannam@0 23 struct ChangeDFConfig
cannam@0 24 {
cannam@0 25 int smoothingWidth;
cannam@0 26 };
cannam@0 27
cannam@0 28 class ChangeDetectionFunction
cannam@0 29 {
cannam@0 30 public:
cannam@0 31 ChangeDetectionFunction(ChangeDFConfig);
cannam@0 32 ~ChangeDetectionFunction();
cannam@0 33 ChangeDistance process(const TCSGram& rTCSGram);
cannam@0 34 private:
cannam@0 35 void setFilterWidth(const int iWidth);
cannam@0 36
cannam@0 37 private:
cannam@0 38 valarray<double> m_vaGaussian;
cannam@0 39 double m_dFilterSigma;
cannam@0 40 int m_iFilterWidth;
cannam@0 41 };
cannam@0 42
cannam@0 43 #endif // _CHANGDETECTIONFUNCTION_