| 1 |
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// |
| 2 |
// test routines |
| 3 |
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// |
| 4 |
|
| 5 |
|
| 6 |
void RootTest(TString filename){ |
| 7 |
Long64_t ntimes = 0; |
| 8 |
inizio: TFile *calheadFile = 0; |
| 9 |
TFile *calcalibFile = 0; |
| 10 |
calheadFile = getFile(filename, "CalibCalPed", "Header"); |
| 11 |
calcalibFile = getFile(filename, "CalibCalPed"); |
| 12 |
//Takes the tree of the header file |
| 13 |
char *filen = 0; |
| 14 |
filen = filename; |
| 15 |
//gObjectTable->Print(); |
| 16 |
if ( !calheadFile || !calcalibFile ) { |
| 17 |
if ( calheadFile ) calheadFile->Close(); |
| 18 |
if ( calcalibFile ) calcalibFile->Close(); |
| 19 |
printf(" Not able to open file! %s \n",filen); |
| 20 |
printf(" ntimes = %i\n",(int)ntimes); |
| 21 |
ntimes++; |
| 22 |
goto inizio; |
| 23 |
return; |
| 24 |
}; |
| 25 |
TTree *tr = (TTree*)calheadFile->Get("Pscu"); |
| 26 |
tr->AddFriend("CalibCalPed", calcalibFile); |
| 27 |
// pamela::calorimeter::CalibCalPedEvent *ce = 0; |
| 28 |
pamela::CalibCalPedEvent *ce = 0; |
| 29 |
pamela::PscuHeader *cph = 0; |
| 30 |
pamela::EventHeader *ceh = 0; |
| 31 |
tr->SetBranchAddress("Header", &ceh); |
| 32 |
tr->SetBranchAddress("Event", &ce); |
| 33 |
Long64_t ncalibs = tr->GetEntries(); |
| 34 |
calheadFile->Close(); |
| 35 |
calcalibFile->Close(); |
| 36 |
printf(" ntimes = %i\n",(int)ntimes); |
| 37 |
ntimes++; |
| 38 |
goto inizio; |
| 39 |
} |
| 40 |
|
| 41 |
void RootTestE(TString filename){ |
| 42 |
Long64_t ntimes = 0; |
| 43 |
inizio: |
| 44 |
TString scalheadFile; |
| 45 |
TString scalcalibFile; |
| 46 |
scalheadFile = getEmiFile(filename, "CalibCalPed", "Header"); |
| 47 |
scalcalibFile = getEmiFile(filename, "CalibCalPed","Event"); |
| 48 |
char *prova; |
| 49 |
prova = scalheadFile; |
| 50 |
if ( prova == "nofile" ){ |
| 51 |
printf("nofile\n"); |
| 52 |
goto inizio; |
| 53 |
return; |
| 54 |
}; |
| 55 |
TFile *calheadFile = 0; |
| 56 |
calheadFile = new TFile(scalheadFile); |
| 57 |
TFile *calcalibFile = 0; |
| 58 |
calcalibFile = new TFile(scalcalibFile); |
| 59 |
// TFile *calheadFile = 0; |
| 60 |
//calheadFile = new TFile(scalheadFile); |
| 61 |
//TFile *calcalibFile = 0; |
| 62 |
//calcalibFile = new TFile(scalcalibFile); |
| 63 |
// |
| 64 |
if ( calheadFile->IsZombie() || calcalibFile->IsZombie() ) { |
| 65 |
if ( !calheadFile->IsZombie() ) calheadFile->Close(); |
| 66 |
if ( !calcalibFile->IsZombie() ) calcalibFile->Close(); |
| 67 |
printf(" Not able to open file! \n"); |
| 68 |
printf(" ntimes = %i\n",ntimes); |
| 69 |
ntimes++; |
| 70 |
goto inizio; |
| 71 |
return; |
| 72 |
}; |
| 73 |
TTree *tr = (TTree*)calheadFile->Get("Pscu"); |
| 74 |
tr->AddFriend("CalibCalPed", calcalibFile); |
| 75 |
// pamela::calorimeter::CalibCalPedEvent *ce = 0; |
| 76 |
pamela::CalibCalPedEvent *ce = 0; |
| 77 |
pamela::PscuHeader *cph = 0; |
| 78 |
pamela::EventHeader *ceh = 0; |
| 79 |
tr->SetBranchAddress("Header", &ceh); |
| 80 |
tr->SetBranchAddress("Event", &ce); |
| 81 |
Long64_t ncalibs = tr->GetEntries(); |
| 82 |
calheadFile->Close(); |
| 83 |
calcalibFile->Close(); |
| 84 |
printf(" ntimes = %i\n",ntimes); |
| 85 |
ntimes++; |
| 86 |
goto inizio; |
| 87 |
} |
| 88 |
|
| 89 |
void RootTest2(TString filename){ |
| 90 |
Long64_t ntimes = 0; |
| 91 |
inizio: TFile calcalibFile(filename); |
| 92 |
if ( calcalibFile.IsZombie() ) { |
| 93 |
if ( !calcalibFile.IsZombie() ) calheadFile.Close(); |
| 94 |
printf(" Not able to open file! \n"); |
| 95 |
printf(" ntimes = %i\n",ntimes); |
| 96 |
ntimes++; |
| 97 |
goto inizio; |
| 98 |
}; |
| 99 |
printf(" ntimes = %i\n",ntimes); |
| 100 |
ntimes++; |
| 101 |
goto inizio; |
| 102 |
} |
| 103 |
|
| 104 |
void RootTest3(TString filename){ |
| 105 |
Long64_t ntimes = 0; |
| 106 |
inizio: TFile *calcalibFile = 0; |
| 107 |
calcalibFile = new TFile(filename); |
| 108 |
if ( !calcalibFile ) { |
| 109 |
if ( calcalibFile ) calheadFile.Close(); |
| 110 |
printf(" Not able to open file! \n"); |
| 111 |
printf(" ntimes = %i\n",ntimes); |
| 112 |
ntimes++; |
| 113 |
goto inizio; |
| 114 |
}; |
| 115 |
printf(" ntimes = %i\n",ntimes); |
| 116 |
ntimes++; |
| 117 |
goto inizio; |
| 118 |
} |
| 119 |
|
| 120 |
|
| 121 |
TString getEmiFile2(TString base, TString packetType, TString subType){ |
| 122 |
Int_t debug = 0; |
| 123 |
// |
| 124 |
TString newfile; |
| 125 |
stringcopy(newfile,base); |
| 126 |
// |
| 127 |
string fil = base; |
| 128 |
Int_t posiz = fil.find("dw_"); |
| 129 |
Int_t upper = 0; |
| 130 |
if ( posiz == -1 ) { |
| 131 |
posiz = fil.find("DW_"); |
| 132 |
upper = 1; |
| 133 |
}; |
| 134 |
if ( posiz == -1 ) return ""; |
| 135 |
TString fullname; |
| 136 |
stringcopy(fullname,base,posiz,posiz+15); |
| 137 |
stringappend(fullname,"."); |
| 138 |
stringappend(fullname,packetType); |
| 139 |
stringappend(fullname,"."); |
| 140 |
stringappend(fullname,subType); |
| 141 |
stringappend(fullname,".root"); |
| 142 |
// |
| 143 |
stringappend(newfile,"/"); |
| 144 |
stringappend(newfile,packetType); |
| 145 |
stringappend(newfile,"/"); |
| 146 |
stringappend(newfile,fullname); |
| 147 |
// char *vediamo; |
| 148 |
//vediamo = newfile; |
| 149 |
//printf("filename: %s \n",vediamo); |
| 150 |
//return; |
| 151 |
TFile retfile(newfile); |
| 152 |
if ( retfile.IsZombie() ) { |
| 153 |
return "nofile"; |
| 154 |
} else { |
| 155 |
retfile.Close(); |
| 156 |
return newfile; |
| 157 |
}; |
| 158 |
} |
| 159 |
|
| 160 |
|
| 161 |
|
| 162 |
void RootTestE2(TString filename){ |
| 163 |
Long64_t ntimes = 0; |
| 164 |
Long64_t ncalibs = 0; |
| 165 |
Int_t forever = 1; |
| 166 |
while ( forever ){ |
| 167 |
printf(" ntimes = %i\n",(int)ntimes); |
| 168 |
TFile *calheadFile = 0; |
| 169 |
calheadFile = getEmiFile(filename, "CalibCalPed","Header"); |
| 170 |
TFile *calcalibFile = 0; |
| 171 |
calcalibFile = getEmiFile(filename, "CalibCalPed"); |
| 172 |
// |
| 173 |
//gObjectTable->Print(); |
| 174 |
// |
| 175 |
if ( !calcalibFile || !calheadFile ) { |
| 176 |
printf(" -> not able to open file \n"); |
| 177 |
if ( calheadFile ) calheadFile->Close(); |
| 178 |
if ( calcalibFile ) calcalibFile->Close(); |
| 179 |
} else { |
| 180 |
TTree *tr = (TTree*)calheadFile->Get("Pscu"); |
| 181 |
tr->AddFriend("CalibCalPed", calcalibFile); |
| 182 |
// pamela::calorimeter::CalibCalPedEvent *ce = 0; |
| 183 |
pamela::CalibCalPedEvent *ce = 0; |
| 184 |
pamela::PscuHeader *cph = 0; |
| 185 |
pamela::EventHeader *ceh = 0; |
| 186 |
tr->SetBranchAddress("Header", &ceh); |
| 187 |
tr->SetBranchAddress("Event", &ce); |
| 188 |
ncalibs = tr->GetEntries(); |
| 189 |
printf(" -> ncalibs = %i \n",(int)ncalibs); |
| 190 |
calheadFile->Close(); |
| 191 |
calcalibFile->Close(); |
| 192 |
}; |
| 193 |
ntimes++; |
| 194 |
}; |
| 195 |
} |
| 196 |
|
| 197 |
void trktesting(TString filename){ |
| 198 |
TString startingdir = gSystem->WorkingDirectory(); |
| 199 |
char *bdir; |
| 200 |
char *sdir=gSystem->Getenv("PAM_LIB"); |
| 201 |
bdir = Form("%s/liboptrklev1.so",sdir); |
| 202 |
gSystem->Load(bdir); |
| 203 |
bdir = Form("%s/liboptrklev1_C.so",sdir); |
| 204 |
gSystem->Load(bdir); |
| 205 |
bdir = Form("%s/libretrklev1.so",sdir); |
| 206 |
gSystem->Load(bdir); |
| 207 |
bdir = Form("%s/libretrklev1_C.so",sdir); |
| 208 |
gSystem->Load(bdir); |
| 209 |
bdir = Form("%s/libcltrklev1.so",sdir); |
| 210 |
gSystem->Load(bdir); |
| 211 |
bdir = Form("%s/libcltrklev1_C.so",sdir); |
| 212 |
gSystem->Load(bdir); |
| 213 |
Int_t trnev = 0; |
| 214 |
struct Tracklev1 trklev1; |
| 215 |
char *name; |
| 216 |
name = filename; |
| 217 |
//char *name2; |
| 218 |
//name2 = filename; |
| 219 |
//// name = Form("%s",filename); |
| 220 |
//name = name2; |
| 221 |
//trnev = 123; |
| 222 |
//printf("name = %s \n",name); |
| 223 |
//printf("filename = %s \n",name2); |
| 224 |
coptrklev1(name,trklev1,trnev); |
| 225 |
//coptrklev1(); |
| 226 |
printf("The tracker ntuple contains %i events\n",trnev); |
| 227 |
for ( Int_t i = 1; i < trnev+1; i++){ |
| 228 |
cretrklev1(i,trklev1); |
| 229 |
printf("Event number %i ---> OBT %i \n",i,trklev1.obt1); |
| 230 |
printf(" ---> PKTnum %i \n",trklev1.pkt_num1); |
| 231 |
printf(" ---> PKTtype %x \n",trklev1.pkt_type1); |
| 232 |
printf(" ---> nev1 %i \n",trklev1.nev1); |
| 233 |
printf(" ---> good %i \n",trklev1.good1); |
| 234 |
printf(" ---> nclstr %i \n",trklev1.nclstr1); |
| 235 |
}; |
| 236 |
ccltrklev1(trklev1); |
| 237 |
//ccltrklev1(); |
| 238 |
} |
| 239 |
|
| 240 |
void trktesting2(TString filename){ |
| 241 |
TString startingdir = gSystem->WorkingDirectory(); |
| 242 |
char *bdir; |
| 243 |
char *sdir; |
| 244 |
sdir = startingdir; |
| 245 |
bdir = Form("%s/tracker/liboptrklev2.so",sdir); |
| 246 |
gSystem->Load(bdir); |
| 247 |
bdir = Form("%s/tracker/coptrklev2_C.so",sdir); |
| 248 |
gSystem->Load(bdir); |
| 249 |
bdir = Form("%s/tracker/libretrklev2.so",sdir); |
| 250 |
gSystem->Load(bdir); |
| 251 |
bdir = Form("%s/tracker/cretrklev2_C.so",sdir); |
| 252 |
gSystem->Load(bdir); |
| 253 |
bdir = Form("%s/tracker/libcltrklev2.so",sdir); |
| 254 |
gSystem->Load(bdir); |
| 255 |
bdir = Form("%s/tracker/ccltrklev2_C.so",sdir); |
| 256 |
gSystem->Load(bdir); |
| 257 |
Int_t trnev = 0; |
| 258 |
struct Tracklev2 trklev2; |
| 259 |
char *name; |
| 260 |
name = filename; |
| 261 |
coptrklev2(name,trklev2,trnev); |
| 262 |
printf("The tracker ntuple contains %i events\n",trnev); |
| 263 |
for ( Int_t i = 1; i < trnev+1; i++){ |
| 264 |
cretrklev2(i,trklev2); |
| 265 |
printf("Event number %i ---> OBT %i \n",i,trklev2.obt); |
| 266 |
printf(" ---> PKTnum %i \n",trklev2.pkt_num); |
| 267 |
printf(" ---> PKTtype %x \n",trklev2.pkt_type); |
| 268 |
printf(" ---> nev2 %i \n",trklev2.nev2); |
| 269 |
printf(" ---> good2 %i \n",trklev2.good2); |
| 270 |
printf(" ---> ntrk %i \n",trklev2.ntrk); |
| 271 |
if ( trklev2.ntrk == 1 && trklev2.al[0][4] != 0. ) printf("c-> RIG = %.9f \n",1./trklev2.al[0][4]); |
| 272 |
}; |
| 273 |
ccltrklev2(trklev2); |
| 274 |
//ccltrklev1(); |
| 275 |
} |
| 276 |
|
| 277 |
void trkhtestlev2(TString filename){ |
| 278 |
// char *name; |
| 279 |
//name = filename; |
| 280 |
//char *nome; |
| 281 |
//nome = Form("%s/Physics/Level1/",name); |
| 282 |
// TFile *f = new TFile(nome); |
| 283 |
TFile *f = getFile(filename,"Physics.Level2","Tracker"); |
| 284 |
TFile *caloFile; |
| 285 |
caloFile = getFile(filename, "Physics.Level2", "Calorimeter"); |
| 286 |
TTree *tr = (TTree*) f->Get("TrkLevel2"); |
| 287 |
tr->AddFriend("CaloLevel2", caloFile); |
| 288 |
struct Tracklev2 trk; |
| 289 |
struct CTracklev2 track; |
| 290 |
settrklev2(tr,trk); |
| 291 |
Int_t nevents = tr->GetEntries(); |
| 292 |
CalorimeterLevel2 *calo = new CalorimeterLevel2(); |
| 293 |
tr->SetBranchAddress("CaloLevel2.Event",&calo); |
| 294 |
for ( Int_t i = 0; i<nevents ; i++){ |
| 295 |
tr->GetEntry(i); |
| 296 |
accesstrklev2(trk,track); |
| 297 |
printf("Event %i tracker OBT = %i \n",i,track.obt); |
| 298 |
if ( track.ntrk>0 ) printf("Event %i tracker RIG = %f \n",i,1./track.al[4][0]); |
| 299 |
// Float_t obt = (float)trk.obt1; |
| 300 |
//printf("Event %i tracker OBT1 = %f \n",i,obt); |
| 301 |
printf("Event %i calo OBT = %i \n",i,calo->OBT); |
| 302 |
}; |
| 303 |
} |
| 304 |
|
| 305 |
void trkhtest(TString filename){ |
| 306 |
// char *name; |
| 307 |
//name = filename; |
| 308 |
//char *nome; |
| 309 |
//nome = Form("%s/Physics/Level1/",name); |
| 310 |
// TFile *f = new TFile(nome); |
| 311 |
TFile *f = getFile(filename,"Physics.Level1","Tracker"); |
| 312 |
TFile *caloFile; |
| 313 |
caloFile = getFile(filename, "Physics.Level2", "Calorimeter"); |
| 314 |
TTree *tr = (TTree*) f->Get("TrkLevel1"); |
| 315 |
tr->AddFriend("CaloLevel2", caloFile); |
| 316 |
struct Tracklev1 trk; |
| 317 |
struct CTracklev1 track; |
| 318 |
settrklev1(tr,trk); |
| 319 |
Int_t nevents = tr->GetEntries(); |
| 320 |
CalorimeterLevel2 *calo = new CalorimeterLevel2(); |
| 321 |
tr->SetBranchAddress("CaloLevel2.Event",&calo); |
| 322 |
for ( Int_t i = 0; i<nevents ; i++){ |
| 323 |
tr->GetEntry(i); |
| 324 |
accesstrklev1(trk,track); |
| 325 |
printf("Event %i tracker OBT1 = %i \n",i,track.obt1); |
| 326 |
// Float_t obt = (float)trk.obt1; |
| 327 |
//printf("Event %i tracker OBT1 = %f \n",i,obt); |
| 328 |
printf("Event %i calo OBT1 = %i \n",i,calo->OBT); |
| 329 |
}; |
| 330 |
} |
| 331 |
|
| 332 |
|
| 333 |
void trkhtest2(TString filename){ |
| 334 |
TFile *f = new TFile(filename); |
| 335 |
TTree *tr = (TTree*) f->Get("TrkLevel1"); |
| 336 |
TrackerLevel1 *trk = new TrackerLevel1(); |
| 337 |
//struct Tracklev1 trk; |
| 338 |
tr->SetBranchAddress("good1", &trk->good1); |
| 339 |
tr->SetBranchAddress("obt1", &trk->obt1); |
| 340 |
tr->SetBranchAddress("pkt_num1", &trk->pkt_num1); |
| 341 |
//tr->SetBranchAddress("obt1", &trk.obt1); |
| 342 |
Int_t nevents = tr->GetEntries(); |
| 343 |
for ( Int_t i = 0; i<nevents ; i++){ |
| 344 |
tr->GetEntry(i); |
| 345 |
printf("Event %i GOOD1 = %i \n",i,trk->good1); |
| 346 |
printf("Event %i PKT_NUM1 = %i \n",i,trk->pkt_num1); |
| 347 |
printf("Event %i OBT1 = %i \n",i,trk->obt1); |
| 348 |
}; |
| 349 |
} |