Make Region's _beat a PBD::Property.
[ardour.git] / libs / ardour / ardour / mtdm.h
1 /*
2     Copyright (C) 2003-2012 Fons Adriaensen <fons@kokkinizita.net>
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17 */
18
19 #ifndef __libardour_mtdm_h__
20 #define __libardour_mtdm_h__
21
22 #include <stddef.h>
23
24 #include "ardour/libardour_visibility.h"
25
26 class LIBARDOUR_API MTDM
27 {
28 public:
29
30     MTDM (int fsamp);
31     int process (size_t len, float *inp, float *out);
32     int resolve (void);
33     void invert (void) { _inv ^= 1; }
34     int    inv (void) { return _inv; }
35     double del (void) { return _del; }
36     double err (void) { return _err; }
37     float get_peak () { const float rv = _peak; _peak = 0; return rv; }
38
39 private:
40     class Freq {
41       public:
42         int   p;
43         int   f;
44         float xa;
45         float ya;
46         float x1;
47         float y1;
48         float x2;
49         float y2;
50     };
51
52     double  _del;
53     double  _err;
54     float   _wlp;
55     int     _cnt;
56     int     _inv;
57     Freq    _freq [13];
58     float   _peak;
59 };
60
61 #endif /* __libardour_mtdm_h__ */