gstreamer
Loading...
Searching...
No Matches
publishDigitized.cc
Go to the documentation of this file.
1// gstreamer
4
5// Implementation summary:
6// Flatten run-level digitized detector data into one CSV row per hit.
7
8bool GstreamerCsvFactory::publishRunDigitizedDataImpl(const std::string& detectorName,
9 const std::vector<const GDigitizedData*>& digitizedData) {
10 if (!ofile_digitized.is_open()) {
11 log->error(ERR_CANTOPENOUTPUT, SFUNCTION_NAME, "Error: can't access ", filename_digitized());
12 }
13
14 // Emit the header row from the first non-empty collection so column names match
15 // the detector schema observed in the data.
16 if (!is_first_event_with_digidata) {
17 if (digitizedData.size() > 0) {
18 ofile_digitized << "evn, timestamp, thread_id, detector, ";
19 auto first_hit = digitizedData[0];
20
21 const auto& imap = first_hit->getIntObservablesMap(0);
22 const auto& dmap = first_hit->getDblObservablesMap(0);
23
24 size_t total = dmap.size();
25 size_t i = 0;
26
27 log->debug(NORMAL, SFUNCTION_NAME, "Writing header for event ", event_number, " with ", total,
28 " variables");
29
30 for (const auto& [name, value] : imap) { ofile_digitized << name << ", "; }
31
32 for (const auto& [name, value] : dmap) {
33 ofile_digitized << name;
34 if (++i < total) ofile_digitized << ", ";
35 }
36
37 ofile_digitized << "\n";
38
39 is_first_event_with_digidata = true;
40 }
41 }
42
43 // Once the header exists, every hit becomes one flattened row.
44 if (is_first_event_with_digidata) {
45 for (auto digi_hit : digitizedData) {
46 const auto& imap = digi_hit->getIntObservablesMap(0);
47 const auto& dmap = digi_hit->getDblObservablesMap(0);
48
49 size_t total = dmap.size();
50 size_t i = 0;
51
52 ofile_digitized << event_number << ", " << timestamp << ", " << thread_id << ", " << detectorName << ", ";
53
54 for (const auto& [variableName, value] : imap) { ofile_digitized << value << ", "; }
55 for (const auto& [variableName, value] : dmap) {
56 ofile_digitized << value;
57 if (++i < total) ofile_digitized << ", ";
58 else ofile_digitized << "\n";
59 }
60 }
61 }
62
63 return true;
64}
std::shared_ptr< GLogger > log
void debug(debug_type type, Args &&... args) const
void error(int exit_code, Args &&... args) const
CSV streamer plugin declarations.
Shared constants and error codes for the gstreamer module.
#define ERR_CANTOPENOUTPUT
Output medium could not be opened successfully.