Merge branch 'export-dialog' into cairocanvas
[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
38 private:
39     class Freq {
40       public:
41         int   p;
42         int   f;
43         float xa;
44         float ya;
45         float x1;
46         float y1;
47         float x2;
48         float y2;
49     };
50
51     double  _del;
52     double  _err;
53     float   _wlp;
54     int     _cnt;
55     int     _inv;
56     Freq    _freq [13];
57 };
58
59 #endif /* __libardour_mtdm_h__ */