]> git.rkrishnan.org Git - dttsp.git/blob - jDttSP/ovsv.h
f4baa164c97b5745fc24dd0d9f607f8cd839c874
[dttsp.git] / jDttSP / ovsv.h
1 /* ovsv.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 _ovsv_h
35 #define _ovsv_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 <update.h>
44 #include <lmadf.h>
45 #include <fftw.h>
46
47 typedef
48 struct _filt_ov_sav {
49   int buflen, fftlen;
50   COMPLEX *zfvec, *zivec, *zovec, *zrvec;
51   fftw_plan pfwd, pinv;
52   REAL scale;
53 } filt_ov_sv, *FiltOvSv;
54
55 extern FiltOvSv newFiltOvSv(COMPLEX *coefs,
56                             int ncoef,
57                             int pbits);
58 extern void delFiltOvSv(FiltOvSv p);
59
60 extern COMPLEX *FiltOvSv_initpoint(FiltOvSv pflt);
61 extern int FiltOvSv_initsize(FiltOvSv pflt);
62
63 extern COMPLEX *FiltOvSv_fetchpoint(FiltOvSv pflt);
64 extern int FiltOvSv_fetchsize(FiltOvSv pflt);
65
66 extern COMPLEX *FiltOvSv_storepoint(FiltOvSv pflt);
67 extern int FiltOvSv_storesize(FiltOvSv pflt);
68
69 extern COMPLEX *FiltOvSv_fetchpt_par(FiltOvSv pflt, int parity);
70 extern COMPLEX *FiltOvSv_storept_par(FiltOvSv pflt, int parity);
71
72 extern void filter_OvSv(FiltOvSv pflt);
73 extern void filter_OvSv_par(FiltOvSv pflt);
74 #endif