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 log->
info(2,
"Filling header tree for local event n. ", gevent_header->getG4LocalEvn(),
" threadID ",
30 gevent_header->getThreadID());
33 intVarsMap[
"g4localEventNumber"].clear();
34 intVarsMap[
"threadID"].clear();
35 stringVarsMap[
"timeStamp"].clear();
37 intVarsMap[
"g4localEventNumber"].emplace_back(gevent_header->getG4LocalEvn());
38 intVarsMap[
"threadID"].emplace_back(gevent_header->getThreadID());
39 stringVarsMap[
"timeStamp"].emplace_back(gevent_header->getTimeStamp());
48 log->
info(2,
"Filling header tree for run n. ",
grun_header->getRunID());
51 intVarsMap[
"runID"].clear();
52 intVarsMap[
"runID"].emplace_back(
grun_header->getRunID());
60 std::shared_ptr<GLogger>& logger) : log(logger) {
64 root_tree->SetAutoFlush(20 * 1024 * 1024);
65 root_tree->SetAutoSave(50 * 1024 * 1024);
76 std::shared_ptr<GLogger>& logger) : log(logger) {
80 root_tree->SetAutoFlush(20 * 1024 * 1024);
81 root_tree->SetAutoSave(50 * 1024 * 1024);
85 for (
auto& [varname, value] : identityMap) { registerVariable(varname, value); }
97 std::shared_ptr<GLogger>& logger) : log(logger) {
101 root_tree->SetAutoFlush(20 * 1024 * 1024);
102 root_tree->SetAutoSave(50 * 1024 * 1024);
106 for (
auto& [varname, value] : identityMap) { registerVariable(varname, value,
true); }
109 registerVariable(varname, value);
111 for (
auto& [varname, value] : gdata->
getDblObservablesMap(0)) { registerVariable(varname, value); }
118 for (
auto& [varname, values] : intVarsMap) { values.clear(); }
119 for (
auto& [varname, values] : doubleVarsMap) { values.clear(); }
120 for (
auto& [varname, values] : stringVarsMap) { values.clear(); }
123 for (
auto& dataHits : trueInfoData) {
126 for (
auto& [varname, value] : identityMap) {
127 intVarsMap[varname].push_back(value);
130 for (
auto& [varname, value] : dataHits->getDoubleVariablesMap()) { doubleVarsMap[varname].push_back(value); }
131 for (
auto& [varname, value] : dataHits->getStringVariablesMap()) { stringVarsMap[varname].push_back(value); }
142 for (
auto& [varname, values] : intVarsMap) { values.clear(); }
143 for (
auto& [varname, values] : doubleVarsMap) { values.clear(); }
144 for (
auto& [varname, values] : stringVarsMap) { values.clear(); }
147 for (
auto& dataHits : digitizedData) {
150 for (
auto& [varname, value] : identityMap) {
151 intVarsMap[varname].push_back(value);
155 for (
auto& [varname, value] : dataHits->getIntObservablesMap(0)) { intVarsMap[varname].push_back(value); }
156 for (
auto& [varname, value] : dataHits->getDblObservablesMap(0)) { doubleVarsMap[varname].push_back(value); }
168void GRootTree::registerVariable(
const std::string& varname, [[maybe_unused]]
int value,
bool can_ignore_duplicates) {
169 if (can_ignore_duplicates) {
170 root_tree->Branch(varname.c_str(), &intVarsMap[varname]);
173 if (intVarsMap.find(varname) == intVarsMap.end()) { root_tree->Branch(varname.c_str(), &intVarsMap[varname]); }
176 "> already registered in the int variable map of tree ", root_tree->GetName());
181void GRootTree::registerVariable(
const std::string& varname, [[maybe_unused]]
double value) {
182 if (doubleVarsMap.find(varname) == doubleVarsMap.end()) {
183 root_tree->Branch(varname.c_str(), &doubleVarsMap[varname]);
187 "> already registered in the double variable map of tree ", root_tree->GetName());
191void GRootTree::registerVariable(
const std::string& varname, [[maybe_unused]]
const std::string& value) {
192 if (stringVarsMap.find(varname) == stringVarsMap.end()) {
193 root_tree->Branch(varname.c_str(), &stringVarsMap[varname]);
197 "> already registered in the string variable map of tree ", root_tree->GetName());
const std::vector< GIdentifier > & getIdentity() const
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
const std::vector< GIdentifier > & getIdentity() 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
std::map< std::string, int > getIdentityMap(std::vector< GIdentifier > gidentity)
Shared constants and error codes for the gstreamer module.
#define ERR_GSTREAMERVARIABLEEXISTS
Duplicate variable registration was attempted in a streamer-specific schema.