]> git.rkrishnan.org Git - dttsp.git/blob - jDttSP/spectrum.h
Major changes. Added metering and power spectrum, other fixes. Rearranged headers...
[dttsp.git] / jDttSP / spectrum.h
1 /* spectrum.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 _spectrum_h
35 #define _spectrum_h
36
37 #include <fromsys.h>
38 #include <defs.h>
39 #include <banal.h>
40 #include <splitfields.h>
41 #include <datatypes.h>
42 #include <bufvec.h>
43 #include <cxops.h>
44 #include <ringb.h>
45 #include <chan.h>
46 #include <lmadf.h>
47 #include <fftw.h>
48 #include <ovsv.h>
49 #include <filter.h>
50 #include <oscillator.h>
51 #include <digitalagc.h>
52 #include <am_demod.h>
53 #include <fm_demod.h>
54 #include <noiseblanker.h>
55 #include <correctIQ.h>
56 #include <crc16.h>
57 #include <speechproc.h>
58 #include <spottone.h>
59 #include <update.h>
60
61 #define SPEC_MAG        (0)
62 #define SPEC_PWR        (1)
63
64 #define SPEC_SEMI_RAW   (0)
65 #define SPEC_PRE_FILT   (1)
66 #define SPEC_POST_FILT  (2)
67
68 typedef
69 struct _spec_block {
70   BOOLEAN flag;
71   int label;
72   CXB accum, timebuf, freqbuf;
73   int fill, buflen, rxk, scale, size, type;
74   REAL *window;
75   float *output;
76   int planbits;
77   fftw_plan plan;
78 } SpecBlock;
79
80 extern void init_spectrum(SpecBlock *sb);
81 extern void reinit_spectrum(SpecBlock *sb);
82 extern void snap_spectrum(SpecBlock *sb, int label);
83 extern void compute_spectrum(SpecBlock *sb);
84 extern void finish_spectrum(SpecBlock *sb);
85
86 #endif