Mercurial > hg > qm-dsp
diff dsp/tonal/TCSgram.h @ 0:d7116e3183f8
* Queen Mary C++ DSP library
author | cannam |
---|---|
date | Wed, 05 Apr 2006 17:35:59 +0000 |
parents | |
children | e5907ae6de17 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/dsp/tonal/TCSgram.h Wed Apr 05 17:35:59 2006 +0000 @@ -0,0 +1,44 @@ +/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ + +/* + QM DSP Library + + Centre for Digital Music, Queen Mary, University of London. + This file copyright 2006 Martin Gasser. + All rights reserved. +*/ + +#ifndef _TCSGram_ +#define _TCSGram_ + +#include <vector> +#include <valarray> +#include <utility> + +#include "TonalEstimator.h" + +typedef std::vector<std::pair<long, TCSVector> > vectorlist_t; + +class TCSGram +{ +public: + TCSGram(); + ~TCSGram(); + void getTCSVector(int, TCSVector&) const; + void addTCSVector(const TCSVector&); + long getTime(size_t) const; + long getDuration() const; + void printDebug(); + int getSize() const { return m_VectorList.size(); } + void reserve(size_t uSize) { m_VectorList.reserve(uSize); } + void clear() { m_VectorList.clear(); } + void setFrameDuration(const double dFrameDurationMS) { m_dFrameDurationMS = dFrameDurationMS; } + void setNumBins(const unsigned int uNumBins) { m_uNumBins = uNumBins; } + void normalize(); +protected: + vectorlist_t m_VectorList; + unsigned int m_uNumBins; + double m_dFrameDurationMS; +}; + +#endif