Blame view

src/Info/ParamTable.hh 4.62 KB
fbe3c2bb   Benjamin Renard   First commit
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
/**
 * ParamTable.hh
 *
 *  Created on: 10 oct. 2014
 *  Author: AKKA
 */

#ifndef PARAMTABLE_HH_
#define PARAMTABLE_HH_

#include "ParameterManager.hh"

#include "log4cxx/logger.h"

namespace AMDA {
namespace Info {

	using namespace AMDA::Parameters;

	/**
	 * @brief Structure that's define a table bound
	 */
	typedef struct {
		int index;
		double min;
		double max;
	} t_TableBound;

	/**
	 * @class ParamTable
	 * @brief Abstract class used to define a Parameter table .
	 * @details
	 */
	class ParamTable
	{
	public:
		ParamTable(const char *paramId);

		virtual ~ParamTable();

		virtual int getSize(ParameterManager *parameterManager) = 0;

f2db3c16   Benjamin Renard   Support variable ...
43
		virtual t_TableBound getBound(ParameterManager *parameterManager, unsigned int index, std::map<std::string, std::vector<double>>* paramsTableData = NULL) = 0;
fbe3c2bb   Benjamin Renard   First commit
44
45
46
47
48
49
50
51
52
53
54

		void setParameterLink(ParameterSPtr parameter);

		void setName(std::string name);

		std::string getName(void);

		void setUnits(std::string name);

		std::string getUnits(void);

f2db3c16   Benjamin Renard   Support variable ...
55
56
57
58
59
60
61
62
63
64
		void setIsVariable(bool isVariable);

		bool isVariable(void);

		void addTableParam(std::string key, std::string name);

		std::string getTableParamByKey(std::string key);

		std::map<std::string, std::string>& getTableParams();

fbe3c2bb   Benjamin Renard   First commit
65
66
67
68
69
70
71
72
73
	protected:
		/** logger of paramTable */
		static log4cxx::LoggerPtr _logger;

		std::string _paramId;

		std::string _tableName;

		std::string _tableUnits;
f2db3c16   Benjamin Renard   Support variable ...
74
75
76
77
78
79
80
81
82
83

		bool _variable;

		std::map<std::string, std::string> _tableParams;

		std::vector<double> getTableParamValuesByKey(ParameterManager *parameterManager, std::map<std::string, std::vector<double>>* paramsTableData, std::string key);

		std::vector<double> getConstantTableParamValuesByKey(ParameterManager *parameterManager, std::string key);

		std::vector<double> getVariableTableParamValuesByKey(std::map<std::string, std::vector<double>>* paramsTableData, std::string key);
fbe3c2bb   Benjamin Renard   First commit
84
85
86
87
88
89
90
91
92
	};

	/**
	 * @class ParamBoundsTable
	 * @brief Implementation of a ParamTable for a table defined by a list
	 * @details
	 */
	class ParamBoundsTable : public ParamTable {
	public:
f2db3c16   Benjamin Renard   Support variable ...
93
		ParamBoundsTable(const char *paramId);
fbe3c2bb   Benjamin Renard   First commit
94
95
96

		virtual int getSize(ParameterManager *parameterManager);

f2db3c16   Benjamin Renard   Support variable ...
97
		virtual t_TableBound getBound(ParameterManager *parameterManager, unsigned int index, std::map<std::string, std::vector<double>>* paramsTableData = NULL);
fbe3c2bb   Benjamin Renard   First commit
98

f2db3c16   Benjamin Renard   Support variable ...
99
		static std::string _boundsParamKey;
fbe3c2bb   Benjamin Renard   First commit
100
101
102
103
104
105
106
107
108
	};

	/**
	 * @class ParamCenterTable
	 * @brief Implementation of a ParamTable for a table defined by a list of center value and a size
	 * @details
	 */
	class ParamCenterTable : public ParamTable {
	public:
f2db3c16   Benjamin Renard   Support variable ...
109
		ParamCenterTable(const char *paramId, double size);
fbe3c2bb   Benjamin Renard   First commit
110
111
112

