/[PAMELA software]/quicklook/calo/FQLOOK/macros/FCaloQLOOK.cxx
ViewVC logotype

Contents of /quicklook/calo/FQLOOK/macros/FCaloQLOOK.cxx

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.10 - (show annotations) (download)
Mon May 29 12:08:13 2006 UTC (18 years, 7 months ago) by mocchiut
Branch: MAIN
Changes since 1.9: +31 -8 lines
Small adjustement in the latchup figures

1 //
2 // Check for possible errors and shows raw distribution of variables coming from the DSP (no calibrations needed) - Emiliano Mocchiutti
3 //
4 // FCaloQLOOK.c version 1.08 (2006-05-29)
5 //
6 // The only input needed is the path to the directory created by YODA for the data file you want to analyze.
7 //
8 // Changelog:
9 //
10 // 1.07 - 1.08 (2006-05-29): Fixed bug in output filename when input is not in the form DW_YYMMDD_NNN.
11 //
12 // 1.06 - 1.07 (2006-05-23): Don't print warning in case of latchup not recognized from the status word, fixed. Added "expert" figures from 21 to 28 which appears only in the
13 // case of latchup alarm.
14 //
15 // 1.05 - 1.06 (2006-03-22): Add optimize flag in compiling the script!
16 //
17 // 1.04 - 1.05 (2006-03-22): Corrected wrong .C files.
18 //
19 // 1.03 - 1.04 (2006-03-20): Documentation updated.
20 //
21 // 1.02 - 1.03 (2006-03-20): Changed name of shared libraries (from FCaloQLOOK_cxx.so to libFCaloQLOOK.so).
22 //
23 // 1.01 - 1.02 (2006-03-13): Include files from YODA without "event" directory.
24 //
25 // 1.00 - 1.01 (2006-02-28): Works on YODA v6 output (single file), does not require anymore calocommon package.
26 //
27 // 0.00 - 1.00 (2006-02-28): Clone of CaloQLOOK.c (ground software).
28 //
29 #include <iostream>
30 #include <fstream>
31 //
32 #include <TObject.h>
33 #include <TString.h>
34 #include <TFile.h>
35 #include <TCanvas.h>
36 #include <TH1.h>
37 #include <TH1F.h>
38 #include <TH2D.h>
39 #include <TLatex.h>
40 #include <TPad.h>
41 #include <TPolyLine.h>
42 #include <TStyle.h>
43 #include <TSystem.h>
44 //
45 #include <PamelaRun.h>
46 #include <physics/calorimeter/CalorimeterEvent.h>
47 //
48 #include <FCaloQLOOKfun.h>
49 //
50 using namespace std;
51 //
52 void stringcopy(TString& s1, const TString& s2, Int_t from=0, Int_t to=0){
53 if ( to == 0 ){
54 Int_t t2length = s2.Length();
55 s1 = "";
56 to = t2length;
57 };
58 for (Int_t i = from; i<to; i++){
59 s1.Append(s2[i],1);
60 };
61 }
62 void stringappend(TString& s1, const TString& s2){
63 Int_t t2length = s2.Length();
64 for (Int_t i = 0; i<t2length; i++){
65 s1.Append(s2[i],1);
66 };
67 }
68
69 TString getFilename(const TString filename){
70 //
71 const string fil = gSystem->BaseName(filename.Data());
72 Int_t posiz = fil.find(".root");
73 //
74 TString file2;
75 if ( posiz == -1 ){
76 file2 = gSystem->BaseName(filename.Data());
77 } else {
78 Int_t posiz2 = 0;
79 stringcopy(file2,gSystem->BaseName(filename.Data()),posiz2,posiz);
80 TString pdat(".dat");
81 stringappend(file2,pdat);
82 };
83 return file2;
84 }
85
86 void FCaloQLOOK(TString filename, Int_t fromevent=0, Int_t toevent=0, TString outDir="", TString saveas = "ps"){
87 gStyle->SetPaperSize(19.,25.);
88 const char* startingdir = gSystem->WorkingDirectory();
89 // printf(" basename is %s \n",gSystem->BaseName(filename.Data()));
90 // printf(" getfilename is %s \n",getFilename(filename).Data());
91 if ( !strcmp(outDir.Data(),"") ) outDir = startingdir;
92 //
93 //
94 ifstream myfile;
95 myfile.open(filename.Data());
96 if ( !myfile ){
97 printf(" %s :no such file, exiting...\n\n",filename.Data());
98 return;
99 };
100 myfile.close();
101 //
102 TFile *File = new TFile(filename.Data());
103 TTree *tr = (TTree*)File->Get("Physics");
104 if ( !tr ) {
105 printf(" Physics : no such tree in %s \n",filename.Data());
106 printf(" Exiting, are you sure this is a LEVEL0 not corrupted file? \n\n");
107 return;
108 };
109 //
110 // Define variables
111 //
112 Float_t ctshitthr = 0.65;
113 Float_t cbasethr = 0.95;
114 Float_t cdexythr = 0.995;
115 Float_t cdexycthr = 0.95;
116 //
117 pamela::calorimeter::CalorimeterEvent *ce = 0;
118 pamela::EventHeader *eh = 0;
119 pamela::PscuHeader *ph = 0;
120 //
121 UInt_t found;
122 tr->SetBranchStatus("*",0,&found); //disable all branches
123 //
124 found = 0;
125 tr->SetBranchStatus("iev*",1,&found);
126 // printf("enabled %i branches \n",found);
127 found = 0;
128 tr->SetBranchStatus("dexy*",1,&found);
129 // printf("enabled %i branches \n",found);
130 found = 0;
131 tr->SetBranchStatus("stwerr*",1,&found);
132 // printf("enabled %i branches \n",found);
133 found = 0;
134 tr->SetBranchStatus("perror*",1,&found);
135 // printf("enabled %i branches \n",found);
136 found = 0;
137 tr->SetBranchStatus("cal*",1,&found);
138 // printf("enabled %i branches \n",found);
139 found = 0;
140 tr->SetBranchStatus("base*",1,&found);
141 //printf("enabled %i branches \n",found);
142 found = 0;
143 tr->SetBranchStatus("Pscu*",1,&found);
144 //printf("enabled %i branches \n",found);
145 found = 0;
146 tr->SetBranchStatus("Calorimeter*",1,&found);
147 //printf("calo enabled %i branches \n",found);
148 found = 0;
149 tr->SetBranchStatus("Header*",1,&found);
150 //printf("head enabled %i branches \n",found);
151 //
152 tr->SetBranchAddress("Calorimeter", &ce);
153 tr->SetBranchAddress("Header", &eh);
154 //
155 Long64_t nevents = tr->GetEntries();
156 if ( nevents < 1 ) {
157 printf("The file is empty!\n");
158 return;
159 };
160 Int_t const size = nevents;
161 Double_t iev2[size+1];
162 Int_t ver[4][23], lver[4][23],shit[4][11], rshit[4][11], se,bl, pl, fulldiff[4],cshit, cpre[4],nullsh[4][11], lalarm[4];
163 se = 0;
164 pl = 0;
165 Float_t allbase = 0.;
166 Int_t tshit, trshit, compdata,rawdata, errorfull, calevn1, calevn2, calevn3, calevn4, pshit[4][11];
167 tshit = 0;
168 trshit = 0;
169 char *sezione;
170 Bool_t check = false;
171 sezione = "";
172 stringstream errore;
173 errore.str("");
174 //
175 TString fififile = getFilename(filename);
176 const char *file = fififile;
177 //
178 // book histograms
179 //
180 TH1F *h1;
181 TH1F *h1r;
182 TH1F *hdiff;
183 TH1F *Baseline;
184 TH1F *Dexy;
185 TH1F *Dexyc;
186 TH1F *Calstriphit;
187 TH1F *calev01;
188 TH1F *calev23;
189 TH1F *calev03;
190 TH1F *lupstw[4];
191 TH1F *lup[4];
192 TH2D *calev2;
193
194 h1 = new TH1F("C7","Strips hit, compress mode",100,0.,200.);
195 h1r = new TH1F("C8","Strips hit, raw mode",100,-1,1);
196 h1r->SetBit(TH1F::kCanRebin);
197 hdiff = new TH1F("C6","Differences in full mode",100,-3,3);
198 hdiff->SetBit(TH1F::kCanRebin);
199 Baseline = new TH1F("C9","baselines",100,0,3);
200 Baseline->SetBit(TH1F::kCanRebin);
201 Dexy = new TH1F("C12","dexy",100,0.,37000.);
202 Dexyc = new TH1F("C10","dexyc",100,0,3);
203 Dexyc->SetBit(TH1F::kCanRebin);
204 Calstriphit = new TH1F("C11","calstriphit[1:4]",100,0.,200.);
205
206 calev01 = new TH1F("C3","|calevnum(1)-calevnum(2)|",100,0,1);
207 calev01->SetBit(TH1F::kCanRebin);
208 calev23 = new TH1F("C4","|calevnum(3)-calevnum(4)|",100,0,1);
209 calev23->SetBit(TH1F::kCanRebin);
210 calev03 = new TH1F("C5","|calevnum(1)-calevnum(4)|",100,0,1);
211 calev03->SetBit(TH1F::kCanRebin);
212 calev2 = new TH2D("C2","calevnum(2)%iev",3000,0.,2.,100,0.,2.);
213 calev2->SetBit(TH2D::kCanRebin);
214
215 stringstream oss;
216 stringstream noss;
217 for ( Int_t i=0; i<4; i++){
218 oss.str("");
219 oss << "OBT stw latch up section " << i;
220 noss.str("");
221 noss << "C" << 21+i;
222 lupstw[i] = new TH1F(noss.str().c_str(),oss.str().c_str(),100,-1,1);
223 lupstw[i]->SetBit(TH1F::kCanRebin);
224 oss.str("");
225 oss << "OBT no stw latch up section " << i;
226 noss.str("");
227 noss << "C" << 25+i;
228 lup[i] = new TH1F(noss.str().c_str(),oss.str().c_str(),100,-1,1);
229 lup[i]->SetBit(TH1F::kCanRebin);
230 };
231
232 //
233 // run over each event and take out some variables
234 //
235 if ( fromevent > toevent && toevent ){
236 printf("It must be fromevent < toevent \n");
237 return;
238 };
239
240
241 if ( fromevent > nevents+1 || fromevent < 0 ) {
242 printf("You can choose fromevent between 0 (all) and %i \n",(int)nevents+1);
243 return;
244 };
245
246 if ( toevent > nevents+1 || toevent < 0 ) {
247 printf("You can choose toevent between 0 (all) and %i \n",(int)nevents+1);
248 return;
249 };
250 Int_t minevent = 0;
251 Int_t maxevent = 0;
252 if ( fromevent == 0 ) {
253 minevent = 0;
254 maxevent = nevents -1;
255 } else {
256 minevent = fromevent - 1;
257 if ( toevent > 0 ){
258 maxevent = toevent - 1;
259 } else {
260 maxevent = fromevent - 1;
261 };
262 };
263
264 for (Int_t k = 0; k < 4; k++ ){
265 for (Int_t m = 0; m < 23 ; m++ ){
266 ver[k][m] = 0 ;
267 lver[k][m] = 0 ;
268 cpre[k]=0;
269 if ( m < 11 ) {
270 pshit[k][m] = 0;
271 nullsh[k][m] = 0;
272 };
273 lalarm[k] = 0;
274 };
275 };
276 Int_t pdone, bdone;
277 pdone = 0;
278 bdone = 0;
279 bool isCOMP = 0;
280 bool isFULL = 0;
281 bool isRAW = 0;
282 Int_t alldexy=0;
283 Int_t alldexy2=0;
284 Int_t stri=0;
285 Int_t fcheck = 0;
286 Int_t cestw=0;
287 Int_t cmask = 127 ;
288 compdata = 0;
289 rawdata = 0;
290 errorfull = 0;
291 calevn1 = 0;
292 calevn2 = 0;
293 calevn3 = 0;
294 calevn4 = 0;
295 fulldiff[0] = 0;
296 fulldiff[1] = 0;
297 fulldiff[2] = 0;
298 fulldiff[3] = 0;
299 printf("\n Processed events: \n\n");
300 unsigned short int calev0=0;
301 unsigned short int oldcalev0;
302 unsigned short int calev1=0;
303 unsigned short int oldcalev1;
304 unsigned short int calevv2=0;
305 unsigned short int oldcalev2;
306 unsigned short int calev3=0;
307 unsigned short int oldcalev3;
308 Int_t i = minevent;
309 Float_t headc = 0.;
310 Float_t headco = 0.;
311 Bool_t h1rcheck = false;
312 Int_t intshit = 0;
313 Int_t outtshit = 0;
314 Int_t incshit = 0;
315 Int_t outcshit = 0;
316 Int_t inbase = 0;
317 Int_t outbase = 0;
318 Int_t indexy = 0;
319 Int_t outdexy = 0;
320 Int_t indexyc = 0;
321 Int_t outdexyc = 0;
322 Int_t obt = 0;
323 Int_t minobt[4];
324 Int_t maxobt[4];
325 Int_t swminobt[4];
326 Int_t swmaxobt[4];
327 Bool_t firstobt[4];
328 Bool_t swfirstobt[4];
329 for ( Int_t i = 0; i<4; i++){
330 minobt[i] = 0;
331 maxobt[i] = 0;
332 swminobt[i] = 0;
333 swmaxobt[i] = 0;
334 firstobt[i] = true;
335 swfirstobt[i] = true;
336 };
337 while ( i < maxevent+1){
338 tshit = 0;
339 trshit = 0;
340 tr->GetEntry(i);
341 iev2[i] = ce->iev;
342 //
343 ph = eh->GetPscuHeader();
344 headco = headc;
345 headc = ph->GetCounter();
346 obt = ph->GetOrbitalTime();
347 calevn1 += (int)abs((int)(ce->calevnum[0]-ce->calevnum[1]));
348 calevn2 += (int)abs((int)(ce->calevnum[2]-ce->calevnum[3]));
349 calevn3 += (int)abs((int)(ce->calevnum[0]-ce->calevnum[3]));
350 calev01->Fill(abs((int)(ce->calevnum[0]-ce->calevnum[1])));
351 calev23->Fill(abs((int)(ce->calevnum[2]-ce->calevnum[3])));
352 calev03->Fill(abs((int)(ce->calevnum[0]-ce->calevnum[3])));
353 unsigned short calvnm2 = (unsigned short)ce->calevnum[2];
354 calev2->Fill(ce->iev,calvnm2);
355 calevn4 += (int)ce->calevnum[2];
356 oldcalev0 = calev0;
357 calev0 = (int)ce->calevnum[0];
358 oldcalev1 = calev1;
359 calev1 = (int)ce->calevnum[1];
360 oldcalev2 = calevv2;
361 calevv2 = (int)ce->calevnum[2];
362 oldcalev3 = calev3;
363 calev3 = (int)ce->calevnum[3];
364 goto jumpprintout;
365 if ( (headc - headco -1.) == 0. && ((calev0 - oldcalev0 - 1) > 0 || (calev1 - oldcalev1 - 1) > 0 || (calevv2 - oldcalev2 - 1) > 0 || (calev3 - oldcalev3 - 1) > 0) ){
366 if ( i != minevent ) {
367 printf(" %f 0 Event %i: %i\n",headco,i,oldcalev0);
368 printf(" %f 0 Event %i: %i\n",headc,i+1,calev0);
369 printf(" %f 1 Event %i: %i\n",headco,i,oldcalev1);
370 printf(" %f 1 Event %i: %i\n",headc,i+1,calev1);
371 printf(" %f 2 Event %i: %i\n",headco,i,oldcalev2);
372 printf(" %f 2 Event %i: %i\n",headc,i+1,calevv2);
373 printf(" %f 3 Event %i: %i\n",headco,i,oldcalev3);
374 printf(" %f 3 Event %i: %i\n",headc,i+1,calev3);
375 isRAW = 0;
376 if ( ce->stwerr[0] & (1 << 3)) isRAW = 1;
377 if ( (calev0 - oldcalev0 - 1) > 0 && !isRAW && ce->perror[0] != 129 && oldcalev0 != 0) {
378 ver[0][10]++;
379 };
380 isRAW = 0;
381 if ( ce->stwerr[0] & (1 << 3)) isRAW = 1;
382 if ( (calev1 - oldcalev1 - 1) > 0 && !isRAW && ce->perror[1] != 129 && oldcalev1 != 0 ){
383 ver[1][10]++;
384 };
385 isRAW = 0;
386 if ( ce->stwerr[0] & (1 << 3)) isRAW = 1;
387 if ( (calevv2 - oldcalev2 - 1) > 0 && !isRAW && ce->perror[2] != 129 && oldcalev2 != 0 ){
388 ver[2][10]++;
389 };
390 isRAW = 0;
391 if ( ce->stwerr[0] & (1 << 3)) isRAW = 1;
392 if ( (calev3 - oldcalev3 - 1) > 0 && !isRAW && ce->perror[3] != 129 && oldcalev3 != 0 ){
393 ver[3][10]++;
394 };
395 }
396 };
397 jumpprintout:
398 memcpy(shit, nullsh, sizeof(nullsh));
399 memcpy(rshit, nullsh, sizeof(nullsh));
400 for (Int_t l = 0; l < 2; l++ ){
401 for (Int_t ii = 0; ii < 22; ii++){
402 if (l == 0 && ii%2 == 0){
403 se = 3;
404 pl = ii/2;
405 pdone = 0;
406 };
407 if (l == 0 && ii%2 != 0){
408 se = 2;
409 pl = (ii-1)/2;
410 pdone = 0;
411 };
412 if (l == 1 && ii%2 == 0){
413 se = 0;
414 pl = ii/2;
415 pdone = 0;
416 };
417 if (l == 1 && ii%2 != 0){
418 se = 1;
419 pl = (ii-1)/2;
420 pdone = 0;
421 };
422
423 isCOMP = 0;
424 isFULL = 0;
425 isRAW = 0;
426 if ( ce->stwerr[se] & (1 << 16) ) isCOMP = 1;
427 if ( ce->stwerr[se] & (1 << 17) ) isFULL = 1;
428 if ( ce->stwerr[se] & (1 << 3) ) isRAW = 1;
429 bl = -1;
430 for (Int_t kk = 0; kk < 96 ; kk++ ){
431 if ( kk%16 == 0 ){
432 bdone = 0;
433 bl++;
434 allbase = ce->base[l][ii][bl];
435 alldexy=0;
436 alldexy2=0;
437 stri=0;
438 for (Int_t e = 0; e < 16 ; e++ ){
439 stri = e + 16 * bl;
440 alldexy += (int)ce->dexyc[l][ii][stri];
441 alldexy2 += (int)ce->dexy[l][ii][stri];
442 };
443 };
444 if ( !isRAW ) {
445 //
446 if ( !pdone ){
447 if ( (ce->base[l][ii][bl]>32000 || ce->base[l][ii][bl] == 0 ) && ( alldexy > 512000 || alldexy == 0) && ce->perror[se] == 0 ) {
448 pdone = 1;
449 pshit[se][pl]++ ;
450 if ( (ce->stwerr[se] & (1 << 4)) == 0 ) {
451 lalarm[se]++;
452 lup[se]->Fill(obt);
453 if ( firstobt[se] ) minobt[se] = obt;
454 if ( obt > maxobt[se] ) maxobt[se] = obt;
455 };
456 lver[se][2]++ ;
457 };
458 }
459 //
460 if ( !bdone ){
461 Baseline->Fill(ce->base[l][ii][bl]);
462 if ( ce->base[l][ii][bl] > 2000. && ce->base[l][ii][bl] < 4500. ){
463 inbase++;
464 } else {
465 outbase++;
466 };
467 bdone = 1;
468 };
469 //
470 if (ce->dexyc[l][ii][kk] > 0 ) {
471 shit[se][pl]++ ;
472 compdata = 1;
473 };
474 //
475 if ( isFULL ) {
476 if ( ce->dexy[l][ii][kk] > 0 && ce->dexy[l][ii][kk] < 32000 ) {
477 rshit[se][pl]++ ;
478 rawdata = 1;
479 };
480 Dexy->Fill(ce->dexy[l][ii][kk]);
481 if ( ce->dexy[l][ii][kk] < 2000. || ce->dexy[l][ii][kk] > 5000. ) {
482 outdexy++;
483 } else {
484 indexy++;
485 };
486 if ( ce->dexyc[l][ii][kk]>0 && (ce->dexy[l][ii][kk]-ce->dexyc[l][ii][kk]) != 0 && ce->perror[se] != 132 && (ce->base[l][ii][bl] == 0 || ce->base[l][ii][bl] >32000) ){
487 hdiff->Fill(ce->dexyc[l][ii][kk]-ce->dexy[l][ii][kk]);
488 fulldiff[se]++;
489 errorfull = 1;
490 };
491 };
492 //
493 Dexyc->Fill(ce->dexyc[l][ii][kk]);
494 if ( ce->dexyc[l][ii][kk] != 0. && ( ce->dexyc[l][ii][kk] < 2000. || ce->dexyc[l][ii][kk] > 5000. ) ) {
495 outdexyc++;
496 } else {
497 indexyc++;
498 };
499 //
500 if (ce->dexyc[l][ii][kk] < 0 ) ver[se][21]++ ;
501 //
502 if ( allbase == 0. || allbase > 32000.) {
503 fcheck = 0;
504 for (Int_t nn = bl*16; nn < (bl+1)*16 ; nn++){
505 if ( ce->dexyc[l][ii][nn] > 0. && ce->dexyc[l][ii][nn] < 32000. ) fcheck++;
506 };
507 if ( fcheck ) {
508 cpre[se]++;
509 allbase = 1.;
510 };
511 };
512 //
513 } else {
514 if ( !pdone ){
515 if ( (alldexy2>512000 || alldexy2 == 0) && ce->perror[se] == 0 ) {
516 pdone = 1;
517 pshit[se][pl]++ ;
518 if ( (ce->stwerr[se] & (1 << 4)) == 0 ){
519 lalarm[se]++;
520 lup[se]->Fill(obt);
521 if ( firstobt[se] ) minobt[se] = obt;
522 if ( obt > maxobt[se] ) maxobt[se] = obt;
523 };
524 lver[se][2]++ ;
525 };
526 };
527 if ( ce->dexy[l][ii][kk] > 0 && ce->dexy[l][ii][kk] < 32000 ) {
528 rshit[se][pl]++ ;
529 rawdata = 1;
530 };
531 Dexy->Fill(ce->dexy[l][ii][kk]);
532 if ( ce->dexy[l][ii][kk] < 2000. || ce->dexy[l][ii][kk] > 5000. ) {
533 outdexy++;
534 } else {
535 indexy++;
536 };
537 };
538 };
539 };
540 };
541 cshit = 0;
542 for (Int_t k = 0; k < 4 ; k++ ){
543 isCOMP = 0;
544 isFULL = 0;
545 if ( ce->stwerr[se] & (1 << 16) ) isCOMP = 1;
546 if ( ce->stwerr[se] & (1 << 17) ) isFULL = 1;
547 if ( isCOMP ) ver[k][16]++;
548 if ( isFULL ) ver[k][17]++;
549 cshit += (int)ce->calstriphit[k];
550 cestw=0;
551 if ( ce->stwerr[k] ) cestw = ce->stwerr[k] & cmask ;
552 if ( cestw ){
553 if ( cestw & (1 << 0) ) ver[k][6]++ ;
554 if ( cestw & (1 << 1) ) ver[k][5]++ ;
555 if ( cestw & (1 << 2) ) ver[k][4]++ ;
556 if ( cestw & (1 << 3) ) ver[k][3]++ ;
557 if ( cestw & (1 << 4) ){
558 ver[k][2]++ ;
559 lupstw[k]->Fill(obt);
560 if ( swfirstobt[k] ) swminobt[k] = obt;
561 if ( obt > swmaxobt[k] ) swmaxobt[k] = obt;
562 };
563 if ( cestw & (1 << 5) ) ver[k][1]++ ;
564 if ( cestw & (1 << 6) ) ver[k][0]++ ;
565 };
566 if ( ce->perror[k] != 0. ){
567 if (ce->perror[k] == 128) ver[k][7]++ ;
568 if (ce->perror[k] == 129) ver[k][8]++ ;
569 if (ce->perror[k] == 132) ver[k][11]++ ;
570 if (ce->perror[k] == 133) ver[k][12]++ ;
571 if (ce->perror[k] == 134) ver[k][13]++ ;
572 if (ce->perror[k] == 135) ver[k][14]++ ;
573 if (ce->perror[k] == 136) ver[k][15]++ ;
574 if (ce->perror[k] == 139) ver[k][18]++ ;
575 if (ce->perror[k] == 140) ver[k][19]++ ;
576 if (ce->perror[k] == 141) ver[k][20]++ ;
577 if (ce->perror[k] == 142) ver[k][22]++ ;
578 };
579 for (Int_t kk = 0; kk < 11 ; kk++ ){
580 tshit += shit[k][kk];
581 trshit += rshit[k][kk];
582 };
583 };
584 Calstriphit->Fill(cshit);
585 if ( (cshit > 0 && cshit < 25) || (cshit > 40 && cshit < 80) ){
586 incshit++;
587 } else {
588 outcshit++;
589 };
590 if ( tshit>0 ) h1->Fill(tshit);
591 if ( (tshit > 0 && tshit < 25) || (tshit > 40 && tshit < 80) ){
592 intshit++;
593 } else {
594 outtshit++;
595 };
596 if ( trshit>0 ) {
597 h1r->Fill(trshit);
598 if ( trshit < 4210 ){
599 h1rcheck = true;
600 // printf("ma come... trshit %i \n",trshit);
601 };
602 };
603 if ( i%1000 == 0 && i > 0 ) printf("%iK\n",i/1000);
604 i++;
605 };
606 printf("\n");
607
608 //
609 // output figures, first sheet:
610 //
611 gStyle->SetOptDate(0);
612 gStyle->SetOptStat(1111);
613 TCanvas *figura = new TCanvas("Calorimeter_Detector_Report_1/3", "Calorimeter_Detector_Report_1/3", 1100, 900);
614 figura->SetFillColor(10);
615 figura->Range(0,0,100,100);
616 errore.str("");
617 errore << "EXPERT -- File: " << file;
618 errore << " ";
619 TLatex *t=new TLatex();
620 t->SetTextFont(32);
621 t->SetTextColor(1);
622 t->SetTextAlign(12);
623 t->SetTextSize(0.015);
624 t->DrawLatex(2.,99.,errore.str().c_str());
625 TPad *pd5;
626 TPad *pd6;
627 TPad *pd7;
628 TPad *pd8;
629 TPad *pad1;
630 TPad *pad2;
631 TPad *pad3;
632 TPad *pad4;
633 TPad *pd1;
634 TPad *pd2;
635 TPad *pd3;
636 TPad *pd4;
637 //
638 Double_t h1max;
639 TPolyLine *banda1;
640 TPolyLine *banda2;
641 Float_t ctshit = 0;
642 Float_t ccshit = 0;
643 Float_t cbase = 0;
644 Float_t cdexy = 0;
645 Float_t cdexyc = 0;
646 //
647 if ( compdata && rawdata ){
648 ctshit = (float)intshit/((float)outtshit + (float)intshit);
649 Int_t pd5col = 10;
650 Int_t pd6col = 10;
651 if ( ctshit < ctshitthr ) {
652 check = true;
653 pd5col = 45;
654 };
655 if ( h1rcheck ) {
656 check = true;
657 pd6col = 45;
658 };
659 pd5 = new TPad("pd5","This is pad5",0.51,0.51,0.98,0.98,pd5col);
660 pd6 = new TPad("pd6","This is pad6",0.51,0.02,0.98,0.49,pd6col);
661 pd5->SetTicks();
662 pd6->SetTicks();
663 pd5->Range(0,0,100,100);
664 pd6->Range(0,0,100,100);
665 figura->cd();
666 pd5->Draw();
667 pd5->cd();
668 h1->SetXTitle("Number of hit (dexyc>0)");
669 h1->SetYTitle("Number of events");
670 h1->Draw();
671 //
672 h1max = h1->GetMaximum()*1.05;
673 Double_t xc[4] = {0.,25.,25.,0.};
674 Double_t yc[4] = {0.,0.,h1max,h1max};
675 banda1 = new TPolyLine(4,xc,yc);
676 banda1->SetLineColor(5);
677 banda1->SetFillColor(5);
678 banda1->SetLineWidth(1);
679 banda1->Draw("fSAME");
680 Double_t xd[4] = {40.,80.,80.,40.};
681 Double_t yd[4] = {0.,0.,h1max,h1max};
682 banda2 = new TPolyLine(4,xd,yd);
683 banda2->SetLineColor(5);
684 banda2->SetFillColor(5);
685 banda2->SetLineWidth(1);
686 banda2->Draw("fSAME");
687 h1->Draw("SAME");
688 //
689 figura->cd();
690 pd6->Draw();
691 pd6->cd();
692 gPad->SetLogy();
693 h1r->SetXTitle("Number of hit (dexy>0)");
694 h1r->SetYTitle("Number of events");
695 h1r->Draw();
696 h1max = h1r->GetMaximum()*2.05;
697 Double_t xg[4] = {4220.,4230.,4230.,4220.};
698 Double_t yg[4] = {0.,0.,h1max,h1max};
699 banda1 = new TPolyLine(4,xg,yg);
700 banda1->SetLineColor(5);
701 banda1->SetFillColor(5);
702 banda1->SetLineWidth(1);
703 banda1->Draw("fSAME");
704 h1r->Draw("SAME");
705 };
706 if ( (compdata && !rawdata) || (!compdata && rawdata) ){
707 if ( tshit !=0 ) {
708 ctshit = (float)intshit/((float)outtshit + (float)intshit);
709 Int_t pd5col = 10;
710 if ( ctshit < ctshitthr ) {
711 check = true;
712 pd5col = 45;
713 };
714 pd5 = new TPad("pd5","This is pad5",0.51,0.02,0.98,0.98,pd5col);
715 pd5->Range(0,0,100,100);
716 pd5->SetTicks();
717 pd5->Draw();
718 pd5->cd();
719 h1->SetXTitle("Number of hit (dexyc>0)");
720 h1->SetYTitle("Number of events");
721 h1->Draw();
722 h1max = h1->GetMaximum()*1.05;
723 Double_t xe[4] = {0.,25.,25.,0.};
724 Double_t ye[4] = {0.,0.,h1max,h1max};
725 banda1 = new TPolyLine(4,xe,ye);
726 banda1->SetLineColor(5);
727 banda1->SetFillColor(5);
728 banda1->SetLineWidth(1);
729 banda1->Draw("fSAME");
730 Double_t xf[4] = {40.,80.,80.,40.};
731 Double_t yf[4] = {0.,0.,h1max,h1max};
732 banda2 = new TPolyLine(4,xf,yf);
733 banda2->SetLineColor(5);
734 banda2->SetFillColor(5);
735 banda2->SetLineWidth(1);
736 banda2->Draw("fSAME");
737 h1->Draw("SAME");
738 };
739 if ( trshit !=0 ) {
740 Int_t pd5col = 10;
741 if ( h1rcheck ) {
742 check = true;
743 pd5col = 45;
744 };
745 pd5 = new TPad("pd5","This is pad5",0.51,0.02,0.98,0.98,pd5col);
746 pd5->Range(0,0,100,100);
747 pd5->SetTicks();
748 pd5->Draw();
749 pd5->cd();
750 gPad->SetLogy();
751 h1r->SetXTitle("Number of hit (dexyc>0 or dexy>0)");
752 h1r->SetYTitle("Number of events");
753 h1r->Draw();
754 h1max = h1r->GetMaximum()*2.05;
755 Double_t xh[4] = {4220.,4230.,4230.,4220.};
756 Double_t yh[4] = {0.,0.,h1max,h1max};
757 banda1 = new TPolyLine(4,xh,yh);
758 banda1->SetLineColor(5);
759 banda1->SetFillColor(5);
760 banda1->SetLineWidth(1);
761 banda1->Draw("fSAME");
762 h1r->Draw("SAME");
763 };
764 };
765 if ( !errorfull ) {
766 if ( calevn1 || calevn2 || calevn3 ) {
767 pd1 = new TPad("pd1","This is pad1",0.02,0.51,0.24,0.98,45);
768 pd2 = new TPad("pd2","This is pad2",0.26,0.51,0.49,0.98,45);
769 pd3 = new TPad("pd3","This is pad3",0.02,0.02,0.24,0.49,45);
770 pd4 = new TPad("pd4","This is pad4",0.26,0.02,0.49,0.49,45);
771 figura->cd();
772 // printf("ou2! \n");
773 check = true;
774 pd1->Range(0,0,100,100);
775 pd2->Range(0,0,100,100);
776 pd3->Range(0,0,100,100);
777 pd4->Range(0,0,100,100);
778 pd1->Draw();
779 pd2->Draw();
780 pd3->Draw();
781 pd4->Draw();
782
783 pd1->cd();
784 gPad->SetLogy();
785 calev01->SetXTitle("delta calevnum 1-2");
786 calev01->SetYTitle("Number of events");
787 calev01->Draw();
788
789 pd2->cd();
790 gPad->SetLogy();
791 calev23->SetXTitle("delta calevnum 3-4");
792 calev23->SetYTitle("Number of events");
793 calev23->Draw();
794
795 pd3->cd();
796 gPad->SetLogy();
797 calev03->SetXTitle("delta calevnum 1-4");
798 calev03->SetYTitle("Number of events");
799 calev03->Draw();
800
801 pd4->cd();
802 calev2->SetYTitle("calevnum 2");
803 calev2->SetXTitle("iev");
804 calev2->Draw();
805 } else {
806 if ( calevn4 ) {
807 pd3 = new TPad("pd3","This is pad3",0.02,0.02,0.49,0.98,10);
808 figura->cd();
809 pd3->Range(0,0,100,100);
810 pd3->Draw();
811 pd3->cd();
812 calev2->SetYTitle("calevnum 2");
813 calev2->SetXTitle("iev");
814 calev2->Draw();
815 } else {
816 figura->cd();
817 t=new TLatex();
818 t->SetTextFont(32);
819 t->SetTextColor(1);
820 t->SetTextSize(0.04);
821 t->SetTextAlign(12);
822 t->DrawLatex(10.,49.,"No calevnum infos from DSP");
823 };
824 };
825 } else {
826 figura->cd();
827 check = true;
828 // printf("nou! \n");
829 pd1 = new TPad("pd1","This is pad1",0.02,0.02,0.49,0.98,45);
830 pd1->Range(0,0,100,100);
831 pd1->Draw();
832 pd1->cd();
833 gPad->SetLogy();
834 hdiff->SetXTitle("Differences in FULL mode");
835 hdiff->SetYTitle("Number of events");
836 hdiff->Draw();
837 };
838
839 //
840 // output figures, second sheet:
841 //
842 TCanvas *figura2 = new TCanvas("Calorimeter_Detector_Report_2/3","Calorimeter_Detector_Report_2/3", 1100, 900);
843 if ( compdata ){
844 Int_t pd1col = 10;
845 Int_t pd2col = 10;
846 Int_t pd3col = 10;
847 Int_t pd4col = 10;
848 if ( (outdexy+indexy) ) {
849 cdexy = (float)indexy/((float)outdexy + (float)indexy);
850 if ( cdexy < cdexythr ) {
851 check = true;
852 pd4col = 45;
853 };
854 };
855 if ( (outcshit+incshit) ) {
856 ccshit = (float)incshit/((float)outcshit + (float)incshit);
857 if ( ccshit < ctshitthr ) {
858 check = true;
859 pd3col = 45;
860 };
861 };
862 if ( (outdexyc+indexyc) ) {
863 cdexyc = (float)indexyc/((float)outdexyc + (float)indexyc);
864 if ( cdexyc < cdexycthr ) {
865 check = true;
866 pd2col = 45;
867 };
868 };
869 if ( (outbase+inbase) ) {
870 cbase = (float)inbase/((float)outbase + (float)inbase);
871 if ( cbase < cbasethr ) {
872 check = true;
873 pd1col = 45;
874 };
875 };
876 figura2->SetFillColor(10);
877 figura2->Range(0,0,100,100);
878 errore.str("");
879 errore << "EXPERT -- File: " << file;
880 errore << " ";
881 t=new TLatex();
882 t->SetTextFont(32);
883 t->SetTextColor(1);
884 t->SetTextAlign(12);
885 t->SetTextSize(0.015);
886 t->DrawLatex(2.,99.,errore.str().c_str());
887 pd1 = new TPad("pd1","This is pad1",0.02,0.51,0.49,0.98,pd1col);
888 pd2 = new TPad("pd2","This is pad2",0.51,0.51,0.98,0.98,pd2col);
889 pd3 = new TPad("pd3","This is pad3",0.02,0.02,0.49,0.49,pd3col);
890 pd4 = new TPad("pd4","This is pad4",0.51,0.02,0.98,0.49,pd4col);
891 figura2->cd();
892 pd1->Range(0,0,100,100);
893 pd2->Range(0,0,100,100);
894 pd3->Range(0,0,100,100);
895 pd4->Range(0,0,100,100);
896 pd1->SetTicks();
897 pd2->SetTicks();
898 pd3->SetTicks();
899 pd4->SetTicks();
900 pd1->Draw();
901 pd2->Draw();
902 pd3->Draw();
903 pd4->Draw();
904 pd1->cd();
905 Baseline->SetXTitle("ADC channels");
906 Baseline->SetYTitle("Number of events");
907 Baseline->Draw();
908 h1max = Baseline->GetMaximum()*1.05;
909 Double_t xc[4] = {2000.,4500.,4500.,2000.};
910 Double_t yc[4] = {0.,0.,h1max,h1max};
911 banda1 = new TPolyLine(4,xc,yc);
912 banda1->SetLineColor(5);
913 banda1->SetFillColor(5);
914 banda1->SetLineWidth(1);
915 banda1->Draw("fSAME");
916 Baseline->Draw("SAME");
917 //
918 pd2->cd();
919 gPad->SetLogy();
920 Dexyc->SetXTitle("ADC channels");
921 Dexyc->SetYTitle("Number of events");
922 Dexyc->Draw();
923 h1max = Dexyc->GetMaximum()*2.05;
924 Double_t xe[4] = {2000.,5000.,5000.,2000.};
925 Double_t ye[4] = {0.,0.,h1max,h1max};
926 banda1 = new TPolyLine(4,xe,ye);
927 banda1->SetLineColor(5);
928 banda1->SetFillColor(5);
929 banda1->SetLineWidth(1);
930 banda1->Draw("fSAME");
931 Double_t xj[4] = {0.,40.,40.,0.};
932 Double_t yj[4] = {0.,0.,h1max,h1max};
933 banda2 = new TPolyLine(4,xj,yj);
934 banda2->SetLineColor(5);
935 banda2->SetFillColor(5);
936 banda2->SetLineWidth(1);
937 banda2->Draw("fSAME");
938 Dexyc->Draw("SAME");
939 //
940 pd3->cd();
941 Calstriphit->SetXTitle("Number of hit");
942 Calstriphit->SetYTitle("Number of events");
943 Calstriphit->Draw();
944 h1max = Calstriphit->GetMaximum()*1.05;
945 Double_t xg[4] = {0.,25.,25.,0.};
946 Double_t yg[4] = {0.,0.,h1max,h1max};
947 banda1 = new TPolyLine(4,xg,yg);
948 banda1->SetLineColor(5);
949 banda1->SetFillColor(5);
950 banda1->SetLineWidth(1);
951 banda1->Draw("fSAME");
952 Double_t xh[4] = {40.,80.,80.,40.};
953 Double_t yh[4] = {0.,0.,h1max,h1max};
954 banda2 = new TPolyLine(4,xh,yh);
955 banda2->SetLineColor(5);
956 banda2->SetFillColor(5);
957 banda2->SetLineWidth(1);
958 banda2->Draw("fSAME");
959 Calstriphit->Draw("SAME");
960 //
961 pd4->cd();
962 Dexy->SetXTitle("ADC channels");
963 Dexy->SetYTitle("Number of events");
964 Dexy->Draw();
965 h1max = Dexy->GetMaximum()*1.05;
966 Double_t xd[4] = {2000.,5000.,5000.,2000.};
967 Double_t yd[4] = {0.,0.,h1max,h1max};
968 banda1 = new TPolyLine(4,xd,yd);
969 banda1->SetLineColor(5);
970 banda1->SetFillColor(5);
971 banda1->SetLineWidth(1);
972 banda1->Draw("fSAME");
973 Dexy->Draw("SAME");
974 } else {
975 Int_t pd4col = 10;
976 if ( (outdexy+indexy) ) {
977 cdexy = (float)indexy/((float)outdexy + (float)indexy);
978 if ( cdexy < cdexythr ) {
979 check = true;
980 pd4col = 45;
981 };
982 };
983 figura2->SetFillColor(10);
984 figura2->Range(0,0,100,100);
985 errore.str("");
986 errore << "EXPERT -- File: " << file;
987 errore << " ";
988 t=new TLatex();
989 t->SetTextFont(32);
990 t->SetTextColor(1);
991 t->SetTextAlign(12);
992 t->SetTextSize(0.015);
993 t->DrawLatex(2.,99.,errore.str().c_str());
994 pd4 = new TPad("pd4","This is pad4",0.02,0.02,0.98,0.98,pd4col);
995 figura2->cd();
996 pd4->Range(0,0,100,100);
997 pd4->SetTicks();
998 pd4->Draw();
999 //
1000 pd4->cd();
1001 Dexy->SetXTitle("ADC channels");
1002 Dexy->SetYTitle("Number of events");
1003 Dexy->Draw();
1004 h1max = Dexy->GetMaximum()*1.05;
1005 Double_t xd[4] = {2000.,5000.,5000.,2000.};
1006 Double_t yd[4] = {0.,0.,h1max,h1max};
1007 banda1 = new TPolyLine(4,xd,yd);
1008 banda1->SetLineColor(5);
1009 banda1->SetFillColor(5);
1010 banda1->SetLineWidth(1);
1011 banda1->Draw("fSAME");
1012 Dexy->Draw("SAME");
1013 };
1014 //
1015 TCanvas *figura3 = 0;
1016 Bool_t printfigure3 = false;
1017 for (Int_t i = 0; i<4; i++){
1018 if ( ver[i][2] || lver[i][2] ){
1019 printfigure3 = true;
1020 break;
1021 };
1022 };
1023 if ( printfigure3 ){
1024 figura3 = new TCanvas("Calorimeter_Detector_Report_2bis/3","Calorimeter_Detector_Report_2bis/3", 1100, 900);
1025 figura3->SetFillColor(10);
1026 figura3->Range(0,0,100,100);
1027 errore.str("");
1028 errore << "EXPERT -- File: " << file;
1029 errore << " ";
1030 t=new TLatex();
1031 t->SetTextFont(32);
1032 t->SetTextColor(1);
1033 t->SetTextAlign(12);
1034 t->SetTextSize(0.015);
1035 t->DrawLatex(2.,99.,errore.str().c_str());
1036 pd1 = new TPad("pd1","This is pad1",0.02,0.51,0.49,0.73,45);
1037 pd5 = new TPad("pd5","This is pad5",0.02,0.76,0.49,0.98,45);
1038 pd2 = new TPad("pd2","This is pad2",0.51,0.51,0.98,0.73,45);
1039 pd6 = new TPad("pd6","This is pad6",0.51,0.76,0.98,0.98,45);
1040 pd3 = new TPad("pd3","This is pad3",0.02,0.02,0.49,0.23,45);
1041 pd7 = new TPad("pd7","This is pad7",0.02,0.26,0.49,0.49,45);
1042 pd4 = new TPad("pd4","This is pad4",0.51,0.02,0.98,0.23,45);
1043 pd8 = new TPad("pd8","This is pad8",0.51,0.26,0.98,0.49,45);
1044 figura3->cd();
1045 pd1->Range(0,0,100,100);
1046 pd2->Range(0,0,100,100);
1047 pd3->Range(0,0,100,100);
1048 pd4->Range(0,0,100,100);
1049 pd1->SetTicks();
1050 pd2->SetTicks();
1051 pd3->SetTicks();
1052 pd4->SetTicks();
1053 pd1->Draw();
1054 pd2->Draw();
1055 pd3->Draw();
1056 pd4->Draw();
1057 pd5->Range(0,0,100,100);
1058 pd6->Range(0,0,100,100);
1059 pd7->Range(0,0,100,100);
1060 pd8->Range(0,0,100,100);
1061 pd5->SetTicks();
1062 pd6->SetTicks();
1063 pd7->SetTicks();
1064 pd8->SetTicks();
1065 pd5->Draw();
1066 pd6->Draw();
1067 pd7->Draw();
1068 pd8->Draw();
1069 pd1->cd();
1070 lup[0]->SetAxisRange((Double_t)min(minobt[0],swminobt[0])*0.9,(Double_t)max(maxobt[0],swmaxobt[0])*1.1,"X");
1071 lup[0]->SetXTitle("OBT");
1072 lup[0]->SetYTitle("Number of events");
1073 lup[0]->Draw();
1074 pd5->cd();
1075 lupstw[0]->SetAxisRange((Double_t)min(minobt[0],swminobt[0])*0.9,(Double_t)max(maxobt[0],swmaxobt[0])*1.1,"X");
1076 // lupstw[0]->SetAxisRange((Double_t)swminobt[0]*0.9,(Double_t)swmaxobt[0]*1.1,"X");
1077 lupstw[0]->SetXTitle("OBT");
1078 lupstw[0]->SetYTitle("Number of events");
1079 lupstw[0]->Draw();
1080 pd2->cd();
1081 lup[1]->SetAxisRange((Double_t)min(minobt[1],swminobt[1])*0.9,(Double_t)max(maxobt[1],swmaxobt[1])*1.1,"X");
1082 // lup[1]->SetAxisRange((Double_t)minobt[1]*0.9,(Double_t)maxobt[1]*1.1,"X");
1083 lup[1]->SetXTitle("OBT");
1084 lup[1]->SetYTitle("Number of events");
1085 lup[1]->Draw();
1086 pd6->cd();
1087 lupstw[1]->SetAxisRange((Double_t)min(minobt[1],swminobt[1])*0.9,(Double_t)max(maxobt[1],swmaxobt[1])*1.1,"X");
1088 // lupstw[1]->SetAxisRange((Double_t)swminobt[1]*0.9,(Double_t)swmaxobt[1]*1.1,"X");
1089 lupstw[1]->SetXTitle("OBT");
1090 lupstw[1]->SetYTitle("Number of events");
1091 lupstw[1]->Draw();
1092 pd3->cd();
1093 lup[2]->SetAxisRange((Double_t)min(minobt[2],swminobt[2])*0.9,(Double_t)max(maxobt[2],swmaxobt[2])*1.1,"X");
1094 // lup[2]->SetAxisRange((Double_t)minobt[2]*0.9,(Double_t)maxobt[2]*1.1,"X");
1095 lup[2]->SetXTitle("OBT");
1096 lup[2]->SetYTitle("Number of events");
1097 lup[2]->Draw();
1098 pd7->cd();
1099 lupstw[2]->SetAxisRange((Double_t)min(minobt[2],swminobt[2])*0.9,(Double_t)max(maxobt[2],swmaxobt[2])*1.1,"X");
1100 // lupstw[2]->SetAxisRange((Double_t)swminobt[2]*0.9,(Double_t)swmaxobt[2]*1.1,"X");
1101 lupstw[2]->SetXTitle("OBT");
1102 lupstw[2]->SetYTitle("Number of events");
1103 lupstw[2]->Draw();
1104 pd4->cd();
1105 lup[3]->SetAxisRange((Double_t)min(minobt[3],swminobt[3])*0.9,(Double_t)max(maxobt[3],swmaxobt[3])*1.1,"X");
1106 // lup[3]->SetAxisRange((Double_t)minobt[3]*0.9,(Double_t)maxobt[3]*1.1,"X");
1107 lup[3]->SetXTitle("OBT");
1108 lup[3]->SetYTitle("Number of events");
1109 lup[3]->Draw();
1110 pd8->cd();
1111 lupstw[3]->SetAxisRange((Double_t)min(minobt[3],swminobt[3])*0.9,(Double_t)max(maxobt[3],swmaxobt[3])*1.1,"X");
1112 // lupstw[3]->SetAxisRange((Double_t)swminobt[3]*0.9,(Double_t)swmaxobt[3]*1.1,"X");
1113 lupstw[3]->SetXTitle("OBT");
1114 lupstw[3]->SetYTitle("Number of events");
1115 lupstw[3]->Draw();
1116 };
1117 //
1118 // output figures, report sheet:
1119 //
1120 TCanvas *rapporto= new TCanvas("Calorimeter_Detector_Report_3/3", "Calorimeter_Detector_Report_3/3", 1100, 900);
1121 rapporto->SetFillColor(10);
1122 rapporto->Range(0,0,100,100);
1123 t=new TLatex();
1124 t->SetTextFont(32);
1125 t->SetTextColor(1);
1126 t->SetTextSize(0.05);
1127 t->SetTextAlign(12);
1128 // t->DrawLatex(33.,95.,"Calorimeter quick look: ");
1129 errore.str("");
1130 errore << "BASIC: C1 - File: " << file;
1131 errore << " ";
1132 t->SetTextSize(0.02);
1133 t->DrawLatex(2.,99.,errore.str().c_str());
1134
1135 pad1 = new TPad("pad1","This is pad1",0.02,0.47,0.49,0.90,19);
1136 pad2 = new TPad("pad2","This is pad2",0.51,0.47,0.98,0.90,19);
1137 pad3 = new TPad("pad3","This is pad3",0.02,0.02,0.49,0.45,19);
1138 pad4 = new TPad("pad4","This is pad4",0.51,0.02,0.98,0.45,19);
1139 pad1->Range(0,0,100,100);
1140 pad2->Range(0,0,100,100);
1141 pad3->Range(0,0,100,100);
1142 pad4->Range(0,0,100,100);
1143
1144 pad1->Draw();
1145 pad2->Draw();
1146 pad3->Draw();
1147 pad4->Draw();
1148
1149 for (Int_t i = 0; i < 4; i++){
1150 if (i == 2)
1151 {
1152 pad1->cd() ;
1153 sezione = "** Section YE (x even) **";
1154 }
1155 if (i == 3)
1156 {
1157 pad2->cd();
1158 sezione = "** Section YO (x odd) **";
1159 }
1160 if (i == 0)
1161 {
1162 pad3->cd();
1163 sezione = "** Section XE (y odd) **";
1164 }
1165 if (i == 1)
1166 {
1167 pad4->cd();
1168 sezione = "** Section XO (y even) **";
1169 }
1170 t->SetTextFont(32);
1171 t->SetTextColor(1);
1172 t->SetTextSize(0.05);
1173 t->SetTextAlign(12);
1174 t->DrawLatex(33.,97.,sezione);
1175 t->SetTextSize(0.05);
1176 for (Int_t j = 0; j < 23; j++){
1177 if ( ver[i][j] || lver[i][j] ) {
1178 t->SetTextColor(50);
1179 if (j == 0) {
1180 errore.str("");
1181 errore << "* DSP ack error: " << ver[i][j];
1182 errore << " time(s)";
1183 t->DrawLatex(2.,30.,errore.str().c_str());
1184 check = true;
1185 }
1186 if (j == 1) {
1187 errore.str("");
1188 errore << "* Temperature alarm: " << ver[i][j];
1189 errore << " time(s)";
1190 t->DrawLatex(2.,74.,errore.str().c_str());
1191 check = true;
1192 }
1193 if (j == 2) {
1194 // printf("boh! lalarm[%i] = %i \n",i,lalarm[i]);
1195 if ( lalarm[i] ){
1196 errore.str("");
1197 errore << "* Latch up: " << ver[i][j];
1198 errore << " (" << lalarm[i];
1199 errore << " NOT rec!): ";
1200 t->DrawLatex(2.,70.,errore.str().c_str());
1201 check = true;
1202 } else {
1203 errore.str("");
1204 errore << "* Latch up alarm: " << ver[i][j];
1205 errore << " time(s). View(s): ";
1206 t->DrawLatex(2.,70.,errore.str().c_str());
1207 check = true;
1208 };
1209 errore.str("");
1210 errore << "(" << lver[i][j];
1211 errore << " view(s))";
1212 t->DrawLatex(27.,65.,errore.str().c_str());
1213 Float_t inc=1.;
1214 for (Int_t e = 0; e < 11; e++){
1215 if ( pshit[i][e] ) {
1216 errore.str("");
1217 errore << " " << (e+1);
1218 errore << " ";
1219 t->DrawLatex(52.+inc,69.,errore.str().c_str());
1220 Int_t numer = pshit[i][e];
1221 errore.str("");
1222 errore << " (" << numer;
1223 errore << ") ";
1224 t->SetTextAngle(-70);
1225 t->DrawLatex(55.+inc,67.,errore.str().c_str());
1226 t->SetTextAngle(0);
1227 inc += 4.;
1228 }
1229 }
1230 }
1231 if (j == 3) {
1232 errore.str("");
1233 errore << "RAW mode: " << ver[i][j];
1234 errore << " time(s)";
1235 t->SetTextColor(32);
1236 t->DrawLatex(2.,90.,errore.str().c_str());
1237 }
1238 if (j == 4) {
1239 errore.str("");
1240 errore << "* CMD length error: " << ver[i][j];
1241 errore << " time(s)";
1242 t->DrawLatex(2.,66.,errore.str().c_str());
1243 check = true;
1244 }
1245 if (j == 5) {
1246 errore.str("");
1247 errore << "* Execution error: " << ver[i][j];
1248 errore << " time(s)";
1249 t->DrawLatex(2.,62.,errore.str().c_str());
1250 check = true;
1251 }
1252 if (j == 6) {
1253 errore.str("");
1254 errore << "* CRC error (st. word): " << ver[i][j];
1255 errore << " time(s)";
1256 t->DrawLatex(2.,58.,errore.str().c_str());
1257 check = true;
1258 }
1259 if (j == 7) {
1260 errore.str("");
1261 errore << "View or command not recognized: " << ver[i][j];
1262 errore << " time(s)";
1263 t->DrawLatex(2.,54.,errore.str().c_str());
1264 check = true;
1265 }
1266 if (j == 8) {
1267 errore.str("");
1268 errore << "Missing section: " << ver[i][j];
1269 errore << " time(s)";
1270 t->DrawLatex(2.,50.,errore.str().c_str());
1271 check = true;
1272 }
1273 if (j == 10) {
1274 errore.str("");
1275 errore << "Calevnum jump: " << ver[i][j];
1276 errore << " time(s)";
1277 t->DrawLatex(2.,42.,errore.str().c_str());
1278 check = true;
1279 }
1280 if (j == 11) {
1281 errore.str("");
1282 errore << "CRC error (data): " << ver[i][j];
1283 errore << " time(s)";
1284 t->DrawLatex(2.,38.,errore.str().c_str());
1285 check = true;
1286 }
1287 if (j == 12) {
1288 errore.str("");
1289 errore << "Length problems in RAW mode: " << ver[i][j];
1290 errore << " time(s)";
1291 t->DrawLatex(2.,34.,errore.str().c_str());
1292 check = true;
1293 }
1294 if (j == 13) {
1295 errore.str("");
1296 errore << "Length problems in COMPRESS mode: " << ver[i][j];
1297 errore << " time(s)";
1298 t->DrawLatex(2.,34.,errore.str().c_str());
1299 check = true;
1300 }
1301 if (j == 14) {
1302 errore.str("");
1303 errore << "Length problems in FULL mode: " << ver[i][j];
1304 errore << " time(s)";
1305 t->DrawLatex(2.,26.,errore.str().c_str());
1306 check = true;
1307 }
1308 if (j == 15) {
1309 errore.str("");
1310 errore << "Acquisition mode problems: " << ver[i][j];
1311 errore << " time(s)";
1312 t->DrawLatex(2.,22.,errore.str().c_str());
1313 check = true;
1314 }
1315 if (j == 16) {
1316 errore.str("");
1317 errore << "COMPRESS mode: " << ver[i][j];
1318 errore << " time(s)";
1319 t->SetTextColor(32);
1320 t->DrawLatex(2.,86.,errore.str().c_str());
1321 }
1322 if (j == 17) {
1323 errore.str("");
1324 errore << "FULL mode: " << ver[i][j];
1325 errore << " time(s)";
1326 t->SetTextColor(32);
1327 t->DrawLatex(2.,82.,errore.str().c_str());
1328 }
1329 if (j == 18) {
1330 errore.str("");
1331 errore << "Problems with coding: " << ver[i][j];
1332 errore << " time(s)";
1333 t->DrawLatex(2.,18.,errore.str().c_str());
1334 check = true;
1335 }
1336 if (j == 19) {
1337 errore.str("");
1338 errore << "Pedestal checksum wrong: " << ver[i][j];
1339 errore << " time(s)";
1340 t->DrawLatex(2.,14.,errore.str().c_str());
1341 check = true;
1342 }
1343 if (j == 20) {
1344 errore.str("");
1345 errore << "Thresholds checksum wrong: " << ver[i][j];
1346 errore << " time(s)";
1347 t->DrawLatex(2.,10.,errore.str().c_str());
1348 check = true;
1349 }
1350 if (j == 21) {
1351 errore.str("");
1352 errore << "WARNING! DEXYC < 0: " << ver[i][j];
1353 errore << " time(s)";
1354 t->DrawLatex(2.,6.,errore.str().c_str());
1355 check = true;
1356 }
1357 if (j == 22) {
1358 errore.str("");
1359 errore << "Packet length is zero (YODA input error), skipped: " << ver[i][j];
1360 errore << " time(s)";
1361 t->DrawLatex(2.,3.,errore.str().c_str());
1362 check = true;
1363 };
1364 };
1365 };
1366 t->SetTextColor(50);
1367 if ( fulldiff[i] !=0 ) {
1368 check = true;
1369 errore.str("");
1370 errore << "Full mode, differences between RAW and COMPRESS mode: " << fulldiff[i];
1371 errore << " time(s)";
1372 t->DrawLatex(2.,46.,errore.str().c_str());
1373 };
1374 if ( cpre[i] !=0 ) {
1375 errore.str("");
1376 errore << "Preamplifier fully transmitted: " << cpre[i];
1377 errore << " time(s)";
1378 t->SetTextColor(32);
1379 t->DrawLatex(2.,78.,errore.str().c_str());
1380 };
1381 };
1382 rapporto->cd();
1383 t->SetTextFont(32);
1384 t->SetTextColor(1);
1385 t->SetTextSize(0.05);
1386 t->SetTextAlign(12);
1387 t->DrawLatex(22.,95.,"Calorimeter quick look: ");
1388 //printf("check %i \n",check);
1389 if ( check ){
1390 t->SetTextColor(50);
1391 t->DrawLatex(60.,95.," WARNING, CHECK! ");
1392 printf("cdexyc %f cdexy %f ctshit %f cbase %f \n",cdexyc,cdexy,ctshit,cbase);
1393 } else {
1394 t->SetTextColor(32);
1395 t->DrawLatex(60.,95.," OK! ");
1396 };
1397 //
1398 // const string fil = (const char*)filename;
1399 // Int_t posiz = fil.find("dw_");
1400 // if ( posiz == -1 ) posiz = fil.find("DW_");
1401 // Int_t posiz2 = posiz+13;
1402 // TString file2;
1403 // stringcopy(file2,filename,posiz,posiz2);
1404 //
1405 const string fil = gSystem->BaseName(filename.Data());
1406 Int_t posiz = fil.find(".root");
1407 //
1408 TString file2;
1409 if ( posiz == -1 ){
1410 file2 = gSystem->BaseName(filename.Data());
1411 } else {
1412 Int_t posiz2 = 0;
1413 stringcopy(file2,gSystem->BaseName(filename.Data()),posiz2,posiz);
1414 };
1415 const char *figrec = file2;
1416 //
1417 const char *outdir = outDir;
1418 stringstream figsave;
1419 stringstream figsave1;
1420 stringstream figsave2;
1421 const char *format = saveas;
1422 if ( !strcmp(format,"ps") ) {
1423 figsave.str("");
1424 figsave << outdir << "/" ;
1425 figsave << figrec << "_CaloQLOOK.";
1426 figsave << format << "(";
1427 rapporto->Print(figsave.str().c_str(),"Landscape");
1428 figsave1.str("");
1429 figsave1 << outdir << "/" ;
1430 figsave1 << figrec << "_CaloQLOOK.";
1431 figsave1 << format;
1432 figura->Print(figsave1.str().c_str(),"Landscape");
1433 figsave2.str("");
1434 figsave2 << outdir << "/" ;
1435 figsave2 << figrec << "_CaloQLOOK.";
1436 if ( printfigure3 ){
1437 figsave2 << format;
1438 figura2->Print(figsave2.str().c_str(),"Landscape");
1439 figsave2.str("");
1440 figsave2 << outdir << "/" ;
1441 figsave2 << figrec << "_CaloQLOOK.";
1442 figsave2 << format << ")";
1443 figura3->Print(figsave2.str().c_str(),"Landscape");
1444 } else {
1445 figsave2 << format << ")";;
1446 figura2->Print(figsave2.str().c_str(),"Landscape");
1447 };
1448 } else {
1449 figsave.str("");
1450 figsave << outdir << "/" ;
1451 figsave << figrec << "_CaloQLOOK1.";
1452 figsave << format;
1453 figura->SaveAs(figsave.str().c_str());
1454 figsave.str("");
1455 figsave << outdir << "/" ;
1456 figsave << figrec << "_CaloQLOOK2.";
1457 figsave << format;
1458 figura2->SaveAs(figsave.str().c_str());
1459 if ( printfigure3 ){
1460 figsave.str("");
1461 figsave << outdir << "/" ;
1462 figsave << figrec << "_CaloQLOOK2bis.";
1463 figsave << format;
1464 figura3->SaveAs(figsave.str().c_str());
1465 };
1466 figsave.str("");
1467 figsave << outdir << "/" ;
1468 figsave << figrec << "_CaloQLOOK3.";
1469 figsave << format;
1470 rapporto->SaveAs(figsave.str().c_str());
1471 };
1472 }
1473

  ViewVC Help
Powered by ViewVC 1.1.23