00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101
00102
00103
00104
00105
00106
00107 #include "StEventClusteringHints.h"
00108 #include <algorithm>
00109
00110 static const char rcsid[] = "$Id: StEventClusteringHints.cxx,v 2.31 2012/04/16 20:28:37 ullrich Exp $";
00111
00112 ClassImp(StEventClusteringHints)
00113
00114 StEventClusteringHints::~StEventClusteringHints() {}
00115
00116 StEventClusteringHints::StEventClusteringHints()
00117 {
00118 fParent = 0;
00119 mNameMap= 0;
00120
00121 setMiniDstMode();
00122 setBranch("StRunInfo", "evt_header", 2);
00123 setBranch("StEventInfo", "evt_header", 2);
00124 setBranch("StEventSummary", "evt_header", 2);
00125 setBranch("StSPtrVecDetectorState", "evt_header", 2);
00126 setBranch("StEventClusteringHints", "evt_header", 2);
00127 setBranch("StL0Trigger", "evt_trigger", 3);
00128 setBranch("StL1Trigger", "evt_trigger", 3);
00129 setBranch("StL3Trigger", "evt_trigger", 3);
00130 setBranch("StTriggerDetectorCollection", "evt_trigger", 3);
00131 setBranch("StTriggerIdCollection", "evt_trigger", 3);
00132 setBranch("StTriggerData", "evt_trigger", 3);
00133 setBranch("StTriggerData2003", "evt_trigger", 3);
00134 setBranch("StTriggerData2004", "evt_trigger", 3);
00135 setBranch("StTriggerData2005", "evt_trigger", 3);
00136 setBranch("StTriggerData2007", "evt_trigger", 3);
00137 setBranch("StTriggerData2008", "evt_trigger", 3);
00138 setBranch("StTriggerData2009", "evt_trigger", 3);
00139 setBranch("StTriggerData2012", "evt_trigger", 3);
00140 setBranch("StSPtrVecTrackDetectorInfo", "evt_tracks", 4);
00141 setBranch("StSPtrVecPrimaryVertex", "evt_tracks", 4);
00142 setBranch("StSPtrVecTrackNode", "evt_tracks", 4);
00143 setBranch("StSPtrVecKinkVertex", "evt_vertices", 5);
00144 setBranch("StSPtrVecV0Vertex", "evt_vertices", 5);
00145 setBranch("StSPtrVecXiVertex", "evt_vertices", 5);
00146 setBranch("StSPtrVecCalibrationVertex", "evt_vertices", 5);
00147 setBranch("StEmcCollection", "evt_emc", 6);
00148 setBranch("StFmsCollection", "evt_emc", 6);
00149 setBranch("StRichCollection", "evt_aux", 7);
00150 setBranch("StTofCollection", "evt_aux", 7);
00151 setBranch("StBTofCollection", "evt_aux", 7);
00152 setBranch("StMtdCollection", "evt_aux", 7);
00153 setBranch("StFpdCollection", "evt_aux", 7);
00154 setBranch("StPhmdCollection", "evt_aux", 7);
00155 setBranch("StRpsCollection", "evt_aux", 7);
00156 setBranch("StSsdHitCollection", "evt_hits", 8);
00157 setBranch("StSvtHitCollection", "evt_hits", 8);
00158 setBranch("StTpcHitCollection", "evt_hits", 8);
00159 setBranch("StFtpcHitCollection", "evt_hits", 8);
00160 setBranch("StRnDHitCollection", "evt_hits", 8);
00161 setBranch("StHltEvent", "evt_hlt", 9);
00162 setBranch("StFgtCollection", "evt_fgt", 9);
00163
00164 setDstMode();
00165 setBranch("StRunInfo", "event", 1);
00166 setBranch("StEventInfo", "event", 1);
00167 setBranch("StEventSummary", "event", 1);
00168 setBranch("StSPtrVecDetectorState", "event", 1);
00169 setBranch("StEventClusteringHints", "event", 1);
00170 setBranch("StEmcCollection", "event", 1);
00171 setBranch("StFmsCollection", "event", 1);
00172 setBranch("StRichCollection", "event", 1);
00173 setBranch("StTofCollection", "event", 1);
00174 setBranch("StBTofCollection", "event", 1);
00175 setBranch("StMtdCollection", "event", 1);
00176 setBranch("StFpdCollection", "event", 1);
00177 setBranch("StRpsCollection", "event", 1);
00178 setBranch("StSsdHitCollection", "event", 1);
00179 setBranch("StSvtHitCollection", "event", 1);
00180 setBranch("StTpcHitCollection", "event", 1);
00181 setBranch("StFtpcHitCollection", "event", 1);
00182 setBranch("StL0Trigger", "event", 1);
00183 setBranch("StL1Trigger", "event", 1);
00184 setBranch("StL3Trigger", "event", 1);
00185 setBranch("StTriggerDetectorCollection", "event", 1);
00186 setBranch("StTriggerIdCollection", "event", 1);
00187 setBranch("StTriggerData", "event", 1);
00188 setBranch("StTriggerData2003", "event", 1);
00189 setBranch("StTriggerData2004", "event", 1);
00190 setBranch("StTriggerData2005", "event", 1);
00191 setBranch("StTriggerData2007", "event", 1);
00192 setBranch("StTriggerData2008", "event", 1);
00193 setBranch("StTriggerData2009", "event", 1);
00194 setBranch("StTriggerData2012", "event", 1);
00195 setBranch("StSPtrVecKinkVertex", "event", 1);
00196 setBranch("StSPtrVecV0Vertex", "event", 1);
00197 setBranch("StSPtrVecXiVertex", "event", 1);
00198 setBranch("StSPtrVecTrackDetectorInfo", "event", 1);
00199 setBranch("StSPtrVecCalibrationVertex", "event", 1);
00200 setBranch("StSPtrVecPrimaryVertex", "event", 1);
00201 setBranch("StSPtrVecTrackNode", "event", 1);
00202 setBranch("StPhmdCollection", "event", 1);
00203 setBranch("StRnDHitCollection", "event", 1);
00204 setBranch("StHltEvent", "event", 1);
00205 setBranch("StFgtCollection", "event", 1);
00206 }
00207
00208 void
00209 StEventClusteringHints::setDstMode()
00210 {
00211 if (mNameMap == &mDstMap) return;
00212 mNameMap = &mDstMap;
00213 if (fParent) fParent->Notify();
00214 }
00215
00216 void
00217 StEventClusteringHints::setMiniDstMode()
00218 {
00219 if (mNameMap == &mMiniDstMap) return;
00220 mNameMap = &mMiniDstMap;
00221 if (fParent) fParent->Notify();
00222 }
00223 const char*
00224 StEventClusteringHints::branchName(const char* classname) const
00225 {
00226 if (strstr(classname,"Hit")) return "evt_hits";
00227 map<string,string>::const_iterator i = mNameMap->find(string(classname));
00228 return i != mNameMap->end() ? i->second.c_str() : "event";
00229 }
00230
00231 void
00232 StEventClusteringHints::setBranch(const char* classname, const char* branchname, int id)
00233 {
00234 (*mNameMap)[string(classname)] = string(branchname);
00235 mBranchIds[string(branchname)] = id;
00236 if (fParent) fParent->Notify();
00237
00238 }
00239
00240 int
00241 StEventClusteringHints::branchId(const char* branchname) const
00242 {
00243 map<string,int>::const_iterator i = mBranchIds.find(string(branchname));
00244 return i != mBranchIds.end() ? i->second : 1;
00245 }
00246
00247 vector<string>
00248 StEventClusteringHints::listOfBranches() const
00249 {
00250 vector<string> result, tmp;
00251 map<string,string>::iterator i;
00252 for (i = mNameMap->begin(); i != mNameMap->end(); i++)
00253 tmp.push_back(i->second);
00254 sort(tmp.begin(), tmp.end());
00255 insert_iterator<vector<string> > ins(result, result.begin());
00256 unique_copy(tmp.begin(), tmp.end(), ins);
00257 return result;
00258 }
00259
00260 vector<string>
00261 StEventClusteringHints::listOfClasses() const
00262 {
00263 vector<string> result;
00264 map<string,string>::iterator i;
00265 for (i = mNameMap->begin(); i != mNameMap->end(); i++)
00266 result.push_back(i->first);
00267 sort(result.begin(), result.end());
00268 return result;
00269 }
00270
00271 vector<string>
00272 StEventClusteringHints::listOfClasses(const char* branchname) const
00273 {
00274 vector<string> result;
00275 map<string,string>::iterator i;
00276 for (i = mNameMap->begin(); i != mNameMap->end(); i++)
00277 if (string(branchname) == i->second) result.push_back(i->first);
00278 sort(result.begin(), result.end());
00279 return result;
00280 }
00281
00282 void
00283 StEventClusteringHints::print(ostream& os)
00284 {
00285 vector<string> branches = listOfBranches();
00286 for (unsigned int j=0; j<branches.size(); j++) {
00287 vector<string> classes = listOfClasses(branches[j].c_str());
00288 cout << branches[j] << "[id=" << branchId(branches[j].c_str()) << "]" << endl;
00289 for (unsigned int k=0; k<classes.size(); k++)
00290 cout << '\t' << classes[k] << endl;
00291 }
00292 }
00293
00294 static TBuffer& operator<<(TBuffer& buf, const map<string,string> &s)
00295 {
00296 TString ts1,ts2;
00297 map<string,string>::const_iterator i;
00298 buf << s.size();
00299 for (i = s.begin(); i != s.end(); i++){
00300 ts1 = i->first. c_str(); ts1.Streamer(buf);
00301 ts2 = i->second.c_str(); ts2.Streamer(buf);}
00302 return buf;
00303 }
00304
00305 static TBuffer& operator>>(TBuffer& buf, map<string,string> & s)
00306 {
00307 TString ts1,ts2; int i,size;
00308 buf >> size;
00309 for (i = 0;i<size;i++){
00310 ts1.Streamer(buf); ts2.Streamer(buf);
00311 s[string(ts1.Data())] = string(ts2.Data());}
00312 return buf;
00313 }
00314
00315 static TBuffer& operator<<(TBuffer& buf, const map<string,int> &s)
00316 {
00317 TString ts1;
00318 map<string,int>::const_iterator i;
00319 int size = s.size();buf << size;
00320 for (i = s.begin(); i != s.end(); i++){
00321 ts1 = i->first.c_str(); ts1.Streamer(buf);
00322 buf << i->second;}
00323 return buf;
00324 }
00325
00326 static TBuffer& operator>>(TBuffer& buf, map<string,int> & s)
00327 {
00328 TString ts1;
00329 int i,size,ii;
00330 buf >> size;
00331 for (i = 0;i<size;i++){
00332 ts1.Streamer(buf); buf>>ii;
00333 s[string(ts1.Data())] = ii;}
00334 return buf;
00335 }
00336
00337
00338
00339 void StEventClusteringHints::Streamer(TBuffer &R__b)
00340 {
00341
00342
00343 UChar_t mode;
00344 UInt_t R__s, R__c;
00345 if (R__b.IsReading()) {
00346 Version_t R__v = R__b.ReadVersion(&R__s, &R__c); if (R__v) { }
00347 R__b >> mode; mNameMap=(mode)? &mMiniDstMap:&mDstMap;
00348 R__b >> mDstMap;
00349 R__b >> mMiniDstMap;
00350 R__b >> mBranchIds;
00351 R__b.CheckByteCount(R__s, R__c, Class());
00352
00353 } else {
00354 R__c = R__b.WriteVersion(Class(), kTRUE);
00355 mode = (mNameMap == &mMiniDstMap);
00356 R__b << mode;
00357 R__b << mDstMap;
00358 R__b << mMiniDstMap;
00359 R__b << mBranchIds;
00360 R__b.SetByteCount(R__c, kTRUE);
00361 }
00362 }