		virtual int getSize(ParameterManager *parameterManager);

f2db3c16   Benjamin Renard   Support variable ...
113
114
115
		virtual t_TableBound getBound(ParameterManager *parameterManager, unsigned int index, std::map<std::string, std::vector<double>>* paramsTableData = NULL);

		static std::string _centersParamKey;
fbe3c2bb   Benjamin Renard   First commit
116
117

	private:
fbe3c2bb   Benjamin Renard   First commit
118
119
120
121
		double _size;
	};

	/**
f5c53312   Benjamin Renard   Get calib info in...
122
123
124
125
126
127
	 * @class ParamCenterWidthTable
	 * @brief Implementation of a ParamTable for a table defined by a list of center value and a list of band width
	 * @details
	 */
	class ParamCenterWidthTable : public ParamTable {
	public:
f2db3c16   Benjamin Renard   Support variable ...
128
		ParamCenterWidthTable(const char *paramId);
f5c53312   Benjamin Renard   Get calib info in...
129
130
131

		virtual int getSize(ParameterManager *parameterManager);

f2db3c16   Benjamin Renard   Support variable ...
132
		virtual t_TableBound getBound(ParameterManager *parameterManager, unsigned int index, std::map<std::string, std::vector<double>>* paramsTableData = NULL);
f5c53312   Benjamin Renard   Get calib info in...
133

f2db3c16   Benjamin Renard   Support variable ...
134
135
		static std::string _centersParamKey;
		static std::string _widthsParamKey;
f5c53312   Benjamin Renard   Get calib info in...
136
137
138
	};

	/**
65c661e8   Benjamin Renard   Table definition ...
139
140
141
142
143
144
	 * @class ParamCenterAutoTable
	 * @brief Implementation of a ParamTable for a table defined by a list of center value. Bounds automatically computed to be at the center of two consecutive channels
	 * @details
	 */
	class ParamCenterAutoTable : public ParamTable {
	public:
f2db3c16   Benjamin Renard   Support variable ...
145
		ParamCenterAutoTable(const char *paramId, bool log);
65c661e8   Benjamin Renard   Table definition ...
146
147
148

		virtual int getSize(ParameterManager *parameterManager);

f2db3c16   Benjamin Renard   Support variable ...
149
150
151
		virtual t_TableBound getBound(ParameterManager *parameterManager, unsigned int index, std::map<std::string, std::vector<double>>* paramsTableData = NULL);

		static std::string _centersParamKey;
65c661e8   Benjamin Renard   Table definition ...
152
153

	private:
65c661e8   Benjamin Renard   Table definition ...
154
155
156
157
		bool _log;
	};

	/**
fbe3c2bb   Benjamin Renard   First commit
158
159
160
161
162
163
	 * @class ParamMinMaxTable
	 * @brief Implementation of a ParamTable for a table defined by two list: one for min and one for max
	 * @details
	 */
	class ParamMinMaxTable : public ParamTable {
		public:
f2db3c16   Benjamin Renard   Support variable ...
164
			ParamMinMaxTable(const char *paramId);
fbe3c2bb   Benjamin Renard   First commit
165
166
167

			virtual int getSize(ParameterManager *parameterManager);

f2db3c16   Benjamin Renard   Support variable ...
168
			virtual t_TableBound getBound(ParameterManager *parameterManager, unsigned int index, std::map<std::string, std::vector<double>>* paramsTableData = NULL);
fbe3c2bb   Benjamin Renard   First commit
169

f2db3c16   Benjamin Renard   Support variable ...
170
171
			static std::string _minParamKey;
			static std::string _maxParamKey;
fbe3c2bb   Benjamin Renard   First commit
172
173
174
175
176
	};
} /* namespace Info */
} /* namespace AMDA */

#endif /* PARAMTABLE_HH_ */