Merge branch 'windows' of git.ardour.org:ardour/ardour into windows
[ardour.git] / libs / qm-dsp / dsp / rhythm / BeatSpectrum.h
1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*-  vi:set ts=8 sts=4 sw=4: */
2
3 /*
4     QM DSP Library
5
6     Centre for Digital Music, Queen Mary, University of London.
7     This file copyright 2008 Kurt Jacobson and QMUL.
8
9     This program is free software; you can redistribute it and/or
10     modify it under the terms of the GNU General Public License as
11     published by the Free Software Foundation; either version 2 of the
12     License, or (at your option) any later version.  See the file
13     COPYING included with this distribution for more information.
14 */
15
16 #ifndef BEATSPECTRUM_H
17 #define BEATSPECTRUM_H
18
19 #include <vector>
20
21 /**
22  * Given a matrix of "feature values", calculate a self-similarity
23  * vector.  The resulting vector will have half as many elements as
24  * the number of columns in the matrix.  This is based on the
25  * SoundBite rhythmic similarity code.
26  */
27
28 class BeatSpectrum
29 {
30 public:
31     BeatSpectrum() { }
32     ~BeatSpectrum() { }
33
34     std::vector<double> process(const std::vector<std::vector<double> > &inmatrix);
35
36 };
37
38 #endif
39
40