SciDAVis  1.D4
FFTFilter.h
Go to the documentation of this file.
1 /***************************************************************************
2  File : FFTFilter.h
3  Project : SciDAVis
4  --------------------------------------------------------------------
5  Copyright : (C) 2007 by Ion Vasilief
6  Email (use @ for *) : ion_vasilief*yahoo.fr
7  Description : Numerical FFT filtering of data sets
8 
9  ***************************************************************************/
10 
11 /***************************************************************************
12  * *
13  * This program is free software; you can redistribute it and/or modify *
14  * it under the terms of the GNU General Public License as published by *
15  * the Free Software Foundation; either version 2 of the License, or *
16  * (at your option) any later version. *
17  * *
18  * This program is distributed in the hope that it will be useful, *
19  * but WITHOUT ANY WARRANTY; without even the implied warranty of *
20  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
21  * GNU General Public License for more details. *
22  * *
23  * You should have received a copy of the GNU General Public License *
24  * along with this program; if not, write to the Free Software *
25  * Foundation, Inc., 51 Franklin Street, Fifth Floor, *
26  * Boston, MA 02110-1301 USA *
27  * *
28  ***************************************************************************/
29 #ifndef FFTFILTER_H
30 #define FFTFILTER_H
31 
32 #include "Filter.h"
33 
34 class FFTFilter : public Filter
35 {
36 Q_OBJECT
37 
38 public:
39  FFTFilter(ApplicationWindow *parent, Graph *g, const QString& curveTitle, int m = 1);
40  FFTFilter(ApplicationWindow *parent, Graph *g, const QString& curveTitle, double start, double end, int m = 1);
41 
42  enum FilterType{LowPass = 1, HighPass = 2, BandPass = 3, BandBlock = 4};
43 
44  void setFilterType(int type);
45  void setFilterType(FilterType type){setFilterType((int)type);};
46 
48  void setCutoff(double f);
49 
51  void setBand(double lowFreq, double highFreq);
52 
54  void enableOffset(bool offset = true){d_offset = offset;};
55 
56 private:
57  void init(int m);
58  void calculateOutputData(double *x, double *y);
59 
62 
64  double d_low_freq;
65 
67  double d_high_freq;
68 
70  bool d_offset;
71 };
72 
73 #endif