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 |
} |