36 namespace po = boost::program_options;
38 TString dir = getenv(
"VMCWORKDIR");
39 TString path = dir +
"/input/";
43 std::vector<std::string> configuration;
46 po::options_description desc(
"Options");
47 desc.add_options()(
"VERSION.id", po::value<float>(&version),
48 "version identificator")(
"COMMENT.str", po::value<std::string>(&comment),
"comment")(
49 "CONFIGURATION.config", po::value<std::vector<std::string>>(&configuration)->multitoken(),
"configuration");
53 std::ifstream config_file((path + mappingFile).Data(), std::ifstream::in);
54 if (!config_file.is_open()) {
55 LOG(error) << Form(
"BmnScWallRaw2Digit : Loading Config from file: %s - file open error!", mappingFile.Data());
58 LOG(debug) << Form(
"BmnScWallRaw2Digit : Loading Config from file: %s", mappingFile.Data());
59 po::store(po::parse_config_file(config_file, desc), vm);
63 std::string board_serial;
68 fuoChannelMap.clear();
69 for (
auto it : configuration) {
71 ss >> board_serial >> board_channel >> cell_id >> zone;
75 auto key = std::make_pair(std::stoul(board_serial,
nullptr, 16), board_channel);
84 namespace po = boost::program_options;
86 TString dir = getenv(
"VMCWORKDIR");
87 TString path = dir +
"/parameters/scwall/";
91 std::vector<std::string> harmonics;
92 std::vector<std::string> calibrations;
95 po::options_description desc(
"Options");
96 desc.add_options()(
"VERSION.id", po::value<float>(&version),
97 "version identificator")(
"COMMENT.str", po::value<std::string>(&comment),
"comment")(
99 "writing waveforms")(
"PARAMETERS.gateBegin", po::value<int>(&
fdigiPars.
gateBegin),
"digi parameters")(
101 "digi parameters")(
"PARAMETERS.threshold", po::value<float>(&
fdigiPars.
threshold),
"digi parameters")(
103 "digi parameters")(
"PARAMETERS.doInvert", po::value<bool>(&
fdigiPars.
doInvert),
"digi parameters")(
104 "FITPARAMETERS.isfit", po::value<bool>(&
fdigiPars.
isfit),
"digi parameters")(
105 "FITPARAMETERS.harmonic", po::value<std::vector<std::string>>(&harmonics)->multitoken(),
"fit harmonics")(
106 "CALIBRATION.calib", po::value<std::vector<std::string>>(&calibrations)->multitoken(),
"calibrations");
109 po::variables_map vm;
110 std::ifstream calib_file((path + calibrationFile).Data(), std::ifstream::in);
111 if (!calib_file.is_open()) {
112 LOG(error) << Form(
"BmnScWallRaw2Digit : Loading Calibration from file: %s - file open error!",
113 calibrationFile.Data());
116 LOG(debug) << Form(
"BmnScWallRaw2Digit : Loading Calibration from file: %s", calibrationFile.Data());
117 po::store(po::parse_config_file(calib_file, desc), vm);
121 for (
auto str : harmonics) {
122 if (str.find(
',') != std::string::npos) {
124 std::string real_part_str, imaginary_part_str;
125 std::istringstream iss(str);
126 std::getline(iss, real_part_str,
',');
127 std::getline(iss, imaginary_part_str);
130 float real_part = std::stof(real_part_str);
131 float imaginary_part = std::stof(imaginary_part_str);
143 for (
auto it : calibrations) {
144 istringstream ss(it);
145 ss >> cell_id >> calibration >> calibError;
147 fuoCalibMap[address] = std::make_pair(calibration, calibError);
153 auto maxElement = std::max_element(
155 [](
const std::complex<float>& a,
const std::complex<float>& b) { return std::abs(a) < std::abs(b); });
158 int maxElementLength = floor(5. / (-
log(real(*maxElement))));
163 fAZik =
new std::complex<float>*[model_order];
164 for (
int i = 0;
i < model_order;
i++) {
165 fAZik[
i] =
new std::complex<float>[model_order];
166 for (
int j = 0; j < model_order; j++)
201 LOG(debug) <<
"BmnScWallRaw2Digit::fillEvent";
203 for (
int i = 0;
i < data->GetEntriesFast();
i++) {
207 if (!catch_address.has_value())
209 auto address = catch_address.value();
214 if (!catch_calib.has_value())
216 auto calib_pair = catch_calib.value();
225 LOG(debug4) <<
"BmnScWallRaw2Digit::ProcessWfm Calibration";
233 TClonesArray& ar_ScWall = *ScWalldigit;
234 new (ar_ScWall[ScWalldigit->GetEntriesFast()])
BmnScWallDigi(ThisDigi);