/[PAMELA software]/calo/flight/FUTILITIES/macros/FCaloADC2MIP.cxx
ViewVC logotype

Annotation of /calo/flight/FUTILITIES/macros/FCaloADC2MIP.cxx

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.1.1.1 - (hide annotations) (download) (vendor branch)
Wed Mar 22 15:07:47 2006 UTC (18 years, 10 months ago) by mocchiut
Branch: FUTILITIES
CVS Tags: start, v1r01
Changes since 1.1: +0 -0 lines
Flight Utilities calorimeter package 1st release

1 mocchiut 1.1 //
2     //- Emiliano Mocchiutti
3     //
4     // FCaloADC2MIP.c version 1.01 (2006-03-20)
5     //
6     // The only input needed is
7     //
8     // Changelog:
9     //
10     // 1.00 - 1.01 (2006-03-20): First flight version, read single yoda file.
11     //
12     // 0.00 - 1.00 (2006-03-20): Clone of CaloADC2MIP v4r01.
13     //
14     //
15     #include <fstream>
16     #include <sstream>
17     #include <string>
18     #include <iostream>
19     #include <TTree.h>
20     #include <TClassEdit.h>
21     #include <TObject.h>
22     #include <TList.h>
23     #include <TSystem.h>
24     #include <TSystemDirectory.h>
25     #include <TString.h>
26     #include <TFile.h>
27     #include <TClass.h>
28     #include <TCanvas.h>
29     #include <TH1.h>
30     #include <TH1F.h>
31     #include <TH2D.h>
32     #include <TLatex.h>
33     #include <TPad.h>
34     #include <TPaveLabel.h>
35     #include <TChain.h>
36     #include <TGraph.h>
37     #include <TMultiGraph.h>
38     #include <TLine.h>
39     #include <TStyle.h>
40     #include <TF1.h>
41     //
42     #include <fcalostructs.h>
43     //
44     extern const char *pathtocalibration();
45     extern TString getFilename(const TString);
46     extern TString whatnamewith(TString, Int_t);
47     extern void stringcopy(TString&, const TString&, Int_t, Int_t);
48     extern int CaloPede(TString, Int_t, Int_t, Calib &);
49     extern void CaloFindBaseRaw(Calib &, Evento &, Int_t, Int_t, Int_t);
50     extern void CaloFindBaseRawNC(Calib &, Evento &, Int_t, Int_t, Int_t);
51     extern void CaloCompressData(Calib &, Evento &, Int_t, Int_t, Int_t);
52     extern int CaloFindCalibs(TString &, TString &, Int_t &, Calib &);
53     extern bool existfile(TString);
54     TF1 *langaufit(TH1F *, Double_t *, Double_t *, Double_t *, Double_t *, Double_t *, Double_t *, Double_t *, Int_t *, TString);
55     Double_t langaupro(Double_t *);
56     //
57     //
58     #include <PamelaRun.h>
59     #include <physics/calorimeter/CalorimeterEvent.h>
60     #include <physics/trigger/TriggerEvent.h>
61     #include <CalibCalPedEvent.h>
62     //
63     #include <caloclassesfun.h>
64     #include <FCaloADC2MIPfun.h>
65     using namespace std;
66    
67     void FCaloADC2MIP(TString Filename, TString calcalibfile = "", TString OutDir="", TString flist=""){
68     const char *pam_calib = pathtocalibration();
69     if ( !strcmp(OutDir.Data(),"") ){
70     OutDir = pam_calib;
71     };
72     //
73     TString calcalib;
74     struct Evento evento;
75     struct Calib calib;
76     Int_t debug = 0;
77     Int_t b[4];
78     Int_t etime,evno;
79     Float_t sdexy[2][22][96],sdexyc[2][22][96];
80     Float_t edelta[2][22][96];
81     Float_t estrip[2][22][96];
82     Float_t estripnull[2][22][96];
83     Float_t delta;
84     delta = 1.;
85     evento.emin = 0.7;
86     Int_t UPYES = 0;
87     Int_t se =5;
88     Int_t pre;
89     Int_t rdone=0;
90     Int_t done;
91     bool isCOMP = 0;
92     bool isFULL = 0;
93     bool isRAW = 0;
94     TH1F *pfmip[2][22][96];
95     TF1 *pfitsnr[2][22][96];
96     stringstream Fmip;
97     for (Int_t i=0; i<2;i++){
98     for (Int_t j=0; j<22;j++){
99     for (Int_t m=0; m<96;m++){
100     Fmip.str("");
101     Fmip << "Fmip " << i;
102     Fmip << " " << j;
103     Fmip << " " << m;
104     pfmip[i][j][m] = new TH1F(Fmip.str().c_str(),"",56,0.,55.);
105     pfitsnr[i][j][m] = new TF1;
106     };
107     };
108     };
109     //
110     // the file which contains the calorimeter ADC to MIP conversion values is file2 = path to the script dir / CaloADC2MIP.root
111     //
112     stringstream file2;
113     file2.str("");
114     file2 << OutDir.Data() << "/CaloADC2MIP.root";
115     //
116     // this the figures and fit (4224 x 2 objects!)
117     //
118     stringstream file3;
119     file3.str("");
120     file3 << OutDir.Data() << "/CaloADC2MIPf.root";
121     //
122     stringstream file4;
123     file4.str("");
124     file4 << OutDir.Data() << "/CaloADC2MIPf";
125     //
126     stringstream file5;
127     file5.str("");
128     file5 << OutDir.Data() << "/CaloADC2MIPdata.root";
129     //
130     Int_t nfile = 0;
131     Int_t fileup = 0;
132     if ( flist != "" ){
133     printf("\n You have given an input file list \n\n Files: \n");
134     ifstream in;
135     in.open(flist, ios::in);
136     char ctime[20];
137     while (1) {
138     in >> ctime;
139     if (!in.good()) break;
140     printf(" File number %i = %s \n",nfile+1,ctime);
141     nfile++;
142     };
143     in.close();
144     if ( !nfile ) {
145     printf("\n\n The list is empty, exiting... \n\n");
146     return;
147     };
148     } else {
149     nfile = 1;
150     };
151     printf("\n");
152     //
153     // First check if the calibration file exists:
154     //
155     Int_t EFILE = 0;
156     printf(" Check the existence of CaloADC2MIP.root file: \n\n");
157     if ( !existfile(file2.str().c_str()) ){
158     printf(" %s :no such file or directory \n",file2.str().c_str());
159     printf("\n OK, I will create it!\n\n");
160     EFILE = 0;
161     } else {
162     printf(" The file already exists! Check if an update is needed \n\n");
163     EFILE = 1;
164     };
165     //
166     // the check for an update is done once even if we have a list.
167     //
168     TTree *tree;
169     CalorimeterCalibration *calo = new CalorimeterCalibration();
170     if ( EFILE == 1) {
171     //
172     // The file exists, open it (READ ONLY) and check if any update is needed:
173     //
174     TFile *hfile = 0;
175     hfile = new TFile(file2.str().c_str(),"READ","Calorimeter CALIBRATION data");
176     tree = (TTree*)hfile->Get("CaloADC");
177     calo = new CalorimeterCalibration();
178     tree->SetBranchAddress("Event", &calo);
179     //
180     Long64_t nevents = tree->GetEntries();
181     printf("\n Number of updates: %i\n",(int)nevents);
182     tree->GetEntry(nevents-1);
183     //
184     // Read the status variable of the last event: if it is 0 then we need an update, if it is one print out informations and exit
185     //
186     if ( calo->status == 0 ) {
187     printf("\n An update is needed: \n");
188     Int_t upstrip = 0;
189     for (Int_t i = 0; i<2; i++){
190     for (Int_t j = 0; j<22; j++){
191     for (Int_t l = 0; l<96; l++){
192     if ( calo->mask[i][j][l] == 0. ) upstrip++;
193     };
194     };
195     };
196     printf(" %i strip out of 4224 have no statistic enough.\n\n",upstrip);
197     } else {
198     printf(" No update is needed! \n The data files used to obtain the ADC to MIP conversion are: \n");
199     for (Int_t i = 0; i<nevents; i++){
200     tree->GetEntry(i);
201     const char *fout = calo->fname;
202     printf(" - %s \n",fout);
203     };
204     printf("\n\n");
205     return;
206     };
207     hfile->Close();
208     };
209     //
210     const char *filename2 = Filename;
211     //
212     TString lfile;
213     TString sfile;
214     //
215     Int_t e = 0;
216     ifstream in;
217     in.open(flist, ios::in);
218     char ctime[20];
219     TString file2f;
220     TString pfile;
221     const char *cali;
222     const char *ffile;
223     Int_t calibex = 0;
224     //
225     TString filename;
226     const char *nome;
227     TFile *hfile = 0;
228     calo = new CalorimeterCalibration();
229     Long64_t nevents;
230     Int_t used = 0;
231     const char *compare;
232     Int_t hf3 = 0;
233     Int_t ufile = 0;
234     TFile *headerFile = 0;
235     file2f = "";
236     pfile = "";
237     stringstream fmippa;
238     const char *porca;
239     Int_t S4;
240     Int_t upnn;
241     Int_t notgood = 0;
242     Int_t notgood1 = 0;
243     stringstream files;
244     TFile *hfileb = 0;
245     //
246     Int_t pl1, pl2, strmin, strmax;
247     Int_t spre=0;
248     Int_t surstrip = 0;
249     Float_t estrippa = 0.;
250     Int_t surmam = 0;
251     Int_t surman = 0;
252     Int_t surmatrix[3][3];
253     //
254     TString fififile;
255     const char *file;
256     //
257     stringstream nofi;
258     nofi.str("");
259     TFile *hfile3 = 0;
260     //
261     while ( e < nfile ){
262     if ( flist != "" ){
263     in >> ctime;
264     nofi.str("");
265     nofi << filename2 << "/";
266     nofi << ctime;
267     lfile = TString(nofi.str().c_str());
268     fififile = getFilename(lfile);
269     file = fififile;
270     nofi.str("");
271     nofi << file;
272     sfile = TString(nofi.str().c_str());
273     } else {
274     nofi.str("");
275     nofi << filename2;
276     lfile = TString(nofi.str().c_str());
277     fififile = getFilename(lfile);
278     file = fififile;
279     nofi.str("");
280     nofi << file;
281     sfile = TString(nofi.str().c_str());
282     };
283     //
284     filename = lfile;
285     nome = filename;
286     printf("\n Processing file number %i: %s \n\n",e,nome);
287     nome = sfile;
288     //
289     // this must be done for each file.
290     //
291     const char *calname;
292     calname = "";
293     Int_t wused = 0;
294     TTree *otr;
295     pamela::calorimeter::CalorimeterEvent *de = 0;
296     pamela::trigger::TriggerEvent *trigger = 0;
297     pamela::PscuHeader *ph = 0;
298     pamela::EventHeader *eh = 0;
299     //
300     if ( EFILE == 1 ){
301     hfile = new TFile(file2.str().c_str(),"UPDATE","Calorimeter CALIBRATION data");
302     tree = (TTree*)hfile->Get("CaloADC");
303     calo = new CalorimeterCalibration();
304     tree->SetBranchAddress("Event", &calo);
305     //
306     // Check if the input file has already been used
307     //
308     printf(" Check if file %s has already been used... \n",nome);
309     nevents = tree->GetEntries();
310     used = 0;
311     for (Int_t i = 0; i<nevents; i++){
312     tree->GetEntry(i);
313     compare= calo->fname;
314     if ( !strcmp(compare,nome) ) {
315     used = 1;
316     break;
317     };
318     };
319     if ( used ) {
320     printf(" The file %s has already been used!\n You cannot run twice this program with that file!\n\n",nome);
321     hfile->Close();
322     goto jumpfile;
323     } else {
324     printf(" Good, the file has not been used yet. \n\n");
325     nevents = tree->GetEntries() -1;
326     tree->GetEntry(nevents);
327     };
328     } else {
329     //
330     // If the file doesn't exist create it
331     //
332     calo = new CalorimeterCalibration();
333     hfile = new TFile(file2.str().c_str(),"NEW","Calorimeter CALIBRATION data");
334     if ( !existfile(file2.str().c_str()) ){
335     printf(" %s :no such file or directory \n",filename.Data());
336     printf(" ERROR: Cannot create file \n");
337     return;
338     };
339     // if ( hfile->IsZombie() ){
340     // printf(" ERROR: Cannot create file \n");
341     // return;
342     //};
343     tree = new TTree("CaloADC","Calorimeter calibration data");
344     tree->Branch("Event","CalorimeterCalibration",&calo);
345     };
346     //
347     //
348     //
349     hf3 = 0;
350     if ( e == 0 ){
351     if ( !existfile(file3.str().c_str()) ){
352     ufile = 0;
353     } else {
354     printf(" Update figures file! \n\n");
355     ufile = 1;
356     };
357     };
358     if ( (EFILE == 1 || ufile == 1) && e == 0 ){
359     printf(" Reading the old MIP figures to be updated...\n ");
360     hfile3 = new TFile(file3.str().c_str());
361     hf3 = 1;
362     //
363     stringstream fmino;
364     fmino.str("");
365     for (Int_t l = 0; l < 2; l++){
366     for (Int_t m = 0; m < 22; m++){
367     for (Int_t n =0 ; n < 96; n++){
368     fmino.str("");
369     fmino << "fmip " << l;
370     fmino << " " << m;
371     fmino << " " << n;
372     gDirectory->Delete(fmino.str().c_str());
373     TH1F *temp = (TH1F*)hfile3->Get(fmino.str().c_str());
374     pfmip[l][m][n] = (TH1F*)temp->Clone();
375     };
376     };
377     };
378     printf(" ...done!\n");
379     };
380     EFILE = 1;
381     //
382     // Check if the input calibration file contains any calibration data
383     //
384     done = 0;
385     printf(" Check for calorimeter calibration: \n");
386     calcalib = filename;
387     findcalibs: printf(" Calibration file: %s \n",calname);
388     calname = calcalib;
389     for (Int_t s=0; s<4;s++){
390     for (Int_t d = 0; d<50; d++){
391     calib.ttime[s][d] = 0 ;
392     if ( d < 49 ) calib.time[s][d] = 0 ;
393     };
394     };
395     for (Int_t m = 0; m < 2 ; m++ ){
396     for (Int_t k = 0; k < 22; k++ ){
397     for (Int_t l = 0; l < 96; l++ ){
398     calib.calped[m][k][l] = 0. ;
399     evento.dexy[m][k][l] = 0. ;
400     evento.dexyc[m][k][l] = 0. ;
401     edelta[m][k][l] = 0.;
402     estrip[m][k][l] = 0.;
403     estripnull[m][k][l] = 0.;
404     };
405     };
406     }
407     wused = 0;
408     CaloFindCalibs(calcalib, calcalib, wused, calib);
409     //
410     // print on the screen the results:
411     //
412     ffile = filename;
413     printf(" ------ %s ------- \n \n",ffile);
414     calibex = 0;
415     for (Int_t s=0; s<4;s++){
416     printf(" ** SECTION %i **\n",s);
417     for (Int_t d = 0; d<51; d++){
418     if ( calib.ttime[s][d] != 0 ) {
419     calibex++;
420     if ( calib.fcode[s][d] != 10 ){
421     file2f = "";
422     stringcopy(file2f,calcalib,0,0);
423     pfile = (TString)whatnamewith(file2f,calib.fcode[s][d]);
424     } else {
425     pfile = (TString)calcalib;
426     };
427     ffile = pfile;
428     printf(" - from time %i to time %i use calibration at\n time %i, file: %s \n",calib.time[s][d],calib.time[s][d+1],calib.ttime[s][d],ffile);
429     };
430     };
431     printf("\n");
432     };
433     printf(" ----------------------------------------------------------------------- \n \n");
434     //
435     if ( calibex < 1 ) {
436     printf("No calibration data in this file!\n");
437     calcalib = calcalibfile;
438     if ( !done && calcalibfile != "" ) {
439     cali = calcalibfile;
440     printf(" Search in the calibration file %s \n",cali);
441     done = 1;
442     goto findcalibs;
443     } else {
444     printf(" Cannot find any calibration for this file! \n");
445     goto jumpfile;
446     };
447     };
448     if ( calibex < 4 ) {
449     printf(" WARNING! No full calibration data in this file! \n\n");
450     };
451     //
452     // upgrade data...
453     //
454     if ( !existfile(filename) ){
455     printf(" %s :no such file or directory \n",filename.Data());
456     goto jumpfile;
457     };
458     headerFile = new TFile(filename.Data());
459     otr = (TTree*)headerFile->Get("Physics");
460     otr->SetBranchAddress("Header", &eh);
461     otr->SetBranchAddress("Calorimeter", &de);
462     otr->SetBranchAddress("Trigger", &trigger);
463     //
464     nevents = otr->GetEntries();
465     //
466     // calibrate before starting
467     //
468     for (Int_t s = 0; s < 4; s++){
469     b[s]=0;
470     if ( calib.fcode[s][b[s]] != 10 ){
471     stringcopy(file2f,calcalib,0,0);
472     pfile = (TString)whatnamewith(file2f,calib.fcode[s][b[s]]);
473     } else {
474     pfile = (TString)calcalib;
475     };
476     porca = pfile;
477     if ( debug ) printf(" porca miseria %s \n",porca);
478     CaloPede(pfile,s,calib.ttime[s][b[s]],calib);
479     };
480     //
481     // run over all the events
482     //
483     printf("\n Processed events: \n\n");
484     //
485     for (Int_t i = 0; i < nevents; i++){
486     evno = i;
487     if ( i%1000 == 0 && i > 0 ) printf(" %iK \n",i/1000);
488     // printf(" %i \n",i);
489     //
490     // read from the header of the event the absolute time at which it was recorded
491     //
492     otr->GetEntry(i);
493     //
494     S4 = trigger->patterntrig[1] & (1<<0);
495     //
496     if ( !S4 || i == 0 ) {
497     ph = eh->GetPscuHeader();
498     etime = ph->GetOrbitalTime();
499     //
500     // for each event check that the calibration we are using are still within calibration limits, if not call the next calibration
501     //
502     if ( !calib.obtjump ) {
503     for (Int_t s = 0; s < 4; s++){
504     if ( calib.ttime[s][b[s]] ){
505     while ( etime > calib.time[s][b[s]+1] ){
506     printf(" CALORIMETER: \n" );
507     printf(" - Section %i, event at time %i while old calibration time limit at %i. Use new calibration at time %i -\n",s,etime,calib.time[s][b[s]+1],calib.ttime[s][b[s]+1]);
508     printf(" END CALORIMETER. \n\n" );
509     b[s]++;
510     if ( calib.fcode[s][b[s]] != 10 ){
511     stringcopy(file2f,calcalib,0,0);
512     pfile = (TString)whatnamewith(file2f,calib.fcode[s][b[s]]);
513     } else {
514     pfile = (TString)calcalib;
515     };
516     porca = pfile;
517     if ( debug ) printf(" porca miseria %s \n",porca);
518     CaloPede(pfile,s,calib.ttime[s][b[s]],calib);
519     };
520     };
521     };
522     };
523     //
524     // do whatever you want with data
525     //
526     evento.iev = de->iev;
527     //
528     // run over views and planes
529     //
530     for (Int_t l = 0; l < 2; l++){
531     for (Int_t m = 0; m < 22; m++){
532     //
533     // determine the section number
534     //
535     if (l == 0 && m%2 == 0) se = 3;
536     if (l == 0 && m%2 != 0) se = 2;
537     if (l == 1 && m%2 == 0) se = 0;
538     if (l == 1 && m%2 != 0) se = 1;
539     //
540     // determine what kind of event we are going to analyze
541     //
542     isCOMP = 0;
543     isFULL = 0;
544     isRAW = 0;
545     if ( de->stwerr[se] & (1 << 16) ) isCOMP = 1;
546     if ( de->stwerr[se] & (1 << 17) ) isFULL = 1;
547     if ( de->stwerr[se] & (1 << 3) ) isRAW = 1;
548     //
549     // save the prevoius energy deposit and calibration in sbase, sdexy, sdexyc
550     //
551     pre = -1;
552     if ( isRAW ){
553     for (Int_t nn = 0; nn < 96; nn++){
554     if ( nn%16 == 0 ) pre++;
555     evento.base[l][m][pre] = calib.calbase[l][m][pre];
556     sdexy[l][m][nn] = evento.dexy[l][m][nn];
557     evento.dexy[l][m][nn] = de->dexy[l][m][nn] ;
558     sdexyc[l][m][nn] = evento.dexyc[l][m][nn];
559     evento.dexyc[l][m][nn] = de->dexyc[l][m][nn] ;
560     };
561     };
562     //
563     // run over strips
564     //
565     pre = -1;
566     for (Int_t n =0 ; n < 96; n++){
567     if ( n%16 == 0 ) {
568     pre++;
569     rdone = 0;
570     done = 0;
571     };
572     if ( calo->mask[l][m][n] == 0. && ( isRAW || ( de->dexyc[l][m][n] > 0. && de->dexyc[l][m][n] < 32000.)) ){
573     //
574     // baseline check and calculation
575     //
576     if ( isRAW ) {
577     if ( !rdone ){
578     CaloFindBaseRaw(calib,evento,l,m,pre);
579     rdone = 1;
580     };
581     } else {
582     if ( !done ){
583     evento.base[l][m][pre] = de->base[l][m][pre] ;
584     evento.dexyc[l][m][n] = de->dexyc[l][m][n] ;
585     };
586     };
587     //
588     // no suitable new baseline, use old ones and compress data!
589     //
590     if ( !done && (evento.base[l][m][pre] > 30000. || evento.base[l][m][pre] == 0.) ){
591     evento.base[l][m][pre] = calib.sbase[l][m][pre];
592     upnn = n+16;
593     if ( upnn > 96 ) upnn = 96;
594     for ( Int_t nn = n; nn<upnn; nn++ ){
595     evento.dexyc[l][m][nn] = de->dexyc[l][m][nn] ;
596     };
597     CaloCompressData(calib,evento,l,m,pre);
598     done = 1;
599     };
600     //
601     // CALIBRATION ALGORITHM
602     //
603     pl1 = -1;
604     pl2 = -1;
605     pl1 = m - 1;
606     pl2 = m + 1;
607     if ( pl1 < 0 ) {
608     pl1 = pl2;
609     pl2 = m + 2;
610     };
611     if ( pl2 > 21 ) {
612     pl2 = pl1;
613     pl1 = m - 2;
614     };
615     strmin = n - 1;
616     if ( strmin < 0 ) strmin = 0;
617     strmax = n + 1;
618     if ( strmax > 95 ) strmax = 95;
619     surstrip = 0;
620     surmam = 0;
621     surman = 0;
622     for (Int_t im = 0; im<3 ;im++){
623     for (Int_t jm = 0; jm<3 ;jm++){
624     surmatrix[im][jm] = 0;
625     };
626     };
627     for (Int_t spl = pl1; spl<pl2+1; spl++){
628     if ( spl != m ){
629     surmam = spl - pl1;
630     for (Int_t sst = strmin; sst <= strmax ; sst++){
631     surman = sst - strmin;
632     if ( sst < 16 ) spre = 0;
633     if ( 15 < sst && sst < 32 ) spre = 1;
634     if ( 31 < sst && sst < 48 ) spre = 2;
635     if ( 47 < sst && sst < 64 ) spre = 3;
636     if ( 63 < sst && sst < 80 ) spre = 4;
637     if ( 79 < sst ) spre = 5;
638     if ( isRAW ){
639     estrippa = ( evento.dexy[l][spl][sst] - calib.calped[l][spl][sst] - calib.sbase[l][spl][spre])/26. ;
640     } else {
641     estrippa = ( evento.dexyc[l][spl][sst] - calib.calped[l][spl][sst] - calib.sbase[l][spl][spre])/26. ;
642     };
643     if ( estrippa > 0.7 && estrippa < 10. && calib.calgood[l][spl][sst] == 0 ){
644     surstrip++;
645     surmatrix[surmam][surman]++;
646     //printf("surstrip = %i estrip = %f \n",surstrip,estrip);
647     };
648     };
649     };
650     };
651     if ( (surmatrix[0][0] && surmatrix[2][0]) ) surstrip = 0;
652     if ( (surmatrix[0][2] && surmatrix[2][2]) ) surstrip = 0;
653     //
654     //
655     estrip[l][m][n] = ( evento.dexyc[l][m][n] - calib.calped[l][m][n] - evento.base[l][m][pre]) ;
656     if ( estrip[l][m][n] >= 0. && estrip[l][m][n] <= 56. && surstrip >=2 ){
657     pfmip[l][m][n]->Fill(estrip[l][m][n]);
658     UPYES = 1;
659     };
660     calib.sbase[l][m][pre] = evento.base[l][m][pre];
661     };
662     };
663     };
664     };
665     };
666     };
667     //
668     // save filename
669     //
670     calo->fname = sfile;
671     tree->Fill();
672     hfile->Write();
673     fileup++;
674     hfile->Close();
675     //
676     // create a backup copy!
677     //
678    
679     if ( nfile > 1 && ( e%10 == 0 || e == nfile-1 ) && e > 0 ){
680     files.str("");
681     files << file4.str().c_str() << (e+1);
682     files << ".bak";
683     printf(" Save the backup file with figures:\n %s \n ",files.str().c_str());
684     hfileb = new TFile(files.str().c_str(),"RECREATE","Calorimeter CALIBRATION figures");
685     if ( !existfile(files.str().c_str()) ){
686     printf(" ERROR: Cannot create file!!! \n");
687     goto oltre;
688     };
689     TH1F *bfmip[2][22][96];
690     stringstream bmippa;
691     bmippa.str("");
692     for (Int_t l = 0; l < 2; l++){
693     for (Int_t m = 0; m < 22; m++){
694     for (Int_t n =0 ; n < 96; n++){
695     bmippa.str("");
696     bmippa << "bmip " << l;
697     bmippa << " " << m;
698     bmippa << " " << n;
699     bfmip[l][m][n] = new TH1F(bmippa.str().c_str(),"",56,0.,55.);
700     bfmip[l][m][n] = (TH1F*)pfmip[l][m][n]->Clone(bmippa.str().c_str());
701     bfmip[l][m][n]->Write();
702     };
703     };
704     };
705     hfileb->Close();
706     };
707     //
708     //
709     //
710     headerFile->Close();
711     // caloFile->Close();
712     //triggerFile->Close();
713     goto oltre;
714     jumpfile: printf(" File not processed! \n ");
715     hfile->Close();
716     oltre:
717     // gObjectTable->Print();
718     e++;
719     };
720     //
721     if ( !UPYES ) goto end;
722     printf("\n OK, now I will fit the MIP distribution for each strip \n\n");
723     //
724     hfile = new TFile(file2.str().c_str(),"UPDATE","Calorimeter CALIBRATION data");
725     calo = new CalorimeterCalibration();
726     tree = (TTree*)hfile->Get("CaloADC");
727     tree->SetBranchAddress("Event", &calo);
728     nevents = tree->GetEntries();
729     if ( (nevents-1-fileup) > 0 ){
730     tree->GetEntry(nevents-1-fileup);
731     };
732     //
733     // Fit all 4224 distributions and save parameters, fit, figures (all basically).
734     //
735     notgood = 0;
736     notgood1 = 0;
737     //
738     //
739     for (Int_t l = 0; l < 2; l++){
740     for (Int_t m = 0; m < 22; m++){
741     for (Int_t n =0 ; n < 96; n++){
742     Double_t SNRPeak = 0.;
743     if ( calo->mask[l][m][n] == 0. ){
744     //
745     // Setting fit range and start values
746     //
747     Double_t fr[2];
748     Double_t sv[4], pllo[4], plhi[4], fp[4], fpe[4];
749     if ( SNRPeak > 16. && SNRPeak < 35. ){
750     fr[0] = (Float_t)SNRPeak - 7.;
751     sv[0]= fp[0];
752     sv[1]= fp[1];
753     sv[2]= fp[2];
754     sv[3]= fp[3];
755     } else {
756     fr[0] = 19.;
757     sv[0] = 2.8;
758     sv[1] = 21.0;
759     sv[2] = 1000.0;
760     sv[3] = 0.1;
761     };
762     Int_t doitagain = 0;
763     fitting: printf("Fitting strip %i %i %i \n",l,m,n);
764     fr[1] = 60.;
765     pllo[0]=0.5; pllo[1]=5.0; pllo[2]=1.0; pllo[3]=0.2;
766     plhi[0]=8.0; plhi[1]=50.0; plhi[2]=1000000.0; plhi[3]=8.0;
767     Double_t chisqr;
768     Int_t ndf;
769     //
770     // fit the figure pfmip and put fit results in pfitsnr
771     //
772     pfitsnr[l][m][n] = langaufit(pfmip[l][m][n],fr,sv,pllo,plhi,fp,fpe,&chisqr,&ndf,"QR0");
773     //
774     // search for the maximum of the distribution, it will be the conversion factor between ADC channels and the MIP
775     //
776     Double_t SNRPeak = langaupro(fp);
777     printf("\n Conversion factor: %f \n\n",SNRPeak);
778     //
779     //
780     //
781     if ( ( SNRPeak < 0. || (SNRPeak < 16. || SNRPeak > 35.) || chisqr > 100.) && doitagain < 3 ){
782     printf("\n The fit is not good, I will try again, step %i \n\n",doitagain);
783     doitagain++;
784     if ( chisqr > 100. ) {
785     fr[0] = fr[0] + 5.;
786     sv[0] = fp[0];
787     sv[1] = fp[1];
788     sv[2] = fp[2];
789     sv[3] = fp[3];
790     goto fitting;
791     };
792     if ( doitagain == 2 ) {
793     fr[0] = 19.;
794     sv[0] = 2.8;
795     sv[1] = 21.0;
796     sv[2] = 1000.0;
797     sv[3] = 0.1;
798     goto fitting;
799     };
800     if ( doitagain == 1 ) {
801     fr[0] = 22.;
802     sv[0] = 2.8;
803     sv[1] = 25.0;
804     sv[2] = 1000.0;
805     sv[3] = 0.1;
806     goto fitting;
807     };
808     if ( doitagain == 3 ) {
809     fr[0] = 12.;
810     sv[0] = 2.8;
811     sv[1] = 15.0;
812     sv[2] = 1000.0;
813     sv[3] = 0.1;
814     goto fitting;
815     };
816     };
817    
818     //
819     // save data
820     //
821     calo->mip[l][m][n] = (float)SNRPeak;
822     calo->ermip[l][m][n] = (float)fpe[1];
823     for (Int_t a = 0; a < 4 ; a++){
824     calo->fp[a][l][m][n] = (float)fp[a];
825     calo->fpe[a][l][m][n] = (float)fpe[a];
826     };
827     calo->ndf[l][m][n] = (float)ndf;
828     calo->chi2[l][m][n] = (float)chisqr;
829     if ( calo->fp[1][l][m][n] > 16. && calo->fp[1][l][m][n] < 35. ) notgood1++;
830     //
831     if ( ndf!=0 && chisqr/ndf < 2. && fpe[1] < 0.15 && fp[1] > 15. && fp[1] < 40. && SNRPeak > 0. ) {
832     printf(" THIS IS A GOOD FIT, SAVED! \n\n");
833     calo->mask[l][m][n] = 1.;
834     } else {
835     notgood++;
836     calo->mask[l][m][n] = 0.;
837     };
838     printf("Fitting done, strip %i %i %i \n\n\n",l,m,n);
839     //
840     // draw the figure and fit on the screen
841     //
842     //c1->Clear();
843     //c1->cd();
844     //pfmip[l][m][n]->DrawCopy();
845     //pfitsnr[l][m][n]->DrawCopy("lsame");
846     //c1->Modified();
847     //c1->Update();
848     };
849     };
850     };
851     };
852     //
853     calo->status = 0;
854     if ( !notgood ) calo->status = 1;
855     //
856     // save fit data
857     //
858     tree->Fill();
859     hfile->Write();
860     hfile->Close();
861     //
862     // Save histograms and fit figures
863     //
864     TFile *hfile2;
865     hfile2 = new TFile(file3.str().c_str(),"RECREATE","Calorimeter CALIBRATION figures");
866     if ( !existfile(file3.str().c_str()) ){
867     printf(" ERROR: Cannot create file \n");
868     return;
869     };
870     TH1F *sfmip[2][22][96];
871     TF1 *sfitsnr[2][22][96];
872     fmippa.str("");
873     for (Int_t l = 0; l < 2; l++){
874     for (Int_t m = 0; m < 22; m++){
875     for (Int_t n =0 ; n < 96; n++){
876     fmippa.str("");
877     fmippa << "fmip " << l;
878     fmippa << " " << m;
879     fmippa << " " << n;
880     sfmip[l][m][n] = new TH1F(fmippa.str().c_str(),"",56,0.,55.);
881     sfmip[l][m][n] = (TH1F*)pfmip[l][m][n]->Clone(fmippa.str().c_str());
882     fmippa.str("");
883     fmippa << "fit " << l;
884     fmippa << " " << m;
885     fmippa << " " << n;
886     sfitsnr[l][m][n] = (TF1*)pfitsnr[l][m][n]->Clone(fmippa.str().c_str());
887     sfmip[l][m][n]->Write();
888     sfitsnr[l][m][n]->Write();
889     };
890     };
891     };
892     hfile2->Close();
893     if ( hf3 ) hfile3->Close();
894     //
895     if ( notgood ) {
896     printf("\n An update will be necessary:\n %i strip with too low statistic (%i of them gave a result anyway)\n\n",notgood,notgood1);
897     };
898     //
899     end: printf("\n");
900     //
901     }
902    
903     void FCaloRAWADC2MIPPLOT(TString Filename, TString calcalibfile = "", TString OutDir="", TString flist=""){
904     const char *pam_calib = pathtocalibration();
905     if ( !strcmp(OutDir.Data(),"") ){
906     OutDir = pam_calib;
907     };
908     //
909     TString calcalib;
910     struct Evento evento;
911     struct Calib calib;
912     Int_t debug = 0;
913     Int_t b[4];
914     Int_t etime,evno;
915     Float_t sdexy[2][22][96],sdexyc[2][22][96];
916     Float_t edelta[2][22][96];
917     Float_t estrip[2][22][96];
918     Float_t estripnull[2][22][96];
919     Float_t delta;
920     CalorimeterCalibration *calo = new CalorimeterCalibration();
921     delta = 1.;
922     evento.emin = 0.7;
923     Int_t se =5;
924     Int_t pre;
925     Int_t rdone = 0;
926     Int_t done;
927     bool isCOMP = 0;
928     bool isFULL = 0;
929     bool isRAW = 0;
930     TH1F *pfmip[2][22][96];
931     TF1 *pfitsnr[2][22][96];
932     stringstream Fmip;
933     Fmip.str("");
934     for (Int_t i=0; i<2;i++){
935     for (Int_t j=0; j<22;j++){
936     for (Int_t m=0; m<96;m++){
937     Fmip.str("");
938     Fmip << "Fmip " << i;
939     Fmip << " " << j;
940     Fmip << " " << m;
941     pfmip[i][j][m] = new TH1F(Fmip.str().c_str(),"",70,-15.,55.);
942     pfitsnr[i][j][m] = new TF1;
943     };
944     };
945     };
946     //
947     // the file which contains the calorimeter ADC to MIP conversion values is file2 = path to the script dir / CaloADC2MIP.root
948     //
949     stringstream file2;
950     file2.str("");
951     file2 << OutDir.Data() << "/CaloADC2MIP.raw";
952     //
953     // this the figures and fit (4224 x 2 objects!)
954     //
955     stringstream file3;
956     file3 << OutDir.Data() << "/CaloADC2MIPfr.raw";
957     //
958     stringstream file4;
959     file4.str("");
960     file4 << OutDir.Data() << "/CaloADC2MIPfr";
961     //
962     stringstream file5;
963     file5.str("");
964     file5 << OutDir.Data() << "/CaloADC2MIPdata.raw";
965     //
966     Int_t nfile = 0;
967     Int_t fileup = 0;
968     if ( flist != "" ){
969     printf("\n You have given an input file list \n\n Files: \n");
970     ifstream in;
971     in.open(flist, ios::in);
972     char ctime[20];
973     while (1) {
974     in >> ctime;
975     if (!in.good()) break;
976     printf(" File number %i = %s \n",nfile+1,ctime);
977     nfile++;
978     };
979     in.close();
980     if ( !nfile ) {
981     printf("\n\n The list is empty, exiting... \n\n");
982     return;
983     };
984     } else {
985     nfile = 1;
986     };
987     printf("\n");
988     //
989     // First check if the calibration file exists:
990     //
991     Int_t EFILE = 0;
992     printf(" Check the existence of CaloADC2MIP.raw file: \n\n");
993    
994     if ( !existfile(file2.str().c_str()) ){
995     printf(" %s :no such file or directory \n",file2.str().c_str());
996     printf("\n OK, I will create it!\n\n");
997     EFILE = 0;
998     } else {
999     printf(" The file already exists! Check if an update is needed \n\n");
1000     EFILE = 1;
1001     };
1002     //
1003     // the check for an update is done once even if we have a list.
1004     //
1005     TTree *tree = 0;
1006     if ( EFILE == 1) {
1007     //
1008     // The file exists, open it (READ ONLY) and check if any update is needed:
1009     //
1010     TFile *hfile = 0;
1011     hfile = new TFile(file2.str().c_str(),"READ","Calorimeter CALIBRATION data");
1012     calo = new CalorimeterCalibration();
1013     tree = (TTree*)hfile->Get("CaloADC");
1014     tree->SetBranchAddress("Event", &calo);
1015     //
1016     Long64_t nevents = tree->GetEntries();
1017     printf("\n Number of updates: %i\n",(int)nevents);
1018     tree->GetEntry(nevents-1);
1019     //
1020     // Read the status variable of the last event: if it is 0 then we need an update, if it is one print out informations and exit
1021     //
1022     if ( calo->status == 0 ) {
1023     printf("\n An update is needed: \n");
1024     Int_t upstrip = 0;
1025     for (Int_t i = 0; i<2; i++){
1026     for (Int_t j = 0; j<22; j++){
1027     for (Int_t l = 0; l<96; l++){
1028     if ( calo->mask[i][j][l] == 0. ) upstrip++;
1029     };
1030     };
1031     };
1032     printf(" %i strip out of 4224 have no statistic enough.\n\n",upstrip);
1033     } else {
1034     printf(" No update is needed! \n The data files used to obtain the ADC to MIP conversion are: \n");
1035     for (Int_t i = 0; i<nevents; i++){
1036     tree->GetEntry(i);
1037     const char *fnout = calo->fname;
1038     printf(" - %s \n",fnout);
1039     };
1040     printf("\n\n");
1041     return;
1042     };
1043     hfile->Close();
1044     };
1045     //
1046     const char *filename2 = Filename;
1047     //
1048     TString lfile;
1049     TString sfile;
1050     //
1051     Int_t e = 0;
1052     ifstream in;
1053     in.open(flist, ios::in);
1054     char ctime[20];
1055     TString pfile;
1056     const char *cali;
1057     const char *ffile;
1058     Int_t calibex = 0;
1059     //
1060     TString filename;
1061     const char *nome = 0;
1062     TFile *hfile = 0;
1063     // CalorimeterCalibration *calo = 0;
1064     Long64_t nevents;
1065     Int_t used = 0;
1066     const char *compare = 0;
1067     Int_t hf3 = 0;
1068     TFile *headerFile = 0;
1069     TString file2f = "";
1070     pfile = "";
1071     const char *porca = 0;
1072     Int_t S4;
1073     Int_t upnn;
1074     stringstream files;
1075     TFile *hfileb = 0;
1076     //
1077     Int_t pl1, pl2, strmin, strmax;
1078     Int_t spre=0;
1079     Int_t surstrip = 0;
1080     Float_t estrippa = 0.;
1081     //
1082     TFile *hfile3 = 0;
1083     TString fififile;
1084     const char *file;
1085     //
1086     calo = new CalorimeterCalibration();
1087     stringstream finome;
1088     finome.str("");
1089     while ( e < nfile ){
1090     if ( flist != "" ){
1091     in >> ctime;
1092     finome.str("");
1093     finome << filename2 << "/";
1094     finome << ctime;
1095     lfile = TString(finome.str().c_str());
1096     fififile = getFilename(lfile);
1097     file = fififile;
1098     finome.str("");
1099     finome << file;
1100     sfile = TString(finome.str().c_str());
1101     } else {
1102     finome.str("");
1103     finome << filename2;
1104     lfile = TString(finome.str().c_str());
1105     fififile = getFilename(lfile);
1106     file = fififile;
1107     finome.str("");
1108     finome << file;
1109     sfile = TString(finome.str().c_str());
1110     };
1111     //
1112     filename = lfile;
1113     nome = filename;
1114     printf("\n Processing file number %i: %s \n\n",e,nome);
1115     nome = sfile;
1116     //
1117     // this must be done for each file.
1118     //
1119     TTree *otr;
1120     pamela::calorimeter::CalorimeterEvent *de = 0;
1121     pamela::trigger::TriggerEvent *trigger = 0;
1122     pamela::PscuHeader *ph = 0;
1123     pamela::EventHeader *eh = 0;
1124     const char *calname;
1125     Int_t wused = 0;
1126     //
1127     // TTree *tree;
1128     if ( EFILE == 1 ){
1129     hfile = new TFile(file2.str().c_str(),"UPDATE","Calorimeter CALIBRATION data");
1130     tree = (TTree*)hfile->Get("CaloADC");
1131     tree->SetBranchAddress("Event", &calo);
1132     //
1133     // Check if the input file has already been used
1134     //
1135     printf(" Check if file %s has already been used... \n",nome);
1136     nevents = tree->GetEntries();
1137     used = 0;
1138     for (Int_t i = 0; i<nevents; i++){
1139     tree->GetEntry(i);
1140     compare= calo->fname;
1141     if ( !strcmp(compare,nome) ) {
1142     used = 1;
1143     break;
1144     };
1145     };
1146     if ( used ) {
1147     printf(" The file %s has already been used!\n You cannot run twice this program with that file!\n\n",nome);
1148     hfile->Close();
1149     goto jumpfile;
1150     } else {
1151     printf(" Good, the file has not been used yet. \n\n");
1152     nevents = tree->GetEntries() -1;
1153     tree->GetEntry(nevents);
1154     };
1155     } else {
1156     //
1157     // If the file doesn't exist create it
1158     //
1159     calo = new CalorimeterCalibration();
1160     hfile = new TFile(file2.str().c_str(),"NEW","Calorimeter CALIBRATION data");
1161     if ( !existfile(file2.str().c_str()) ){
1162     printf(" %s :no such file or directory \n",filename.Data());
1163     printf(" ERROR: Cannot create file \n");
1164     return;
1165     };
1166     tree = new TTree("CaloADC","Calorimeter calibration data");
1167     tree->Branch("Event","CalorimeterCalibration",&calo);
1168     };
1169     //
1170     //
1171     //
1172     hf3 = 0;
1173     if ( EFILE == 1 && e == 0 ){
1174     printf(" Reading the old MIP figures to be updated...\n ");
1175     hfile3 = new TFile(file3.str().c_str());
1176     hf3 = 1;
1177     //
1178     stringstream fmippa;
1179     fmippa.str("");
1180     for (Int_t l = 0; l < 2; l++){
1181     for (Int_t m = 0; m < 22; m++){
1182     for (Int_t n =0 ; n < 96; n++){
1183     fmippa.str("");
1184     fmippa << "fmip " << l;
1185     fmippa << " " << m;
1186     fmippa << " " << n;
1187     TH1F *temp = (TH1F*)hfile3->Get(fmippa.str().c_str());
1188     pfmip[l][m][n] = (TH1F*)temp->Clone();
1189     };
1190     };
1191     };
1192     printf(" ...done!\n");
1193     };
1194     EFILE = 1;
1195     //
1196     // Check if the input calibration file contains any calibration data
1197     //
1198     done = 0;
1199     printf(" Check for calorimeter calibration: \n");
1200     calcalib = filename;
1201     findcalibs: calname = calcalib;
1202     printf(" Calibration file: %s \n",calname);
1203     for (Int_t s=0; s<4;s++){
1204     for (Int_t d = 0; d<50; d++){
1205     calib.ttime[s][d] = 0 ;
1206     if ( d < 49 ) calib.time[s][d] = 0 ;
1207     };
1208     };
1209     for (Int_t m = 0; m < 2 ; m++ ){
1210     for (Int_t k = 0; k < 22; k++ ){
1211     for (Int_t l = 0; l < 96; l++ ){
1212     calib.calped[m][k][l] = 0. ;
1213     evento.dexy[m][k][l] = 0. ;
1214     evento.dexyc[m][k][l] = 0. ;
1215     edelta[m][k][l] = 0.;
1216     estrip[m][k][l] = 0.;
1217     estripnull[m][k][l] = 0.;
1218     };
1219     };
1220     }
1221     wused = 0;
1222     CaloFindCalibs(calcalib, calcalib, wused, calib);
1223     //
1224     // print on the screen the results:
1225     //
1226     ffile = filename;
1227     printf(" ------ %s ------- \n \n",ffile);
1228     calibex = 0;
1229     for (Int_t s=0; s<4;s++){
1230     printf(" ** SECTION %i **\n",s);
1231     for (Int_t d = 0; d<51; d++){
1232     if ( calib.ttime[s][d] != 0 ) {
1233     calibex++;
1234     if ( calib.fcode[s][d] != 10 ){
1235     file2f = "";
1236     stringcopy(file2f,calcalib,0,0);
1237     pfile = (TString)whatnamewith(file2f,calib.fcode[s][d]);
1238     } else {
1239     pfile = (TString)calcalib;
1240     };
1241     ffile = pfile;
1242     printf(" - from time %i to time %i use calibration at\n time %i, file: %s \n",calib.time[s][d],calib.time[s][d+1],calib.ttime[s][d],ffile);
1243     };
1244     };
1245     printf("\n");
1246     };
1247     printf(" ----------------------------------------------------------------------- \n \n");
1248     //
1249     if ( calibex < 1 ) {
1250     printf("No calibration data in this file!\n");
1251     calcalib = calcalibfile;
1252     if ( !done && calcalibfile != "" ) {
1253     cali = calcalibfile;
1254     printf(" Search in the calibration file %s \n",cali);
1255     done = 1;
1256     goto findcalibs;
1257     } else {
1258     printf(" Cannot find any calibration for this file! \n");
1259     goto jumpfile;
1260     };
1261     };
1262     if ( calibex < 4 ) {
1263     printf(" WARNING! No full calibration data in this file! \n\n");
1264     };
1265     //
1266     // upgrade data...
1267     //
1268     if ( !existfile(filename) ){
1269     printf(" %s :no such file or directory \n",filename.Data());
1270     goto jumpfile;
1271     };
1272     headerFile = new TFile(filename.Data());
1273     otr = (TTree*)headerFile->Get("Physics");
1274     otr->SetBranchAddress("Header", &eh);
1275     otr->SetBranchAddress("Calorimeter", &de);
1276     otr->SetBranchAddress("Trigger", &trigger);
1277     //
1278     //
1279     nevents = otr->GetEntries();
1280     //
1281     // calibrate before starting
1282     //
1283     for (Int_t s = 0; s < 4; s++){
1284     b[s]=0;
1285     if ( calib.fcode[s][b[s]] != 10 ){
1286     stringcopy(file2f,calcalib,0,0);
1287     pfile = (TString)whatnamewith(file2f,calib.fcode[s][b[s]]);
1288     } else {
1289     pfile = (TString)calcalib;
1290     };
1291     porca = pfile;
1292     if ( debug ) printf(" porca miseria %s \n",porca);
1293     CaloPede(pfile,s,calib.ttime[s][b[s]],calib);
1294     };
1295     //
1296     // run over all the events
1297     //
1298     printf("\n Processed events: \n\n");
1299     //
1300     for (Int_t i = 0; i < nevents; i++){
1301     evno = i;
1302     if ( i%1000 == 0 && i > 0 ) printf(" %iK \n",i/1000);
1303     //
1304     // read from the header of the event the absolute time at which it was recorded
1305     //
1306     otr->GetEntry(i);
1307     //
1308     S4 = trigger->patterntrig[1] & (1<<0);
1309     //
1310     if ( !S4 || i == 0 ) {
1311     ph = eh->GetPscuHeader();
1312     etime = ph->GetOrbitalTime();
1313     //
1314     // for each event check that the calibration we are using are still within calibration limits, if not call the next calibration
1315     //
1316     if ( !calib.obtjump ) {
1317     for (Int_t s = 0; s < 4; s++){
1318     if ( calib.ttime[s][b[s]] ){
1319     while ( etime > calib.time[s][b[s]+1] ){
1320     printf(" CALORIMETER: \n" );
1321     printf(" - Section %i, event at time %i while old calibration time limit at %i. Use new calibration at time %i -\n",s,etime,calib.time[s][b[s]+1],calib.ttime[s][b[s]+1]);
1322     printf(" END CALORIMETER. \n\n" );
1323     b[s]++;
1324     if ( calib.fcode[s][b[s]] != 10 ){
1325     stringcopy(file2f,calcalib,0,0);
1326     pfile = (TString)whatnamewith(file2f,calib.fcode[s][b[s]]);
1327     } else {
1328     pfile = (TString)calcalib;
1329     };
1330     porca = pfile;
1331     if ( debug ) printf(" porca miseria %s \n",porca);
1332     CaloPede(pfile,s,calib.ttime[s][b[s]],calib);
1333     };
1334     };
1335     };
1336     };
1337     //
1338     // do whatever you want with data
1339     //
1340     evento.iev = de->iev;
1341     //
1342     // run over views and planes
1343     //
1344     for (Int_t l = 0; l < 2; l++){
1345     for (Int_t m = 0; m < 22; m++){
1346     //
1347     // determine the section number
1348     //
1349     if (l == 0 && m%2 == 0) se = 3;
1350     if (l == 0 && m%2 != 0) se = 2;
1351     if (l == 1 && m%2 == 0) se = 0;
1352     if (l == 1 && m%2 != 0) se = 1;
1353     //
1354     // determine what kind of event we are going to analyze
1355     //
1356     isCOMP = 0;
1357     isFULL = 0;
1358     isRAW = 0;
1359     if ( de->stwerr[se] & (1 << 16) ) isCOMP = 1;
1360     if ( de->stwerr[se] & (1 << 17) ) isFULL = 1;
1361     if ( de->stwerr[se] & (1 << 3) ) isRAW = 1;
1362     //
1363     // save the prevoius energy deposit and calibration in sbase, sdexy, sdexyc
1364     //
1365     pre = -1;
1366     if ( isRAW ){
1367     for (Int_t nn = 0; nn < 96; nn++){
1368     if ( nn%16 == 0 ) pre++;
1369     evento.base[l][m][pre] = calib.calbase[l][m][pre];
1370     sdexy[l][m][nn] = evento.dexy[l][m][nn];
1371     evento.dexy[l][m][nn] = de->dexy[l][m][nn] ;
1372     sdexyc[l][m][nn] = evento.dexyc[l][m][nn];
1373     evento.dexyc[l][m][nn] = de->dexyc[l][m][nn] ;
1374     };
1375     //
1376     // run over strips
1377     //
1378     pre = -1;
1379     for (Int_t n =0 ; n < 96; n++){
1380     if ( n%16 == 0 ) {
1381     pre++;
1382     rdone = 0;
1383     done = 0;
1384     };
1385     if ( calo->mask[l][m][n] == 0. && ( isRAW || ( de->dexyc[l][m][n] > 0. && de->dexyc[l][m][n] < 32000.)) ){
1386     //
1387     // baseline check and calculation
1388     //
1389     if ( !rdone ){
1390     CaloFindBaseRawNC(calib,evento,l,m,pre);
1391     rdone = 1;
1392     };
1393     //
1394     // no suitable new baseline, use old ones and compress data!
1395     //
1396     if ( !done && (evento.base[l][m][pre] > 30000. || evento.base[l][m][pre] == 0.) ){
1397     evento.base[l][m][pre] = calib.sbase[l][m][pre];
1398     upnn = n+16;
1399     if ( upnn > 96 ) upnn = 96;
1400     for ( Int_t nn = n; nn<upnn; nn++ ){
1401     evento.dexyc[l][m][nn] = de->dexyc[l][m][nn] ;
1402     };
1403     done = 1;
1404     };
1405     //
1406     // CALIBRATION ALGORITHM
1407     //
1408     pl1 = -1;
1409     pl2 = -1;
1410     pl1 = m - 1;
1411     pl2 = m + 1;
1412     if ( pl1 < 0 ) {
1413     pl1 = pl2;
1414     pl2 = m + 2;
1415     };
1416     if ( pl2 > 21 ) {
1417     pl2 = pl1;
1418     pl1 = m - 2;
1419     };
1420     strmin = n - 2;
1421     if ( strmin < 0 ) strmin = 0;
1422     strmax = n + 2;
1423     if ( strmax > 95 ) strmax = 95;
1424     surstrip = 0;
1425     for (Int_t spl = pl1; spl<pl2+1; spl++){
1426     if ( spl != m ){
1427     for (Int_t sst = strmin; sst<strmax+1; sst++){
1428     if ( sst < 16 ) spre = 0;
1429     if ( 15 < sst && sst < 32 ) spre = 2;
1430     if ( 31 < sst && sst < 48 ) spre = 3;
1431     if ( 47 < sst && sst < 64 ) spre = 4;
1432     if ( 63 < sst && sst < 80 ) spre = 5;
1433     if ( 79 < sst ) spre = 6;
1434     if ( isRAW ){
1435     estrippa = ( evento.dexy[l][spl][sst] - calib.calped[l][spl][sst] - calib.sbase[l][spl][spre])/26. ;
1436     } else {
1437     estrippa = ( evento.dexyc[l][spl][sst] - calib.calped[l][spl][sst] - calib.sbase[l][spl][spre])/26. ;
1438     };
1439     if ( estrippa > 0.7 && estrippa < 10. && calib.calgood[l][spl][sst] == 0 ){
1440     surstrip++;
1441     //printf("surstrip = %i estrip = %f \n",surstrip,estrip);
1442     };
1443     };
1444     };
1445     };
1446     //
1447     //
1448     estrip[l][m][n] = ( evento.dexyc[l][m][n] - calib.calped[l][m][n] - evento.base[l][m][pre]) ;
1449     pfmip[l][m][n]->Fill(estrip[l][m][n]);
1450     calib.sbase[l][m][pre] = evento.base[l][m][pre];
1451     };
1452     };
1453     };
1454     };
1455     };
1456     };
1457     };
1458     //
1459     // save filename
1460     //
1461     calo->fname = sfile;
1462     tree->Fill();
1463     hfile->Write();
1464     fileup++;
1465     hfile->Close();
1466     //
1467     // create a backup copy!
1468     //
1469     if ( nfile > 1 && ( e%10 == 0 || e == nfile-1 ) && e > 0 ){
1470     files.str("");
1471     files << file4.str().c_str() << (e+1);
1472     files << ".bak";
1473     printf(" Save the backup file with figures:\n %s \n ",files.str().c_str());
1474     hfileb = new TFile(files.str().c_str(),"RECREATE","Calorimeter CALIBRATION figures");
1475     if ( !existfile(files.str().c_str()) ){
1476     printf(" ERROR: Cannot create file!!! \n");
1477     goto oltre;
1478     };
1479     TH1F *bfmip[2][22][96];
1480     stringstream bmippa;
1481     for (Int_t l = 0; l < 2; l++){
1482     for (Int_t m = 0; m < 22; m++){
1483     for (Int_t n =0 ; n < 96; n++){
1484     bmippa.str("");
1485     bmippa << "bmip " << l;
1486     bmippa << " " << m;
1487     bmippa << " " << n;
1488     bfmip[l][m][n] = new TH1F(bmippa.str().c_str(),"",70,-15.,55.);
1489     bfmip[l][m][n] = (TH1F*)pfmip[l][m][n]->Clone(bmippa.str().c_str());
1490     bfmip[l][m][n]->Write();
1491     };
1492     };
1493     };
1494     hfileb->Close();
1495     };
1496     //
1497     //
1498     //
1499     headerFile->Close();
1500     goto oltre;
1501     jumpfile: printf(" File not processed! \n ");
1502     hfile->Close();
1503     oltre:
1504     // gObjectTable->Print();
1505     e++;
1506     };
1507     //
1508     // Save histograms and fit figures
1509     //
1510     TFile *hfile2;
1511     hfile2 = new TFile(file3.str().c_str(),"RECREATE","Calorimeter CALIBRATION figures");
1512     if ( !existfile(file3.str().c_str()) ){
1513     printf(" ERROR: Cannot create file!!! \n");
1514     return;
1515     };
1516     TH1F *sfmip[2][22][96];
1517     stringstream fmippa;
1518     for (Int_t l = 0; l < 2; l++){
1519     for (Int_t m = 0; m < 22; m++){
1520     for (Int_t n =0 ; n < 96; n++){
1521     fmippa.str("");
1522     fmippa << "fmip " << l;
1523     fmippa << " " << m;
1524     fmippa << " " << n;
1525     sfmip[l][m][n] = new TH1F(fmippa.str().c_str(),"",72,-15.,55.);
1526     sfmip[l][m][n] = (TH1F*)pfmip[l][m][n]->Clone(fmippa.str().c_str());
1527     sfmip[l][m][n]->Write();
1528     };
1529     };
1530     };
1531     hfile2->Close();
1532     if ( hf3 ) hfile3->Close();
1533     }
1534    
1535     void FCaloRAWADC2MIPDATA(TString Filename, TString calcalibfile = "", TString OutDir="", TString flist=""){
1536     const char *pam_calib = pathtocalibration();
1537     if ( !strcmp(OutDir.Data(),"") ){
1538     OutDir = pam_calib;
1539     };
1540     TString calcalib;
1541     struct Evento evento;
1542     struct Calib calib;
1543     Int_t debug = 0;
1544     Int_t b[4];
1545     Int_t etime,evno;
1546     Float_t sdexy[2][22][96],sdexyc[2][22][96];
1547     Float_t edelta[2][22][96];
1548     Float_t estrip[2][22][96];
1549     Float_t estripnull[2][22][96];
1550     Float_t delta;
1551     delta = 1.;
1552     evento.emin = 0.7;
1553     Int_t se =5;
1554     Int_t pre;
1555     Int_t rdone = 0;
1556     Int_t done;
1557     bool isCOMP = 0;
1558     bool isFULL = 0;
1559     bool isRAW = 0;
1560     //
1561     // the file which contains the calorimeter ADC to MIP conversion values is file2 = path to the script dir / CaloADC2MIP.root
1562     //
1563     stringstream file5;
1564     file5.str("");
1565     file5 << OutDir.Data() << "/CaloADC2MIPdata.raw";
1566     //
1567     Int_t nfile = 0;
1568     Int_t fileup = 0;
1569     if ( flist != "" ){
1570     printf("\n You have given an input file list \n\n Files: \n");
1571     ifstream in;
1572     in.open(flist, ios::in);
1573     char ctime[20];
1574     while (1) {
1575     in >> ctime;
1576     if (!in.good()) break;
1577     printf(" File number %i = %s \n",nfile+1,ctime);
1578     nfile++;
1579     };
1580     in.close();
1581     if ( !nfile ) {
1582     printf("\n\n The list is empty, exiting... \n\n");
1583     return;
1584     };
1585     } else {
1586     nfile = 1;
1587     };
1588     printf("\n");
1589     //
1590     // First check if the calibration file exists:
1591     //
1592     //
1593     const char *filename2 = Filename;
1594     //
1595     TString lfile;
1596     TString sfile;
1597     //
1598     Int_t e = 0;
1599     ifstream in;
1600     in.open(flist, ios::in);
1601     char ctime[20];
1602     TString file2f;
1603     TString pfile;
1604     const char *cali;
1605     const char *ffile;
1606     Int_t calibex = 0;
1607     //
1608     TString filename;
1609     const char *nome = 0;
1610     Long64_t nevents;
1611     TFile *headerFile = 0;
1612     file2f = "";
1613     pfile = "";
1614     const char *porca = 0;
1615     Int_t upnn;
1616     //
1617     //
1618     TFile *hfl1 = 0;
1619     hfl1 = new TFile(file5.str().c_str(),"RECREATE","Calorimeter LEVEL1 data");
1620     //
1621     // class CalorimeterLevel1
1622     //
1623     CalorimeterADCRAW *clev1 = new CalorimeterADCRAW();
1624     TTree *trl1 = 0;
1625     trl1 = new TTree("CaloADCRAW","PAMELA Level1 calorimeter data");
1626     trl1->Branch("Rawdata","CalorimeterADCRAW",&clev1);
1627     //
1628     Int_t glbc = 0;
1629     //
1630     TString fififile;
1631     const char *file;
1632     //
1633     stringstream lfillo;
1634     while ( e < nfile ){
1635     if ( flist != "" ){
1636     in >> ctime;
1637     lfillo.str("");
1638     lfillo << filename2 << "/";
1639     lfillo << ctime;
1640     lfile = TString(lfillo.str().c_str());
1641     fififile = getFilename(lfile);
1642     file = fififile;
1643     lfillo.str("");
1644     lfillo << file;
1645     sfile = TString(lfillo.str().c_str());
1646     } else {
1647     lfillo.str("");
1648     lfillo << filename2;
1649     lfile = TString(lfillo.str().c_str());
1650     fififile = getFilename(lfile);
1651     file = fififile;
1652     lfillo.str("");
1653     lfillo << file;
1654     sfile = TString(lfillo.str().c_str());
1655     };
1656     //
1657     filename = lfile;
1658     nome = filename;
1659     printf("\n Processing file number %i: %s \n\n",e,nome);
1660     nome = sfile;
1661     //
1662     // Check if the input calibration file contains any calibration data
1663     //
1664     TTree *otr;
1665     pamela::calorimeter::CalorimeterEvent *de = 0;
1666     pamela::PscuHeader *ph = 0;
1667     pamela::EventHeader *eh = 0;
1668     //
1669     done = 0;
1670     printf(" Check for calorimeter calibration: \n");
1671     calcalib = filename;
1672     findcalibs: const char *calname = calcalib;
1673     printf(" Calibration file: %s \n",calname);
1674     for (Int_t s=0; s<4;s++){
1675     for (Int_t d = 0; d<50; d++){
1676     calib.ttime[s][d] = 0 ;
1677     if ( d < 49 ) calib.time[s][d] = 0 ;
1678     };
1679     };
1680     for (Int_t m = 0; m < 2 ; m++ ){
1681     for (Int_t k = 0; k < 22; k++ ){
1682     for (Int_t l = 0; l < 96; l++ ){
1683     calib.calped[m][k][l] = 0. ;
1684     evento.dexy[m][k][l] = 0. ;
1685     evento.dexyc[m][k][l] = 0. ;
1686     edelta[m][k][l] = 0.;
1687     estrip[m][k][l] = 0.;
1688     estripnull[m][k][l] = 0.;
1689     };
1690     };
1691     }
1692     Int_t wused = 0;
1693     CaloFindCalibs(filename, calcalibfile, wused, calib);
1694     if ( wused == 1 ) calcalibfile = filename;
1695     //
1696     // print on the screen the results:
1697     //
1698     ffile = filename;
1699     printf(" ------ %s ------- \n \n",ffile);
1700     calibex = 0;
1701     for (Int_t s=0; s<4;s++){
1702     printf(" ** SECTION %i **\n",s);
1703     for (Int_t d = 0; d<51; d++){
1704     if ( calib.ttime[s][d] != 0 ) {
1705     calibex++;
1706     if ( calib.fcode[s][d] != 10 ){
1707     file2f = "";
1708     stringcopy(file2f,calcalib,0,0);
1709     pfile = (TString)whatnamewith(file2f,calib.fcode[s][d]);
1710     } else {
1711     pfile = (TString)calcalib;
1712     };
1713     ffile = pfile;
1714     printf(" - from time %i to time %i use calibration at\n time %i, file: %s \n",calib.time[s][d],calib.time[s][d+1],calib.ttime[s][d],ffile);
1715     };
1716     };
1717     printf("\n");
1718     };
1719     printf(" ----------------------------------------------------------------------- \n \n");
1720     //
1721     if ( calibex < 1 ) {
1722     printf("No calibration data in this file!\n");
1723     calcalib = calcalibfile;
1724     if ( !done && calcalibfile != "" ) {
1725     cali = calcalibfile;
1726     printf(" Search in the calibration file %s \n",cali);
1727     done = 1;
1728     goto findcalibs;
1729     } else {
1730     printf(" Cannot find any calibration for this file! \n");
1731     goto jumpfile;
1732     };
1733     };
1734     if ( calibex < 4 ) {
1735     printf(" WARNING! No full calibration data in this file! \n\n");
1736     };
1737     //
1738     // upgrade data...
1739     //
1740     if ( !existfile(filename) ){
1741     printf(" %s :no such file or directory \n",filename.Data());
1742     goto jumpfile;
1743     };
1744     headerFile = new TFile(filename.Data());
1745     otr = (TTree*)headerFile->Get("Physics");
1746     otr->SetBranchAddress("Header", &eh);
1747     otr->SetBranchAddress("Calorimeter", &de);
1748     //
1749     nevents = otr->GetEntries();
1750     //
1751     // calibrate before starting
1752     //
1753     for (Int_t s = 0; s < 4; s++){
1754     b[s]=0;
1755     if ( calib.fcode[s][b[s]] != 10 ){
1756     stringcopy(file2f,calcalib,0,0);
1757     pfile = (TString)whatnamewith(file2f,calib.fcode[s][b[s]]);
1758     } else {
1759     pfile = (TString)calcalib;
1760     };
1761     porca = pfile;
1762     if ( debug ) printf(" porca miseria %s \n",porca);
1763     CaloPede(pfile,s,calib.ttime[s][b[s]],calib);
1764     };
1765     //
1766     // run over all the events
1767     //
1768     printf("\n Processed events: \n\n");
1769     //
1770     Int_t updata;
1771     for (Int_t i = 0; i < nevents; i++){
1772     evno = i;
1773     if ( i%1000 == 0 && i > 0 ) printf(" %iK \n",i/1000);
1774     //
1775     // read from the header of the event the absolute time at which it was recorded
1776     //
1777     otr->GetEntry(i);
1778     //
1779     //
1780     ph = eh->GetPscuHeader();
1781     etime = ph->GetOrbitalTime();
1782     //
1783     // for each event check that the calibration we are using are still within calibration limits, if not call the next calibration
1784     //
1785     if ( !calib.obtjump ) {
1786     for (Int_t s = 0; s < 4; s++){
1787     if ( calib.ttime[s][b[s]] ){
1788     while ( etime > calib.time[s][b[s]+1] ){
1789     printf(" CALORIMETER: \n" );
1790     printf(" - Section %i, event at time %i while old calibration time limit at %i. Use new calibration at time %i -\n",s,etime,calib.time[s][b[s]+1],calib.ttime[s][b[s]+1]);
1791     printf(" END CALORIMETER. \n\n" );
1792     b[s]++;
1793     if ( calib.fcode[s][b[s]] != 10 ){
1794     stringcopy(file2f,calcalib,0,0);
1795     pfile = (TString)whatnamewith(file2f,calib.fcode[s][b[s]]);
1796     } else {
1797     pfile = (TString)calcalib;
1798     };
1799     porca = pfile;
1800     if ( debug ) printf(" porca miseria %s \n",porca);
1801     CaloPede(pfile,s,calib.ttime[s][b[s]],calib);
1802     };
1803     };
1804     };
1805     };
1806     //
1807     // do whatever you want with data
1808     //
1809     evento.iev = de->iev;
1810     //
1811     // run over views and planes
1812     //
1813     updata = 0;
1814     glbc++;
1815     for (Int_t l = 0; l < 2; l++){
1816     for (Int_t m = 0; m < 22; m++){
1817     //
1818     // determine the section number
1819     //
1820     if (l == 0 && m%2 == 0) se = 3;
1821     if (l == 0 && m%2 != 0) se = 2;
1822     if (l == 1 && m%2 == 0) se = 0;
1823     if (l == 1 && m%2 != 0) se = 1;
1824     //
1825     // determine what kind of event we are going to analyze
1826     //
1827     isCOMP = 0;
1828     isFULL = 0;
1829     isRAW = 0;
1830     if ( de->stwerr[se] & (1 << 16) ) isCOMP = 1;
1831     if ( de->stwerr[se] & (1 << 17) ) isFULL = 1;
1832     if ( de->stwerr[se] & (1 << 3) ) isRAW = 1;
1833     //
1834     // save the prevoius energy deposit and calibration in sbase, sdexy, sdexyc
1835     //
1836     pre = -1;
1837     if ( isRAW || isFULL ){
1838     updata = 1;
1839     for (Int_t nn = 0; nn < 96; nn++){
1840     if ( nn%16 == 0 ) pre++;
1841     evento.base[l][m][pre] = calib.calbase[l][m][pre];
1842     sdexy[l][m][nn] = evento.dexy[l][m][nn];
1843     evento.dexy[l][m][nn] = de->dexy[l][m][nn] ;
1844     sdexyc[l][m][nn] = evento.dexyc[l][m][nn];
1845     // !!!
1846     evento.dexyc[l][m][nn] = de->dexy[l][m][nn] ;
1847     // !!!
1848     };
1849     //
1850     // run over strips
1851     //
1852     pre = -1;
1853     for (Int_t n =0 ; n < 96; n++){
1854     if ( n%16 == 0 ) {
1855     pre++;
1856     rdone = 0;
1857     done = 0;
1858     };
1859     if ( isRAW || ( de->dexyc[l][m][n] > 0. && de->dexyc[l][m][n] < 32000.) || isFULL ){
1860     if ( isFULL && !rdone ) rdone = 1;
1861     //
1862     // baseline check and calculation
1863     //
1864     if ( !rdone ){
1865     CaloFindBaseRawNC(calib,evento,l,m,pre);
1866     rdone = 1;
1867     };
1868     //
1869     // no suitable new baseline, use old ones and compress data!
1870     //
1871     if ( !done && (evento.base[l][m][pre] > 30000. || evento.base[l][m][pre] == 0.) ){
1872     evento.base[l][m][pre] = calib.sbase[l][m][pre];
1873     upnn = n+16;
1874     if ( upnn > 96 ) upnn = 96;
1875     for ( Int_t nn = n; nn<upnn; nn++ ){
1876     evento.dexyc[l][m][nn] = de->dexy[l][m][nn] ;
1877     };
1878     done = 1;
1879     };
1880     //
1881     // CALIBRATION ALGORITHM
1882     //
1883     estrip[l][m][n] = ( evento.dexyc[l][m][n] - calib.calped[l][m][n] - evento.base[l][m][pre]) ;
1884     calib.sbase[l][m][pre] = evento.base[l][m][pre];
1885     clev1->diffbas[l][m][pre] = evento.base[l][m][pre];
1886     clev1->estrip[l][m][n] = estrip[l][m][n];
1887     };
1888     };
1889     };
1890     };
1891     };
1892     // if ( updata ){
1893     clev1->evno = glbc;
1894     clev1->etime = etime;
1895     trl1->Fill();
1896     for (Int_t l =0 ; l < 2; l++){
1897     for (Int_t m =0 ; m < 22; m++){
1898     pre = -1;
1899     for (Int_t n =0 ; n < 96; n++){
1900     // memcpy(estrip, estripnull, sizeof(estrip));
1901     if ( n%16 == 0 ) pre++;
1902     estrip[l][m][n] = 0.;
1903     evento.base[l][m][pre] = 0.;
1904     clev1->diffbas[l][m][pre] = evento.base[l][m][pre];
1905     clev1->estrip[l][m][n] = estrip[l][m][n];
1906     };
1907     };
1908     };
1909     //gObjectTable->Print();
1910     //};
1911     };
1912     //
1913     // save filename
1914     //
1915     fileup++;
1916     //
1917     headerFile->Close();
1918     goto oltre;
1919     jumpfile: printf(" File not processed! \n ");
1920     oltre:
1921     e++;
1922     };
1923     hfl1->Write();
1924     hfl1->Close();
1925     }
1926    
1927     void FCalo4224STATUS(TString filename = "", TString style = ""){
1928     const char *pam_calib = pathtocalibration();
1929     //
1930     // this routine shows the calorimeter calibration status with a figure. You can choose style between "error" (or "") to show the error on the
1931     // peak maximum determined and "status" to show which strips have converged to a certain value.
1932     //
1933     if ( filename == "" ){
1934     stringstream filenome;
1935     filenome.str("");
1936     filenome << pam_calib << "/CaloADC2MIP.root";
1937     filename = (TString)filenome.str().c_str();
1938     };
1939     if ( style == "" ) style = "error";
1940     const char *file2 = filename;
1941     TFile *hfile;
1942     hfile = new TFile(file2,"READ","Calorimeter CALIBRATION data");
1943     CalorimeterCalibration *calo = 0;
1944     TTree *tree;
1945     tree = (TTree*)hfile->Get("CaloADC");
1946     tree->SetBranchAddress("Event", &calo);
1947     //
1948     Long64_t nevents = tree->GetEntries();
1949     tree->GetEntry(nevents-1);
1950     //
1951     // Book the histograms:
1952     //
1953     //
1954     TH2F *Xview = new TH2F("x-view event ","",96,-0.5,95.5,22,-0.5,21.5);
1955     TH2F *Yview = new TH2F("y-view event ","",96,-0.5,95.5,22,-0.5,21.5);
1956     //
1957     // figures:
1958     //
1959     TCanvas *figura2 = new TCanvas("Calorimeter:_strip_RMS", "Calorimeter:_strip_RMS", 750, 650);
1960     figura2->SetFillColor(10);
1961     figura2->Range(0,0,100,100);
1962     Int_t bgcolor = 10;
1963     TPad *pd1 = new TPad("pd1","This is pad1",0.02,0.05,0.88,0.49,bgcolor);
1964     TPad *pd2 = new TPad("pd2","This is pad2",0.02,0.51,0.88,0.95,bgcolor);
1965     TPad *palette = new TPad("palette","This is palette",0.90,0.05,0.98,0.90,bgcolor);
1966     figura2->cd();
1967     TLatex *t=new TLatex();
1968     t->SetTextFont(32);
1969     t->SetTextColor(1);
1970     t->SetTextSize(0.03);
1971     t->SetTextAlign(12);
1972     t->DrawLatex(90.,92.5,"error");
1973     pd1->Range(0,0,100,100);
1974     pd2->Range(0,0,100,100);
1975     palette->Range(0,0,101,100);
1976     pd1->SetTicks();
1977     pd2->SetTicks();
1978     pd1->Draw();
1979     pd2->Draw();
1980     palette->Draw();
1981     palette->cd();
1982     const char *style2 = style;
1983     if ( !strcmp(style2,"error") ){
1984     // palette
1985     TPaveLabel *box1 = new TPaveLabel(1,2,99,14,"no fit","");
1986     box1->SetTextFont(32);
1987     box1->SetTextColor(1);
1988     box1->SetTextSize(0.25);
1989     box1->SetFillColor(10);
1990     box1->Draw();
1991     TPaveLabel *box2 = new TPaveLabel(1,16,99,28,"< 0.15","");
1992     box2->SetTextFont(32);
1993     box2->SetTextColor(1);
1994     box2->SetTextSize(0.25);
1995     box2->SetFillColor(38);
1996     box2->Draw();
1997     TPaveLabel *box3 = new TPaveLabel(1,30,99,42,"0.15 - 0.25","");
1998     box3->SetTextFont(32);
1999     box3->SetTextColor(1);
2000     box3->SetTextSize(0.2);
2001     box3->SetFillColor(4);
2002     box3->Draw();
2003     TPaveLabel *box4 = new TPaveLabel(1,44,99,56,"0.25 - 0.55","");
2004     box4->SetTextFont(32);
2005     box4->SetTextColor(1);
2006     box4->SetTextSize(0.2);
2007     box4->SetFillColor(3);
2008     box4->Draw();
2009     TPaveLabel *box5 = new TPaveLabel(1,58,99,70,"0.55 - 1","");
2010     box5->SetTextFont(32);
2011     box5->SetTextColor(1);
2012     box5->SetTextSize(0.25);
2013     box5->SetFillColor(2);
2014     box5->Draw();
2015     TPaveLabel *box6 = new TPaveLabel(1,72,99,84,"1 - 5","");
2016     box6->SetTextFont(32);
2017     box6->SetTextColor(1);
2018     box6->SetTextSize(0.25);
2019     box6->SetFillColor(6);
2020     box6->Draw();
2021     TPaveLabel *box7 = new TPaveLabel(1,86,99,98,"> 5","");
2022     box7->SetTextFont(32);
2023     box7->SetTextColor(10);
2024     box7->SetTextSize(0.25);
2025     box7->SetFillColor(1);
2026     box7->Draw();
2027     } else {
2028     TPaveLabel *box1 = new TPaveLabel(1,2,99,14,"not done","");
2029     box1->SetTextFont(32);
2030     box1->SetTextColor(1);
2031     box1->SetTextSize(0.25);
2032     box1->SetFillColor(10);
2033     box1->Draw();
2034     TPaveLabel *box2 = new TPaveLabel(1,16,99,28,"done","");
2035     box2->SetTextFont(32);
2036     box2->SetTextColor(1);
2037     box2->SetTextSize(0.25);
2038     box2->SetFillColor(38);
2039     box2->Draw();
2040     };
2041     //
2042     pd1->cd();
2043     gStyle->SetOptStat(0);
2044     Xview->SetXTitle("strip");
2045     Xview->SetYTitle("X - plane");
2046     Xview->GetYaxis()->SetTitleOffset(0.5);
2047     Xview->SetFillColor(bgcolor);
2048     Xview->Fill(1.,1.,1.);
2049     Xview->Draw("box");
2050     pd1->Update();
2051     pd2->cd();
2052     gStyle->SetOptStat(0);
2053     Yview->SetXTitle("strip");
2054     Yview->SetYTitle("Y - plane");
2055     Yview->GetYaxis()->SetTitleOffset(0.5);
2056     Yview->SetFillColor(bgcolor);
2057     Yview->Fill(1.,1.,1.);
2058     Yview->Draw("box");
2059     pd2->Update();
2060     //
2061     // run over views and planes
2062     //
2063     stringstream xview;
2064     stringstream yview;
2065     for (Int_t m = 0; m < 22; m++){
2066     for (Int_t l = 0; l < 2; l++){
2067     for (Int_t n = 0; n < 96; n++){
2068     xview.str("");
2069     xview << "x-view event " << n;
2070     xview << " " << m;
2071     xview << " " << l;
2072     yview.str("");
2073     yview << "y-view event " << n;
2074     yview << " " << m;
2075     yview << " " << l;
2076     gDirectory->Delete(xview.str().c_str());
2077     gDirectory->Delete(yview.str().c_str());
2078     TH2F *Xview = new TH2F(xview.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
2079     TH2F *Yview = new TH2F(yview.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
2080     if ( !strcmp(style2,"error") ){
2081     if ( calo->fpe[1][l][m][n] < 0.15 ){
2082     Xview->SetFillColor(38);
2083     Yview->SetFillColor(38);
2084     };
2085     if ( calo->fpe[1][l][m][n] >= 0.15 ){
2086     Xview->SetFillColor(4);
2087     Yview->SetFillColor(4);
2088     };
2089     if ( calo->fpe[1][l][m][n] >= 0.25){
2090     Xview->SetFillColor(3);
2091     Yview->SetFillColor(3);
2092     };
2093     if ( calo->fpe[1][l][m][n] >= 0.55 ){
2094     Xview->SetFillColor(2);
2095     Yview->SetFillColor(2);
2096     };
2097     if ( calo->fpe[1][l][m][n] >= 1. ){
2098     Xview->SetFillColor(6);
2099     Yview->SetFillColor(6);
2100     };
2101     if ( calo->fpe[1][l][m][n] >= 5. ){
2102     Xview->SetFillColor(1);
2103     Yview->SetFillColor(1);
2104     };
2105     if ( calo->mip[l][m][n] < 15. || calo->mip[l][m][n] > 40. ){
2106     Xview->SetFillColor(10);
2107     Yview->SetFillColor(10);
2108     };
2109     } else {
2110     if ( calo->mask[l][m][n] == 1 ){
2111     Xview->SetFillColor(38);
2112     Yview->SetFillColor(38);
2113     } else {
2114     Xview->SetFillColor(10);
2115     Yview->SetFillColor(10);
2116     };
2117     };
2118     if ( l == 0 ) {
2119     Xview->Fill(n,m,1.);
2120     pd1->cd();
2121     Xview->Draw("box same");
2122     };
2123     if ( l == 1 ) {
2124     Yview->Fill(n,m,1.);
2125     pd2->cd();
2126     Yview->Draw("box same");
2127     };
2128     };
2129     };
2130     };
2131     figura2->cd();
2132     gStyle->SetOptDate(1);
2133     //
2134     t=new TLatex();
2135     t->SetTextFont(32);
2136     t->SetTextColor(8);
2137     t->SetTextAlign(12);
2138     t->SetTextSize(0.02);
2139     figura2->Update();
2140     pd1->Update();
2141     pd2->Update();
2142     //
2143     }
2144    
2145     void FCalo4224FIT(TString filename = "", TString OutDir="", TString filevalue = "", TString type=""){
2146     const char *pam_calib = pathtocalibration();
2147     if ( !strcmp(OutDir.Data(),"") ){
2148     OutDir=pam_calib;
2149     };
2150     //
2151     // this routine shows the 4224 figures with fit from the main program
2152     //
2153     const char* startingdir = gSystem->WorkingDirectory();
2154     stringstream filenome;
2155     filenome.str("");
2156     if ( filename == "" ){
2157     filenome << OutDir.Data() << "/CaloADC2MIPf.root";
2158     filename = (TString)filenome.str().c_str();
2159     filenome.str("");
2160     };
2161     if ( filevalue == "" ){
2162     filenome.str("");
2163     filenome << OutDir.Data() << "/CaloADC2MIP.root";
2164     } else {
2165     filenome << filevalue.Data();
2166     };
2167     // EM
2168     const char *file2;
2169     file2 = filenome.str().c_str();
2170     TFile *hfile = 0;
2171     hfile = new TFile(file2,"UPDATE","Calorimeter CALIBRATION data");
2172     CalorimeterCalibration *calo = 0;
2173     TTree *tree;
2174     tree = (TTree*)hfile->Get("CaloADC");
2175     tree->SetBranchAddress("Event", &calo);
2176     Long64_t nevents = tree->GetEntries();
2177     tree->GetEntry(nevents-1);
2178     // EM end
2179     //
2180     const char *file = filename;
2181     stringstream file3;
2182     file3.str("");
2183     // file3 << OutDir.Data() << "/";
2184     file3 << file;
2185     TFile hfile3(file3.str().c_str());
2186     Int_t l = 0;
2187     TCanvas *c1;
2188     Int_t ty = 1;
2189     if ( type != "" ) ty = 0;
2190     c1 = new TCanvas("canvas","canvas",800,800);
2191     c1->Draw();
2192     gStyle->SetOptFit(111);
2193     gPad->SetLogy();
2194     gPad->SetTickx();
2195     gPad->SetTicky();
2196     gPad->SetGrid();
2197     Int_t j = -1;
2198     Int_t k = -1;
2199     Int_t h = -1;;
2200     Int_t changed = 0;
2201     beginning:
2202     if ( j >= 0 ) l = j;
2203     stringstream fmippa;
2204     TF1 *tempf = 0;
2205     TH1F *temp;
2206     while ( l < 2){
2207     Int_t m = 0;
2208     if ( k >= 0 ) m = k;
2209     while ( m < 22 ){
2210     Int_t n =0 ;
2211     if ( h >= 0 ) n = h;
2212     while ( n < 96 ){
2213     c1->Clear();
2214     c1->cd();
2215     fmippa.str("");
2216     fmippa << "fmip " << l;
2217     fmippa << " " << m;
2218     fmippa << " " << n;
2219     temp = (TH1F*)hfile3.Get(fmippa.str().c_str());
2220     if ( ty ) {
2221     fmippa.str("");
2222     fmippa << "fit " << l;
2223     fmippa << " " << m;
2224     fmippa << " " << n;
2225     tempf = (TF1*)hfile3.Get(fmippa.str().c_str());
2226     };
2227     j = -1;
2228     k = -1;
2229     h = -1;
2230     temp->DrawCopy();
2231     if ( ty ) tempf->DrawCopy("lsame");
2232     c1->Update();
2233     //
2234     //
2235     //
2236     printf(" **** STRIP: %i %i %i **** \n",l,m,n);
2237     printf(" MIP: %f \n",calo->mip[l][m][n]);
2238     printf(" ERMIP: %f \n",calo->ermip[l][m][n]);
2239     printf(" FP[0-3]: %f / %f / %f / %f \n",calo->fp[0][l][m][n],calo->fp[1][l][m][n],calo->fp[2][l][m][n],calo->fp[3][l][m][n]);
2240     printf(" FPE[0-3]: %f / %f / %f / %f \n",calo->fpe[0][l][m][n],calo->fpe[1][l][m][n],calo->fpe[2][l][m][n],calo->fpe[3][l][m][n]);
2241     printf(" CHI2: %f \n",calo->chi2[l][m][n]);
2242     printf(" NDF: %f \n",calo->ndf[l][m][n]);
2243     printf(" MASK: %f \n",calo->mask[l][m][n]);
2244     //
2245     // what to do?
2246     //
2247     char tellme[256];
2248     char tellme2[256];
2249     stringstream input;
2250     stringstream input2;
2251     stringstream out;
2252     stringstream stc;
2253     input.str("a");
2254     out.str("a");
2255     while ( !strcmp(input.str().c_str(),out.str().c_str()) ) {
2256     printf("\nPress <enter> to continue, b<enter> to go backward, j<enter> to jump to a\nfigure, p<enter> to save the figure, f<enter> to do the fit, q<enter> to quit: \n");
2257     cin.getline(tellme,256);
2258     input.str("");
2259     input << tellme;
2260     out.str("1");
2261     //
2262     stc.str("f");
2263     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2264     printf("\n Do you want to give a number by hand, h<enter>, or do you want to try a better fit, f<enter>?");
2265     cin.getline(tellme,256);
2266     input.str("");
2267     input << tellme;
2268     out.str("f");
2269     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2270     Double_t fr[2],vtemp;
2271     Double_t sv[4], pllo[4], plhi[4], ffp[4], ffpe[4];
2272     for ( Int_t fk = 0; fk < 4; fk++){
2273     sv[fk] = (int)calo->fp[fk][l][m][n];
2274     printf(" Give input parameter [fp[%i]=%f] \n",fk,sv[fk]);
2275     cin.getline(tellme2,256);
2276     input2.str("");
2277     input2 << tellme2;
2278     vtemp = (Double_t)atoi(input2.str().c_str());
2279     if ( vtemp != 0. ) sv[fk] = vtemp;
2280     printf(" -> fp[%i] = %f \n\n",fk,sv[fk]);
2281     };
2282     printf(" Give lower limit of fitting range fr[0] \n");
2283     cin.getline(tellme2,256);
2284     input2.str("");
2285     input2 << tellme2;
2286     fr[0] = (Double_t)atoi(input2.str().c_str());
2287     printf(" -> fr[0] = %f \n\n",fr[0]);
2288     printf(" Give upper limit of fitting range fr[1] \n");
2289     cin.getline(tellme2,256);
2290     input2.str("");
2291     input2 << tellme2;
2292     fr[1] = (Double_t)atoi(input2.str().c_str());
2293     printf(" -> fr[1] = %f \n",fr[1]);
2294     pllo[0]=0.5; pllo[1]=5.0; pllo[2]=1.0; pllo[3]=0.2;
2295     plhi[0]=8.0; plhi[1]=50.0; plhi[2]=1000000.0; plhi[3]=8.0;
2296     Double_t chisqr;
2297     Int_t fndf;
2298     //
2299     // fit the figure pfmip and put fit results in pfitsnr
2300     //
2301     tempf = langaufit(temp,fr,sv,pllo,plhi,ffp,ffpe,&chisqr,&fndf,"R0");
2302     Double_t SNRPeak = langaupro(ffp);
2303     printf("\n Conversion factor: %f \n",SNRPeak);
2304     tempf->DrawCopy("lsame");
2305     c1->Update();
2306     c1->Modified();
2307     c1->Update();
2308     printf(" Do you want to save this result y/n<enter> ?\n");
2309     cin.getline(tellme,256);
2310     input.str("");
2311     input << tellme;
2312     out.str("y");
2313     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2314     calo->mip[l][m][n] = (float)SNRPeak;
2315     calo->ermip[l][m][n] = (float)ffpe[1];
2316     for (Int_t a = 0; a < 4 ; a++){
2317     calo->fp[a][l][m][n] = (float)ffp[a];
2318     calo->fpe[a][l][m][n] = (float)ffpe[a];
2319     };
2320     calo->ndf[l][m][n] = (float)fndf;
2321     calo->chi2[l][m][n] = (float)chisqr;
2322     //
2323     if ( fndf!=0 && (float)chisqr/(float)fndf < 2. && ffpe[1] < 0.15 && ffp[1] > 15. && ffp[1] < 40. ) {
2324     calo->mask[l][m][n] = 1.;
2325     } else {
2326     calo->mask[l][m][n] = 0.;
2327     };
2328     printf(" Saved! \n");
2329     changed = 1;
2330     };
2331     } else {
2332     printf(" Give the MIP conversion value \n");
2333     cin.getline(tellme2,256);
2334     input2.str("");
2335     input2 << tellme2;
2336     calo->mip[l][m][n] = (Float_t)atoi(input2.str().c_str());
2337     printf(" -> mip = %f \n",calo->mip[l][m][n]);
2338     printf(" Give the mask value \n");
2339     cin.getline(tellme2,256);
2340     input2.str("");
2341     input2 << tellme2;
2342     calo->mask[l][m][n] = (Float_t)atoi(input2.str().c_str());
2343     printf(" -> mask = %f \n",calo->mask[l][m][n]);
2344     changed = 1;
2345     };
2346     out.str("");
2347     out << input.str().c_str();
2348     };
2349     stc.str("b");
2350     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2351     if ( n > 0 ) {
2352     printf("WARNING: going one figure backward!\n\n");
2353     n -= 2;
2354     } else {
2355     printf("This is the first strip of plane, you can't go backward! \n");
2356     out.str("");
2357     out << input.str().c_str();
2358     };
2359     };
2360     stc.str("j");
2361     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2362     printf("\n Enter the view number you want to jump to (0 = x, 1 = y): ");
2363     cin.getline(tellme2,256);
2364     input2.str("");
2365     input2 << tellme2;
2366     j = atoi(input2.str().c_str());
2367     if ( j < 0 || j > 1 ) {
2368     printf("\n You can choose between 0 and 1 \n");
2369     out.str("");
2370     out << input.str().c_str();
2371     } else {
2372     printf("\n Enter the plane number you want to jump to (0 to 21): ");
2373     cin.getline(tellme2,256);
2374     input2.str("");
2375     input2 << tellme2;
2376     k = atoi(input2.str().c_str());
2377     if ( k < 0 || k > 21 ) {
2378     printf("\n You can choose between 0 and 21 \n");
2379     out.str("");
2380     out << input.str().c_str();
2381     } else {
2382     printf("\n Enter the strip number you want to jump to (0 to 95): ");
2383     cin.getline(tellme2,256);
2384     input2.str("");
2385     input2 << tellme2;
2386     h = atoi(input2.str().c_str());
2387     if ( h < 0 || h > 95 ) {
2388     printf("\n You can choose between 0 and 95 \n");
2389     out.str("");
2390     out << input.str().c_str();
2391     } else {
2392     printf("\n Jumping to strip %i %i %i \n\n",j,k,h);
2393     goto beginning;
2394     };
2395     };
2396     };
2397     };
2398     //
2399     stc.str("q");
2400     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2401     printf("Exiting...\n");
2402     goto end;
2403     };
2404     //
2405     stc.str("p");
2406     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2407     printf("Enter a file extension recognized by ROOT (ps, eps, gif,...):\n");
2408     cin.getline(tellme2,256);
2409     input2.str("");
2410     input2 << tellme2;
2411     out.str("");
2412     out << input.str().c_str();
2413     stringstream figsave;
2414     figsave.str("");
2415     figsave << startingdir << "/mip2adc_";
2416     figsave << l << "_";
2417     figsave << m << "_";
2418     figsave << n << ".";
2419     figsave << input2.str().c_str();
2420     c1->SaveAs(figsave.str().c_str());
2421     printf("\n");
2422     };
2423     };
2424     n++;
2425     };
2426     m++;
2427     };
2428     l++;
2429     };
2430     end: printf("\n");
2431     if ( changed ){
2432     tree->Fill();
2433     hfile->Write();
2434     };
2435     hfile->Close();
2436     }
2437    
2438     void FCalo4224MIPVALUES(TString filevalue = "", TString type=""){
2439     const char* startingdir = gSystem->WorkingDirectory();
2440     const char *pam_calib = pathtocalibration();
2441     //
2442     // this routine shows the 4224 figures with fit from the main program
2443     //
2444     stringstream filenome;
2445     filenome.str("");
2446     if ( filevalue == "" ){
2447     filenome << pam_calib << "/CaloADC2MIP.root";
2448     } else {
2449     filenome << filevalue.Data();
2450     };
2451     // EM
2452     const char *file2;
2453     file2 = filenome.str().c_str();
2454     TFile *hfile = 0;
2455     hfile = new TFile(file2,"READ","Calorimeter CALIBRATION data");
2456     CalorimeterCalibration *calo = 0;
2457     TTree *tree;
2458     tree = (TTree*)hfile->Get("CaloADC");
2459     tree->SetBranchAddress("Event", &calo);
2460     Long64_t nevents = tree->GetEntries();
2461     tree->GetEntry(nevents-1);
2462     // EM end
2463     //
2464     TCanvas *c1;
2465     Int_t ty = 1;
2466     if ( type != "" ) ty = 0;
2467     c1 = new TCanvas("canvas","canvas",1200,800);
2468     c1->Draw();
2469     gStyle->SetOptFit(111);
2470     gPad->SetTickx();
2471     gPad->SetTicky();
2472     Int_t k = -1;
2473     Int_t changed = 0;
2474     Float_t mipf[1]={0};
2475     Float_t val[1]={0};
2476     TLatex *text=new TLatex();
2477     TLine *linea;
2478     stringstream testo;
2479     beginning:
2480     Int_t m = 0;
2481     if ( k >= 0 ) m = k;
2482     while ( m < 22 ){
2483     Int_t l = 0;
2484     c1->Clear();
2485     c1->cd();
2486     TMultiGraph *mg = new TMultiGraph();
2487     while ( l < 2){
2488     Int_t n = 0;
2489     while ( n < 96 ){
2490     val[0] = (float)n + 100.*(float)l ;
2491     mipf[0] = (float)calo->mip[l][m][n];
2492     TGraph *graph = new TGraph(1, val, mipf);
2493     graph->SetMarkerColor(2);
2494     graph->SetMarkerStyle(22+l);
2495     graph->SetMarkerSize(0.7);
2496     mg->Add(graph);
2497     printf(" **** STRIP: %i %i %i **** \n",l,m,n);
2498     printf(" MIP: %f \n",calo->mip[l][m][n]);
2499     printf(" ERMIP: %f \n",calo->ermip[l][m][n]);
2500     printf(" FP[0-3]: %f / %f / %f / %f \n",calo->fp[0][l][m][n],calo->fp[1][l][m][n],calo->fp[2][l][m][n],calo->fp[3][l][m][n]);
2501     printf(" FPE[0-3]: %f / %f / %f / %f \n",calo->fpe[0][l][m][n],calo->fpe[1][l][m][n],calo->fpe[2][l][m][n],calo->fpe[3][l][m][n]);
2502     printf(" CHI2: %f \n",calo->chi2[l][m][n]);
2503     printf(" NDF: %f \n",calo->ndf[l][m][n]);
2504     printf(" MASK: %f \n",calo->mask[l][m][n]);
2505     n++;
2506     };
2507     l++;
2508     };
2509     mg->SetMaximum(50.);
2510     mg->SetMinimum(0.);
2511     mg->Draw("AP");
2512     for (Int_t e = 0; e<2 ; e++){
2513     for (Int_t ep = 0; ep<96 ; ep++){
2514     if ( ep%16 == 0 ) {
2515     linea = new TLine((float)ep+100.*(float)e,0.,(float)ep+100.*(float)e,50.);
2516     linea->SetLineColor(15);
2517     linea->SetLineStyle(2);
2518     linea->SetLineWidth(1);
2519     linea->Draw("lsame");
2520     if ( ep > 0 ){
2521     linea = new TLine((float)ep-1.+100.*(float)e,0.,(float)ep-1.+100.*(float)e,50.);
2522     linea->SetLineColor(15);
2523     linea->SetLineStyle(2);
2524     linea->SetLineWidth(1);
2525     linea->Draw("lsame");
2526     };
2527     };
2528     if ( ep == 95 ){
2529     linea = new TLine(95.+100.*(float)e,0.,95.+100.*(float)e,50.);
2530     linea->SetLineColor(15);
2531     linea->SetLineStyle(2);
2532     linea->SetLineWidth(1);
2533     linea->Draw("lsame");
2534     };
2535     };
2536     };
2537     text->SetTextAngle(0);
2538     text->SetTextFont(32);
2539     text->SetTextColor(1);
2540     text->SetTextSize(0.050);
2541     text->SetTextAlign(12);
2542     testo.str("");
2543     testo << "Plane " << m;
2544     text->DrawLatex(85.,52.,testo.str().c_str());
2545     c1->Update();
2546     //
2547     // what to do?
2548     //
2549    
2550     char tellme[256];
2551     char tellme2[256];
2552     stringstream input;
2553     stringstream input2;
2554     stringstream out;
2555     stringstream stc;
2556     input.str("a");
2557     out.str("a");
2558     while ( !strcmp(input.str().c_str(),out.str().c_str()) ) {
2559     printf("\nPress <enter> to continue, b<enter> to go backward, j<enter> to jump to a\nfigure, p<enter> to save the figure, q<enter> to quit: \n");
2560     cin.getline(tellme,256);
2561     input.str("");
2562     input << tellme;
2563     out.str("1");
2564     //
2565     stc.str("b");
2566     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2567     if ( m > 0 ) {
2568     printf("WARNING: going one figure backward!\n\n");
2569     m -= 2;
2570     } else {
2571     printf("This is the first plane, you can't go backward! \n");
2572     out.str("");
2573     out << input.str().c_str();
2574     };
2575     };
2576     stc.str("j");
2577     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2578     printf("\n Enter the plane number you want to jump to (0 to 21): ");
2579     cin.getline(tellme2,256);
2580     input2.str("");
2581     input2 << tellme2;
2582     k = atoi(input2.str().c_str());
2583     if ( k < 0 || k > 21 ) {
2584     printf("\n You can choose between 0 and 21 \n");
2585     out.str("");
2586     out << input.str().c_str();
2587     } else {
2588     printf("\n Jumping to plane %i \n\n",k);
2589     m = k;
2590     goto beginning;
2591     };
2592     };
2593     //
2594     stc.str("q");
2595     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2596     printf("Exiting...\n");
2597     goto end;
2598     };
2599     //
2600     stc.str("p");
2601     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2602     printf("Enter a file extension recognized by ROOT (ps, eps, gif,...):\n");
2603     cin.getline(tellme2,256);
2604     input2.str("");
2605     input2 << tellme2;
2606     out.str("");
2607     out << input.str().c_str();
2608     stringstream figsave;
2609     figsave.str("");
2610     figsave << startingdir << "/mip2adc_plane_";
2611     figsave << m << ".";
2612     figsave << input2.str().c_str();
2613     c1->SaveAs(figsave.str().c_str());
2614     printf("\n");
2615     };
2616     };
2617     m++;
2618     };
2619     end: printf("\n");
2620     if ( changed ){
2621     tree->Fill();
2622     hfile->Write();
2623     };
2624     hfile->Close();
2625     }
2626    
2627     void FCalo4224BAK(TString filename){
2628     //
2629     // this shows the 4224 figure from a backup file
2630     //
2631     const char* startingdir = gSystem->WorkingDirectory();
2632     const char *file3 = filename;
2633     TFile hfile3(file3);
2634     Int_t l = 0;
2635     TCanvas *c1;
2636     c1 = new TCanvas("canvas","canvas",800,800);
2637     c1->Draw();
2638     gStyle->SetOptFit(111);
2639     gPad->SetLogy();
2640     Int_t j = 0;
2641     Int_t k = 0;
2642     Int_t h = 0;
2643     beginning:
2644     if ( j ) l = j;
2645     stringstream bmippa;
2646     while ( l < 2){
2647     Int_t m = 0;
2648     if ( k ) m = k;
2649     while ( m < 22 ){
2650     Int_t n =0 ;
2651     if ( h ) n = h;
2652     while ( n < 96 ){
2653     c1->Clear();
2654     c1->cd();
2655     bmippa.str("");
2656     bmippa << "bmip " << l;
2657     bmippa << " " << m;
2658     bmippa << " " << n;
2659     TH1F *temp = (TH1F*)hfile3.Get(bmippa.str().c_str());
2660     j = 0;
2661     k = 0;
2662     h = 0;
2663     temp->DrawCopy();
2664     c1->Update();
2665     //
2666     // what to do?
2667     //
2668     char tellme[256];
2669     char tellme2[256];
2670     stringstream input;
2671     stringstream input2;
2672     stringstream out;
2673     stringstream stc;
2674     input.str("a");
2675     out.str("a");
2676     while ( !strcmp(input.str().c_str(),out.str().c_str()) ) {
2677     printf("\nPress <enter> to continue, b<enter> to go backward, j<enter> to jump to a\nfigure, p<enter> to save the figure, q<enter> to quit: \n");
2678     cin.getline(tellme,256);
2679     input.str("");
2680     input << tellme;
2681     out.str("1");
2682     //
2683     stc.str("b");
2684     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2685     if ( n > 0 ) {
2686     printf("WARNING: going one figure backward!\n\n");
2687     n -= 2;
2688     } else {
2689     printf("This is the first strip of plane, you can't go backward! \n");
2690     out.str("");
2691     out << input.str().c_str();
2692     };
2693     };
2694     stc.str("j");
2695     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2696     printf("\n Enter the view number you want to jump to (0 = x, 1 = y): ");
2697     cin.getline(tellme2,256);
2698     input2.str("");
2699     input2 << tellme2;
2700     j = atoi(input2.str().c_str());
2701     if ( j < 0 || j > 1 ) {
2702     printf("\n You can choose between 0 and 1 \n");
2703     out.str("");
2704     out << input.str().c_str();
2705     } else {
2706     printf("\n Enter the plane number you want to jump to (0 to 21): ");
2707     cin.getline(tellme2,256);
2708     input2.str("");
2709     input2 << tellme2;
2710     k = atoi(input2.str().c_str());
2711     if ( k < 0 || k > 21 ) {
2712     printf("\n You can choose between 0 and 21 \n");
2713     out.str("");
2714     out << input.str().c_str();
2715     } else {
2716     printf("\n Enter the strip number you want to jump to (0 to 95): ");
2717     cin.getline(tellme2,256);
2718     input2.str("");
2719     input2 << tellme2;
2720     h = atoi(input2.str().c_str());
2721     if ( h < 0 || h > 95 ) {
2722     printf("\n You can choose between 0 and 95 \n");
2723     out.str("");
2724     out << input.str().c_str();
2725     } else {
2726     printf("\n Jumping to strip %i %i %i \n\n",j,k,h);
2727     goto beginning;
2728     };
2729     };
2730     };
2731     };
2732     //
2733     stc.str("q");
2734     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2735     printf("Exiting...\n");
2736     goto end;
2737     };
2738     //
2739     stc.str("p");
2740     if ( !strcmp(input.str().c_str(),stc.str().c_str()) ) {
2741     printf("Enter a file extension recognized by ROOT (ps, eps, gif,...):\n");
2742     cin.getline(tellme2,256);
2743     input2.str("");
2744     input2 << tellme2;
2745     out.str("");
2746     out << input.str().c_str();
2747     stringstream figsave;
2748     figsave.str("");
2749     figsave << startingdir << "/mip2adcbak_";
2750     figsave << l << "_";
2751     figsave << m << "_";
2752     figsave << n << ".";
2753     figsave << input2.str().c_str();
2754     c1->SaveAs(figsave.str().c_str());
2755     printf("\n");
2756     };
2757     };
2758     n++;
2759     };
2760     m++;
2761     };
2762     l++;
2763     };
2764     end: printf("\n");
2765     }
2766    
2767     void FCaloBAKFIT(TString filename, TString OutDir=""){
2768     const char *pam_calib = pathtocalibration();
2769     if ( !strcmp(OutDir.Data(),"") ){
2770     OutDir = pam_calib;
2771     };
2772     //
2773     // this routine perform the 4224 fit on a backup figure file and save - with extension .bak - the two output file
2774     // in the correct format, ready to be updated etc. etc.
2775     // NB: you will LOSE information about used files
2776     //
2777     stringstream file2;
2778     file2.str("");
2779     file2 << OutDir.Data() << "/CaloADC2MIP.bak";
2780     stringstream file4;
2781     file4.str("");
2782     file4 << OutDir.Data() << "/CaloADC2MIPf.bak";
2783     //
2784     Int_t notgood = 0;
2785     //
2786     TFile *hfile = 0;
2787     CalorimeterCalibration *calo = new CalorimeterCalibration();
2788     hfile = new TFile(file2.str().c_str(),"RECREATE","Calorimeter CALIBRATION data");
2789     if ( !existfile(file2.str().c_str()) ){
2790     printf(" ERROR: Cannot create file!!! \n");
2791     return;
2792     };
2793     TTree *tree = 0;
2794     tree = new TTree("CaloADC","Calorimeter calibration data");
2795     tree->Branch("Event","CalorimeterCalibration",&calo);
2796     //
2797     const char *file3 = filename;
2798     TFile hfile3(file3);
2799     TCanvas *c1;
2800     c1 = new TCanvas("canvas","canvas",800,800);
2801     c1->Draw();
2802     gStyle->SetOptFit(111);
2803     TH1F *pfmip[2][22][96];
2804     TF1 *pfitsnr[2][22][96];
2805     stringstream Fmip;
2806     for (Int_t i=0; i<2;i++){
2807     for (Int_t j=0; j<22;j++){
2808     for (Int_t m=0; m<96;m++){
2809     Fmip.str("");
2810     Fmip << "Fmip " << i;
2811     Fmip << " " << j;
2812     Fmip << " " << m;
2813     pfmip[i][j][m] = new TH1F(Fmip.str().c_str(),"",56,0.,55.);
2814     pfitsnr[i][j][m] = new TF1;
2815     };
2816     };
2817     };
2818     gStyle->SetOptFit(111);
2819     gPad->SetLogy();
2820     //
2821     Int_t l = 0;
2822     stringstream bmippa;
2823     while ( l < 2){
2824     Int_t m = 0;
2825     while ( m < 22 ){
2826     Int_t n =0 ;
2827     Double_t SNRPeak = 0.;
2828     while ( n < 96 ){
2829     c1->Clear();
2830     c1->cd();
2831     bmippa.str("");
2832     bmippa << "bmip " << l;
2833     bmippa << " " << m;
2834     bmippa << " " << n;
2835     TH1F *temp = (TH1F*)hfile3.Get(bmippa.str().c_str());
2836     bmippa.str("");
2837     bmippa << "fmip " << l;
2838     bmippa << " " << m;
2839     bmippa << " " << n;
2840     pfmip[l][m][n] = (TH1F*)temp->Clone(bmippa.str().c_str());
2841     Int_t doitagain = 0;
2842     Double_t fr[2];
2843     Double_t sv[4], pllo[4], plhi[4], fp[4], fpe[4];
2844     if ( SNRPeak > 16. && SNRPeak < 35. ){
2845     fr[0] = (Float_t)SNRPeak - 7.;
2846     sv[0]= fp[0];
2847     sv[1]= fp[1];
2848     sv[2]= fp[2];
2849     sv[3]= fp[3];
2850     } else {
2851     fr[0] = 19.;
2852     sv[0] = 2.8;
2853     sv[1] = 21.0;
2854     sv[2] = 1000.0;
2855     sv[3] = 0.1;
2856     };
2857     fitting: printf("Fitting strip %i %i %i \n",l,m,n);
2858     fr[1] = 60.;
2859     pllo[0]=0.5; pllo[1]=5.0; pllo[2]=1.0; pllo[3]=0.2;
2860     plhi[0]=8.0; plhi[1]=50.0; plhi[2]=1000000.0; plhi[3]=8.0;
2861     Double_t chisqr;
2862     Int_t ndf;
2863     pfitsnr[l][m][n] = langaufit(pfmip[l][m][n],fr,sv,pllo,plhi,fp,fpe,&chisqr,&ndf,"QR0");
2864     //
2865     Double_t SNRPeak = langaupro(fp);
2866     printf("\n Conversion factor: %f \n\n",SNRPeak);
2867     //
2868     //
2869     //
2870     if ( (SNRPeak<0. || (SNRPeak < 16. || SNRPeak > 35.) || chisqr > 100.) && doitagain < 3 ){
2871     printf("\n The fit is not good, I will try again, step %i \n\n",doitagain);
2872     doitagain++;
2873     if ( chisqr > 100. ) {
2874     fr[0] = fr[0] + 5.;
2875     sv[0] = fp[0];
2876     sv[1] = fp[1];
2877     sv[2] = fp[2];
2878     sv[3] = fp[3];
2879     goto fitting;
2880     };
2881     if ( doitagain == 1 ) {
2882     fr[0] = 19.;
2883     sv[0] = 2.8;
2884     sv[1] = 21.0;
2885     sv[2] = 1000.0;
2886     sv[3] = 0.1;
2887     goto fitting;
2888     };
2889     if ( doitagain == 2 ) {
2890     fr[0] = 22.;
2891     sv[0] = 2.8;
2892     sv[1] = 25.0;
2893     sv[2] = 1000.0;
2894     sv[3] = 0.1;
2895     goto fitting;
2896     };
2897     if ( doitagain == 3 ) {
2898     fr[0] = 12.;
2899     sv[0] = 2.8;
2900     sv[1] = 15.0;
2901     sv[2] = 1000.0;
2902     sv[3] = 0.1;
2903     goto fitting;
2904     };
2905     };
2906     //
2907     calo->mip[l][m][n] = (float)SNRPeak;
2908     calo->ermip[l][m][n] = (float)fpe[1];
2909     for (Int_t a = 0; a < 4 ; a++){
2910     calo->fp[a][l][m][n] = (float)fp[a];
2911     calo->fpe[a][l][m][n] = (float)fpe[a];
2912     };
2913     calo->ndf[l][m][n] = (float)ndf;
2914     calo->chi2[l][m][n] = (float)chisqr;
2915     //
2916     if ( ndf!=0 && chisqr/ndf < 2. && fpe[1] < 0.15 && fp[1] > 15. && fp[1] < 40. && SNRPeak > 0. ) {
2917     printf("\n THIS IS A GOOD FIT, SAVED! \n\n");
2918     calo->mask[l][m][n] = 1.;
2919     } else {
2920     notgood++;
2921     calo->mask[l][m][n] = 0.;
2922     };
2923     printf("Fitting done, strip %i %i %i \n\n\n",l,m,n);
2924     c1->cd();
2925     pfmip[l][m][n]->DrawCopy();
2926     pfitsnr[l][m][n]->DrawCopy("lsame");
2927     c1->Modified();
2928     c1->Update();
2929     n++;
2930     };
2931     m++;
2932     };
2933     l++;
2934     };
2935     //
2936     calo->status = 0;
2937     if ( !notgood ) calo->status = 1;
2938     //
2939     tree->Fill();
2940     hfile->Write();
2941     hfile->Close();
2942     //
2943     // Save histograms
2944     //
2945     TFile *hfile2;
2946     hfile2 = new TFile(file4.str().c_str(),"RECREATE","Calorimeter CALIBRATION figures");
2947     if ( !existfile(file4.str().c_str()) ){
2948     printf(" ERROR: Cannot create file!!! \n");
2949     return;
2950     };
2951     TH1F *sfmip[2][22][96];
2952     TF1 *sfitsnr[2][22][96];
2953     stringstream fmipfi;
2954     for (Int_t l = 0; l < 2; l++){
2955     for (Int_t m = 0; m < 22; m++){
2956     for (Int_t n =0 ; n < 96; n++){
2957     fmipfi.str("");
2958     fmipfi << "fmip " << l;
2959     fmipfi << " " << m;
2960     fmipfi << " " << n;
2961     sfmip[l][m][n] = new TH1F(fmipfi.str().c_str(),"",56,0.,55.);
2962     sfmip[l][m][n] = (TH1F*)pfmip[l][m][n]->Clone(fmipfi.str().c_str());
2963     fmipfi.str("");
2964     fmipfi << "fit " << l;
2965     fmipfi << " " << m;
2966     fmipfi << " " << n;
2967     sfitsnr[l][m][n] = (TF1*)pfitsnr[l][m][n]->Clone(fmipfi.str().c_str());
2968     sfmip[l][m][n]->Write();
2969     sfitsnr[l][m][n]->Write();
2970     };
2971     };
2972     };
2973     hfile2->Close();
2974     printf("\n");
2975     hfile3.Close();
2976     FCalo4224STATUS("CaloADC2MIP.bak","");
2977     }
2978    
2979     void FCaloROOT2TXT(TString rootple, TString txtple){
2980     FILE *f;
2981     f = fopen(txtple.Data(),"wb");
2982     TTree *ctree = 0;
2983     TFile *chfile;
2984     CalorimeterCalibration *ccalo = new CalorimeterCalibration();
2985     chfile = new TFile(rootple.Data(),"READ","Calorimeter CALIBRATION data");
2986     if ( chfile->IsZombie() ){
2987     printf(" ERROR: no calorimeter calibration file! \n");
2988     } else {
2989     ctree = (TTree*)chfile->Get("CaloADC");
2990     ctree->SetBranchAddress("Event", &ccalo);
2991     //
2992     Long64_t cnevents = ctree->GetEntries();
2993     ctree->GetEntry(cnevents-1);
2994     };
2995     //
2996     Float_t mip = 0.;
2997     for (Int_t m = 0; m < 2 ; m++ ){
2998     for (Int_t k = 0; k < 22; k++ ){
2999     for (Int_t l = 0; l < 96; l++ ){
3000     mip = 0.;
3001     if ( (ccalo->fp[1][m][k][l] > 20. && ccalo->fp[1][m][k][l] < 32.) || ccalo->mask[m][k][l] == 1. ) {
3002     mip = ccalo->mip[m][k][l];
3003     } else {
3004     mip = 26. ;
3005     };
3006     if ( mip == 0 ) mip = 26. ;
3007     // if ( m == 1 && k == 17 ) printf(" %i mip = %f \n",l,mip);
3008     fwrite(&mip,sizeof(mip),1,f);
3009     };
3010     };
3011     };
3012     fclose(f);
3013     }
3014    
3015     void FCaloREADTXT(TString txtple){
3016     FILE *f;
3017     f = fopen(txtple.Data(),"rb");
3018     Float_t mip = 0.;
3019     for (Int_t m = 0; m < 2 ; m++ ){
3020     for (Int_t k = 0; k < 22; k++ ){
3021     for (Int_t l = 0; l < 96; l++ ){
3022     mip = 0.;
3023     fread(&mip,sizeof(mip),1,f);
3024     // if ( m == 1 && k == 17 ) printf(" %i mip = %f \n",l,mip);
3025     };
3026     };
3027     };
3028     fclose(f);
3029     }

  ViewVC Help
Powered by ViewVC 1.1.23