Copiste
0.1
Main Page
Related Pages
Classes
Files
File List
All
Classes
Functions
Variables
Enumerations
Friends
Pages
include
filters
highlowratio.h
1
/*
2
* This file is part of Copiste.
3
*
4
* Copiste is free software: you can redistribute it and/or modify
5
* it under the terms of the GNU General Public License as published by
6
* the Free Software Foundation, either version 3 of the License, or
7
* (at your option) any later version.
8
*
9
* Copiste is distributed in the hope that it will be useful,
10
* but WITHOUT ANY WARRANTY; without even the implied warranty of
11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
* GNU General Public License for more details.
13
*
14
* You should have received a copy of the GNU General Public License
15
* along with Copiste. If not, see <http://www.gnu.org/licenses/>.
16
*/
17
18
19
#ifndef INCLUDED_HIGHLOWRATIOH
20
#define INCLUDED_HIGHLOWRATIOH
21
22
#include "filters/filter.h"
23
24
const
int
DEFAULT_HIGH_LOW_WINDOW_SIZE = 100;
25
32
class
HighLowRatioFilter
:
public
Filter
33
{
34
public
:
36
HighLowRatioFilter
() : mBound(1),
37
mHigh(true),
38
mWindowSize(DEFAULT_HIGH_LOW_WINDOW_SIZE),
39
mCurrentIndex(0)
40
{ ; }
41
43
~HighLowRatioFilter
();
44
46
void
transform
(vector<float> data);
47
49
float
value
(
int
index = 0) {
return
mResults[index] / mWindowSize; }
50
52
void
setFloat
(
string
key,
float
value
);
54
void
setInt
(
string
key,
int
value
);
56
float
getFloat
(
string
key);
58
virtual
int
getInt
(
string
key);
59
61
int
size
() {
return
mResults.size(); }
63
float
min
() {
return
0; }
65
float
max
() {
return
1; }
66
67
private
:
68
void
reallocate(
unsigned
int
newSize);
69
70
float
mBound;
71
bool
mHigh;
72
int
mWindowSize;
73
vector<float> mResults;
74
vector<float> mAverage;
75
vector<float*> mMemory;
76
unsigned
int
mCurrentIndex;
77
};
78
79
#endif
Generated on Sun Sep 2 2012 09:48:30 for Copiste by
1.8.1.1