153int main(
int argc,
char const *argv[])
156 CLI::App app{
"tapipe"};
159 std::string input_file_path;
160 app.add_option(
"-i", input_file_path,
"Input TPStream file path")->required();
161 std::string output_file_path;
162 app.add_option(
"-o", output_file_path,
"Output TPStream file path");
163 std::string channel_map_name =
"VDColdboxTPCChannelMap";
164 app.add_option(
"-m", channel_map_name,
"Detector Channel Map");
165 std::string config_name;
166 app.add_option(
"-j", config_name,
"Trigger Activity and Candidate config JSON to use.")->required();
167 uint64_t skip_rec(0);
168 app.add_option(
"-s", skip_rec,
"Skip records");
170 app.add_option(
"-n", num_rec,
"Process records");
173 app.add_flag(
"--quiet", quiet,
"Quiet outputs.");
175 bool latencies =
false;
176 app.add_flag(
"--latencies", latencies,
"Saves latencies per TP into csv");
177 CLI11_PARSE(app, argc, argv);
181 fmt::print(
"TPStream file: {}\n", input_file_path);
186 auto tp_subsystem_requirement = daqdataformats::SourceID::Subsystem::kTrigger;
188 auto channel_map = dunedaq::detchannelmaps::make_tpc_map(channel_map_name);
191 std::ifstream config_stream(config_name);
192 nlohmann::json config = nlohmann::json::parse(config_stream);
195 nlohmann::json ta_algo = config[
"trigger_activity_plugin"][0];
196 nlohmann::json ta_config = config[
"trigger_activity_config"][0];
198 nlohmann::json tc_algo = config[
"trigger_candidate_plugin"][0];
199 nlohmann::json tc_config = config[
"trigger_candidate_config"][0];
203 std::unique_ptr<triggeralgs::TriggerActivityMaker> ta_maker =
205 ta_maker->configure(ta_config);
206 std::unique_ptr<trgtools::EmulateTAUnit> ta_emulator = std::make_unique<trgtools::EmulateTAUnit>();
207 ta_emulator->set_maker(ta_maker);
210 std::filesystem::path output_path(output_file_path);
211 ta_emulator->set_timing_file((output_path.parent_path() / (
"ta_timings_" + output_path.stem().string() +
".csv")).string());
212 ta_emulator->write_csv_header(
"TP Time Start,TP ADC Integral,Time Diffs,Is Last TP In TA");
216 std::unique_ptr<triggeralgs::TriggerCandidateMaker> tc_maker =
218 tc_maker->configure(tc_config);
219 std::unique_ptr<trgtools::EmulateTCUnit> tc_emulator = std::make_unique<trgtools::EmulateTCUnit>();
220 tc_emulator->set_maker(tc_maker);
223 std::filesystem::path output_path(output_file_path);
224 tc_emulator->set_timing_file((output_path.parent_path() / (
"tc_timings_" + output_path.stem().string() +
".csv")).string());
225 tc_emulator->write_csv_header(
"Time Diffs");
232 return (channel_map->get_plane_from_offline_channel(tp.channel) != 2);
235 tp_filter = z_plane_filter;
238 const std::vector<std::unique_ptr<daqdataformats::Fragment>>& frags = tsl.
get_fragments_ref();
239 const size_t num_frags = frags.size();
241 fmt::print(
"The number of fragments: {}\n", num_frags);
243 uint64_t average_ta_time = 0;
244 uint64_t average_tc_time = 0;
250 for (
size_t i = 0; i < num_frags; i++) {
251 const auto& frag = frags[i];
254 if (frag->get_element_id().subsystem != tp_subsystem_requirement) {
256 fmt::print(
" Warning, got non kTrigger SourceID {}\n", frag->get_element_id().to_string());
261 if(frag->get_fragment_type() != daqdataformats::FragmentType::kTriggerPrimitive){
263 fmt::print(
" Error: FragmentType is: {}!\n", fragment_type_to_string(frag->get_fragment_type()));
269 fmt::print(
" Fragment id: {} [{}]\n", frag->get_element_id().to_string(), daqdataformats::fragment_type_to_string(frag->get_fragment_type()));
274 fmt::print(
" TP fragment size: {}\n", frag->get_data_size());
275 fmt::print(
" Num TPs: {}\n", n_tps);
279 std::vector<trgdataformats::TriggerPrimitive> tp_buffer;
281 tp_buffer.reserve(tp_buffer.size()+n_tps);
285 uint64_t last_ts = 0;
286 for(
size_t i(0); i<n_tps; ++i) {
287 auto& tp = tp_array[i];
288 if (tp.time_start <= last_ts && !quiet) {
289 fmt::print(
" ERROR: {} {} ", +tp.time_start, last_ts );
291 tp_buffer.push_back(tp);
297 fmt::print(
" TS gap: {} {} ms\n", d_ts, d_ts*16.0/1'000'000);
303 const auto ta_start = std::chrono::steady_clock::now();
304 std::unique_ptr<daqdataformats::Fragment> ta_frag = ta_emulator->emulate_vector(tp_buffer);
305 const auto ta_end = std::chrono::steady_clock::now();
307 if (ta_frag ==
nullptr)
309 num_tas += ta_emulator->get_last_output_buffer().size();
312 const uint64_t ta_diff = std::chrono::nanoseconds(ta_end - ta_start).count();
313 average_ta_time += ta_diff;
315 fmt::print(
"\tTA Time Process: {} ns.\n", ta_diff);
323 ta_frag->set_header_fields(frag_hdr);
324 ta_frag->set_type(daqdataformats::FragmentType::kTriggerActivity);
336 std::vector<triggeralgs::TriggerActivity> ta_buffer = ta_emulator->get_last_output_buffer();
337 const auto tc_start = std::chrono::steady_clock::now();
338 std::unique_ptr<daqdataformats::Fragment> tc_frag = tc_emulator->emulate_vector(ta_buffer);
339 const auto tc_end = std::chrono::steady_clock::now();
341 if (tc_frag ==
nullptr)
343 num_tcs += tc_emulator->get_last_output_buffer().size();
346 const uint64_t tc_diff = std::chrono::nanoseconds(tc_end - tc_start).count();
347 average_tc_time += tc_diff;
349 fmt::print(
"\tTC Time Process: {} ns.\n", tc_diff);
353 tc_frag->set_header_fields(frag_hdr);
354 tc_frag->set_type(daqdataformats::FragmentType::kTriggerCandidate);
360 if (num_tas == 0) average_ta_time = 0;
361 else average_ta_time /= num_tas;
362 if (num_tcs == 0) average_tc_time = 0;
363 else average_tc_time /= num_tcs;
365 fmt::print(
"\t\tAverage TA Time Process ({} TAs): {} ns.\n", num_tas, average_ta_time);
366 fmt::print(
"\t\tAverage TC Time Process ({} TCs): {} ns.\n", num_tcs, average_tc_time);
370 rp.
loop(num_rec, skip_rec);