ardour
mtdm.h
Go to the documentation of this file.
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 
25 
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__ */
double del(void)
Definition: mtdm.h:35
int f
Definition: mtdm.h:42
Definition: mtdm.h:26
double err(void)
Definition: mtdm.h:36
float _wlp
Definition: mtdm.h:53
double _del
Definition: mtdm.h:51
int _inv
Definition: mtdm.h:55
double _err
Definition: mtdm.h:52
float xa
Definition: mtdm.h:43
int p
Definition: mtdm.h:41
float x2
Definition: mtdm.h:47
float x1
Definition: mtdm.h:45
float y1
Definition: mtdm.h:46
int _cnt
Definition: mtdm.h:54
void invert(void)
Definition: mtdm.h:33
float y2
Definition: mtdm.h:48
float ya
Definition: mtdm.h:44
int inv(void)
Definition: mtdm.h:34
#define LIBARDOUR_API