9 #include "trg/cdc/HandleRoot.h"
11 #include "HandleRoot.h"
15 #include <TBranchObject.h>
26 namespace HandleRoot {
29 std::map<std::string, TVectorD*>& eventMapTVectorD,
30 std::map<std::string, TClonesArray*>& trackMapTVectorD
33 for (map<string, TVectorD*>::iterator it = eventMapTVectorD.begin(); it != eventMapTVectorD.end(); ++it) {
36 for (map<string, TClonesArray*>::iterator it = trackMapTVectorD.begin(); it != trackMapTVectorD.end(); ++it) {
42 std::map<std::string, TClonesArray*>& trackMapTVectorD
45 map<string, TVectorD*> eventMapTVectorD;
46 initializeEvent(eventMapTVectorD, trackMapTVectorD);
49 void initializeRoot(
const std::string& prefix, TTree** runTree, TTree** eventTree,
50 std::map<std::string, TVectorD*>& runMapTVectorD,
51 std::map<std::string, TVectorD*>& eventMapTVectorD,
52 std::map<std::string, TClonesArray*>& trackMapTVectorD,
53 std::map<std::string, double>& constMapD, std::map<std::string, std::vector<double> >& constMapV,
54 std::map<std::string, double>& eventMapD, std::map<std::string, std::vector<double> >& eventMapV,
55 std::map<std::string, double>& trackMapD, std::map<std::string, std::vector<double> >& trackMapV
60 (*runTree) =
new TTree((prefix +
"runTree").c_str(),
"run");
62 for (map<string, double>::iterator it = constMapD.begin(); it != constMapD.end(); ++it) {
63 runMapTVectorD[prefix +
"Double" + (*it).first] =
new TVectorD(1, &(*it).second);
66 for (map<
string, vector<double> >::iterator it = constMapV.begin(); it != constMapV.end(); ++it) {
67 unsigned t_vectorSize = it->second.size();
68 runMapTVectorD[prefix +
"Vector" + (*it).first] =
new TVectorD(t_vectorSize, &((*it).second)[0]);
71 for (map<string, TVectorD*>::iterator it = runMapTVectorD.begin(); it != runMapTVectorD.end(); ++it) {
72 (*runTree)->Branch(it->first.c_str(), &it->second, 32000, 0);
79 (*eventTree) =
new TTree((prefix +
"eventTree").c_str(),
"event");
82 for (map<string, double>::iterator it = eventMapD.begin(); it != eventMapD.end(); ++it) {
83 eventMapTVectorD[prefix +
"EventDouble" + (*it).first] =
new TVectorD(1);
86 for (map<
string, vector<double> >::iterator it = eventMapV.begin(); it != eventMapV.end(); ++it) {
87 unsigned t_vectorSize = it->second.size();
88 eventMapTVectorD[prefix +
"EventVector" + (*it).first] =
new TVectorD(t_vectorSize);
91 for (map<string, TVectorD*>::iterator it = eventMapTVectorD.begin(); it != eventMapTVectorD.end(); ++it) {
92 (*eventTree)->Branch(it->first.c_str(), &it->second, 32000, 0);
96 for (map<string, double>::iterator it = trackMapD.begin(); it != trackMapD.end(); ++it) {
97 trackMapTVectorD[prefix +
"TrackDouble" + (*it).first] =
new TClonesArray(
"TVectorD");
100 for (map<
string, vector<double> >::iterator it = trackMapV.begin(); it != trackMapV.end(); ++it) {
101 trackMapTVectorD[prefix +
"TrackVector" + (*it).first] =
new TClonesArray(
"TVectorD");
104 for (map<string, TClonesArray*>::iterator it = trackMapTVectorD.begin(); it != trackMapTVectorD.end(); ++it) {
105 (*eventTree)->Branch(it->first.c_str(), &it->second, 32000, 0);
110 void initializeRoot(
const std::string& prefix, TTree** runTree, TTree** eventTree,
111 std::map<std::string, TVectorD*>& runMapTVectorD,
112 std::map<std::string, TClonesArray*>& trackMapTVectorD,
113 std::map<std::string, double>& constMapD, std::map<std::string, std::vector<double> >& constMapV,
114 std::map<std::string, double>& trackMapD, std::map<std::string, std::vector<double> >& trackMapV
117 map<string, TVectorD*> eventMapTVectorD;
118 map<string, double> eventMapD;
119 map<string, vector<double> > eventMapV;
120 initializeRoot(prefix, runTree, eventTree,
121 runMapTVectorD, eventMapTVectorD, trackMapTVectorD,
122 constMapD, constMapV,
123 eventMapD, eventMapV,
128 void saveTrackValues(
const std::string& prefix,
129 const std::map<std::string, TClonesArray*>& trackMapTVectorD,
130 std::map<std::string, double>& trackMapD, std::map<std::string, std::vector<double> >& trackMapV
134 for (map<string, double >::iterator it = trackMapD.begin(); it != trackMapD.end(); ++it) {
135 new ((*trackMapTVectorD.at(prefix +
"TrackDouble" + (*it).first))[trackMapD[
"iSave"]]) TVectorD(1, &(*it).second);
138 for (map<
string, vector<double> >::iterator it = trackMapV.begin(); it != trackMapV.end(); ++it) {
139 unsigned t_vectorSize = it->second.size();
140 new ((*trackMapTVectorD.at(prefix +
"TrackVector" + (*it).first))[trackMapD[
"iSave"]]) TVectorD(t_vectorSize, &((*it).second)[0]);
143 trackMapD[
"iSave"]++;
146 void saveEventValues(
const std::string& prefix,
147 std::map<std::string, TVectorD*>& eventMapTVectorD,
148 std::map<std::string, double>& eventMapD, std::map<std::string, std::vector<double> >& eventMapV
152 for (map<string, double>::iterator it = eventMapD.begin(); it != eventMapD.end(); ++it) {
153 eventMapTVectorD[prefix +
"EventDouble" + (*it).first]->Use(1, &(*it).second);
156 for (map<
string, vector<double> >::iterator it = eventMapV.begin(); it != eventMapV.end(); ++it) {
157 unsigned t_vectorSize = it->second.size();
158 if (t_vectorSize != 0) eventMapTVectorD[prefix +
"EventVector" + (*it).first]->Use(t_vectorSize, &((*it).second)[0]);
162 void writeRoot(TFile* file)
171 std::map<std::string, TVectorD*>& runMapTVectorD,
172 std::map<std::string, TVectorD*>& eventMapTVectorD,
173 std::map<std::string, TClonesArray*>& trackMapTVectorD
176 for (map<string, TVectorD*>::iterator it = runMapTVectorD.begin(); it != runMapTVectorD.end(); ++it) {
179 for (map<string, TVectorD*>::iterator it = eventMapTVectorD.begin(); it != eventMapTVectorD.end(); ++it) {
182 for (map<string, TClonesArray*>::iterator it = trackMapTVectorD.begin(); it != trackMapTVectorD.end(); ++it) {
188 std::map<std::string, TVectorD*>& runMapTVectorD,
189 std::map<std::string, TClonesArray*>& trackMapTVectorD
192 std::map<std::string, TVectorD*> eventMapTVectorD;
193 terminateRoot(runMapTVectorD, eventMapTVectorD, trackMapTVectorD);
196 void initializeBranches(
const std::string& prefix, TFile* file, TTree** runTree, TTree** eventTree,
197 std::map<std::string, TVectorD*>& runMapTVectorD,
198 std::map<std::string, TVectorD*>& eventMapTVectorD,
199 std::map<std::string, TClonesArray*>& trackMapTVectorD
203 (*runTree) = (TTree*)file->Get((prefix +
"runTree").c_str());
204 (*eventTree) = (TTree*)file->Get((prefix +
"eventTree").c_str());
206 TObjArray* constBranchList = (*runTree)->GetListOfBranches();
207 for (
int iBranch = 0; iBranch < constBranchList->GetEntries(); iBranch++) {
208 string t_branchName = constBranchList->At(iBranch)->GetName();
209 runMapTVectorD[t_branchName] =
new TVectorD();
210 (*runTree)->SetBranchAddress(t_branchName.c_str(), &runMapTVectorD[t_branchName]);
213 TObjArray* trackBranchList = (*eventTree)->GetListOfBranches();
214 for (
int iBranch = 0; iBranch < trackBranchList->GetEntries(); iBranch++) {
215 string t_branchName = trackBranchList->At(iBranch)->GetName();
216 string t_className = ((TBranchObject*)trackBranchList->At(iBranch))->GetClassName();
218 if (t_className ==
"TClonesArray") {
219 trackMapTVectorD[t_branchName] =
new TClonesArray(
"TVectorD");
220 (*eventTree)->SetBranchAddress(t_branchName.c_str(), &trackMapTVectorD[t_branchName]);
221 }
else if (t_className ==
"TVectorT<double>") {
223 eventMapTVectorD[t_branchName] =
new TVectorD();
224 (*eventTree)->SetBranchAddress(t_branchName.c_str(), &eventMapTVectorD[t_branchName]);
226 cout <<
"[Warning] HandleRoot::initializeBranches => Type of branch " << t_branchName <<
" is unkown." << endl;
231 void initializeBranches(
const std::string& prefix, TFile* file, TTree** runTree, TTree** eventTree,
232 std::map<std::string, TVectorD*>& runMapTVectorD,
233 std::map<std::string, TClonesArray*>& trackMapTVectorD
236 map<string, TVectorD*> eventMapTVectorD;
237 initializeBranches(prefix, file, runTree, eventTree,
238 runMapTVectorD, eventMapTVectorD, trackMapTVectorD
242 void getRunValues(std::string prefix,
243 std::map<std::string, TVectorD*>& runMapTVectorD,
244 std::map<std::string, double>& constMapD, std::map<std::string, std::vector<double> >& constMapV
248 for (map<string, TVectorD*>::iterator it = runMapTVectorD.begin(); it != runMapTVectorD.end(); ++it) {
249 string t_name = it->first.substr(prefix.size() + 6);
250 string t_type = it->first.substr(prefix.size(), 6);
251 if (t_type ==
"Double") {
252 constMapD[t_name] = (*it->second)[0];
253 }
else if (t_type ==
"Vector") {
254 unsigned nElements = it->second->GetNrows();
255 constMapV[t_name] = vector<double> (nElements);
256 for (
unsigned i = 0; i < nElements; i++) {
257 constMapV[t_name][i] = (*it->second)[i];
260 cout <<
"[Error] HandleRoot::getRunValues => t_type: " << t_type <<
" is unknown." << endl;
265 void getEventValues(
const std::string& prefix,
266 std::map<std::string, TVectorD*>& eventMapTVectorD,
267 std::map<std::string, double>& eventMapD, std::map<std::string, std::vector<double> >& eventMapV
271 for (map<string, TVectorD*>::iterator it = eventMapTVectorD.begin(); it != eventMapTVectorD.end(); ++it) {
272 string t_name = it->first.substr((prefix +
"Event").size() + 6);
273 string t_type = it->first.substr((prefix +
"Event").size(), 6);
274 if (t_type ==
"Double") {
275 eventMapD[t_name] = (*it->second)[0];
276 }
else if (t_type ==
"Vector") {
277 unsigned nElements = it->second->GetNrows();
278 eventMapV[t_name] = vector<double> (nElements);
279 for (
unsigned i = 0; i < nElements; i++) {
280 eventMapV[t_name][i] = (*it->second)[i];
283 cout <<
"[Error] HandleRoot::getEventValues => t_type: " << t_type <<
" is unknown." << endl;
288 void getTrackValues(
const std::string& prefix,
int iTrack,
289 std::map<std::string, TClonesArray*>& trackMapTVectorD,
290 std::map<std::string, double>& trackMapD, std::map<std::string, std::vector<double> >& trackMapV
293 for (map<string, TClonesArray*>::iterator it = trackMapTVectorD.begin(); it != trackMapTVectorD.end(); ++it) {
294 string t_name = it->first.substr((prefix +
"Track").size() + 6);
295 string t_type = it->first.substr((prefix +
"Track").size(), 6);
296 if (t_type ==
"Double") {
297 trackMapD[t_name] = (*(TVectorD*)it->second->At(iTrack))[0];
298 }
else if (t_type ==
"Vector") {
299 unsigned nElements = ((TVectorD*)it->second->At(iTrack))->GetNrows();
300 trackMapV[t_name] = vector<double> (nElements);
301 for (
unsigned i = 0; i < nElements; i++) {
302 trackMapV[t_name][i] = (*(TVectorD*)it->second->At(iTrack))[i];
305 cout <<
"[Error] HandleRoot::getTrackValues => t_type: " << t_type <<
" is unknown." << endl;
310 void convertSignalValuesToMaps(std::vector<std::tuple<std::string, double, int, double, double, int> >
const& inValues,
311 std::map<std::string, double>& trackMapD, std::map<std::string, std::vector<double> >& trackMapV)
313 for (
unsigned iValue = 0; iValue < inValues.size(); iValue++) {
314 string const& t_name = get<0>(inValues[iValue]);
315 double const& t_value = get<1>(inValues[iValue]);
321 size_t t_find = t_name.find(
"_");
323 if (t_find != string::npos) {
324 string t_vectorName = t_name.substr(0, t_find);
325 int t_vectorIndex = stoi(t_name.substr(t_find + 1, t_name.size()));
327 if (!trackMapV.count(t_vectorName)) {
328 trackMapV[t_vectorName] = vector<double> (1);
331 int nIncrease = t_vectorIndex + 1 - trackMapV[t_vectorName].size();
333 for (
int iIncrease = 0; iIncrease < nIncrease; iIncrease++) trackMapV[t_vectorName].push_back(0);
336 trackMapV[t_vectorName][t_vectorIndex] = t_value;
339 trackMapD[t_name] = t_value;