File: realFFT.H

package info (click to toggle)
mffm-fftw 1.7-4
  • links: PTS
  • area: main
  • in suites: bullseye, buster, stretch
  • size: 3,724 kB
  • ctags: 1,182
  • sloc: cpp: 711; makefile: 72
file content (64 lines) | stat: -rw-r--r-- 1,961 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
/* Copyright 2001,2002 Matt Flax <[email protected]>
   This file is part of the MFFM FFTw Wrapper library.

   MFFM MFFM FFTw Wrapper library is free software; you can 
   redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 2 of the License, or
   (at your option) any later version.
   
   MFFM FFTw Wrapper library is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.
   
   You have received a copy of the GNU General Public License
   along with the MFFM FFTw Wrapper library
*/
#ifndef REALFFT_H_
#define REALFFT_H_

#include "realFFTData.H"
#include <fftw3.h>

#include <iostream>
using namespace std;

class realFFTData;

#define PLANTYPE FFTW_ESTIMATE

///class realFFT controls fftw plans and executes fwd/inv transforms
class realFFT {
  /// The fwd/inv plans
  fftw_plan fwdPlan, invPlan;

  /// Method to create the plans
  void createPlan(void);
  /// Method to destroy the plans
  void destroyPlan(void);
protected:
  /// The pointer to the relevant data
  realFFTData *data;
public:
  /// fft init ... don't forget to associate data using switchData
  realFFT(void);
  /// fft init ... data pointed to by 'd'
  realFFT(realFFTData *d);
  /// fft deconstructor
  ~realFFT(void);

  /// Use this to change associated fft data (for fft'ing)
  void switchData(realFFTData *d);

  /// Forward transform the data (in to out)
  void fwdTransform(); // Forward fft
  /// Inverse transform the data (out to in)
  void invTransform(); // Inverse fft
};
/** \example realFFTExample.cc
 * This is an example of how to use the class.
 * It transforms a sine tone stored in the .dat file and saves the
 * in, out, and power_spectrum results of using the class
 */
#endif // REALFFT_H_