/[PAMELA software]/eventviewer/flight/src/FEVdetector.cpp
ViewVC logotype

Diff of /eventviewer/flight/src/FEVdetector.cpp

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.4 by mocchiut, Tue Nov 28 14:05:51 2006 UTC revision 1.25 by mocchiut, Thu Nov 29 15:53:10 2007 UTC
# Line 46  char* operator+( std::streampos&, char* Line 46  char* operator+( std::streampos&, char*
46  #include <TEllipse.h>  #include <TEllipse.h>
47  #include <TArrow.h>  #include <TArrow.h>
48  #include <TStyle.h>  #include <TStyle.h>
49    #include <TStreamerElement.h>
50    #include <TRealData.h>
51  //  //
52  #include <PamelaRun.h>  #include <PamelaRun.h>
53  #include <physics/calorimeter/CalorimeterEvent.h>  #include <physics/calorimeter/CalorimeterEvent.h>
# Line 67  char* operator+( std::streampos&, char* Line 69  char* operator+( std::streampos&, char*
69  #include <FEVdetector.h>  #include <FEVdetector.h>
70  #include <FEventViewer.h>  #include <FEventViewer.h>
71  #include <feventvstruct.h>  #include <feventvstruct.h>
72    #include <color.h>
73  //  //
74  extern Bool_t existfile(TString);  extern Bool_t existfile(TString);
75  //  //
# Line 80  FEVdetector::FEVdetector(TString filenam Line 83  FEVdetector::FEVdetector(TString filenam
83    thefigure = &figure;    thefigure = &figure;
84    checkctrlword();    checkctrlword();
85    var.selex = false;    var.selex = false;
86      var.showall = false;
87    
88      var.showsi = false;
89      var.shownd = false;
90      var.shows4 = false;
91      var.showorb = false;
92      var.showtof = false;
93      var.showtrg = false;
94      var.showtrk = false;
95      var.showcal = false;
96      var.showrun = false;
97      var.showac = false;
98  }  }
99    
100  void FEVdetector::checkctrlword(){  void FEVdetector::checkctrlword(){
101    var.SHOWDEC = 0;    var.SHOWDEC = 0;
102    var.TOF = 0;    var.TOF = 0;
103    var.AC = 0;    var.AC = 0;
104      var.RUN = 1;
105    var.TRK = 0;    var.TRK = 0;
106      var.ORB = 1;
107      var.TRG = 1;
108    var.CALO = 0;    var.CALO = 0;
109      var.CALOT = 0;
110    var.S4 = 0;    var.S4 = 0;
111    var.ND = 0;    var.ND = 0;
112    var.INFOS = 0;    var.INFOS = 0;
# Line 122  void FEVdetector::checkctrlword(){ Line 141  void FEVdetector::checkctrlword(){
141    };    };
142  }  }
143    
144    void FEVdetector::SetDDEC(TString de){
145      ddec=de;
146    };
147    
148  void FEVdetector::GetWindow(){  void FEVdetector::GetWindow(){
149    otr->GetEntry(maxevent);    //
150      if ( level.file == 2 ){
151        //    printf("0qui\n");
152        L2->GetEntry(minevent);
153      } else {
154        otr->GetEntry(minevent);
155      }
156    if ( level.file < 2 ){    if ( level.file < 2 ){
157      ph = eh->GetPscuHeader();      ph = eh->GetPscuHeader();
158      lastevno = (int)ph->Counter;      firstevno = (int)ph->Counter;
159    } else {    } else {
160      lastevno = oinfoL2->pkt_num; // to be changed as soon as we will have pkt_counter in the level2 file!      if ( var.ORB ){
161          firstevno = L2->GetOrbitalInfo()->pkt_num;
162        } else {
163          firstevno = 0;
164        };
165    };    };
166    otr->GetEntry(minevent);    //
167      if ( level.file == 2 ){
168        //    printf("1qui\n");
169        L2->GetEntry(maxevent);
170      } else {
171        otr->GetEntry(maxevent);
172      }
173      //
174    if ( level.file < 2 ){    if ( level.file < 2 ){
175      ph = eh->GetPscuHeader();      ph = eh->GetPscuHeader();
176      firstevno = (int)ph->Counter;      lastevno = (int)ph->Counter;
177    } else {    } else {
178      firstevno = oinfoL2->pkt_num; // to be changed as soon as we will have pkt_counter in the level2 file!      if ( var.ORB ){
179          lastevno = L2->GetOrbitalInfo()->pkt_num;
180        } else {
181          lastevno = 0;
182        };
183    };    };
184      //
185  }  }
186    
187  void FEVdetector::ClearVariables(){  void FEVdetector::ClearVariables(){
# Line 159  void FEVdetector::ClearVariables(){ Line 204  void FEVdetector::ClearVariables(){
204  }  }
205    
206  void FEVdetector::GetEntry(Int_t i){  void FEVdetector::GetEntry(Int_t i){
207    thisentry = i;    thisentry = i;  
208    otr->GetEntry(i);    if ( level.file == 2 ){
209        L2->Clear();
210        //    printf("qui\n");
211        L2->GetEntry(i);
212        if ( var.showall ){
213          ShowInfo("RunInfo");
214          ShowInfo("SoftInfo");
215          ShowInfo("OrbitalInfo");
216          ShowInfo("TrigLevel2");
217          ShowInfo("ToFLevel2");
218          ShowInfo("TrkLevel2");
219          ShowInfo("AcLevel2");
220          ShowInfo("CaloLevel2");
221          ShowInfo("CaloLevel1");
222          ShowInfo("S4Level2");
223          ShowInfo("NDLevel2");
224        } else {
225          if ( var.showrun ) ShowInfo("RunInfo");
226          if ( var.showsi ) ShowInfo("SoftInfo");
227          if ( var.showorb ) ShowInfo("OrbitalInfo");
228          if ( var.showtrg ) ShowInfo("TrigLevel2");
229          if ( var.showtof ) ShowInfo("ToFLevel2");
230          if ( var.showtrk ) ShowInfo("TrkLevel2");
231          if ( var.showac ) ShowInfo("AcLevel2");
232          if ( var.showcal ) ShowInfo("CaloLevel2");
233          if ( var.showcal ) ShowInfo("CaloLevel1");
234          if ( var.shows4 ) ShowInfo("S4Level2");
235          if ( var.shownd ) ShowInfo("NDLevel2");
236        };
237      } else {
238        otr->GetEntry(i);
239        if ( var.showall ){
240          ShowInfo("Pscu");
241          ShowInfo("Trigger");
242          ShowInfo("Tof");
243          ShowInfo("Tracker");
244          ShowInfo("Anticounter");
245          ShowInfo("Calorimeter");
246          ShowInfo("S4");
247          ShowInfo("Neutron");
248        } else {
249          if ( var.showorb ) ShowInfo("Pscu");
250          if ( var.showtrg ) ShowInfo("Trigger");
251          if ( var.showtof ) ShowInfo("Tof");
252          if ( var.showtrk ) ShowInfo("Tracker");
253          if ( var.showac ) ShowInfo("Anticounter");
254          if ( var.showcal ) ShowInfo("Calorimeter");
255          if ( var.shows4 ) ShowInfo("S4");
256          if ( var.shownd ) ShowInfo("Neutron");
257        };
258      };
259  }  }
260    
261  void FEVdetector::SetEntry(Int_t i){  void FEVdetector::SetEntry(Int_t i){
# Line 173  int FEVdetector::GetCounter(){ Line 268  int FEVdetector::GetCounter(){
268      return((int)ph->Counter);      return((int)ph->Counter);
269    } else {    } else {
270      //    return(thisentry); // to be changed as soon as we will have pkt_counter in the level2 file!      //    return(thisentry); // to be changed as soon as we will have pkt_counter in the level2 file!
271      return((int)oinfoL2->pkt_num); // to be changed as soon as we will have pkt_counter in the level2 file!      return((int)L2->GetOrbitalInfo()->pkt_num); // to be changed as soon as we will have pkt_counter in the level2 file!
272    };    };
273  }  }
274    
# Line 281  void FEVdetector::ColorTRKMIP(Float_t mi Line 376  void FEVdetector::ColorTRKMIP(Float_t mi
376    };    };
377  }  }
378    
379    void FEVdetector::ShowInfo(TString detector){
380      //
381      TBranch *b1 = 0;
382      //  TBranch *b3 = 0;
383      TObjArray *branch_array = 0;
384      //  TObjArray *leaf_array = 0;                
385      //
386      if ( !strcmp(detector.Data(),"RunInfo") || !strcmp(detector.Data(),"SoftInfo") ){
387        if ( L2->GetRunTree() ) b1 = L2->GetRunTree()->FindBranch(detector.Data());
388      } else {
389        b1 = otr->FindBranch(detector.Data());
390      };
391      //
392      if ( !b1 ) return;
393      //
394      Int_t dlen = 10;
395      //
396      char o[200000];
397      char col[13];
398      char col2[13];
399      //
400      setcolor(col,RESET, GREEN, WHITE);
401      sprintf(o,"%s======> EVENT:%i\n",col, thisentry);
402      //
403      setcolor(col,RESET, RED, WHITE);
404      sprintf(o,"%s%sBranch %s\n",o,col,b1->GetName());
405      setcolor(col,RESET, BLACK, WHITE);
406      sprintf(o,"%s%s",o,col);
407      //
408      branch_array = b1->GetListOfBranches();
409      //
410      Int_t j = 0;
411      //
412      for(Int_t l=0;l<(branch_array->GetLast()+1);l++){
413        //
414        TBranchElement *tb = (TBranchElement*)branch_array->At(l);
415        Int_t type = tb->GetType();
416        Int_t atype = tb->GetStreamerType() - 20;
417        Int_t len = (tb->GetInfo()->GetLengths())[tb->GetID()];
418        Int_t length = min(len,dlen);
419        //
420        //        printf("Branches : type is %i type is %i tb getname %s  slen %i slength %i\n",atype,type,tb->GetName(),len,length);
421        switch (type){
422        case 0:
423          //      
424          // IS A VARIABLE
425          //
426          //
427          // NAME
428          //
429          setcolor(col,RESET, BLUE, WHITE);
430          setcolor(col2,RESET, BLACK, WHITE);
431          sprintf(o,"%s%s %-15s%s =",o,col,((TBranch*)branch_array->At(l))->GetName(),col2);
432          //
433          j = 0;
434          //
435          // VALUES
436          //
437          //
438          // Integer
439          //
440          if ( atype == 3 || atype == -17 ){
441            while ( j < length ){
442              if ( j < length -1 ){
443                sprintf(o,"%s %i ,",o,(Int_t)tb->GetValue(j,0));
444              } else {
445                sprintf(o,"%s %i",o,(Int_t)tb->GetValue(j,0));
446              };
447              j++;
448            };
449          };
450          //
451          // Unsigned integer
452          //
453          if ( atype == -7 || atype == 13 || atype == -9 || atype == -8 || atype == 12 ){
454            while ( j < length ){
455              if ( j < length -1 ){
456                sprintf(o,"%s %u ,",o,(UInt_t)tb->GetValue(j,0));
457              } else {
458                sprintf(o,"%s %u",o,(UInt_t)tb->GetValue(j,0));
459              };
460              j++;
461            };
462          };
463          //
464          // Float
465          //
466          if ( atype == -15 || atype == 5 ){
467            while ( j < length ){
468              if ( j < length -1 ){
469                sprintf(o,"%s %f ,",o,tb->GetValue(j,0));
470              } else {
471                sprintf(o,"%s %f",o,tb->GetValue(j,0));
472              };
473              j++;
474            };
475          };
476          //
477          // Strings
478          //
479          if ( atype == 45 ){
480            //      TObjArray *cl = (TObjArray*)(tb->GetInfo()->GetOffsets())[tb->GetID()];//tb->GetValuePointer();
481            //      TString *stringa = (TString*)(*cl)[0];  
482            //      TBranchElement *utb = (TBranchElement*)tb->GetBranchCount();
483            //      TString** stringa = (TString*)(&tb->GetValuePointer());
484            //TStreamerElement *tste = (TStreamerElement*)tb->GetInfo()->GetCurrentElement();
485    
486            //      char *ladd;
487            //      ladd = tb->GetValuePointer()
488            //      TString *stringa = (TString*)((tste->GetOffset()));
489            //      TString& mstr = *stringa;
490            //      printf(" la mia stringa %s \n",mstr.Data());
491            //      printf(" offset %i \n",(Int_t)utb->GetValue(0,0));
492            //      int pointer = (tb->GetInfo()->GetOffsets())[tb->GetID()];
493            //      TString *stringa = (TString*)(tb->GetInfo()->GetOffsets())[tb->GetID()];
494    //      TString *stringa = (TString*)tb->GetAddress();
495    //      printf(" address 0x%X \n",tb->GetAddress());
496    //      printf(" pointer 0x%X \n",tb->GetValuePointer());
497    //      printf(" object  0x%X \n",tb->GetObject());
498    //      printf("stringa %s lung %i\n",stringa.Data(),stringa.Length());
499            //      TLeaf *striglia = tb->FindLeaf(tb->GetName());
500    //      if ( striglia ){
501    //        char *pointer = (char *)striglia->GetValuePointer();
502    //        TString *pr= (TString*)pointer;
503    //        printf("ciao %s \n",pr->Data());
504    //      };
505            sprintf(o,"%s TString - not implemented yet -",o);
506          };
507          //
508          // TArray
509          //
510          if ( atype == 42 ){
511            //
512    //      TObjArray *cl = (TObjArray*)tb->GetObject();
513    //      //
514    //      TClass *myc = cl->IsA();
515    //      //
516    //      printf("qui \n");
517    //      //
518    //      // determine offset to fetch data
519    //      //
520    //      int thisoffset = 0;
521    //      TRealData *rd = myc->GetRealData(tb->GetName());
522    //      if ( rd ){
523    //        thisoffset = rd->GetThisOffset();
524    //      };
525    //      Int_t niente = 0;
526    //      TStreamerElement *tste = tb->GetInfo()->GetStreamerElement(rd->GetName(),niente);
527    //      printf(" typename %s \n",tste->GetTypeName());
528    //      //
529    //      // TArrayI
530    //      //
531    //      if ( !strcmp(tste->GetTypeName(),"TArrayI") ){
532    //        //
533    //        printf("qua \n");
534    //        char *pointer = (char*)cl->At(0);
535    //        //      char *pu = thisoffset + pointer;
536    //        int pu = (int)tste->GetTObjectOffset();
537    //        TArrayI arr = (TArrayI)*pu;
538    //        //      TArrayI arr = (TArrayI)(thisoffset);
539    //        //TArrayI *arr = (TArrayI*)pu;
540    //        //TArraI arr = (TArrayI)
541    //        Int_t jj=0;
542    //        j=0;
543    //        printf("quii \n");
544    //        Int_t arlen = min(arr.GetSize(),dlen);
545    //        //
546    //        printf("que \n");
547    //        setcolor(col,RESET, BLUE, WHITE);
548    //        setcolor(col2,RESET, BLACK, WHITE);
549    //        sprintf(o,"%s%s %s[%i]%s = ",o,col,tb->GetName(),arr.GetSize(),col2);
550    //        //
551    //        //      while ( j < tb->GetNdata() ){
552    //        //
553    //        printf("quo \n");
554    //        //        pointer = (char*)cl->UncheckedAt(j);
555    //        //        pu = pointer + thisoffset;
556    //        //        arr = (TArrayI*)(thisoffset);
557    //        //
558    //        while ( jj < arlen ){
559    //          if ( jj < arlen-1 ){
560    //            sprintf(o,"%s %i ,",o,arr.At(jj));
561    //          } else {
562    //            sprintf(o,"%s %i",o,arr.At(jj));
563    //          };
564    //          jj++;
565    //        };
566    //          //      if ( j < tb->GetNdata() -1 ) sprintf(o,"%s ,",o);
567    //          //      j++;
568    //          //    };
569    //      };
570    //      //
571    //      // TArrayF
572    //      //
573    //      if ( !strcmp(tste->GetTypeName(),"TArrayF") ){
574    //        //
575    //        char *pointer = (char*)cl->UncheckedAt(0);
576    //        char *pu = pointer + thisoffset;
577    //        TArrayF *arr = (TArrayF*)(pu);
578    //        Int_t jj=0;
579    //        Int_t arlen = min(arr->GetSize(),dlen);
580    //        //
581    //        setcolor(col,RESET, BLUE, WHITE);
582    //        setcolor(col2,RESET, BLACK, WHITE);
583    //        sprintf(o,"%s%s %s[%i]%s = ",o,col,tb->GetName(),arr->GetSize(),col2);
584    //        //
585    //        while ( j < tb->GetNdata() ){
586    //          //
587    //          pointer = (char*)cl->UncheckedAt(j);
588    //          pu = pointer + thisoffset;
589    //          arr = (TArrayF*)(pu);
590    //          //
591    //          while ( jj < arlen ){
592    //            if ( jj < arlen-1 ){
593    //              sprintf(o,"%s %f ,",o,arr->At(jj));
594    //            } else {
595    //              sprintf(o,"%s %f",o,arr->At(jj));
596    //            };
597    //            jj++;
598    //          };
599    //          if ( j < tb->GetNdata() -1 ) sprintf(o,"%s ,",o);
600    //          j++;
601    //        };
602    //      };
603    //      sprintf(o,"%s\n",o);
604            //      
605            sprintf(o,"%s TArray - not implemented yet -",o);
606            //
607          };
608          //
609          sprintf(o,"%s\n",o);
610          break;
611        case 3:
612          //
613          // IS A TCLONESARRAY
614          //
615          setcolor(col,RESET, BLUE, WHITE);
616          setcolor(col2,RESET, BLACK, WHITE);
617          sprintf(o,"%s%s %-15s%s = %d\n",o,col,tb->GetName(), col2, tb->GetNdata());
618    
619          //
620          if ( tb->GetNdata() ){
621            //
622            TClonesArray *cl = (TClonesArray*)tb->GetObject();
623            //
624            TClass *myc = cl->GetClass();
625            //
626            TList *lme = myc->GetListOfDataMembers();
627            TIter next(lme);
628            TBranchElement *tb2 = 0;
629            //
630            while ( (tb2 = (TBranchElement*)next()) ){
631              //
632              const char *name = tb2->GetName();
633              TBranch *foglia = tb->FindBranch(name);
634              if ( foglia ){
635                //
636                TBranchElement *stb = (TBranchElement*)tb->FindBranch(name);
637                Int_t stype = stb->GetType();
638                Int_t satype = stb->GetStreamerType() - 20;
639                Int_t slen = (stb->GetInfo()->GetLengths())[stb->GetID()];
640                Int_t slength = min(slen,dlen);
641                //      printf("SubBranches : atype is %i type is %i tb getname %s  slen %i slength %i\n",satype,stype,stb->GetName(),slen,slength);
642                switch (stype){
643                case 31:
644                  //      
645                  // IS A VARIABLE
646                  //
647                  //
648                  // NAME
649                  //
650                  j = 0;
651                  //
652                  // VALUES
653                  //
654                  if ( satype == 41 || satype == 44){
655                    //
656                    // skip TRef
657                    //
658                    break;
659                  };
660                  //
661                  // Integer
662                  //
663                  if ( satype == -17 || satype == -9 ){
664                    //
665                    setcolor(col,RESET, BLUE, WHITE);
666                    setcolor(col2,RESET, BLACK, WHITE);
667                    sprintf(o,"%s%s %-15s%s = ",o,col,foglia->GetName(),col2);
668                    while ( j < cl->GetEntriesFast() ){
669                      if ( j < cl->GetEntriesFast() -1 ){
670                        sprintf(o,"%s %i ,",o,(Int_t)stb->GetValue(j,slength));
671                      } else {
672                        sprintf(o,"%s %i",o,(Int_t)stb->GetValue(j,slength));
673                      };
674                      j++;
675                    };
676                  };
677                  //
678                  // Float
679                  //
680                  if ( satype == -15 ){
681                    //
682                    setcolor(col,RESET, BLUE, WHITE);
683                    setcolor(col2,RESET, BLACK, WHITE);
684                    sprintf(o,"%s%s %-15s%s = ",o,col,foglia->GetName(),col2);
685                    while ( j < cl->GetEntriesFast() ){
686                      if ( j < cl->GetEntriesFast() -1 ){
687                        sprintf(o,"%s %f ,",o,stb->GetValue(j,slength));
688                      } else {
689                        sprintf(o,"%s %f",o,stb->GetValue(j,slength));
690                      };
691                      j++;
692                    };
693                  };
694                  //
695                  // Array of float
696                  //
697                  if ( satype == 5 ){
698                    //
699                    setcolor(col,RESET, BLUE, WHITE);
700                    setcolor(col2,RESET, BLACK, WHITE);
701                    sprintf(o,"%s%s %-15s%s = ",o,col,foglia->GetName(),col2);
702                    Bool_t bold = true;
703                    while ( j < tb->GetNdata() ){
704                      if ( bold ){
705                        setcolor(col,RESET, BLACK, WHITE);
706                        sprintf(o,"%s%s",o,col);
707                      } else {
708                        setcolor(col,BOLD, BLACK, WHITE);
709                        sprintf(o,"%s%s",o,col);                
710                      };
711                      Int_t jj = 0;          
712                      while ( jj < slength ){                  
713                        if ( jj < slength-1 ){
714                          sprintf(o,"%s %f ,",o,stb->GetValue(j,jj,true));
715                        } else {
716                          sprintf(o,"%s %f",o,stb->GetValue(j,jj,true));
717                        };
718                        jj++;
719                      };
720                      if ( j < tb->GetNdata() -1 ) sprintf(o,"%s ,",o);
721                      if ( !bold ){
722                        bold = true;
723                      } else {
724                        bold = false;
725                      };
726                      j++;
727                    };
728                    if ( bold ){
729                      setcolor(col,RESET, BLACK, WHITE);
730                      sprintf(o,"%s%s",o,col);
731                    };
732                  };
733                  //
734                  // Array of integers
735                  //
736                  if ( satype == 3 ){
737                    //
738                    setcolor(col,RESET, BLUE, WHITE);
739                    setcolor(col2,RESET, BLACK, WHITE);
740                    sprintf(o,"%s%s %-15s%s = ",o,col,foglia->GetName(),col2);
741                    while ( j < tb->GetNdata() ){
742                      Int_t jj = 0;
743                      while ( jj < slength ){
744                        if ( jj < slength-1 ){
745                          sprintf(o,"%s %i ,",o,(Int_t)stb->GetValue(j,jj,true));
746                        } else {
747                          sprintf(o,"%s %i",o,(Int_t)stb->GetValue(j,jj,true));
748                        };
749                        jj++;
750                      };
751                      if ( j < tb->GetNdata() -1 ) sprintf(o,"%s ,",o);
752                      j++;
753                    };
754                  };
755    
756                  //
757                  // TArray
758                  //
759                  if ( satype == 42 ){
760                    //
761                    // determine offset to fetch data
762                    //
763                    int thisoffset = 0;
764                    TRealData *rd = myc->GetRealData(foglia->GetName());
765                    if ( rd ){
766                      thisoffset = rd->GetThisOffset();
767                    };
768                    Int_t niente = 0;
769                    TStreamerElement *tste = stb->GetInfo()->GetStreamerElement(rd->GetName(),niente);
770                    //
771                    // TArrayI
772                    //
773                    if ( !strcmp(tste->GetTypeName(),"TArrayI") ){
774                      //
775                      char *pointer = (char*)cl->UncheckedAt(0);
776                      char *pu = pointer + thisoffset;
777                      TArrayI *arr = (TArrayI*)(pu);
778                      Int_t jj=0;
779                      Int_t arlen = min(arr->GetSize(),dlen);
780                      //
781                      setcolor(col,RESET, BLUE, WHITE);
782                      setcolor(col2,RESET, BLACK, WHITE);
783                      sprintf(o,"%s%s %s[%i]%s = ",o,col,foglia->GetName(),arr->GetSize(),col2);
784                      //
785                      while ( j < tb->GetNdata() ){
786                        //
787                        pointer = (char*)cl->UncheckedAt(j);
788                        pu = pointer + thisoffset;
789                        arr = (TArrayI*)(pu);
790                        //
791                        while ( jj < arlen ){
792                          if ( jj < arlen-1 ){
793                            sprintf(o,"%s %i ,",o,arr->At(jj));
794                          } else {
795                            sprintf(o,"%s %i",o,arr->At(jj));
796                          };
797                          jj++;
798                        };
799                        if ( j < tb->GetNdata() -1 ) sprintf(o,"%s ,",o);
800                        j++;
801                      };
802                    };
803                    //
804                    // TArrayF
805                    //
806                    if ( !strcmp(tste->GetTypeName(),"TArrayF") ){
807                      //
808                      char *pointer = (char*)cl->UncheckedAt(0);
809                      char *pu = pointer + thisoffset;
810                      TArrayF *arr = (TArrayF*)(pu);
811                      Int_t jj=0;
812                      Int_t arlen = min(arr->GetSize(),dlen);
813                      //
814                      setcolor(col,RESET, BLUE, WHITE);
815                      setcolor(col2,RESET, BLACK, WHITE);
816                      sprintf(o,"%s%s %s[%i]%s = ",o,col,foglia->GetName(),arr->GetSize(),col2);
817                      //
818                      while ( j < tb->GetNdata() ){
819                        //
820                        pointer = (char*)cl->UncheckedAt(j);
821                        pu = pointer + thisoffset;
822                        arr = (TArrayF*)(pu);
823                        //
824                        while ( jj < arlen ){
825                          if ( jj < arlen-1 ){
826                            sprintf(o,"%s %f ,",o,arr->At(jj));
827                          } else {
828                            sprintf(o,"%s %f",o,arr->At(jj));
829                          };
830                          jj++;
831                        };
832                        if ( j < tb->GetNdata() -1 ) sprintf(o,"%s ,",o);
833                        j++;
834                      };
835                    };
836                  };
837                  sprintf(o,"%s\n",o);
838                  break;        
839                };
840              };
841            };
842          };
843          break;
844        };
845      };  
846      //  pamgui->DIALOG(0,o);
847      printf("%s\n",o);
848    };
849    
850    
851  void FEVdetector::GetGeneralInfo(){  void FEVdetector::GetGeneralInfo(){
852    //    //
853    // Get Orbital Time information and header event number    // Get Orbital Time information and header event number
# Line 290  void FEVdetector::GetGeneralInfo(){ Line 857  void FEVdetector::GetGeneralInfo(){
857      headcold = headc;      headcold = headc;
858      headc = ph->Counter;      headc = ph->Counter;
859      var.headc = (int)ph->Counter;      var.headc = (int)ph->Counter;
860      OBT = ph->OrbitalTime;      OBT = (UInt_t)ph->OrbitalTime;
861      DOBT = OBT - OOBT;      DOBT = OBT - OOBT;
862      OOBT = OBT;      OOBT = OBT;
863      if ( thisentry == minevent || DOBT < 0 || (headc-headcold-1)!=0 ) DOBT = 0;      if ( thisentry == minevent || DOBT < 0 || (headc-headcold-1)!=0 ) DOBT = 0;
# Line 326  void FEVdetector::GetGeneralInfo(){ Line 893  void FEVdetector::GetGeneralInfo(){
893      trcs = (TString)trc.str().c_str();      trcs = (TString)trc.str().c_str();
894    } else {    } else {
895      headcold = headc;      headcold = headc;
896      headc = oinfoL2->pkt_num; // to be changed as soon as we will have obt in the level2 file!      if ( var.RUN ){
897      OBT = oinfoL2->OBT; // to be changed as soon as we will have obt in the level2 file!        var.idrun = L2->GetRunInfo()->ID;
898      DOBT = OBT - OOBT;        var.idroot = L2->GetRunInfo()->ID_ROOT_L0;
899      OOBT = OBT;        var.EVF = L2->GetRunInfo()->EV_FROM;
900      if ( thisentry == minevent || DOBT < 0 || (headc-headcold-1)!=0 ) DOBT = 0;      };
901      var.etime = OBT;      if ( var.ORB ){
902          headc = L2->GetOrbitalInfo()->pkt_num;
903          OBT = L2->GetOrbitalInfo()->OBT;
904          DOBT = OBT - OOBT;
905          OOBT = OBT;
906          if ( thisentry == minevent || DOBT < 0 || (headc-headcold-1)!=0 ) DOBT = 0;
907          var.etime = OBT;
908        } else {
909          var.etime = 0;
910        };
911      //            //      
912      // who gave the trigger?      // who gave the trigger?
913      //      //
914      calotrig = 0;      Int_t trigconf = 0;
915      if ( L2->patterntrig[0] ) calotrig = 1;      if ( var.TRG ){
916      toftrig = 0;        calotrig = 0;
917      if ( L2->patterntrig[2] || L2->patterntrig[3] || L2->patterntrig[4] || L2->patterntrig[5] ) toftrig = 1;        if ( L2->GetTrigLevel2()->patterntrig[0] ) calotrig = 1;
918      s4pulser = 0;        toftrig = 0;
919      if ( L2->patterntrig[1] & (1<<0) ) s4pulser = 1;        if ( L2->GetTrigLevel2()->patterntrig[2] || L2->GetTrigLevel2()->patterntrig[3] || L2->GetTrigLevel2()->patterntrig[4] || L2->GetTrigLevel2()->patterntrig[5] ) toftrig = 1;
920      //        s4pulser = 0;
921      // TOF and calorimeter when giving a trigger will always set this flag since the time window of the signal is greater than 100 ns.        if ( L2->GetTrigLevel2()->patterntrig[1] & (1<<0) ) s4pulser = 1;
922      // S4 sometimes could not set the flag even if the trigger is given. This is a workaround to fix this "bug":        //
923      //        // TOF and calorimeter when giving a trigger will always set this flag since the time window of the signal is greater than 100 ns.
924      if ( !calotrig && !toftrig ) s4pulser = 1;        // S4 sometimes could not set the flag even if the trigger is given. This is a workaround to fix this "bug":
925      //        //
926      Int_t trigconf = L2->trigconf;        if ( !calotrig && !toftrig ) s4pulser = 1;
927          //
928          trigconf = L2->GetTrigLevel2()->trigconf;
929        } else {
930          trigconf = 0;
931        }
932      stringstream trc;      stringstream trc;
933      trc.str("");      trc.str("");
934      if ( trigconf & (1<<0) ) trc << "TOF1";      if ( trigconf & (1<<0) ) trc << "TOF1";
# Line 456  int FEVdetector::SelectEvent(){ Line 1037  int FEVdetector::SelectEvent(){
1037        //        //
1038        if ( level.file == -1 ) isOK = gApplication->ProcessLine("filter((TTree *)otr,-1,(Variables &)var);");        if ( level.file == -1 ) isOK = gApplication->ProcessLine("filter((TTree *)otr,-1,(Variables &)var);");
1039        //        //
1040        if ( level.file ==  2 ) isOK = gApplication->ProcessLine("filter((PamLevel2 *)L2,2);");        //      if ( level.file ==  2 ) isOK = gApplication->ProcessLine("filter((PamLevel2 *)L2,2);");
1041          if ( level.file ==  2 ) isOK = gApplication->ProcessLine("filter();");
1042        //        //
1043        // progress bar in text window        // progress bar in text window
1044        //        //
# Line 469  int FEVdetector::SelectEvent(){ Line 1051  int FEVdetector::SelectEvent(){
1051    //    //
1052  }  }
1053    
1054  void FEVdetector::Load(TTree &mainotr, TFile &mainfile){  TChain* FEVdetector::Load(TString file){
1055    file = &mainfile;    //
1056    otr = &mainotr;    //  file = &mainfile;
   L2 = new PamLevel2();  
1057    //    //
1058    if ( level.file == 2 ){    if ( level.file == 2 ){
     //    otr = L2->LoadPamTrees(file);  
     otr = L2->GetPamTree(file);  
     // ********************  
     // load magnetic field  
     // ********************  
     const char *pam_calib = pathtocalibration();  
1059      //      //
1060      stringstream magfie;      printf(" %s \n",ddec.Data());
1061      magfie.str("");      if ( !L2 ){
1062      //    magfie << "/localdisk/mocchiut/test/calib/trk-param/field_param-0/";        L2 = new PamLevel2("",file.Data(),ddec.Data());
1063      magfie << pam_calib;        otr = L2->GetPamTree();
1064      magfie << "/trk-param/field_param-0/";        printf(" l2 constructor\n");
1065          //      printf(" abst %u obt %u qtot %f \n",L2->GetOrbitalInfo()->absTime,L2->GetOrbitalInfo()->OBT,L2->GetCaloLevel2()->qtot);    
1066        } else {
1067          //
1068          printf(" l2 already exist \n");
1069          otr = L2->GetPamTree(gSystem->DirName(file.Data()),file.Data(),ddec.Data());
1070          L2->GetRunTree(gSystem->DirName(file.Data()),file.Data());
1071          //
1072        };
1073        //
1074        //
1075        if ( !otr ) return(0);
1076        //
1077        //    otr->CanDeleteRefs(true);
1078        //    if ( runtree ) runtree->CanDeleteRefs(true);
1079      //      //
     L2->LoadField(magfie.str().c_str());  
1080    } else {    } else {
1081      //      //
1082      // load calorimeter ADC2MIP conversion file      // load calorimeter ADC2MIP conversion file
# Line 528  void FEVdetector::Load(TTree &mainotr, T Line 1116  void FEVdetector::Load(TTree &mainotr, T
1116      //      //
1117    };    };
1118    //    //
   
1119    //    //
1120    trigger = new pamela::trigger::TriggerEvent();    // Load level0 file if the case
   eh = new pamela::EventHeader();  
   ph = new pamela::PscuHeader();  
   oinfoL2 = new OrbitalInfo();  
   runinfo = new ItoRunInfo(file);  
   //  
   de = new pamela::calorimeter::CalorimeterEvent();  
   trk = new pamela::tracker::TrackerEvent();  
   ne = new pamela::neutron::NeutronEvent();  
   ace = new pamela::anticounter::AnticounterEvent();  
   s4 = new pamela::S4::S4Event();  
   tof = new pamela::tof::TofEvent();  
1121    //    //
1122    if ( level.file == 0 || level.file == -1 ){    if ( level.file == 0 || level.file == -1 ){
1123        //
1124        trigger = new pamela::trigger::TriggerEvent();
1125        eh = new pamela::EventHeader();
1126        ph = new pamela::PscuHeader();
1127        de = new pamela::calorimeter::CalorimeterEvent();
1128        trk = new pamela::tracker::TrackerEvent();
1129        ne = new pamela::neutron::NeutronEvent();
1130        ace = new pamela::anticounter::AnticounterEvent();
1131        s4 = new pamela::S4::S4Event();
1132        tof = new pamela::tof::TofEvent();
1133        //
1134        otr = new TChain("Physics");
1135        otr->Add(file.Data(),-1);
1136      otr->SetBranchAddress("Trigger", &trigger);      otr->SetBranchAddress("Trigger", &trigger);
1137      otr->SetBranchAddress("Header", &eh);      otr->SetBranchAddress("Header", &eh);
1138    };    };
   if ( level.file == 2 ){  
     otr->AddFriend("OrbitalInfo", file);        
     otr->SetBranchAddress("OrbitalInfo", &oinfoL2);      
     runinfo->Read(0ULL);  
   };  
1139    //    //
1140    if ( var.TRK ) {    if ( var.TRK ) {
1141      if ( level.file == 0 || level.file == -1 ){      if ( level.file == 0 || level.file == -1 ){
# Line 623  void FEVdetector::Load(TTree &mainotr, T Line 1207  void FEVdetector::Load(TTree &mainotr, T
1207        printf("Show the Time of Flight detector, LEVEL2 data \n");        printf("Show the Time of Flight detector, LEVEL2 data \n");
1208      };      };
1209    };    };
1210      //
1211      if ( !otr ){
1212        return(0);
1213      };
1214      //
1215      return otr;
1216    //        //    
1217  }  }
1218    
# Line 698  void FEVdetector::DisplayEvent(){ Line 1288  void FEVdetector::DisplayEvent(){
1288      text->DrawLatex(0.33,txthi,testo.str().c_str());      text->DrawLatex(0.33,txthi,testo.str().c_str());
1289      txthi -= 0.03;      txthi -= 0.03;
1290      testo2.str("");      testo2.str("");
1291      testo2 << "On Board Time: " << (int)OBT;      testo2 << "On Board Time: " << (unsigned int)OBT;
1292      if ( DOBT > 0 ) {                    if ( DOBT > 0 ) {              
1293        testo2 << " (delta: " << (int)DOBT;        testo2 << " (delta: " << (unsigned int)DOBT;
1294        testo2 << ")";        testo2 << ")";
1295      };      };
1296      testo2 << " [ms]";      testo2 << " [ms]";
# Line 858  void FEVdetector::DisplayEvent(){ Line 1448  void FEVdetector::DisplayEvent(){
1448        text->DrawLatex(var.xxvc+0.17*var.sfx,var.yxvc-0.08*var.sfy,"CAS1");        text->DrawLatex(var.xxvc+0.17*var.sfx,var.yxvc-0.08*var.sfy,"CAS1");
1449        text->DrawLatex(var.xyvc-0.192*var.sfx,var.yyvc-0.08*var.sfy,"CAS4");        text->DrawLatex(var.xyvc-0.192*var.sfx,var.yyvc-0.08*var.sfy,"CAS4");
1450        text->DrawLatex(var.xyvc+0.17*var.sfx,var.yyvc-0.08*var.sfy,"CAS3");        text->DrawLatex(var.xyvc+0.17*var.sfx,var.yyvc-0.08*var.sfy,"CAS3");
1451        text->DrawLatex(var.xxvc-0.192*var.sfx,var.yxvc+0.48*var.sfy,"CARD2");        text->DrawLatex(var.xxvc-0.222*var.sfx,var.yxvc+0.48*var.sfy,"CARD2");
1452        text->DrawLatex(var.xxvc+0.155*var.sfx,var.yxvc+0.48*var.sfy,"CARD3");        text->DrawLatex(var.xxvc+0.185*var.sfx,var.yxvc+0.48*var.sfy,"CARD3");
1453        text->DrawLatex(var.xyvc-0.170*var.sfx,var.yyvc+0.48*var.sfy,"CARD1");        text->DrawLatex(var.xyvc-0.190*var.sfx,var.yyvc+0.48*var.sfy,"CARD1");
1454        text->DrawLatex(var.xyvc+0.13*var.sfx,var.yyvc+0.48*var.sfy,"CARD4");        text->DrawLatex(var.xyvc+0.16*var.sfx,var.yyvc+0.48*var.sfy,"CARD4");
1455        text->DrawLatex(var.xxvc-0.192*var.sfx,var.yxvc+0.39*var.sfy,"CAT3");        text->DrawLatex(var.xxvc-0.192*var.sfx,var.yxvc+0.39*var.sfy,"CAT3");
1456        text->DrawLatex(var.xxvc+0.155*var.sfx,var.yxvc+0.39*var.sfy,"CAT4");        text->DrawLatex(var.xxvc+0.155*var.sfx,var.yxvc+0.39*var.sfy,"CAT4");
1457        text->DrawLatex(var.xyvc-0.170*var.sfx,var.yyvc+0.39*var.sfy,"CAT2");        text->DrawLatex(var.xyvc-0.170*var.sfx,var.yyvc+0.39*var.sfy,"CAT2");
# Line 989  void FEVdetector::DisplayEvent(){ Line 1579  void FEVdetector::DisplayEvent(){
1579    //    //
1580    // print infos on terminal    // print infos on terminal
1581    //    //
1582      //  if ( !var.selex ){
1583    printf(" File: %s \n",var.thefilename.Data());            printf(" File: %s \n",var.thefilename.Data());        
1584    if ( !s4pulser && !calotrig ){    if ( !s4pulser && !calotrig ){
1585      printf(" Pkt_num: %i  - Progressive number: %i \n",(int)headc,thisentry+1);      printf(" Pkt_num: %i  - Progressive number: %i \n",(int)headc,thisentry+1);
# Line 999  void FEVdetector::DisplayEvent(){ Line 1590  void FEVdetector::DisplayEvent(){
1590    if ( calotrig ){    if ( calotrig ){
1591      printf(" Pkt_num: %i  - Progressive number: %i   - CALO trigger -\n",(int)headc,thisentry+1);      printf(" Pkt_num: %i  - Progressive number: %i   - CALO trigger -\n",(int)headc,thisentry+1);
1592    };    };
1593    printf(" On Board Time: %i (delta %i) [ms]\n",OBT,DOBT);    printf(" On Board Time: %u (delta %i) [ms]\n",OBT,DOBT);
1594    const char *trc2 = trcs;    const char *trc2 = trcs;
1595    printf(" TRIGGER: %s \n",trc2);          printf(" TRIGGER: %s \n",trc2);      
1596    printf(" AC: CARD hit = %i  CAT hit = %i  CAS hit = %i \n",var.hcard,var.hcat,var.hcas);          printf(" AC: CARD hit = %i  CAT hit = %i  CAS hit = %i \n",var.hcard,var.hcat,var.hcas);      
# Line 1011  void FEVdetector::DisplayEvent(){ Line 1602  void FEVdetector::DisplayEvent(){
1602    printf(" CALO: NSTRIP = %i  QTOT = %i [MIP]\n",var.nstrip,var.qtot);      printf(" CALO: NSTRIP = %i  QTOT = %i [MIP]\n",var.nstrip,var.qtot);  
1603    printf(" S4: %.2f [MIP]   TOF: beta = %.2f \n",var.s4sig,var.beta[4]);            printf(" S4: %.2f [MIP]   TOF: beta = %.2f \n",var.s4sig,var.beta[4]);        
1604    printf(" ND: Trigger: neutrons = %i - Background: upper = %i lower = %i \n",var.trup,var.bkup,var.bkbo);          printf(" ND: Trigger: neutrons = %i - Background: upper = %i lower = %i \n",var.trup,var.bkup,var.bkbo);      
1605      //  };
1606    //    //
1607  }  }
1608    
# Line 1318  void FEVdetector::ShowPalette(){ Line 1910  void FEVdetector::ShowPalette(){
1910  void FEVdetector::ShowTOF(){  void FEVdetector::ShowTOF(){
1911    //    //
1912    //    //
   //  
1913    if ( !var.TOF ) return;    if ( !var.TOF ) return;
1914    //    //
1915    Int_t tt = 0;    Int_t tt = 0;
1916      Int_t rj = 0;
1917    //    //
1918    // force level0, i.e. show patterntrig variable!    // force level0, i.e. show patterntrig variable!
1919    //    //
# Line 1515  void FEVdetector::ShowTOF(){ Line 2107  void FEVdetector::ShowTOF(){
2107      Float_t s12p = 0.055;      Float_t s12p = 0.055;
2108      ocolo = 10;      ocolo = 10;
2109      TPolyLine *ftof12ya[6];      TPolyLine *ftof12ya[6];
2110        rj=6;
2111      for ( Int_t j=0; j<6; j++){      for ( Int_t j=0; j<6; j++){
2112          rj--;
2113        Float_t xc1[4]={ (s12p*j),       s12p*(j),               s12p*(j+1),     (s12p*j)};        Float_t xc1[4]={ (s12p*j),       s12p*(j),               s12p*(j+1),     (s12p*j)};
2114        Float_t yc1[4]={      -ws13,     0.,  0., -ws13};        Float_t yc1[4]={      -ws13,     0.,  0., -ws13};
2115        Float_t xc[4];            Float_t xc[4];    
# Line 1531  void FEVdetector::ShowTOF(){ Line 2125  void FEVdetector::ShowTOF(){
2125        } else {        } else {
2126          colo = 1;          colo = 1;
2127        };        };
2128        ColorMIP(ms12a[j],colo);        ColorMIP(ms12a[rj],colo);
2129        //        //
2130        if ( colo != 10 ) ocolo = colo;        if ( colo != 10 ) ocolo = colo;
2131        if ( mt12[0][j] == 4095. ) colo = noadc;        if ( mt12[0][rj] == 4095. ) colo = noadc;
2132        //        //
2133        ftof12ya[j]->SetFillColor(colo);        ftof12ya[j]->SetFillColor(colo);
2134        ftof12ya[j]->SetLineWidth(1);        ftof12ya[j]->SetLineWidth(1);
# Line 1544  void FEVdetector::ShowTOF(){ Line 2138  void FEVdetector::ShowTOF(){
2138      // B      // B
2139      s12p = 0.055;      s12p = 0.055;
2140      TPolyLine *ftof12yb[6];      TPolyLine *ftof12yb[6];
2141        rj=6;
2142      for ( Int_t j=0; j<6; j++){      for ( Int_t j=0; j<6; j++){
2143          rj--;
2144        Float_t xc1[4]={ (s12p*j),       s12p*(j+1),               s12p*(j+1),     (s12p*j)};        Float_t xc1[4]={ (s12p*j),       s12p*(j+1),               s12p*(j+1),     (s12p*j)};
2145        Float_t yc1[4]={ -ws13,     -ws13,    0., -ws13};        Float_t yc1[4]={ -ws13,     -ws13,    0., -ws13};
2146        Float_t xc[4];            Float_t xc[4];    
# Line 1560  void FEVdetector::ShowTOF(){ Line 2156  void FEVdetector::ShowTOF(){
2156        } else {        } else {
2157          colo = 1;          colo = 1;
2158        };        };
2159        ColorMIP(ms12b[j],colo);        ColorMIP(ms12b[rj],colo);
2160        //        //
2161        if ( colo != 10 ) ocolo = colo;        if ( colo != 10 ) ocolo = colo;
2162        if ( mt12[1][j] == 4095. ) colo = noadc;        if ( mt12[1][rj] == 4095. ) colo = noadc;
2163        //        //
2164        ftof12yb[j]->SetFillColor(colo);        ftof12yb[j]->SetFillColor(colo);
2165        ftof12yb[j]->SetLineWidth(1);        ftof12yb[j]->SetLineWidth(1);
# Line 1597  void FEVdetector::ShowTOF(){ Line 2193  void FEVdetector::ShowTOF(){
2193      Float_t s21p = 0.075;      Float_t s21p = 0.075;
2194      ocolo = 10;      ocolo = 10;
2195      TPolyLine *ftof21ya[2];      TPolyLine *ftof21ya[2];
2196        rj=2;
2197      for ( Int_t j=0; j<2; j++){      for ( Int_t j=0; j<2; j++){
2198          rj--;
2199        Float_t xc1[4]={ s21p*(j-1),       s21p*(j-1),               s21p*j,     s21p*(j-1)};        Float_t xc1[4]={ s21p*(j-1),       s21p*(j-1),               s21p*j,     s21p*(j-1)};
2200        Float_t yc1[4]={ 0.,                ws2,     ws2,    0.};        Float_t yc1[4]={ 0.,                ws2,     ws2,    0.};
2201        Float_t xc[4];            Float_t xc[4];    
# Line 1613  void FEVdetector::ShowTOF(){ Line 2211  void FEVdetector::ShowTOF(){
2211        } else {        } else {
2212          colo = 1;          colo = 1;
2213        };        };
2214        ColorMIP(ms21a[j],colo);        ColorMIP(ms21a[rj],colo);
2215        //        //
2216        if ( colo != 10 ) ocolo = colo;        if ( colo != 10 ) ocolo = colo;
2217        if ( mt21[0][j] == 4095. ) colo = noadc;        if ( mt21[0][rj] == 4095. ) colo = noadc;
2218        //        //
2219        ftof21ya[j]->SetFillColor(colo);        ftof21ya[j]->SetFillColor(colo);
2220        ftof21ya[j]->SetLineWidth(1);        ftof21ya[j]->SetLineWidth(1);
# Line 1626  void FEVdetector::ShowTOF(){ Line 2224  void FEVdetector::ShowTOF(){
2224      // B      // B
2225      s21p = 0.075;      s21p = 0.075;
2226      TPolyLine *ftof21yb[2];      TPolyLine *ftof21yb[2];
2227        rj=2;
2228      for ( Int_t j=0; j<2; j++){      for ( Int_t j=0; j<2; j++){
2229          rj--;
2230        Float_t xc1[4]={ s21p*(j-1),       s21p*j,               s21p*j,     s21p*(j-1)};        Float_t xc1[4]={ s21p*(j-1),       s21p*j,               s21p*j,     s21p*(j-1)};
2231        Float_t yc1[4]={ 0.,         0.,                ws2,         0.};        Float_t yc1[4]={ 0.,         0.,                ws2,         0.};
2232        Float_t xc[4];            Float_t xc[4];    
# Line 1642  void FEVdetector::ShowTOF(){ Line 2242  void FEVdetector::ShowTOF(){
2242        } else {        } else {
2243          colo = 1;          colo = 1;
2244        };        };
2245        ColorMIP(ms21b[j],colo);        ColorMIP(ms21b[rj],colo);
2246        //        //
2247        if ( colo != 10 ) ocolo = colo;        if ( colo != 10 ) ocolo = colo;
2248        if ( mt21[1][j] == 4095. ) colo = noadc;        if ( mt21[1][rj] == 4095. ) colo = noadc;
2249        //        //
2250        ftof21yb[j]->SetFillColor(colo);        ftof21yb[j]->SetFillColor(colo);
2251        ftof21yb[j]->SetLineWidth(1);        ftof21yb[j]->SetLineWidth(1);
# Line 1760  void FEVdetector::ShowTOF(){ Line 2360  void FEVdetector::ShowTOF(){
2360      Float_t s31p = 0.060;      Float_t s31p = 0.060;
2361      ocolo = 10;      ocolo = 10;
2362      TPolyLine *ftof31xa[3];      TPolyLine *ftof31xa[3];
2363        rj=3;
2364      for ( Int_t j=0; j<3; j++){      for ( Int_t j=0; j<3; j++){
2365          rj--;
2366        Float_t xc1[4]={ (s31p*j),       (s31p*j),               s31p*(j+1),       (s31p*j)};        Float_t xc1[4]={ (s31p*j),       (s31p*j),               s31p*(j+1),       (s31p*j)};
2367        Float_t yc1[4]={ 0.,                       ws13,     ws13,    0.};        Float_t yc1[4]={ 0.,                       ws13,     ws13,    0.};
2368        Float_t xc[4];            Float_t xc[4];    
# Line 1776  void FEVdetector::ShowTOF(){ Line 2378  void FEVdetector::ShowTOF(){
2378        } else {        } else {
2379          colo = 1;          colo = 1;
2380        };        };
2381        ColorMIP(ms31a[j],colo);        ColorMIP(ms31a[rj],colo);
2382        //        //
2383        if ( colo != 10 ) ocolo = colo;        if ( colo != 10 ) ocolo = colo;
2384        if ( mt31[0][j] == 4095. ) colo = noadc;        if ( mt31[0][rj] == 4095. ) colo = noadc;
2385        //        //
2386        ftof31xa[j]->SetFillColor(colo);        ftof31xa[j]->SetFillColor(colo);
2387        ftof31xa[j]->SetLineWidth(1);        ftof31xa[j]->SetLineWidth(1);
# Line 1789  void FEVdetector::ShowTOF(){ Line 2391  void FEVdetector::ShowTOF(){
2391      // B      // B
2392      s31p = 0.060;      s31p = 0.060;
2393      TPolyLine *ftof31xb[3];      TPolyLine *ftof31xb[3];
2394        rj=3;
2395      for ( Int_t j=0; j<3; j++){      for ( Int_t j=0; j<3; j++){
2396          rj--;
2397        Float_t xc1[4]={ (s31p*j),       s31p*(j+1),               s31p*(j+1),     (s31p*j)};        Float_t xc1[4]={ (s31p*j),       s31p*(j+1),               s31p*(j+1),     (s31p*j)};
2398        Float_t yc1[4]={ 0.,                        0.,     ws13,    0.};        Float_t yc1[4]={ 0.,                        0.,     ws13,    0.};
2399        Float_t xc[4];            Float_t xc[4];    
# Line 1805  void FEVdetector::ShowTOF(){ Line 2409  void FEVdetector::ShowTOF(){
2409        } else {        } else {
2410          colo = 1;          colo = 1;
2411        };        };
2412        ColorMIP(ms31b[j],colo);        ColorMIP(ms31b[rj],colo);
2413        //        //
2414        if ( colo != 10 ) ocolo = colo;        if ( colo != 10 ) ocolo = colo;
2415        if ( mt31[1][j] == 4095. ) colo = noadc;        if ( mt31[1][rj] == 4095. ) colo = noadc;
2416        //        //
2417        ftof31xb[j]->SetFillColor(colo);        ftof31xb[j]->SetFillColor(colo);
2418        ftof31xb[j]->SetLineWidth(1);        ftof31xb[j]->SetLineWidth(1);
# Line 1840  void FEVdetector::ShowTOF(){ Line 2444  void FEVdetector::ShowTOF(){
2444      Float_t s32p = 0.050;      Float_t s32p = 0.050;
2445      ocolo = 10;      ocolo = 10;
2446      TPolyLine *ftof32ya[3];      TPolyLine *ftof32ya[3];
2447        rj=3;
2448      for ( Int_t j=0; j<3; j++){      for ( Int_t j=0; j<3; j++){
2449          rj--;
2450        Float_t xc1[4]={ (s32p*j),       (s32p*j),               s32p*(j+1),     (s32p*j)};        Float_t xc1[4]={ (s32p*j),       (s32p*j),               s32p*(j+1),     (s32p*j)};
2451        Float_t yc1[4]={     -ws13,     0.,    0., -ws13};        Float_t yc1[4]={     -ws13,     0.,    0., -ws13};
2452        Float_t xc[4];            Float_t xc[4];    
# Line 1856  void FEVdetector::ShowTOF(){ Line 2462  void FEVdetector::ShowTOF(){
2462        } else {        } else {
2463          colo = 1;          colo = 1;
2464        };        };
2465        ColorMIP(ms32a[j],colo);        ColorMIP(ms32a[rj],colo);
2466        //        //
2467        if ( colo != 10 ) ocolo = colo;        if ( colo != 10 ) ocolo = colo;
2468        if ( mt32[0][j] == 4095. ) colo = noadc;        if ( mt32[0][rj] == 4095. ) colo = noadc;
2469        //        //
2470        ftof32ya[j]->SetFillColor(colo);        ftof32ya[j]->SetFillColor(colo);
2471        ftof32ya[j]->SetLineWidth(1);        ftof32ya[j]->SetLineWidth(1);
# Line 1868  void FEVdetector::ShowTOF(){ Line 2474  void FEVdetector::ShowTOF(){
2474      };      };
2475      s32p = 0.050;      s32p = 0.050;
2476      TPolyLine *ftof32yb[3];      TPolyLine *ftof32yb[3];
2477        rj=3;
2478      for ( Int_t j=0; j<3; j++){      for ( Int_t j=0; j<3; j++){
2479          rj--;
2480        Float_t xc1[4]={ (s32p*j),       s32p*(j+1),               s32p*(j+1),     (s32p*j)};        Float_t xc1[4]={ (s32p*j),       s32p*(j+1),               s32p*(j+1),     (s32p*j)};
2481        Float_t yc1[4]={ -ws13,   -ws13,    0., -ws13};        Float_t yc1[4]={ -ws13,   -ws13,    0., -ws13};
2482        Float_t xc[4];            Float_t xc[4];    
# Line 1884  void FEVdetector::ShowTOF(){ Line 2492  void FEVdetector::ShowTOF(){
2492        } else {        } else {
2493          colo = 1;          colo = 1;
2494        };        };
2495        ColorMIP(ms32b[j],colo);        ColorMIP(ms32b[rj],colo);
2496        //        //
2497        if ( colo != 10 ) ocolo = colo;        if ( colo != 10 ) ocolo = colo;
2498        if ( mt32[1][j] == 4095. ) colo = noadc;        if ( mt32[1][rj] == 4095. ) colo = noadc;
2499        //        //
2500        ftof32yb[j]->SetFillColor(colo);        ftof32yb[j]->SetFillColor(colo);
2501        ftof32yb[j]->SetLineWidth(1);        ftof32yb[j]->SetLineWidth(1);
# Line 2024  void FEVdetector::ShowTOF(){ Line 2632  void FEVdetector::ShowTOF(){
2632          ms11b[i] = 0.;          ms11b[i] = 0.;
2633        } else {        } else {
2634          ms11b[i] = 1.;          ms11b[i] = 1.;
2635        };    };        };
2636        };
2637      for ( Int_t i = 0; i<6; i++ ) {      for ( Int_t i = 0; i<6; i++ ) {
2638        mt12[0][i] = tof->tdc[ch12a[i]][hb12a[i]];        mt12[0][i] = tof->tdc[ch12a[i]][hb12a[i]];
2639        mt12[1][i] = tof->tdc[ch12b[i]][hb12b[i]];        mt12[1][i] = tof->tdc[ch12b[i]][hb12b[i]];
# Line 2118  void FEVdetector::ShowTOF(){ Line 2727  void FEVdetector::ShowTOF(){
2727    //    //
2728    Bool_t repeat = true;    Bool_t repeat = true;
2729    Int_t numtr = 1;    Int_t numtr = 1;
2730    //  Int_t numtr = 0;
2731    Int_t repuntil = 0;    Int_t repuntil = 0;
2732    //      //  
2733    //    //
2734    var.tofraw = 0;    var.tofraw = 0;
2735    //    //
2736    repuntil = L2->ToFLevel2::ntrk();        if ( level.file == 2 ) repuntil = L2->GetToFLevel2()->ntrk();    
2737    //  printf("repuntil = %i \n",repuntil);    //  printf("repuntil = %i \n",repuntil);
2738      //if ( level.file == 2 ) repuntil = L2->GetTrkLevel2()->GetNTracks();    
2739    //repuntil = L2->GetNTracks();        //repuntil = L2->GetNTracks();    
2740    //    //
2741    while ( repeat ){    while ( repeat ){
# Line 2134  void FEVdetector::ShowTOF(){ Line 2745  void FEVdetector::ShowTOF(){
2745        //        //
2746        //        //
2747        ToFTrkVar *ptt = 0;        ToFTrkVar *ptt = 0;
2748    //      PamTrack *ptrack = 0;
2749          Float_t adc[4][12];
2750          Float_t tdc[4][12];
2751          memset(adc,0,4*12*sizeof(Float_t));
2752          memset(tdc,0,4*12*sizeof(Float_t));
2753        //              //      
2754        //        //
2755          //      if ( repuntil == 0 || var.tofraw ){
2756        if ( repuntil == 1 || var.tofraw ){        if ( repuntil == 1 || var.tofraw ){
2757          numtr = 0;          numtr = 0;
2758          ptt = L2->GetToFTrkVar(0);          ptt = L2->GetToFLevel2()->GetToFTrkVar(0);
2759          repeat = false;          repeat = false;
2760        } else {        } else {
2761          //          //
2762          //          //
2763          if ( numtr >= repuntil-1 ) repeat = false;          if ( numtr >= repuntil-1 ) repeat = false;
2764          //          //
2765          ptt = L2->GetToFTrkVar(numtr);          //      printf(" numtr is %i \n",numtr);
2766            ptt = L2->GetToFLevel2()->GetToFTrkVar(numtr);  
2767            //ptrack = L2->GetTrack(numtr);
2768            //ptt = ptrack->GetToFTrack();
2769        };        };
2770        //        //
2771        xp11[0] = 0.;        xp11[0] = 0.;
# Line 2159  void FEVdetector::ShowTOF(){ Line 2779  void FEVdetector::ShowTOF(){
2779        //        //
2780        ii = 2;        ii = 2;
2781        //        //
2782        Float_t adc[4][12];        Int_t myseq = ptt->trkseqno + 1;
2783        Float_t tdc[4][12];        L2->GetToFLevel2()->GetMatrix(myseq,adc,tdc);
2784        L2->GetMatrix(numtr,adc,tdc);        //
2785          //      printf(" qua \n");
2786        //        //
2787        for ( Int_t i = 0; i<8; i++ ) {          for ( Int_t i = 0; i<8; i++ ) {  
2788          if ( adc[ch11a[i]][hb11a[i]] < 1000. ){          if ( adc[ch11a[i]][hb11a[i]] < 1000. ){
# Line 2319  void FEVdetector::ShowTOF(){ Line 2939  void FEVdetector::ShowTOF(){
2939      ftof11y->Draw();      ftof11y->Draw();
2940      TPolyLine *sftof11[8];      TPolyLine *sftof11[8];
2941      tt = 1;      tt = 1;
2942      if ( level.file == -1 ) tt = 8;      rj=1;
2943        if ( level.file == -1 ){
2944          tt = 8;
2945          rj = 8;
2946        };
2947      for ( Int_t j=0; j<tt; j++){      for ( Int_t j=0; j<tt; j++){
2948        if ( (mt11[0][j]<4095. || mt11[1][j]<4095.)){        rj--;
2949          if ( (mt11[0][rj]<4095. || mt11[1][rj]<4095.)){
2950          if ( ocolo == 10 ) ocolo = noadc;          if ( ocolo == 10 ) ocolo = noadc;
2951          Float_t lowp = (xp11[j]-E11[j])/100.;          Float_t lowp = -(xp11[rj]+E11[rj])/100.;
2952          Float_t higp = (xp11[j]+E11[j])/100.;          Float_t higp = -(xp11[rj]-E11[rj])/100.;
2953          if ( lowp < -0.164 ) lowp = -0.164;          if ( lowp < -0.164 ) lowp = -0.164;
2954          if ( higp > 0.164 ) higp = 0.164;          if ( higp > 0.164 ) higp = 0.164;
2955          if ( lowp < higp && ( level.file == -1 || (level.file == 2 && xp11[j] != 0.))){          if ( lowp < higp && ( level.file == -1 || (level.file == 2 && xp11[rj] != 0.))){
2956            Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};            Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
2957            Float_t nyc1[5]={ 0.0015,         0.0015,                ws13-0.0015,    ws13-0.0015,    0.0015};            Float_t nyc1[5]={ 0.0015,         0.0015,                ws13-0.0015,    ws13-0.0015,    0.0015};
2958            Float_t nxc[5];                Float_t nxc[5];    
# Line 2352  void FEVdetector::ShowTOF(){ Line 2977  void FEVdetector::ShowTOF(){
2977      Float_t s12p = 0.055;      Float_t s12p = 0.055;
2978      ocolo = 10;      ocolo = 10;
2979      TPolyLine *ftof12y[6];      TPolyLine *ftof12y[6];
2980        rj = 6;
2981      for ( Int_t j=0; j<6; j++){      for ( Int_t j=0; j<6; j++){
2982          rj--;
2983        Float_t nxc1[5]={ (s12p*j),       (s12p*j),               s12p*(j+1), s12p*(j+1),    (s12p*j)};        Float_t nxc1[5]={ (s12p*j),       (s12p*j),               s12p*(j+1), s12p*(j+1),    (s12p*j)};
2984        Float_t nyc1[5]={      -ws13,     0.,  0., -ws13, -ws13};        Float_t nyc1[5]={      -ws13,     0.,  0., -ws13, -ws13};
2985        Float_t nxc[5];            Float_t nxc[5];    
# Line 2369  void FEVdetector::ShowTOF(){ Line 2996  void FEVdetector::ShowTOF(){
2996          colo = 1;          colo = 1;
2997        };        };
2998        if ( level.file == -1 ){        if ( level.file == -1 ){
2999          ColorMIP(ms12a[j]+ms12b[j],colo);          ColorMIP(ms12a[rj]+ms12b[rj],colo);
3000        } else {        } else {
3001          ColorTOFMIP(ms12a[j]+ms12b[j],colo);          ColorTOFMIP(ms12a[rj]+ms12b[rj],colo);
3002        };        };
3003        //        //
3004        if ( colo != 10 ) ocolo = colo;        if ( colo != 10 ) ocolo = colo;
# Line 2438  void FEVdetector::ShowTOF(){ Line 3065  void FEVdetector::ShowTOF(){
3065      Float_t s21p = 0.075;      Float_t s21p = 0.075;
3066      ocolo = 10;      ocolo = 10;
3067      TPolyLine *ftof21y[2];      TPolyLine *ftof21y[2];
3068        rj=2;
3069      for ( Int_t j=0; j<2; j++){      for ( Int_t j=0; j<2; j++){
3070          rj--;
3071        Float_t nxc1[5]={ s21p*(j-1),       s21p*(j-1),               s21p*j,s21p*j,     s21p*(j-1)};        Float_t nxc1[5]={ s21p*(j-1),       s21p*(j-1),               s21p*j,s21p*j,     s21p*(j-1)};
3072        Float_t nyc1[5]={ 0.,                ws2,     ws2,  0.,  0.};        Float_t nyc1[5]={ 0.,                ws2,     ws2,  0.,  0.};
3073        Float_t nxc[5];            Float_t nxc[5];    
# Line 2455  void FEVdetector::ShowTOF(){ Line 3084  void FEVdetector::ShowTOF(){
3084          colo = 1;          colo = 1;
3085        };        };
3086        if ( level.file == -1 ){        if ( level.file == -1 ){
3087          ColorMIP(ms21a[j]+ms21b[j],colo);          ColorMIP(ms21a[rj]+ms21b[rj],colo);
3088        } else {        } else {
3089          ColorTOFMIP(ms21a[j]+ms21b[j],colo);          ColorTOFMIP(ms21a[rj]+ms21b[rj],colo);
3090        };        };
3091        //        //
3092        if ( colo != 10 ) ocolo = colo;        if ( colo != 10 ) ocolo = colo;
# Line 2574  void FEVdetector::ShowTOF(){ Line 3203  void FEVdetector::ShowTOF(){
3203        ftof22y->Draw();        ftof22y->Draw();
3204        TPolyLine *sftof22[2];        TPolyLine *sftof22[2];
3205        tt = 1;        tt = 1;
3206        if ( level.file == -1 ) tt = 2;        rj = 1;
3207          if ( level.file == -1 ){
3208            tt = 2;
3209            rj = 2;
3210          };
3211        for (Int_t j=0; j<tt; j++){        for (Int_t j=0; j<tt; j++){
3212            rj--;
3213          //    for ( Int_t j=0; j<2; j++){          //    for ( Int_t j=0; j<2; j++){
3214          if ( (mt22[0][j]<4095. || mt22[1][j]<4095.) ){          if ( (mt22[0][rj]<4095. || mt22[1][rj]<4095.) ){
3215            if ( ocolo == 10 ) ocolo = noadc;            if ( ocolo == 10 ) ocolo = noadc;
3216            Float_t lowp = (xp22[j]-E22[j])/100.;            Float_t lowp = -(xp22[rj]+E22[rj])/100.;
3217            Float_t higp = (xp22[j]+E22[j])/100.;            Float_t higp = -(xp22[rj]-E22[rj])/100.;
3218            if ( lowp < -0.074 ) lowp = -0.074;            if ( lowp < -0.074 ) lowp = -0.074;
3219            if ( higp > 0.074 ) higp = 0.074;            if ( higp > 0.074 ) higp = 0.074;
3220            if ( lowp < higp && ( level.file == -1 || (level.file == 2 && xp22[j] != 0.))){            if ( lowp < higp && ( level.file == -1 || (level.file == 2 && xp22[rj] != 0.))){
3221              Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};              Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
3222              Float_t nyc1[5]={ -0.0015,         -0.0015,                -ws2+0.0015,    -ws2+0.0015,    -0.0015};              Float_t nyc1[5]={ -0.0015,         -0.0015,                -ws2+0.0015,    -ws2+0.0015,    -0.0015};
3223              Float_t nxc[5];                  Float_t nxc[5];    
# Line 2603  void FEVdetector::ShowTOF(){ Line 3237  void FEVdetector::ShowTOF(){
3237        };        };
3238      };      };
3239      //      //
3240        //daquiinbasso
3241      //      //
3242      // S31  X-view      // S31  X-view
3243      //      //
# Line 2660  void FEVdetector::ShowTOF(){ Line 3294  void FEVdetector::ShowTOF(){
3294        ftof31y->Draw();        ftof31y->Draw();
3295        TPolyLine *sftof31[3];        TPolyLine *sftof31[3];
3296        tt = 1;        tt = 1;
3297        if ( level.file == -1 ) tt = 3;        rj = 1;
3298          if ( level.file == -1 ){
3299            tt = 3;
3300            rj = 3;
3301          };
3302        for (Int_t j=0; j<tt; j++){        for (Int_t j=0; j<tt; j++){
3303            rj--;
3304          //    for ( Int_t j=0; j<3; j++){          //    for ( Int_t j=0; j<3; j++){
3305          if ( (mt31[0][j]<4095. || mt31[1][j]<4095.)){          if ( (mt31[0][rj]<4095. || mt31[1][rj]<4095.)){
3306            if ( ocolo == 10 ) ocolo = noadc;            if ( ocolo == 10 ) ocolo = noadc;
3307            Float_t lowp = (xp31[j]-E31[j])/100.;            Float_t lowp = -(xp31[rj]+E31[rj])/100.;
3308            Float_t higp = (xp31[j]+E31[j])/100.;            Float_t higp = -(xp31[rj]-E31[rj])/100.;
3309            if ( lowp < -0.074 ) lowp = -0.074;            if ( lowp < -0.074 ) lowp = -0.074;
3310            if ( higp > 0.074 ) higp = 0.074;            if ( higp > 0.074 ) higp = 0.074;
3311            if ( lowp < higp && ( level.file == -1 || (level.file == 2 && xp31[j] != 0.))){            if ( lowp < higp && ( level.file == -1 || (level.file == 2 && xp31[rj] != 0.))){
3312              Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};              Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
3313              Float_t nyc1[5]={ 0.0015,         0.0015,                ws13-0.0015,    ws13-0.0015,    0.0015};              Float_t nyc1[5]={ 0.0015,         0.0015,                ws13-0.0015,    ws13-0.0015,    0.0015};
3314              Float_t nxc[5];                  Float_t nxc[5];    
# Line 2696  void FEVdetector::ShowTOF(){ Line 3335  void FEVdetector::ShowTOF(){
3335      Float_t s32p = 0.050;      Float_t s32p = 0.050;
3336      ocolo = 10;      ocolo = 10;
3337      TPolyLine *ftof32y[3];      TPolyLine *ftof32y[3];
3338        rj = 3;
3339      for ( Int_t j=0; j<3; j++){      for ( Int_t j=0; j<3; j++){
3340          rj--;
3341        Float_t nxc1[5]={ (s32p*j),       (s32p*j),               s32p*(j+1),s32p*(j+1),     (s32p*j)};        Float_t nxc1[5]={ (s32p*j),       (s32p*j),               s32p*(j+1),s32p*(j+1),     (s32p*j)};
3342        Float_t nyc1[5]={     -ws13,     0.,    0., -ws13, -ws13};        Float_t nyc1[5]={     -ws13,     0.,    0., -ws13, -ws13};
3343        Float_t nxc[5];            Float_t nxc[5];    
# Line 2713  void FEVdetector::ShowTOF(){ Line 3354  void FEVdetector::ShowTOF(){
3354          colo = 1;          colo = 1;
3355        };        };
3356        if ( level.file == -1 ){        if ( level.file == -1 ){
3357          ColorMIP(ms32a[j]+ms32b[j],colo);          ColorMIP(ms32a[rj]+ms32b[rj],colo);
3358        } else {        } else {
3359          ColorTOFMIP(ms32a[j]+ms32b[j],colo);          ColorTOFMIP(ms32a[rj]+ms32b[rj],colo);
3360        };        };
3361        //        //
3362        if ( colo != 10 ) ocolo = colo;        if ( colo != 10 ) ocolo = colo;
# Line 2805  void FEVdetector::ShowAC(){ Line 3446  void FEVdetector::ShowAC(){
3446    // full infos from ac    // full infos from ac
3447    //    //
3448    if ( level.file == 2 ){    if ( level.file == 2 ){
3449      hitmapA = L2->hitmap[0];      hitmapA = L2->GetAcLevel2()->hitmap[0];
3450      hitmapB = L2->hitmap[1];      hitmapB = L2->GetAcLevel2()->hitmap[1];
3451      hitstatusA = L2->hitstatus[0];      hitstatusA = L2->GetAcLevel2()->hitstatus[0];
3452      hitstatusB = L2->hitstatus[1];      hitstatusB = L2->GetAcLevel2()->hitstatus[1];
3453    };    };
3454    //    //
3455    //    //
# Line 3682  void FEVdetector::ShowAC(){ Line 4323  void FEVdetector::ShowAC(){
4323      pcasp4b->Draw("f");      pcasp4b->Draw("f");
4324      pcasp4b->Draw();      pcasp4b->Draw();
4325    };    };
4326    Float_t alfa = 1.2020334;    //  Float_t alfax = 1.2020334;
4327      Float_t alfax = 1.22157778;
4328      Float_t alfay = 1.27393111;
4329    Float_t lcrd = 0.1815/2.;    Float_t lcrd = 0.1815/2.;
4330    Float_t wcrd = 0.008;    Float_t wcrd = 0.008;
4331    if ( true ){    if ( true ){
# Line 3893  void FEVdetector::ShowAC(){ Line 4536  void FEVdetector::ShowAC(){
4536      //      //
4537      //    Float_t cardcx = 0.143168*var.sfx;      //    Float_t cardcx = 0.143168*var.sfx;
4538      //Float_t cardcy = 0.1475*var.sfy;      //Float_t cardcy = 0.1475*var.sfy;
4539      Float_t cardcx = 0.153168*var.sfx;      //
4540      Float_t cardcy = 0.1575*var.sfy;      //    Float_t cardcx = 0.153168*var.sfx;
4541      Float_t acrdx[4] = {-lcrd*cos(alfa), lcrd*cos(alfa), -lcrd*cos(alfa)+wcrd*sin(alfa), -lcrd*cos(alfa)};      //
4542      Float_t acrdy[4] = {-lcrd*sin(alfa), lcrd*sin(alfa), -lcrd*sin(alfa)-wcrd*cos(alfa), -lcrd*sin(alfa)};      Float_t cardcx = (0.19123*(1.-lcrd*cos(alfax)))*var.sfx;
4543      Float_t bcrdx[4] = { lcrd*cos(alfa), lcrd*cos(alfa)+wcrd*sin(alfa), -lcrd*cos(alfa)+wcrd*sin(alfa), lcrd*cos(alfa)};      //    Float_t cardcy = 0.1575*var.sfy;
4544      Float_t bcrdy[4] = { lcrd*sin(alfa), lcrd*sin(alfa)-wcrd*cos(alfa), -lcrd*sin(alfa)-wcrd*cos(alfa), lcrd*sin(alfa)};      Float_t cardcy = (0.179212*(1.-lcrd*sin(alfax)))*var.sfy;
4545        Float_t acrdx[4] = {-lcrd*cos(alfax), lcrd*cos(alfax), -lcrd*cos(alfax)+wcrd*sin(alfax), -lcrd*cos(alfax)};
4546        Float_t acrdy[4] = {-lcrd*sin(alfax), lcrd*sin(alfax), -lcrd*sin(alfax)-wcrd*cos(alfax), -lcrd*sin(alfax)};
4547        Float_t bcrdx[4] = { lcrd*cos(alfax), lcrd*cos(alfax)+wcrd*sin(alfax), -lcrd*cos(alfax)+wcrd*sin(alfax), lcrd*cos(alfax)};
4548        Float_t bcrdy[4] = { lcrd*sin(alfax), lcrd*sin(alfax)-wcrd*cos(alfax), -lcrd*sin(alfax)-wcrd*cos(alfax), lcrd*sin(alfax)};
4549    
4550      //      //
4551      // CARD3  X/  Y      // CARD3  X/  Y
# Line 3958  void FEVdetector::ShowAC(){ Line 4605  void FEVdetector::ShowAC(){
4605    };    };
4606    
4607    if ( true ){    if ( true ){
4608      Float_t acrdx[4] = {-lcrd*cos(alfa), lcrd*cos(alfa), -lcrd*cos(alfa)+wcrd*sin(alfa), -lcrd*cos(alfa)};      Float_t acrdx[4] = {-lcrd*cos(alfay), lcrd*cos(alfay), -lcrd*cos(alfay)+wcrd*sin(alfay), -lcrd*cos(alfay)};
4609      Float_t acrdy[4] = {-lcrd*sin(alfa), lcrd*sin(alfa), -lcrd*sin(alfa)-wcrd*cos(alfa), -lcrd*sin(alfa)};      Float_t acrdy[4] = {-lcrd*sin(alfay), lcrd*sin(alfay), -lcrd*sin(alfay)-wcrd*cos(alfay), -lcrd*sin(alfay)};
4610      Float_t bcrdx[4] = { lcrd*cos(alfa), lcrd*cos(alfa)+wcrd*sin(alfa), -lcrd*cos(alfa)+wcrd*sin(alfa), lcrd*cos(alfa)};      Float_t bcrdx[4] = { lcrd*cos(alfay), lcrd*cos(alfay)+wcrd*sin(alfay), -lcrd*cos(alfay)+wcrd*sin(alfay), lcrd*cos(alfay)};
4611      Float_t bcrdy[4] = { lcrd*sin(alfa), lcrd*sin(alfa)-wcrd*cos(alfa), -lcrd*sin(alfa)-wcrd*cos(alfa), lcrd*sin(alfa)};      Float_t bcrdy[4] = { lcrd*sin(alfay), lcrd*sin(alfay)-wcrd*cos(alfay), -lcrd*sin(alfay)-wcrd*cos(alfay), lcrd*sin(alfay)};
4612      //      //
4613      // CARD - Y-view      // CARD - Y-view
4614      //      //
4615      Float_t cardcx = 0.12*var.sfx;      //    Float_t cardcx = 0.12*var.sfx;
4616      Float_t cardcy = 0.1475*var.sfy;      Float_t cardcx = (0.16014*(1.-lcrd*cos(alfay)))*var.sfx;
4617        //    Float_t cardcy = 0.178818*var.sfy;
4618        Float_t cardcy = (0.178818*(1.-lcrd*sin(alfay)))*var.sfy;
4619        //    Float_t cardcy = 0.1475*var.sfy;
4620      //      //
4621      // CARD4  X  Y/      // CARD4  X  Y/
4622      //      //
# Line 4065  void FEVdetector::ShowS4(Bool_t upd){ Line 4715  void FEVdetector::ShowS4(Bool_t upd){
4715    //    //
4716    if ( level.file == 2 ){    if ( level.file == 2 ){
4717      for ( Int_t j = 0; j<3; j++ ) {              for ( Int_t j = 0; j<3; j++ ) {        
4718        if ( L2->S4adc != 32. ) ms4[j] = L2->S4calibrated;        if ( L2->GetS4Level2()->S4adc != 32. ) ms4[j] = L2->GetS4Level2()->S4calibrated;
4719      };              };        
4720    };    };
4721    //        //    
# Line 4150  void FEVdetector::ShowND(){ Line 4800  void FEVdetector::ShowND(){
4800      };      };
4801    };    };
4802    if ( level.file == 2 ){    if ( level.file == 2 ){
4803      yUpperTrig = (Int_t)L2->trigPhysics;      yUpperTrig = (Int_t)L2->GetNDLevel2()->trigPhysics;
4804      yUpperBk = (Int_t)L2->upperBack;      yUpperBk = (Int_t)L2->GetNDLevel2()->upperBack;
4805      yBottomBk = (Int_t)L2->bottomBack;      yBottomBk = (Int_t)L2->GetNDLevel2()->bottomBack;
4806    };    };
4807    //    //
4808    var.trup = yUpperTrig;    var.trup = yUpperTrig;
# Line 4420  void FEVdetector::ShowTRK(Bool_t upd){ Line 5070  void FEVdetector::ShowTRK(Bool_t upd){
5070            for (Int_t m = 0; m<3; m++){            for (Int_t m = 0; m<3; m++){
5071              if ( trk->signcluster[l][m] != 0. ){              if ( trk->signcluster[l][m] != 0. ){
5072                if ( planeno == 10 ) {                if ( planeno == 10 ) {
                 x = 1024 - trk->addrcluster[l][m];  
               } else {  
5073                  x = trk->addrcluster[l][m];                  x = trk->addrcluster[l][m];
5074                  } else {
5075                    x = 1024 - trk->addrcluster[l][m];
5076                };                };
5077                linea = new TLine(14.+x,0.01,14.+x,0.3);                linea = new TLine(14.+x,0.01,14.+x,0.3);
5078                linea->SetLineWidth(2);                linea->SetLineWidth(2);
# Line 4459  void FEVdetector::ShowTRK(Bool_t upd){ Line 5109  void FEVdetector::ShowTRK(Bool_t upd){
5109        //        //
5110        // singlets X        // singlets X
5111        //        //
5112        for (Int_t sing = 0; sing < L2->nclsx(); sing++){        for (Int_t sing = 0; sing < L2->GetTrkLevel2()->nclsx(); sing++){
5113          TClonesArray &t = *(L2->SingletX);          TClonesArray &t = *(L2->GetTrkLevel2()->SingletX);
5114          TrkSinglet *singlet = (TrkSinglet*)t[sing];          TrkSinglet *singlet = (TrkSinglet*)t[sing];
5115          x = (singlet->coord[0]+singlet->coord[1])/2.;                            x = (singlet->coord[0]+singlet->coord[1])/2.;                  
5116          //          //
# Line 4484  void FEVdetector::ShowTRK(Bool_t upd){ Line 5134  void FEVdetector::ShowTRK(Bool_t upd){
5134        //        //
5135        // singlets Y        // singlets Y
5136        //        //
5137        for (Int_t sing = 0; sing < L2->nclsy(); sing++){        for (Int_t sing = 0; sing < L2->GetTrkLevel2()->nclsy(); sing++){
5138          TClonesArray &t = *(L2->SingletY);          TClonesArray &t = *(L2->GetTrkLevel2()->SingletY);
5139          TrkSinglet *singlet = (TrkSinglet*)t[sing];          TrkSinglet *singlet = (TrkSinglet*)t[sing];
5140          //          //
5141          Int_t planepad = (singlet->plane - 1)* 2;          Int_t planepad = (singlet->plane - 1)* 2;
5142          trkpad[planepad]->cd();          trkpad[planepad]->cd();
5143          trkpad[planepad]->Range(-7.05,0.,7.05,8.);          trkpad[planepad]->Range(-7.05,0.,7.05,8.);
5144          for (Int_t img=0; img<2; img++){          for (Int_t img=0; img<2; img++){
5145            x = singlet->coord[img];            x = -singlet->coord[img];
5146            Float_t xsig = singlet->sgnl;            Float_t xsig = singlet->sgnl;
5147            if ( xsig > 8. ) xsig = 8.;            if ( xsig > 8. ) xsig = 8.;
5148            //            //
# Line 4530  void FEVdetector::ShowTRK(Bool_t upd){ Line 5180  void FEVdetector::ShowTRK(Bool_t upd){
5180          dcol = 2;          dcol = 2;
5181        };        };
5182        //        //
5183        if ( L2->GetNTracks() > 0 ){        if ( L2->GetTrkLevel2()->GetNTracks() > 0 ){
5184          for (Int_t nt = 0; nt < L2->GetNTracks(); nt++){          for (Int_t nt = 0; nt < L2->GetTrkLevel2()->GetNTracks(); nt++){
5185            TrkTrack *track = L2->GetTrack(nt);              PamTrack *ptrack= L2->GetTrack(nt);
5186              TrkTrack *track = ptrack->GetTrkTrack();  
5187            if ( nt == 0 ){            if ( nt == 0 ){
5188              var.rig = 0.;              var.rig = 0.;
5189              if ( track->al[4] != 0. ) var.rig = 1./track->al[4];              if ( track->al[4] != 0. ) var.rig = 1./track->al[4];
# Line 4548  void FEVdetector::ShowTRK(Bool_t upd){ Line 5199  void FEVdetector::ShowTRK(Bool_t upd){
5199              //              //
5200              x = track->xm[plane];              x = track->xm[plane];
5201              Float_t xsig = track->dedx_x[plane];              Float_t xsig = track->dedx_x[plane];
5202              if ( track->xgood[plane] ){              if ( track->XGood(plane) ){
5203                //if ( x > -100 ){                //if ( x > -100 ){
5204                if ( xsig > 8. ) xsig = 8.;                if ( xsig > 8. ) xsig = 8.;
5205                if ( var.bw ){                if ( var.bw ){
# Line 4576  void FEVdetector::ShowTRK(Bool_t upd){ Line 5227  void FEVdetector::ShowTRK(Bool_t upd){
5227              planepad = plane * 2;              planepad = plane * 2;
5228              trkpad[planepad]->cd();              trkpad[planepad]->cd();
5229              trkpad[planepad]->Range(-7.05,0.,7.05,8.);              trkpad[planepad]->Range(-7.05,0.,7.05,8.);
5230              x = track->ym[plane];              x = -track->ym[plane];
5231              xsig = track->dedx_y[plane];              xsig = track->dedx_y[plane];
5232              if ( track->ygood[plane] ){              if ( track->YGood(plane) ){
5233                //            if ( x > -100 ){                //            if ( x > -100 ){
5234                if ( xsig > 8. ) xsig = 8.;                if ( xsig > 8. ) xsig = 8.;
5235                if ( var.bw ){                if ( var.bw ){
# Line 4628  void FEVdetector::ShowTRK(Bool_t upd){ Line 5279  void FEVdetector::ShowTRK(Bool_t upd){
5279        //        //
5280        // first of all plot crosses relatives to tracks        // first of all plot crosses relatives to tracks
5281        //        //
5282        if ( L2->GetNTracks() > 0 ){        if ( L2->GetTrkLevel2()->GetNTracks() > 0 ){
5283          for (Int_t nt = 0; nt < L2->GetNTracks(); nt++){  //      for (Int_t nt = 0; nt < L2->GetTrkLevel2()->GetNTracks(); nt++){
5284            TrkTrack *track = L2->GetTrack(nt);    //        TrkTrack *track = L2->GetTrkLevel2()->GetTrack(nt);  
5285            for (Int_t nt = 0; nt < L2->GetTrkLevel2()->GetNTracks(); nt++){
5286              PamTrack *ptrack= L2->GetTrack(nt);
5287              TrkTrack *track = ptrack->GetTrkTrack();  
5288              //
5289            for (Int_t plane = 0; plane<6; plane++){            for (Int_t plane = 0; plane<6; plane++){
5290              //              //
5291              x = track->xm[plane];              x = track->xm[plane];
5292              Float_t y = track->ym[plane];              Float_t y = -track->ym[plane];
5293              Float_t xsig = track->dedx_x[plane];              Float_t xsig = track->dedx_x[plane];
5294              Float_t ysig = track->dedx_y[plane];              Float_t ysig = track->dedx_y[plane];
5295              //    if ( x > -100 && y > -100. ){              //    if ( x > -100 && y > -100. ){
5296              if ( track->xgood[plane] && track->ygood[plane] ){              if ( track->XGood(plane) && track->YGood(plane) ){
5297                if ( var.bw ){                if ( var.bw ){
5298                  sigcol1 = -1;                  sigcol1 = -1;
5299                  sigcol2 = -1;                  sigcol2 = -1;
# Line 4676  void FEVdetector::ShowTRK(Bool_t upd){ Line 5331  void FEVdetector::ShowTRK(Bool_t upd){
5331        //        //
5332        // try to plot crosses relative to singlets        // try to plot crosses relative to singlets
5333        //        //
5334        if ( L2->nclsx() > 0 && L2->nclsy() > 0 ){        if ( L2->GetTrkLevel2()->nclsx() > 0 && L2->GetTrkLevel2()->nclsy() > 0 ){
5335          for (Int_t plane = 1; plane<7; plane++){          for (Int_t plane = 1; plane<7; plane++){
5336            //            //
5337            // count how many singlet in the x and y view for this plane:            // count how many singlet in the x and y view for this plane:
# Line 4690  void FEVdetector::ShowTRK(Bool_t upd){ Line 5345  void FEVdetector::ShowTRK(Bool_t upd){
5345            TArrayF *array2 = new TArrayF(5000);            TArrayF *array2 = new TArrayF(5000);
5346            TArrayF *sigarrax = new TArrayF(5000);            TArrayF *sigarrax = new TArrayF(5000);
5347            TArrayF *sigarray = new TArrayF(5000);            TArrayF *sigarray = new TArrayF(5000);
5348            for (Int_t sing = 0; sing < L2->nclsx(); sing++){            for (Int_t sing = 0; sing < L2->GetTrkLevel2()->nclsx(); sing++){
5349              TClonesArray &t = *(L2->SingletX);              TClonesArray &t = *(L2->GetTrkLevel2()->SingletX);
5350              TrkSinglet *singlet = (TrkSinglet*)t[sing];              TrkSinglet *singlet = (TrkSinglet*)t[sing];
5351              if ( singlet->plane == plane ){              if ( singlet->plane == plane ){
5352                arrax->AddAt(((singlet->coord[0]+singlet->coord[1])/2.),totsx);                arrax->AddAt(((singlet->coord[0]+singlet->coord[1])/2.),totsx);
# Line 4720  void FEVdetector::ShowTRK(Bool_t upd){ Line 5375  void FEVdetector::ShowTRK(Bool_t upd){
5375                totsx++;                      totsx++;      
5376              };              };
5377            };            };
5378            for (Int_t sing = 0; sing < L2->nclsy(); sing++){            for (Int_t sing = 0; sing < L2->GetTrkLevel2()->nclsy(); sing++){
5379              TClonesArray &t = *(L2->SingletY);              TClonesArray &t = *(L2->GetTrkLevel2()->SingletY);
5380              TrkSinglet *singlet = (TrkSinglet*)t[sing];              TrkSinglet *singlet = (TrkSinglet*)t[sing];
5381              if ( singlet->plane == plane ){              if ( singlet->plane == plane ){
5382                array1->AddAt(singlet->coord[0],totsy);                array1->AddAt(singlet->coord[0],totsy);
# Line 4756  void FEVdetector::ShowTRK(Bool_t upd){ Line 5411  void FEVdetector::ShowTRK(Bool_t upd){
5411              for (Int_t sing = 0; sing < min(totsx,totsy); sing++){              for (Int_t sing = 0; sing < min(totsx,totsy); sing++){
5412                //                              //              
5413                x = arrax->At(orderx->At(sing));                x = arrax->At(orderx->At(sing));
5414                Float_t y1 = array1->At(ordery->At(sing));                Float_t y1 = -array1->At(ordery->At(sing));
5415                Float_t y2 = array2->At(ordery->At(sing));                Float_t y2 = -array2->At(ordery->At(sing));
5416                Float_t xsig = sigarrax->At(orderx->At(sing));                Float_t xsig = sigarrax->At(orderx->At(sing));
5417                Float_t ysig = sigarray->At(ordery->At(sing));                Float_t ysig = sigarray->At(ordery->At(sing));
5418                if ( x > -100 && y1 > -100. ){                if ( x > -100 && y1 > -100. ){
# Line 4850  void FEVdetector::ShowTRK(Bool_t upd){ Line 5505  void FEVdetector::ShowTRK(Bool_t upd){
5505                  for (Int_t m = 0; m<3; m++){                                          for (Int_t m = 0; m<3; m++){                        
5506                    if ( trk->signcluster[l][m] != 0. ){                    if ( trk->signcluster[l][m] != 0. ){
5507                      if ( planeno == 10 ) {                      if ( planeno == 10 ) {
                       x = 1024 - trk->addrcluster[l][m];  
                     } else {  
5508                        x = trk->addrcluster[l][m];                        x = trk->addrcluster[l][m];
5509                        } else {
5510                          x = 1024 - trk->addrcluster[l][m];
5511                      };                      };
5512                      x += 1024.;                                      x += 1024.;                
5513                      if ( trk->signcluster[l][m]> ysig  ){                      if ( trk->signcluster[l][m]> ysig  ){
5514                        ysig = trk->signcluster[l][m];                        ysig = trk->signcluster[l][m];
5515                        yh1[ncro] = x-1024.;                        yh1[ncro] = x - 1024.;
5516                        yh2[ncro] = x;                        yh2[ncro] = x;
5517                      };                      };
5518                    };                    };
# Line 4885  void FEVdetector::ShowTRK(Bool_t upd){ Line 5540  void FEVdetector::ShowTRK(Bool_t upd){
5540                    for (Int_t m = 0; m<3; m++){                    for (Int_t m = 0; m<3; m++){
5541                      if ( trk->signcluster[e][m] != 0. ){                      if ( trk->signcluster[e][m] != 0. ){
5542                        if ( planeno == 10 ) {                        if ( planeno == 10 ) {
                         x = 1024 - trk->addrcluster[e][m];  
                       } else {  
5543                          x = trk->addrcluster[e][m];                          x = trk->addrcluster[e][m];
5544                          } else {
5545                            x = 1024 - trk->addrcluster[e][m];
5546                        };                        };
5547                        x += 1024.;                                              x += 1024.;                      
5548                        if ( trk->signcluster[e][m]> ysig  ){                        if ( trk->signcluster[e][m]> ysig  ){
5549                          ysig = trk->signcluster[e][m];                          ysig = trk->signcluster[e][m];
5550                          yh1[ncro] = x-1024.;                          yh1[ncro] = x - 1024.;
5551                          yh2[ncro] = x;                          yh2[ncro] = x;
5552                        };                        };
5553                      };                      };
# Line 4944  void FEVdetector::ShowTRK(Bool_t upd){ Line 5599  void FEVdetector::ShowTRK(Bool_t upd){
5599    
5600  void FEVdetector::ShowTrack(){  void FEVdetector::ShowTrack(){
5601    //    //
5602      if ( level.file != 2 ) return;
5603    //    //
5604    //    //
   if ( !var.TRK || level.file != 2 ) return;  
5605    //    //
5606    if ( L2->GetNTracks() > 0 ){    if ( var.CALO && var.CALOT ){
5607      for (Int_t nt = 0; nt < L2->GetNTracks(); nt++){      if ( L2->GetCaloLevel2()->npcfit[0] > 0 && L2->GetCaloLevel2()->npcfit[1] > 0 ){
5608        TrkTrack *track = L2->GetTrack(nt);        Float_t calx[22];
5609          Float_t caly[22];
5610          Float_t calzx[22];
5611          Float_t calzy[22];
5612          Float_t zpiano[22];
5613          zpiano[0] = (CTZ+118.)*var.sfy/1000.;
5614          for (Int_t plane = 1; plane < 22; plane++){      
5615            if ( !(plane%2) ){
5616              zpiano[plane] = zpiano[plane-1] - 8.09*var.sfy/1000.;
5617            }else {
5618              zpiano[plane] = zpiano[plane-1] - 10.09*var.sfy/1000.;
5619            };
5620          };
5621          for (Int_t plane = 0; plane < 22; plane++){      
5622            calx[plane] = (L2->GetCaloLevel2()->cbar[plane][0]/100.)*var.sfx + var.xxvc;;
5623            caly[plane] = (-L2->GetCaloLevel2()->cbar[plane][1]/100.)*var.sfx + var.xyvc;
5624            //      calzx[plane] = zpiano[plane] -5.81*var.sfy/1000. + var.yxvc;
5625            calzx[plane] = zpiano[plane] + var.yxvc;
5626            calzy[plane] = zpiano[plane] + var.yyvc;
5627            //      printf(" calx %f caly %f calzx %f calzy %f \n",calx[plane],caly[plane],calzx[plane],calzy[plane]);
5628          };
5629          //
5630          // Calorimeter track
5631          //
5632          Int_t trcol = 30;
5633          if ( var.bw ){
5634            trcol = 14;
5635          } else {
5636            trcol = 44;
5637          };
5638          thefigure->cd();
5639          TPolyLine *trakx = new TPolyLine(22,calx,calzx);
5640          trakx->SetLineColor(trcol);
5641          if ( L2->GetCaloLevel2()->fitmode[0] == 1 ) trakx->SetLineStyle(3);
5642          if ( L2->GetCaloLevel2()->fitmode[0] == 2 ) trakx->SetLineStyle(4);
5643          trakx->SetLineWidth(2);
5644          trakx->Draw();
5645          TPolyLine *traky = new TPolyLine(22,caly,calzy);
5646          traky->SetLineColor(trcol);
5647          if ( L2->GetCaloLevel2()->fitmode[1] == 1 ) traky->SetLineStyle(3);
5648          if ( L2->GetCaloLevel2()->fitmode[1] == 2 ) traky->SetLineStyle(4);
5649          traky->SetLineWidth(2);
5650          traky->Draw();      
5651        };
5652        if ( L2->GetCaloLevel2()->npcfit[2] > 0 ){
5653          Float_t calx[22];
5654          Float_t caly[22];
5655          Float_t calzx[22];
5656          Float_t calzy[22];
5657          Float_t zpiano[22];
5658          zpiano[0] = (CTZ+118.)*var.sfy/1000.;
5659          for (Int_t plane = 1; plane < 22; plane++){      
5660            if ( !(plane%2) ){
5661              zpiano[plane] = zpiano[plane-1] - 8.09*var.sfy/1000.;
5662            }else {
5663              zpiano[plane] = zpiano[plane-1] - 10.09*var.sfy/1000.;
5664            };
5665          };
5666          //
5667          //
5668          CaloTrkVar *ctra = L2->GetCaloStoredTrack(-1);
5669          //
5670          for (Int_t plane = 0; plane < 22; plane++){      
5671            calx[plane] = (ctra->tbar[plane][0]/100.)*var.sfx + var.xxvc;;
5672            caly[plane] = (-ctra->tbar[plane][1]/100.)*var.sfx + var.xyvc;
5673            //      calzx[plane] = zpiano[plane] -5.81*var.sfy/1000. + var.yxvc;
5674            calzx[plane] = zpiano[plane] + var.yxvc;
5675            calzy[plane] = zpiano[plane] + var.yyvc;
5676            //      printf(" calx %f caly %f calzx %f calzy %f \n",calx[plane],caly[plane],calzx[plane],calzy[plane]);
5677          };
5678          //
5679          // Calorimeter track
5680          //
5681          Int_t trcol = 30;
5682          if ( var.bw ){
5683            trcol = 16;
5684          } else {
5685            trcol = 46;
5686          };
5687          thefigure->cd();
5688          TPolyLine *trakx = new TPolyLine(22,calx,calzx);
5689          trakx->SetLineColor(trcol);
5690          trakx->SetLineStyle(3);
5691          trakx->SetLineWidth(2);
5692          trakx->Draw();
5693          TPolyLine *traky = new TPolyLine(22,caly,calzy);
5694          traky->SetLineColor(trcol);
5695          traky->SetLineStyle(3);
5696          traky->SetLineWidth(2);
5697          traky->Draw();      
5698        };
5699      };
5700      //
5701      if ( !var.TRK ) return;
5702      //
5703      if ( L2->GetTrkLevel2()->GetNTracks() > 0 ){
5704        for (Int_t nt = 0; nt < L2->GetTrkLevel2()->GetNTracks(); nt++){
5705    
5706          //      TrkTrack *track = L2->GetTrkLevel2()->GetTrack(nt);
5707          //      printf("qui \n");
5708          PamTrack *ptrack = L2->GetTrack(nt);
5709          TrkTrack *track = ptrack->GetTrkTrack();
5710          //      printf("qua \n");
5711        Int_t npoint = 100;        Int_t npoint = 100;
5712        Float_t zin[100];        Float_t zin[100];
5713        Double_t xout[100];        Double_t xout[100];
# Line 5004  void FEVdetector::ShowTrack(){ Line 5761  void FEVdetector::ShowTrack(){
5761        if ( !ifail ){        if ( !ifail ){
5762          for ( Int_t e = 0; e < npoint ; e++) {          for ( Int_t e = 0; e < npoint ; e++) {
5763            tx[e] = ((float)tr->x[e]/100.)*var.sfx + var.xxvc;            tx[e] = ((float)tr->x[e]/100.)*var.sfx + var.xxvc;
5764            ty[e] = ((float)tr->y[e]/100.)*var.sfx + var.xyvc;            ty[e] = (-(float)tr->y[e]/100.)*var.sfx + var.xyvc;
5765            if ( e < 50 ) {            if ( e < 50 ) {
5766              ptx1[e] = ((float)tr->y[e]/100.)*var.sfx + var.xcat;              ptx1[e] = (-(float)tr->y[e]/100.)*var.sfx + var.xcat;
5767              pty1[e] = ((float)tr->x[e]/100.)*var.sfy + var.ycat;              pty1[e] = ((float)tr->x[e]/100.)*var.sfy + var.ycat;
5768            } else {            } else {
5769              ptx2[e-50] = ((float)tr->y[e]/100.)*var.sfx + var.xcat;              ptx2[e-50] = (-(float)tr->y[e]/100.)*var.sfx + var.xcat;
5770              pty2[e-50] = ((float)tr->x[e]/100.)*var.sfy + var.ycat;              pty2[e-50] = ((float)tr->x[e]/100.)*var.sfy + var.ycat;
5771            };            };
5772            if ( e > 84 ) {            if ( e > 84 ) {
5773              tx1[e-85] = ((float)tr->x[e]/100.)*var.nds4 + var.xxvc;              tx1[e-85] = ((float)tr->x[e]/100.)*var.nds4 + var.xxvc;
5774              ty1[e-85] = ((float)tr->y[e]/100.)*var.nds4 + var.xyvc;                  ty1[e-85] = (-(float)tr->y[e]/100.)*var.nds4 + var.xyvc;    
5775              tzx1[e-85] = (0.112)*var.sfy+((float)zin[e]/100.)*var.sfy + var.yxvc;              tzx1[e-85] = (0.112)*var.sfy+((float)zin[e]/100.)*var.sfy + var.yxvc;
5776              tzy1[e-85] = (0.112)*var.sfy+((float)zin[e]/100.)*var.sfy + var.yyvc;              tzy1[e-85] = (0.112)*var.sfy+((float)zin[e]/100.)*var.sfy + var.yyvc;
5777            };            };
5778            tzx[e] = (0.112)*var.sfy+((float)zin[e]/100.)*var.sfy + var.yxvc;                            tzx[e] = (0.112)*var.sfy+((float)zin[e]/100.)*var.sfy + var.yxvc;                
5779            tzy[e] = (0.112)*var.sfy+((float)zin[e]/100.)*var.sfy + var.yyvc;            tzy[e] = (0.112)*var.sfy+((float)zin[e]/100.)*var.sfy + var.yyvc;
5780              //      printf("tx[e] %f ty [e] %f tzx %f tzy %f \n",tx[e],ty[e],tzx[e],tzy[e]);
5781          };          };
5782          //          //
5783          // From S1 to CALO          // From S1 to CALO
# Line 5157  void FEVdetector::ShowCalo(Bool_t upd){ Line 5915  void FEVdetector::ShowCalo(Bool_t upd){
5915          Int_t se = 5;          Int_t se = 5;
5916          if ( !l && m%2 == 0 ) se = 3;          if ( !l && m%2 == 0 ) se = 3;
5917          if ( !l && m%2 != 0 ) se = 2;          if ( !l && m%2 != 0 ) se = 2;
5918          if (  l && m%2 == 0 ) se = 1;          if (  l && m%2 != 0 ) se = 1;
5919          if (  l && m%2 != 0 ) se = 0;          if (  l && m%2 == 0 ) se = 0;
5920          //          //
5921          // determine what kind of event we are going to analyze          // determine what kind of event we are going to analyze
5922          //          //
# Line 5253  void FEVdetector::ShowCalo(Bool_t upd){ Line 6011  void FEVdetector::ShowCalo(Bool_t upd){
6011                Xview->Draw("box same");                Xview->Draw("box same");
6012              };                                            };                              
6013              if ( l == 1 ) {                                      if ( l == 1 ) {                        
6014                Yview->Fill(n,21-m,1.);                Yview->Fill(95-n,21-m,1.);
6015                pd2->cd();                pd2->cd();
6016                Yview->Draw("box same");                Yview->Draw("box same");
6017              };              };
# Line 5273  void FEVdetector::ShowCalo(Bool_t upd){ Line 6031  void FEVdetector::ShowCalo(Bool_t upd){
6031      //      //
6032      // Define variables      // Define variables
6033      //      //
6034      Int_t etime = var.etime;      UInt_t etime = var.etime;
6035      Float_t estrip[2][22][96], ener, basel,sdexy[2][22][96],sdexyc[2][22][96];      Float_t estrip[2][22][96], ener, basel,sdexy[2][22][96],sdexyc[2][22][96];
6036      Int_t badstrip = 0;      Int_t badstrip = 0;
6037      qtot = 0.;      qtot = 0.;
# Line 5345  void FEVdetector::ShowCalo(Bool_t upd){ Line 6103  void FEVdetector::ShowCalo(Bool_t upd){
6103        if ( calib.ttime[s][b[s]+1] && calib.time[s][b[s]] ){        if ( calib.ttime[s][b[s]+1] && calib.time[s][b[s]] ){
6104          while ( etime > calib.time[s][b[s]] && calib.time[s][b[s]] != 0 ){                                        while ( etime > calib.time[s][b[s]] && calib.time[s][b[s]] != 0 ){                              
6105            printf(" CALORIMETER: \n" );            printf(" CALORIMETER: \n" );
6106            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]],calib.ttime[s][b[s]+1]);            printf(" - Section %i, event at time %u while old calibration time limit at %u. Use new calibration at time %u -\n",s,(UInt_t)etime,(UInt_t)calib.time[s][b[s]],(UInt_t)calib.ttime[s][b[s]+1]);
6107            printf(" END CALORIMETER. \n\n" );            printf(" END CALORIMETER. \n\n" );
6108            b[s]++;            b[s]++;
6109            CaloPede(s);            CaloPede(s);
# Line 5365  void FEVdetector::ShowCalo(Bool_t upd){ Line 6123  void FEVdetector::ShowCalo(Bool_t upd){
6123          Int_t se = 5;          Int_t se = 5;
6124          if (l == 0 && m%2 == 0) se = 3;          if (l == 0 && m%2 == 0) se = 3;
6125          if (l == 0 && m%2 != 0) se = 2;          if (l == 0 && m%2 != 0) se = 2;
6126          if (l == 1 && m%2 == 0) se = 1;          if (l == 1 && m%2 != 0) se = 1;
6127          if (l == 1 && m%2 != 0) se = 0;                  if (l == 1 && m%2 == 0) se = 0;        
6128          //          //
6129          // determine what kind of event we are going to analyze          // determine what kind of event we are going to analyze
6130          //          //
# Line 5482  void FEVdetector::ShowCalo(Bool_t upd){ Line 6240  void FEVdetector::ShowCalo(Bool_t upd){
6240                    Xview->Draw("box same");                    Xview->Draw("box same");
6241                  };                                                    };                                  
6242                  if ( l == 1 ) {                                      if ( l == 1 ) {                    
6243                    Yview->Fill(n,21-m,1.);                    Yview->Fill(96-n,21-m,1.);
6244                    pd2->cd();                    pd2->cd();
6245                    Yview->Draw("box same");                    Yview->Draw("box same");
6246                  };                  };
# Line 5569  void FEVdetector::ShowCalo(Bool_t upd){ Line 6327  void FEVdetector::ShowCalo(Bool_t upd){
6327      //      //
6328      stringstream xvev;      stringstream xvev;
6329      stringstream yvev;          stringstream yvev;    
6330      for (Int_t ii = 0; ii < L2->nstrip; ii++){      for (Int_t ii = 0; ii < L2->GetCaloLevel2()->nstrip; ii++){
6331        Int_t colo;        Int_t colo;
6332        Int_t l;        Int_t l;
6333        Int_t m;        Int_t m;
6334        Int_t n;        Int_t n;
6335        Float_t mip = L2->DecodeEstrip(ii,l,m,n);        Float_t mip = L2->GetCaloLevel1()->DecodeEstrip(ii,l,m,n);
6336        if ( var.bw ){        if ( var.bw ){
6337          colo = -1;          colo = -1;
6338        } else {        } else {
# Line 5601  void FEVdetector::ShowCalo(Bool_t upd){ Line 6359  void FEVdetector::ShowCalo(Bool_t upd){
6359          gDirectory->Delete(yvev.str().c_str());          gDirectory->Delete(yvev.str().c_str());
6360          TH2F *Yview = new TH2F(yvev.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);                            TH2F *Yview = new TH2F(yvev.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);                  
6361          Yview->SetFillColor(colo);          Yview->SetFillColor(colo);
6362          Yview->Fill(n,21-m,1.);          Yview->Fill(96-n,21-m,1.);
6363          pd2->cd();          pd2->cd();
6364          Yview->Draw("box same");          Yview->Draw("box same");
6365        };        };
6366      };      };
6367      pd1->Update();      pd1->Update();
6368      pd2->Update();      pd2->Update();
6369      var.qtot=(int)L2->qtot;      var.qtot=(int)L2->GetCaloLevel2()->qtot;
6370      var.nstrip=(int)L2->nstrip;      var.nstrip=(int)L2->GetCaloLevel2()->nstrip;
6371    };    };
6372  }  }
6373    
# Line 5650  void FEVdetector::Calo1stcalib(){ Line 6408  void FEVdetector::Calo1stcalib(){
6408      for (Int_t d = 0; d<48; d++){      for (Int_t d = 0; d<48; d++){
6409        if ( calib.ttime[s][d] != 0 ) calibex++;        if ( calib.ttime[s][d] != 0 ) calibex++;
6410        if ( calib.time[s][0] != 0 ){        if ( calib.time[s][0] != 0 ){
6411          if ( d == 0 )  printf(" Section %i from time 0 to time %i use calibration at time %i \n",s,calib.time[s][d],calib.ttime[s][d]);          if ( d == 0 )  printf(" Section %i from time 0 to time %u use calibration at time %u \n",s,calib.time[s][d],calib.ttime[s][d]);
6412          if ( calib.time[s][d+1] != 0 ) {          if ( calib.time[s][d+1] != 0 ) {
6413            printf(" Section %i from time %i to time %i use calibration at time %i \n",s,calib.time[s][d],calib.time[s][d+1],calib.ttime[s][d+1]);            printf(" Section %i from time %u to time %u use calibration at time %u \n",s,calib.time[s][d],calib.time[s][d+1],calib.ttime[s][d+1]);
6414          } else {          } else {
6415            if ( !stop ){            if ( !stop ){
6416              printf(" Section %i from time %i use calibration at time %i \n",s,calib.time[s][d],calib.ttime[s][d+1]);                          printf(" Section %i from time %u use calibration at time %u \n",s,calib.time[s][d],calib.ttime[s][d+1]);            
6417              stop = 1;              stop = 1;
6418            };            };
6419          };          };
6420        } else {        } else {
6421          if ( calib.ttime[s][d] != 0 ) printf(" Section %i from time 0 use calibration at time %i \n",s,calib.ttime[s][d]);          if ( calib.ttime[s][d] != 0 ) printf(" Section %i from time 0 use calibration at time %u \n",s,calib.ttime[s][d]);
6422        };        };
6423      };      };
6424      printf("\n");            printf("\n");      
# Line 5725  int FEVdetector::OLDCaloFindCalibs(){ Line 6483  int FEVdetector::OLDCaloFindCalibs(){
6483        calib.ttime[s][inter] = 0;        calib.ttime[s][inter] = 0;
6484        if ( ce->cstwerr[s] != 0 && ce->cperror[s] == 0 ) {        if ( ce->cstwerr[s] != 0 && ce->cperror[s] == 0 ) {
6485          //calib.ttime[s][inter] = cph->GetOrbitalTime();          //calib.ttime[s][inter] = cph->GetOrbitalTime();
6486          calib.ttime[s][inter] = cph->OrbitalTime;          calib.ttime[s][inter] = (UInt_t)cph->OrbitalTime;
6487          inter++;          inter++;
6488        } else {        } else {
6489          if ( ce->cstwerr[s] != 0 && ce->cperror[s] != 0 ) {          if ( ce->cstwerr[s] != 0 && ce->cperror[s] != 0 ) {
# Line 5779  int FEVdetector::CaloPede(Int_t s){ Line 6537  int FEVdetector::CaloPede(Int_t s){
6537      tr->GetEntry(ci);      tr->GetEntry(ci);
6538      cph = ceh->GetPscuHeader();                      cph = ceh->GetPscuHeader();                
6539      //if ( atime == cph->GetOrbitalTime()){      //if ( atime == cph->GetOrbitalTime()){
6540      if ( atime == cph->OrbitalTime){      if ( atime == (UInt_t)cph->OrbitalTime){
6541        //      calib.iev = ce->iev;        //      calib.iev = ce->iev;
6542        if (ce->cstwerr[s] != 0 && ce->cperror[s] == 0 ) {        if (ce->cstwerr[s] != 0 && ce->cperror[s] == 0 ) {
6543          for ( Int_t d=0 ; d<11 ;d++  ){          for ( Int_t d=0 ; d<11 ;d++  ){

Legend:
Removed from v.1.4  
changed lines
  Added in v.1.25

  ViewVC Help
Powered by ViewVC 1.1.23