Strip trailing whitespace and fix other whitespace errors (e.g. space/tab mixing...
[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 <cstdlib>
23 #include <cstdio>
24 #include <cmath>
25 #include <unistd.h>
26
27 class MTDM {
28 public:
29
30         MTDM ();
31
32         int process (size_t len, float *inp, float *out);
33         int resolve (void);
34         void invert (void) { _inv ^= 1; }
35         int    inv (void) { return _inv; }
36         double del (void) { return _del; }
37         double err (void) { return _err; }
38
39 private:
40         class Freq {
41                 public:
42                         int   p;
43                         int   f;
44                         float a;
45                         float xa;
46                         float ya;
47                         float xf;
48                         float yf;
49         };
50
51         double  _del;
52         double  _err;
53         int     _cnt;
54         int     _inv;
55         Freq    _freq [5];
56 };
57
58 #endif /* __libardour_mtdm_h__ */