Minor tidy-ups to MTDM code; add test.
[ardour.git] / libs / ardour / ardour / mtdm.h
1 /*
2     Copyright (C) 2003-2008 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 public:
26
27         MTDM ();
28
29         int process (size_t len, float *inp, float *out);
30         int resolve ();
31         void invert () { _inv ^= 1; }
32         int    inv () { return _inv; }
33         double del () { return _del; }
34         double err () { return _err; }
35
36 private:
37         class Freq {
38                 public:
39                         int   p;
40                         int   f;
41                         float a;
42                         float xa;
43                         float ya;
44                         float xf;
45                         float yf;
46         };
47
48         double  _del;
49         double  _err;
50         int     _cnt;
51         int     _inv;
52         Freq    _freq [5];
53 };
54
55 #endif /* __libardour_mtdm_h__ */