Copiste  0.1
 All Classes Functions Variables Enumerations Friends Pages
lster.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_LSTERH
20 #define INCLUDED_LSTERH
21 
22 class LSTERExtr;
23 
24 #include "features/extractor.h"
25 #include "features/ste.h"
26 
27 const float DEFAULT_STE_BOUND = 0.5;
28 const int DEFAULT_LSTER_CHUNK_SIZE = 40;
29 
35 {
36  public:
38  LSTERExtr(int chunkSize = 0);
39 
41  ~LSTERExtr();
42 
45 
47  bool extract(std::deque<uint16_t> data, int size);
48 
50  float value(int index = 0) { return mLSTER; };
51 
53  int size() { return 1; }
55  float min() { return 0; }
57  float max() { return 1; }
58 
60  void setFloat(string key, float value);
62  void setInt(string key, int value);
64  float getFloat(string key);
66  int getInt(string key);
67 
69  void clear();
70  private:
71  STEExtr *mSteExtr;
72  float* mHistory;
73  int mCurrentFrame;
74 
75  float mLSTER;
76  float mBound;
77  int mChunkSize;
78 };
79 
80 #endif
81