11 std::shared_ptr<GLogger>& logger) : log(logger) {
17 root_tree->SetAutoFlush(20 * 1024 * 1024);
20 root_tree->SetAutoSave(50 * 1024 * 1024);
22 registerVariable(
"g4localEventNumber", gevent_header->getG4LocalEvn());
23 registerVariable(
"threadID", gevent_header->getThreadID());
24 registerVariable(
"timeStamp", gevent_header->getTimeStamp());
29 std::shared_ptr<GLogger>& logger) : log(logger) {
34 root_tree->SetAutoFlush(20 * 1024 * 1024);
35 root_tree->SetAutoSave(50 * 1024 * 1024);
46 std::shared_ptr<GLogger>& logger) : log(logger) {
50 root_tree->SetAutoFlush(20 * 1024 * 1024);
51 root_tree->SetAutoSave(50 * 1024 * 1024);
63 std::shared_ptr<GLogger>& logger) : log(logger) {
67 root_tree->SetAutoFlush(20 * 1024 * 1024);
68 root_tree->SetAutoSave(50 * 1024 * 1024);
70 for (
auto& [varname, value] : gdata->
getIntObservablesMap(0)) { registerVariable(varname, value); }
71 for (
auto& [varname, value] : gdata->
getDblObservablesMap(0)) { registerVariable(varname, value); }
76 log->
info(2,
"Filling header tree for local event n. ", gevent_header->getG4LocalEvn(),
" threadID ",
77 gevent_header->getThreadID());
80 intVarsMap[
"g4localEventNumber"].clear();
81 intVarsMap[
"threadID"].clear();
82 stringVarsMap[
"timeStamp"].clear();
84 intVarsMap[
"g4localEventNumber"].emplace_back(gevent_header->getG4LocalEvn());
85 intVarsMap[
"threadID"].emplace_back(gevent_header->getThreadID());
86 stringVarsMap[
"timeStamp"].emplace_back(gevent_header->getTimeStamp());
95 log->
info(2,
"Filling header tree for run n. ",
grun_header->getRunID());
98 intVarsMap[
"runID"].clear();
99 intVarsMap[
"runID"].emplace_back(
grun_header->getRunID());
109 for (
auto& [varname, values] : doubleVarsMap) { values.clear(); }
110 for (
auto& [varname, values] : stringVarsMap) { values.clear(); }
112 for (
auto& dataHits : trueInfoData) {
113 for (
auto& [varname, value] : dataHits->getDoubleVariablesMap()) { doubleVarsMap[varname].push_back(value); }
114 for (
auto& [varname, value] : dataHits->getStringVariablesMap()) { stringVarsMap[varname].push_back(value); }
125 for (
auto& [varname, values] : intVarsMap) { values.clear(); }
126 for (
auto& [varname, values] : doubleVarsMap) { values.clear(); }
128 for (
auto& dataHits : digitizedData) {
129 for (
auto& [varname, value] : dataHits->getIntObservablesMap(0)) { intVarsMap[varname].push_back(value); }
130 for (
auto& [varname, value] : dataHits->getDblObservablesMap(0)) { doubleVarsMap[varname].push_back(value); }
142void GRootTree::registerVariable(
const std::string& varname, [[maybe_unused]]
int value) {
143 if (intVarsMap.find(varname) == intVarsMap.end()) { root_tree->Branch(varname.c_str(), &intVarsMap[varname]); }
146 "< already exist in the int variable map of tree ", root_tree->GetName());
150void GRootTree::registerVariable(
const std::string& varname, [[maybe_unused]]
double value) {
151 if (doubleVarsMap.find(varname) == doubleVarsMap.end()) {
152 root_tree->Branch(varname.c_str(), &doubleVarsMap[varname]);
156 "< already exist in the double variable map of tree ", root_tree->GetName());
160void GRootTree::registerVariable(
const std::string& varname, [[maybe_unused]]
const std::string& value) {
161 if (stringVarsMap.find(varname) == stringVarsMap.end()) {
162 root_tree->Branch(varname.c_str(), &stringVarsMap[varname]);
166 "< already exist in the string variable map of tree ", root_tree->GetName());
std::map< std::string, int > getIntObservablesMap(int which) const
std::map< std::string, double > getDblObservablesMap(int which) const
void debug(debug_type type, Args &&... args) const
void info(int level, Args &&... args) const
void error(int exit_code, Args &&... args) const
GRootTree(const std::unique_ptr< GEventHeader > &gevent_header, std::shared_ptr< GLogger > &log)
Construct an event-header tree and register its branches.
bool fillTree(const std::unique_ptr< GEventHeader > &gevent_header)
Fill the event-header tree with one event header entry.
std::map< std::string, double > getDoubleVariablesMap() const
std::map< std::string, std::string > getStringVariablesMap() const
ROOT tree adapter used internally by the ROOT gstreamer plugin.
#define DIGITIZEDTREENAMEDESC
#define TRUEINFOTREENAMEDESC
#define RUNHEADERTREENAMEDESC
#define EVENTHEADERTREENAMEDESC
#define EVENTHEADERTREENAME
#define RUNHEADERTREENAME
Shared constants and error codes for the gstreamer module.
#define ERR_GSTREAMERVARIABLEEXISTS
Duplicate variable registration was attempted in a streamer-specific schema.