new MTDM implementation from Fons' latest jack_delay implementation
[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 class MTDM
25 {
26 public:
27
28     MTDM (int fsamp);
29     int process (size_t len, float *inp, float *out);
30     int resolve (void);
31     void invert (void) { _inv ^= 1; }
32     int    inv (void) { return _inv; }
33     double del (void) { return _del; }
34     double err (void) { return _err; }
35
36 private:
37     class Freq {
38       public:
39         int   p;
40         int   f;
41         float xa;
42         float ya;
43         float x1;
44         float y1;
45         float x2;
46         float y2;
47     };
48
49     double  _del;
50     double  _err;
51     float   _wlp;
52     int     _cnt;
53     int     _inv;
54     Freq    _freq [13];
55 };
56
57 #endif /* __libardour_mtdm_h__ */