]> git.rkrishnan.org Git - dttsp.git/blob - jDttSP/chap.h
Initial revision
[dttsp.git] / jDttSP / chap.h
1 /* chap.h
2
3 This file is part of a program that implements a Software-Defined Radio.
4
5 Copyright (C) 2004 by Frank Brickle, AB2KT and Bob McGwier, N4HY
6
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
20
21 The authors can be reached by email at
22
23 ab2kt@arrl.net
24 or
25 rwmcgwier@comcast.net
26
27 or by paper mail at
28
29 The DTTS Microwave Society
30 6 Kathleen Place
31 Bridgewater, NJ 08807
32 */
33
34 #ifndef _chap_h
35 #define _chap_h
36
37 #include <fromsys.h>
38 #include <banal.h>
39 #include <splitfields.h>
40 #include <datatypes.h>
41 #include <bufvec.h>
42 #include <cxops.h>
43 #include <fastrig.h>
44 #include <update.h>
45 #include <lmadf.h>
46 #include <fftw.h>
47 #include <ovsv.h>
48 #include <filter.h>
49 #include <oscillator.h>
50
51 typedef struct
52 _cheby_approx {
53   REAL (*func)(REAL);
54   int len;
55   REAL *coef;
56   struct { REAL lo, hi, df; } lim;
57   char *tag;
58 } ChApDesc, *ChAp;
59
60 #define ChApFunc(p) ((p)->func)
61 #define ChApLen(p) ((p)->len)
62 #define ChApLob(p) ((p)->lim.lo)
63 #define ChApHib(p) ((p)->lim.hi)
64 #define ChApDif(p) ((p)->lim.df)
65 #define ChApCoefBase(p) ((p)->coef)
66 #define ChApCoef(p, i) (((p)->coef)[i])
67 #define ChApTag(p) ((p)->tag)
68
69 extern REAL ChAp_eval(ChAp ca, REAL x, BOOLEAN *err);
70 extern ChAp ChAp_fit(ChAp ca);
71 extern ChAp newChAp(REAL (*func)(REAL arg),
72                     REAL lo,
73                     REAL hi,
74                     int len,
75                     char *tag);
76
77 extern void delChAp(ChAp ca);
78
79 #endif