summaryrefslogtreecommitdiff
path: root/gtk2_ardour/fft_result.h
blob: ddf2bb18424fdd04568b4b817960dbb013685fde (plain)
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
65
66
67
68
69
70
71
72
73
74
75
76
77
/*
    Copyright (C) 2006 Paul Davis
	Written by Sampo Savolainen

    This program 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.

    This program 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 should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.

*/

#ifndef __ardour_fft_result_h
#define __ardour_fft_result_h

#include <fftw3.h>

#include <gdkmm/color.h>

#include <string>

class FFTGraph;

class FFTResult
{
	public:

		~FFTResult();

		void analyzeWindow(float *window);
		void finalize();

		int length() const { return _dataSize; }

		float avgAt(int x);
		float maxAt(int x);
		float minAt(int x);

		float minimum() const { return _minimum; }
		float maximum() const { return _maximum; }

		Gdk::Color get_color() const { return _color; }

	private:
		FFTResult(FFTGraph *graph, Gdk::Color color, std::string trackname);

		int 	_averages;

		float*	_data_avg;
		float*  _data_max;
		float*  _data_min;

		float*	_work;

		int	_windowSize;
		int 	_dataSize;

		float 	_minimum;
		float 	_maximum;

		FFTGraph *_graph;

		Gdk::Color _color;
		std::string _trackname;

	friend class FFTGraph;
};

#endif /* __ardour_fft_result_h */