Blame view

src/ExternLib/GetClbInfo/GetClbInfoProcess.cc 2.55 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
43
44
45
46
47
48
49
50
51
52
/*
 * GetClbInfoProcess.cc
 *
 *  Created on: Dec 12, 2012
 *      Author: f.casimir
 */
#include <stdlib.h>
#include <string>

#include "AMDA_exception.hh"
#include "DicError.hh"

#include "Operation.hh"
#include "ParameterManager.hh"
#include "GetClbInfoProcess.hh"
#include "GetClbInfoCreator.hh"
#include "ParameterCreatorFromExpression.hh"

using namespace std;
using namespace boost;
using namespace log4cxx;

namespace AMDA {
namespace GetClbInfo {

  GetClbInfoProcess::GetClbInfoProcess(Parameter &parameter)
  : SingleParamProcess_CRTP(parameter) {
  }

  GetClbInfoProcess::GetClbInfoProcess(const GetClbInfoProcess& pProcess, Parameter &parameter)
    : SingleParamProcess_CRTP(pProcess,parameter) {
  }

  GetClbInfoProcess::~GetClbInfoProcess() {
  }

TimeStamp GetClbInfoProcess::init() {
	TimeStamp timeStamp = _parameterInput->init( this, _timeIntervalList);
	Parameter::InfoList lInfoList = _parameterInput->getInfoList();
	_parameter.getInfoList().insert(lInfoList.begin(), lInfoList.end());
	_paramInput = _parameterInput->getParamData(this).get();

	//GET Sampling
	if (_attributList.size() == 0) {
		BOOST_THROW_EXCEPTION(AMDA::AMDA_exception() << AMDA::errno_code(AMDA_PROCESS_ERR) << AMDA::ex_msg(std::string("GetClbInfoProcess::init required at least one attribute'")));
	}

	GetClbInfoCreator lGetClbInfoCreator(*this,*_paramInput);
	_operation = lGetClbInfoCreator.getOperation();
	dynamic_cast<Base::GetClbInfo*>(_operation)->init(*_parameterInput,_attributList);
	_paramData = ParamDataSPtr(_operation->getParamOutput());
	_paramData->setMinSampling(_paramInput->getMinSampling());
d7d55a02   Hacene SI HADJ MOHAND   ok for getClbInfo...
53
54
55
56
                    AMDA::Parameters::SemiVariableTable semiVariableTableElements;
                    int i = 0;
                    unsigned int nbHeader = 0;
                    for (auto info : lInfoList){
7abf24a0   Hacene SI HADJ MOHAND   correcting bug
57
                               semiVariableTableElements.tabValues[std::to_string(i)] = *info.second; 
d7d55a02   Hacene SI HADJ MOHAND   ok for getClbInfo...
58
59
60
61
62
63
64
65
66
67
                               if (nbHeader < (*info.second).size()) 
                                        nbHeader = (*info.second).size();  
                               i++;
                    }
                    for (unsigned int i = 0 ; i < nbHeader; i++)
                        semiVariableTableElements.tabHeader.push_back("Energy[" + std::to_string(i)+"]"); 
                    this->setSemiVariableTable(semiVariableTableElements);
                    if (!semiVariableTableElements.tabValues.empty())
                           _parameterInput->setIsTableIndexParam(true);
           
fbe3c2bb   Benjamin Renard   First commit
68
	return timeStamp;
d7d55a02   Hacene SI HADJ MOHAND   ok for getClbInfo...
69
70
         }

fbe3c2bb   Benjamin Renard   First commit
71
72
73

} /* namespace GetClbInfo */
} /* namespace AMDA */