/[PAMELA software]/eventviewer/ground/macros/EventViewer.c
ViewVC logotype

Annotation of /eventviewer/ground/macros/EventViewer.c

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.4 - (hide annotations) (download)
Mon Mar 13 08:53:18 2006 UTC (18 years, 10 months ago) by mocchiut
Branch: MAIN
CVS Tags: v9r03, HEAD
Changes since 1.3: +10 -4 lines
File MIME type: text/plain
CPU consuming bug fixed

1 mocchiut 1.1 //-------------------------------------------------------------------------------------------------------------------------------------------------------
2     //
3 mocchiut 1.4 // EventViewer.c version 9.03 (2006-03-10)
4 mocchiut 1.1 //
5     // Shows PAMELA events - Emiliano Mocchiutti
6     //
7     //-------------------------------------------------------------------------------------------------------------------------------------------------------
8     //
9     // The only input needed is the path to the directory ("filename") created by YODA for the data file you want to analyze.
10     //
11     // Standard use:
12     //
13 mocchiut 1.3 // bash> EventViewer
14 mocchiut 1.1 //
15     // For further informations use:
16     //
17 mocchiut 1.3 // EventViewer --help
18 mocchiut 1.1 //
19     // or
20     //
21 mocchiut 1.3 // EventViewer --version
22 mocchiut 1.1 //
23     //-------------------------------------------------------------------------------------------------------------------------------------------------------
24     //
25     // Changelog:
26     //
27 mocchiut 1.4 // 9.02 - 9.03 (2006-03-10): Figure still editable during searching, fixed. Fixed CPU consuming.
28     //
29 mocchiut 1.3 // 9.01 - 9.02 (2006-03-09): Now reads tracker software output from v3r02. Small bugs fixed (figure not editable now and complete text inside the GUI if there are only files with the same name).
30     //
31     // 9.00 - 9.01 (2006-03-03): Many bugs fixed and some correction in the behaviour in some cases (many thanks to Silvio for help in developing and debugging!).
32     //
33     // 8.02 - 9.00 (2006-02-17): Added the Graphic User Interface, fixed some old bugs, many new features (on fly load and unload files and selection files, stop searching
34     // while in selection mode, on fly level0/best level switching, fork the application/no text output flag,... )
35     //
36     // 8.01 - 8.02 (2006-02-16): Don't show positions not used in determine the track. Shows S4 mip values in standard mode (not scientific notation).
37     //
38 mocchiut 1.2 // 8.00 - 8.01 (2006-01-10): Added tracker measured positions used to determine the track.
39     //
40 mocchiut 1.1 // 7.03 - 8.00 (2005-11-24): many changes to compile the macro. The code is still very redundant and heavy but some bugs were fixed and now it should be more stable.
41     // Do not require anymore the AcFunctions.h header, a clone has been written (aclev1class.h).
42     //
43     // 7.02 - 7.03 (2005-10-14): load library containing CalorimeterLevel1 class definition.
44     //
45     // 7.01 - 7.02 (2005-10-12): changed neutron detector color scale to a more realistic one.
46     //
47     // 7.00 - 7.01 (2005-10-10): simplyfied input (less parameters), added support for TOF level1 data.
48     //
49     // 6.05 - 7.00 (2005-09-21): changes to work with tracker software version 2.00.
50     //
51     // 6.04 - 6.05 (2005-08-03): changes to fix bugs related to 64 bit arch.
52     //
53     // 6.03 - 6.04 (2005-07-22): small bug in signal visualization in TOF S11 fixed.
54     //
55     // 6.02 - 6.03 (2005-07-19): use clone routines of yodaUtility.c that can be found in CaloFunctions.h and don't load anymore yodaUtility.c
56     //
57     // 6.01 - 6.02 (2005-07-12): small changes due to correction for the compilation of CaloFunctions.h.
58     //
59     // 6.00 - 6.01 (2005-07-07): AC, now it reads LEVEL1 output (hit are shown with different colour if they are not in time with trigger). Some AC related small bugs fixed.
60     // Added synchronization routines between "YODA" output and tracker output (I am assuming that everything comes out from YODA is synchronized).
61     //
62     // 5.21 - 6.00 (2005-07-06): Now it can read tracker rootples generated by the GroundDataConvert software. Some minor bugs related to tracker visualization fixed.
63     // Notice that tracker data are not synchronized yet to the "YODA" data.
64     //
65     // 5.20 - 5.21 (2005-06-29): Added some options in the interactive menu (B/W toggling, track in S4/ND toggling). Created a new include file with structures for the
66     // event viewer, changed the WhatToDO routine, now renamed in WhatToDoEV. Bug: cannot run program twice when showing track without quitting
67     // ROOT, fixed. Changed "CALO" to "Calorimeter" and "TRK" to "Tracker" in verbose infos mode. Bug: don't show trigger configuration on the text
68     // output when no infos are shown on the figure, fixed. Increased the width of the track line.
69     //
70     // 5.19 - 5.20 (2005-06-28): Bug: S4 z dimension is wrong! corrected. New filename and changes needed to upgrade to the new software architecture.
71     //
72     // 5.18 - 5.19 (2005-06-16): Bug: S4/PULSER flag is not always correct since sometimes the trigger is given by S4 but the flag is not set. Fixed (?) with a
73     // workaround, to be checked that is the best we can do.
74     //
75     // 5.17 - 5.18 (2005-06-14): Added black and white visualization (use input variable "BW" as flag). Wrong position of S4 in level0 visualization, fixed. Saved PS files do not
76     // contain the TOF information from TDC position, fixed.
77     //
78     // 5.16 - 5.17 (2005-06-08): S4 level0 and level1 splitted. Level0 shows the patterntrig variable (NB: NOT ALWAYS CORRECT!!), Level1 shows calibrated info from S4.
79     //
80     // 5.15 - 5.16 (2005-06-07): Unload libraries when exiting and change back to the starting directory. Check if the file is older than 050515_007.
81     //
82     // 5.14 - 5.15 (2005-05-17): Crashes if ADC to MIP calorimeter conversion value is zero, fixed.
83     //
84     // 5.13 - 5.14 (2005-05-13): Force level0 visualization also for the calorimeter.
85     //
86     // 5.12 - 5.13 (2005-05-10): Calorimeter Z dimension is WRONG!!! fixed.
87     //
88     // 5.11 - 5.12 (2005-05-02): OBT is On Board Time and not Orbital Time!
89     //
90     // 5.10 - 5.11 (2005-04-19): Bug fixed in the new subroutine ShowTOFL1 and changed to the old behaviour the calorimeter calibration search (it could took long time
91     // to find a good calibration with the new method expecially in the case of a directory with a single file).
92     //
93     // 5.09 - 5.10 (2005-04-18): Added ShowTOFL1 subroutine to show TOF informations instead of trigger infos. Still it possible to see trigger infos forcing level0 data.
94     //
95     // 5.08 - 5.09 (2005-04-11): Changes in the CaloShowL0 subroutine: do not calibrate more than once if there is a jump in OBT.
96     //
97     // 5.07 - 5.08 (2005-04-07): Changes in the CaloShowL0 subroutine. Changed tree name of level1 and adc2mip calorimeter data.
98     //
99     // 5.06 - 5.07 (2005-04-05): Bug in the rigidity and chi2 report in the figure, fixed.
100     //
101     // 5.05 - 5.06 (2005-03-30): Small changes in the whattodo behaviour.
102     //
103     // 5.04 - 5.05 (2005-03-23): Introduced the input variable FORCELEV to force the data level to load. For now it is possible only to force level0 data
104     // reading of calorimeter and tracker. News: the selection file name now can be anyone and must be used as input if you want
105     // to select events. Hence the "selection" integer input has become the string "selfile".
106     //
107     // 5.03 - 5.04 (2005-03-18): Small changes in the print out.
108     //
109     // 5.02 - 5.03 (2005-03-17): Cannot go backward in selection mode, fixed. Change in ShowS4 the S4 calibration parameter.
110     // New: now it is possible to jump to a certain event number and not only to progressive number.
111     //
112     // 5.01 - 5.02 (2005-03-16): Pulser information is now printed in the INFOS and S4 MIP signal (first order calibration) is represented with colours
113     // (same palette as for calorimeter).
114     //
115     // 5.00 - 5.01 (2005-03-14): Information text size increased.
116     //
117     // 4.11 - 5.00 (2005-03-11): Track visualization offset bug fixed. Reload magnetic field maps if back to the first event, fixed.
118     // Added some comments in the code. Added level2 tracker data to filter.c.
119     //
120     // 4.10 - 4.11 (2005-03-10): Tracker LEVEL1 visualization implemented. Changed the tracker directory from "magnet" to "tracker". Show LEVEL1 information
121     // even if LEVEL2 data are not present.
122     //
123     // 4.09 - 4.10 (2005-03-08): Read the calorimeter calibration file if trying to generate level 1 data.
124     //
125     // 4.08 - 4.09 (2005-03-03): S4 always shown as hit, fixed.
126     //
127     // 4.07 - 4.08 (2005-02-25): In filter mode added a progress viewer. CAS1 plane view was filled with full red colour instead of pinkish colour, fixed.
128     //
129     // 4.06 - 4.07 (2005-02-25): crashes when exiting on empty files. Fixed.
130     //
131     // 4.05 - 4.06 (2005-02-24): Changed order of input variables.
132     //
133     // 4.04 - 4.05 (2005-02-24): Changed variable definition from C/C++ style to ROOT style (int->Int_t).
134     //
135     // 4.03 - 4.04 (2005-02-23): Added the "selection" input variable. If set greater than zero the program will look for
136     // events satisfying the condition in the filter.c program. Notice that running in this configuration
137     // will not let you to go backward with events.
138     //
139     // 4.02 - 4.03 (2005-02-23): Sometimes the calorimeter was repeating an event to infinity. Fixed.
140     //
141     // 4.01 - 4.02 (2005-02-22): ROOT 4.03/02 version bug fixed (calorimeter only).
142     //
143     // 4.00 - 4.01 (2005-02-18): Calorimeter compress/full raw mode visualization didn't work. Fixed. Neutron detector data format changed, fixed accordingly.
144     //
145     // 3.04 - 4.00 (2005-02-14): Small changes in the calorimeter x/y view and in the tracker plane view geometries.
146     // Added the track visualization code once you have tracker LEVEL2 data.
147     //
148     // 3.03 - 3.04 (2005-02-10): Show not only the YODA number (progressive number) but also the EVENT NUMBER from the packet header!
149     //
150     // 3.02 - 3.03 (2005-02-08): TOF scintillators divided into A and B PMTs. Upper triangles are A PMT, lower triangles are B PMTs. S4 readout implemented:
151     // the information comes from the trigger board and the energy level is drawn out as LEVEL0 information. Some bugs in the
152     // scintillators order fixed. Changed color of shadow hit in the tracker Y-view; added small black dot on tracker ladders to
153     // indicate the detectors edges.
154     //
155     // 3.01 - 3.02 (2005-02-04): Tracker hit shown in the plane view. CAS shown in the plane view. Level0 TOF information shown in the scintillators.
156     // Bug for which it is not possible to see only the last event, fixed.
157     //
158     // 3.00 - 3.01 (2005-01-31): AC CARD view from above added. Printing bug fixed, now it calls for the WhatToDo routine in CaloFunctions.h.
159     //
160     // 2.01 - 3.00 (2005-01-21): Major changes in the program philosophy: now it will check first for higher order LEVEL data and it will use low level data
161     // only as last resurce.
162     //
163     // 2.00 - 2.01 (2005-01-18): AC cat changed, added PMTs, AC hits out of triggers are shown now in a different colour. Added "go backward" capability.
164     //
165     // 1.01 - 2.00 (2005-01-14): many changes, some cleanup of the code, detectors are in scale.
166     //
167     // 1.00 - 1.01 (2004-12-15): Include also yodaUtility.c .
168     //
169     #include <math.h>
170     #include <stdio.h>
171     //
172     #include <fstream>
173     #include <sstream>
174     #include <iostream>
175     #include <iomanip>
176     //
177 mocchiut 1.3 #include <TObjectTable.h>
178     #include <TGClient.h>
179     #include <TGButton.h>
180     #include <TGComboBox.h>
181     #include <TGLabel.h>
182     #include <TGTextEntry.h>
183     #include <TGFrame.h>
184     #include <TGButtonGroup.h>
185     #include <TGProgressBar.h>
186     #include <TGMsgBox.h>
187     #include <TGComboBox.h>
188     //
189 mocchiut 1.1 #include <TTree.h>
190     #include <TClassEdit.h>
191     #include <TObject.h>
192     #include <TList.h>
193     #include <TSystem.h>
194     #include <TSystemDirectory.h>
195     #include <TString.h>
196     #include <TFile.h>
197     #include <TClass.h>
198     #include <TCanvas.h>
199     #include <TH1.h>
200     #include <TH1F.h>
201     #include <TH2D.h>
202     #include <TLatex.h>
203     #include <TPad.h>
204     #include <TPaveLabel.h>
205     #include <TLine.h>
206     #include <TPolyLine.h>
207     #include <TChain.h>
208     #include <TApplication.h>
209     #include <TVirtualX.h>
210     #include <TGClient.h>
211     #include <TGWindow.h>
212     #include <TEllipse.h>
213     #include <TArrow.h>
214     #include <TStyle.h>
215     //
216     #include <trklev1struct.h>
217     //
218     #if !defined (__CINT__)
219     #include <event/PamelaRun.h>
220     #include <event/physics/calorimeter/CalorimeterEvent.h>
221     #include <event/physics/trigger/TriggerEvent.h>
222     #include <event/physics/tof/TofEvent.h>
223     #include <event/physics/tracker/TrackerEvent.h>
224     #include <event/physics/anticounter/AnticounterEvent.h>
225     #include <event/physics/neutronDetector/NeutronEvent.h>
226     #include <event/physics/S4/S4Event.h>
227     #include <event/CalibCalPedEvent.h>
228     #include <event/CalibTrk1Event.h>
229     #include <event/CalibTrk2Event.h>
230     #include <caloclasses.h>
231     extern const char *pathtocalibration();
232     extern void creadB(const char []);
233     extern void projectlev1(Trklev1 &);
234     extern void ctrack(int, Double_t [], Double_t [], Double_t [], Double_t [], int &);
235     #endif
236     //
237     //
238     #include <CaloFunctions.h>
239     #include <eventviewer.h>
240     //
241     #include <ctrkstruct.h>
242     #include <ctrkinclude.h>
243     #include <ctofstruct.h>
244     #include <ctofinclude.h>
245     #include <aclev1class.h>
246     //
247    
248     void unload1(){
249     #if defined (__CINT__)
250     char *pam_lib=gSystem->Getenv("PAM_LIB");
251     stringstream libload1;
252     libload1.str("");
253     libload1 << pam_lib << "/libptlevel1_C";
254     gSystem->Unload(libload1.str().c_str());
255     char *pam_lib=gSystem->Getenv("PAM_LIB");
256     stringstream libload1;
257     libload1.str("");
258     libload1 << pam_lib << "/libptlevel1";
259     gSystem->Unload(libload1.str().c_str());
260     #endif
261     }
262    
263     void unload2(){
264     #if defined (__CINT__)
265     char *pam_lib=gSystem->Getenv("PAM_LIB");
266     stringstream libload;
267     libload.str("");
268     libload << pam_lib << "/libreadb2maps_C";
269     gSystem->Unload(libload.str().c_str());
270     libload.str("");
271     char *pam_lib=gSystem->Getenv("PAM_LIB");
272     libload << pam_lib << "/libreadb2maps";
273     gSystem->Unload(libload.str().c_str());
274     libload.str("");
275     char *pam_lib=gSystem->Getenv("PAM_LIB");
276     libload << pam_lib << "/libtrack_C";
277     gSystem->Unload(libload.str().c_str());
278     stringstream libload;
279     libload.str("");
280     char *pam_lib=gSystem->Getenv("PAM_LIB");
281     libload << pam_lib << "/libtrack";
282     gSystem->Unload(libload.str().c_str());
283     #endif
284     }
285 mocchiut 1.3
286     //
287     // GUI
288     //
289    
290     class PAMevcontrol : public TGMainFrame {
291    
292     private:
293     TGHProgressBar *fHProg1;
294     TGTextEntry *fText2;
295     TGTextEntry *fText4;
296     TGComboBox *fCombo;
297     TCanvas *thefigure;
298     struct Variables *cvar;
299    
300     public:
301     PAMevcontrol(const TGWindow *p,UInt_t w,UInt_t h,struct Variables & var, TCanvas &figure);
302     virtual ~PAMevcontrol();
303     void chktof();
304     void chkac();
305     void chktrk();
306     void chkcalo();
307     void chks4();
308     void chknd();
309     void chkinfo();
310     void chknames();
311     void chkpalette();
312     void radiocolor();
313     void radiobw();
314     void radiotrack();
315     void forcel0();
316     void next();
317     void prev();
318     void stop();
319     void SetFilename();
320     void SetFilter();
321     void jumpto();
322     void radioevent();
323     void radioprog();
324     void saveas();
325     void CompleteText();
326     void Close();
327     void increment(float val);
328     void DIALOG(Int_t ty, TString warn);
329     void clearselfi();
330     void upgrnamfi();
331     void Terminate();
332     ClassDef(PAMevcontrol,0);
333     };
334    
335     PAMevcontrol::PAMevcontrol(const TGWindow *p,UInt_t w,UInt_t h,Variables & var, TCanvas &figure) : TGMainFrame(p, w, h){
336     //
337     SetCleanup(kDeepCleanup);
338     DontCallClose();
339     Connect("CloseWindow()","PAMevcontrol",this,"Terminate()");
340     //
341     cvar = &var;
342     thefigure = &figure;
343     //
344     TGCompositeFrame *cframe1 = new TGCompositeFrame(this, 280, 60, kVerticalFrame);
345     TGCompositeFrame *cframe2 = new TGCompositeFrame(this, 280, 60, kVerticalFrame);
346     TGCompositeFrame *cframe3 = new TGCompositeFrame(this, 280, 60, kVerticalFrame);
347     TGCompositeFrame *cframe4 = new TGCompositeFrame(this, 280, 60, kVerticalFrame);
348     TGGroupFrame *gf = new TGGroupFrame(cframe1, "Appearance");
349     TGGroupFrame *inputf = new TGGroupFrame(cframe2, "Input");
350     TGGroupFrame *jumpf = new TGGroupFrame(cframe3, "Jump to");
351     TGGroupFrame *savef = new TGGroupFrame(cframe4, "Save figure as");
352     //
353     TGHorizontalFrame *htexts = new TGHorizontalFrame(savef,400,800);
354     TGHorizontalFrame *htextsl = new TGHorizontalFrame(cframe4,400,800);
355     TGHorizontalFrame *htext = new TGHorizontalFrame(inputf,400,800);
356     TGHorizontalFrame *htext2 = new TGHorizontalFrame(inputf,400,800);
357     TGHorizontalFrame *htext3 = new TGHorizontalFrame(jumpf,400,800);
358     TGHorizontalFrame *htext4 = new TGHorizontalFrame(jumpf,400,80);
359     TGHorizontalFrame *hframe = new TGHorizontalFrame(this,400,800);
360     TGHorizontalFrame *hframe1 = new TGHorizontalFrame(gf, 280, 50);
361     TGHorizontalFrame *hframe2 = new TGHorizontalFrame(gf, 280, 40);
362     TGHorizontalFrame *hframe3 = new TGHorizontalFrame(gf, 280, 40);
363     TGHorizontalFrame *hframe4 = new TGHorizontalFrame(gf,280,10);
364     TGVerticalFrame *hframe5 = new TGVerticalFrame(hframe4, 280, 40);
365     TGHorizontalFrame *hfrprog = new TGHorizontalFrame(this,400,800);
366     //
367     TGTextEntry *fText = new TGTextEntry(htext, new TGTextBuffer(20),-1);
368     fText->SetText(cvar->thefilename.Data());
369     TGTextButton *Load = new TGTextButton(htext,"Load");
370     Load->Connect("Pressed()","TGTextEntry",fText,"ReturnPressed()");
371     fText->Connect("ReturnPressed()", "PAMevcontrol", this,"SetFilename()");
372     fText->Connect("TabPressed()", "PAMevcontrol", this,"CompleteText()");
373     htext->AddFrame(fText, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY, 0, 5, 5, 5));
374     htext->AddFrame(Load, new TGLayoutHints(kLHintsCenterX | kLHintsExpandX,0,5,5,5));
375     inputf->AddFrame(new TGLabel(inputf, new TGHotString("Filename:")));
376     inputf->AddFrame(htext, new TGLayoutHints(kLHintsExpandX));
377     //
378     fText2 = new TGTextEntry(htext2, new TGTextBuffer(20),-1);
379     fText2->SetText(cvar->thefilter.Data());
380     TGTextButton *Load2 = new TGTextButton(htext2,"Load");
381     Load2->Connect("Clicked()","TGTextEntry",fText2,"ReturnPressed()");
382     fText2->Connect("ReturnPressed()", "PAMevcontrol", this,"SetFilter()");
383     fText2->Connect("TabPressed()", "PAMevcontrol", this,"CompleteText()");
384     htext2->AddFrame(fText2, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY, 0, 5, 5, 5));
385     htext2->AddFrame(Load2, new TGLayoutHints(kLHintsCenterX | kLHintsExpandX,0,5,5,5));
386     inputf->AddFrame(new TGLabel(inputf, new TGHotString("Selection file:")));
387     inputf->AddFrame(htext2, new TGLayoutHints(kLHintsExpandX));
388     //
389     cframe2->AddFrame(inputf,new TGLayoutHints(kLHintsExpandX,5,5,5,5));
390     //
391     TGCheckButton *fchktof = new TGCheckButton(hframe1, "TOF");
392     fchktof->Connect("Clicked()","PAMevcontrol", this,"chktof()");
393     if ( cvar->TOF ) fchktof->SetState(kButtonDown);
394     hframe1->AddFrame(fchktof, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,0,5,5,5));
395     //
396     TGCheckButton *fchkac = new TGCheckButton(hframe1, "AC");
397     fchkac->Connect("Clicked()","PAMevcontrol", this,"chkac()");
398     if ( cvar->AC ) fchkac->SetState(kButtonDown);
399     hframe1->AddFrame(fchkac, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,5,25,5,5));
400     //
401     TGCheckButton *fchktrk = new TGCheckButton(hframe1, "Tracker");
402     fchktrk->Connect("Clicked()","PAMevcontrol",this,"chktrk()");
403     if ( cvar->TRK ) fchktrk->SetState(kButtonDown);
404     hframe1->AddFrame(fchktrk, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,10,5,5,5));
405     //
406     gf->AddFrame(hframe1, new TGLayoutHints(kLHintsExpandX));
407     //
408     TGCheckButton *fchks4 = new TGCheckButton(hframe2, "S4");
409     fchks4->Connect("Clicked()","PAMevcontrol",this,"chks4()");
410     if ( cvar->S4 ) fchks4->SetState(kButtonDown);
411     hframe2->AddFrame(fchks4, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,0,15,5,5));
412     //
413     TGCheckButton *fchknd = new TGCheckButton(hframe2, "ND");
414     fchknd->Connect("Clicked()","PAMevcontrol",this,"chknd()");
415     if ( cvar->ND ) fchknd->SetState(kButtonDown);
416     hframe2->AddFrame(fchknd, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,5,25,5,5));
417     //
418     TGCheckButton *fchkcalo = new TGCheckButton(hframe2, "Calorimeter");
419     fchkcalo->Connect("Clicked()","PAMevcontrol",this,"chkcalo()");
420     if ( cvar->CALO ) fchkcalo->SetState(kButtonDown);
421     hframe2->AddFrame(fchkcalo, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,10,2,5,5));
422     //
423     gf->AddFrame(hframe2, new TGLayoutHints(kLHintsExpandX));
424     //
425     TGCheckButton *fchkinfo = new TGCheckButton(hframe3, "Infos");
426     fchkinfo->Connect("Clicked()","PAMevcontrol",this,"chkinfo()");
427     if ( cvar->INFOS ) fchkinfo->SetState(kButtonDown);
428     hframe3->AddFrame(fchkinfo, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,0,5,5,5));
429     //
430     TGCheckButton *fchknames = new TGCheckButton(hframe3, "Names");
431     fchknames->Connect("Clicked()","PAMevcontrol",this,"chknames()");
432     if ( cvar->VINFOS ) fchknames->SetState(kButtonDown);
433     hframe3->AddFrame(fchknames, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,5,5,5,5));
434     TGCheckButton *fchkpalette = new TGCheckButton(hframe3, "Palette");
435     fchkpalette->Connect("Clicked()","PAMevcontrol",this,"chkpalette()");
436     if ( cvar->PALETTE) fchkpalette->SetState(kButtonDown);
437     hframe3->AddFrame(fchkpalette, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,10,5,5,5));
438     gf->AddFrame(hframe3, new TGLayoutHints(kLHintsExpandX));
439     //
440     TGVButtonGroup *group = new TGVButtonGroup(hframe4);
441     TGRadioButton *bwc0;
442     TGRadioButton *bwc1;
443     bwc0 = new TGRadioButton(group, "Colour");
444     bwc1 = new TGRadioButton(group, "B/W");
445     if ( cvar->bw ){
446     bwc1->SetState(kButtonDown);
447     } else {
448     bwc0->SetState(kButtonDown);
449     };
450     bwc0->Connect("Pressed()", "PAMevcontrol",this,"radiocolor()");
451     bwc1->Connect("Pressed()", "PAMevcontrol",this,"radiobw()");
452     hframe4->AddFrame(group,new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,1,5,5,5));
453     //
454     //
455     TGCheckButton *ftrks4 = new TGCheckButton(hframe5, "Track in S4/ND");
456     ftrks4->Connect("Clicked()","PAMevcontrol",this,"radiotrack()");
457     if ( cvar->tracknds4) ftrks4->SetState(kButtonDown);
458     hframe5->AddFrame(ftrks4, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,5,2,5,5));
459     TGCheckButton *ffl0 = new TGCheckButton(hframe5, "Force LEVEL0");
460     ffl0->Connect("Clicked()","PAMevcontrol",this,"forcel0()");
461     if ( cvar->fl0 ) ffl0->SetState(kButtonDown);
462     hframe5->AddFrame(ffl0, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,5,2,5,5));
463     //
464     hframe4->AddFrame(hframe5, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY,10,5,5,5));
465     gf->AddFrame(hframe4, new TGLayoutHints(kLHintsExpandX));
466     //
467     cframe1->AddFrame(gf, new TGLayoutHints(kLHintsExpandX));
468     //
469     TGHButtonGroup *jgroup = new TGHButtonGroup(htext4);
470     TGRadioButton *jbwc0;
471     TGRadioButton *jbwc1;
472     jbwc0 = new TGRadioButton(jgroup, "event ");
473     jbwc1 = new TGRadioButton(jgroup, "progressive");
474     jbwc1->SetState(kButtonDown);
475     jbwc0->Connect("Pressed()", "PAMevcontrol",this,"radioevent()");
476     jbwc1->Connect("Pressed()", "PAMevcontrol",this,"radioprog()");
477     htext4->AddFrame(jgroup,new TGLayoutHints(kLHintsExpandX,1,1,0,0));
478     //
479     TGTextEntry *fText3 = new TGTextEntry(htext3, new TGTextBuffer(6),-1);
480     TGTextButton *Jump = new TGTextButton(htext3,"go");
481     Jump->Connect("Clicked()","TGTextEntry",fText3,"ReturnPressed()");
482     fText3->Connect("ReturnPressed()", "PAMevcontrol", this,"jumpto()");
483     htext3->AddFrame(new TGLabel(htext3, new TGHotString("number")), new TGLayoutHints(kLHintsExpandX,0,0,1,1));
484     htext3->AddFrame(fText3, new TGLayoutHints(kLHintsExpandX, 0, 8, 0, 0));
485     htext3->AddFrame(Jump, new TGLayoutHints(kLHintsExpandX,0,0,0,0));
486     jumpf->AddFrame(htext4, new TGLayoutHints(kLHintsExpandX,0,0,1,1)); //
487     jumpf->AddFrame(htext3, new TGLayoutHints(kLHintsExpandX,0,0,0,1)); //
488     //
489     cframe3->AddFrame(jumpf,new TGLayoutHints(kLHintsExpandX,5,5,5,5));
490     //
491     fText4 = new TGTextEntry(htexts, new TGTextBuffer(18),-1);
492     TGTextButton *save = new TGTextButton(htextsl,"save");
493     save->Connect("Clicked()","TGTextEntry",fText4,"ReturnPressed()");
494     fText4->Connect("ReturnPressed()", "PAMevcontrol", this,"saveas()");
495     fText4->Connect("TabPressed()", "PAMevcontrol", this,"CompleteText()");
496     htexts->AddFrame(fText4, new TGLayoutHints(kLHintsExpandX, 0, 8, 1, 1));
497     //
498     fCombo = new TGComboBox(htexts, 98);
499     fCombo->AddEntry(".ps", 0);
500     fCombo->AddEntry(".eps", 1);
501     fCombo->AddEntry(".gif", 2);
502     fCombo->AddEntry(".jpg", 3);
503     fCombo->AddEntry(".tiff", 4);
504     fCombo->AddEntry(".xpm", 5);
505     fCombo->AddEntry(".pdf", 6);
506     fCombo->AddEntry(".xml", 7);
507     fCombo->AddEntry(".png", 8);
508     fCombo->AddEntry(".svg", 9);
509     fCombo->AddEntry(".root", 10);
510     fCombo->AddEntry(".C", 11);
511     fCombo->Select(0);
512     fCombo->Resize(50,23);
513     // htexts->AddFrame(fCombo, new TGLayoutHints(kLHintsCenterX | kLHintsTop | kLHintsLeft | kLHintsCenterY | kLHintsExpandX, 0, 8, 1, 1));
514     htexts->AddFrame(fCombo, new TGLayoutHints(kLHintsExpandY | kLHintsRight, 2, 2, 2, 1));
515     //
516     htextsl->AddFrame(save, new TGLayoutHints(kLHintsExpandX,0,0,2,1));
517     savef->AddFrame(htexts, new TGLayoutHints(kLHintsExpandX,0,0,2,5));
518     // savef->AddFrame(htextsl, new TGLayoutHints(kLHintsExpandX,5,2,5,2));
519     savef->AddFrame(htextsl, new TGLayoutHints(kLHintsExpandX,8,0,5,2));
520     //
521     cframe4->AddFrame(savef,new TGLayoutHints(kLHintsExpandX,5,5,5,5));
522     //
523     fHProg1 = new TGHProgressBar(hfrprog, TGProgressBar::kFancy, 260);
524     fHProg1->SetBarColor("green");
525     fHProg1->ShowPosition();
526     hfrprog->AddFrame(fHProg1, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsCenterY | kLHintsExpandX,5,5,5,5));
527     //
528     //
529     TGTextButton *prev = new TGTextButton(hframe,"< &Back");
530     prev->Connect("Clicked()","PAMevcontrol",this,"prev()");
531     hframe->AddFrame(prev, new TGLayoutHints(kLHintsCenterX | kLHintsExpandX,5,5,3,4));
532     //
533     TGTextButton *exit = new TGTextButton(hframe,"E&xit");
534     exit->Connect("Clicked()","PAMevcontrol",this,"Terminate()");
535     //,"gApplication->Terminate(0)");
536     exit->SetToolTipText("Quit the event viewer");
537     hframe->AddFrame(exit, new TGLayoutHints(kLHintsCenterX | kLHintsExpandX,5,5,3,4));
538     //
539     TGTextButton *stop = new TGTextButton(hframe,"&Stop");
540     stop->Connect("Clicked()","PAMevcontrol",this,"stop()");
541     hframe->AddFrame(stop, new TGLayoutHints(kLHintsCenterX | kLHintsExpandX,5,5,3,4));
542     //
543     TGTextButton *next = new TGTextButton(hframe,"&Next >");
544     next->Connect("Clicked()","PAMevcontrol",this,"next()");
545     hframe->AddFrame(next, new TGLayoutHints(kLHintsCenterX | kLHintsExpandX,5,5,3,4));
546     //
547     //
548     // AddFrame(htext, new TGLayoutHints(kLHintsExpandX,2,2,15,1));
549     AddFrame(cframe2, new TGLayoutHints(kLHintsExpandX,1,1,1,1));
550     AddFrame(cframe1, new TGLayoutHints(kLHintsExpandX,1,1,1,1));
551     AddFrame(cframe3, new TGLayoutHints(kLHintsExpandX,1,1,1,1));
552     AddFrame(cframe4, new TGLayoutHints(kLHintsExpandX,1,1,1,1));
553     AddFrame(hfrprog, new TGLayoutHints(kLHintsExpandX,1,1,1,1));
554     AddFrame(hframe, new TGLayoutHints(kLHintsExpandX | kLHintsExpandY,1,1,1,1));
555     // Set a name to the main frame
556     SetWindowName("PAMELA Event Viewer control panel");
557     // Map all subwindows of main frame
558     MapSubwindows();
559     // Initialize the layout algorithm
560     Resize(GetDefaultSize());
561     // Map main frame
562     MapWindow();
563     }
564    
565     void PAMevcontrol::DIALOG(Int_t ty, TString warn){
566     //
567     // ty = 0 -> INFO, ty = 1 -> WARNING, ty = 3 -> ERROR
568     //
569     Int_t retval;
570     TString title;
571     EMsgBoxIcon mb_icon = kMBIconStop;
572     if ( ty == 0 ){
573     title="INFO";
574     mb_icon = kMBIconAsterisk;
575     };
576     if ( ty == 1 ){
577     title="WARNING!";
578     mb_icon = kMBIconExclamation;
579     };
580     if ( ty == 2 ){
581     title="ERROR!!";
582     mb_icon = kMBIconStop;
583     };
584     new TGMsgBox(gClient->GetRoot(), this, title.Data(), warn.Data(), mb_icon, kMBOk, &retval);
585     }
586    
587    
588     void PAMevcontrol::SetFilename() {
589     TGTextEntry *entry = (TGTextEntry*)gTQSender;
590     TString text = entry->GetText();
591     cvar->thefilename=text.Data();
592     cvar->nevents = 0;
593     cvar->firstevno = 0;
594     cvar->lastevno = 0;
595     cvar->restart = true;
596     cvar->waitforever = false;
597     }
598    
599     void PAMevcontrol::SetFilter() {
600     TGTextEntry *entry = (TGTextEntry*)gTQSender;
601     TString text = entry->GetText();
602     cvar->thefilter=text.Data();
603     cvar->i--;
604     cvar->selex = false;
605     cvar->nevents = 0;
606     cvar->firstevno = 0;
607     cvar->lastevno = 0;
608     cvar->refresh = true;
609     }
610    
611     void PAMevcontrol::CompleteText() {
612     TGTextEntry *entry = (TGTextEntry*)gTQSender;
613     TString text = entry->GetText();
614     Int_t curspos = entry->GetCursorPosition();
615     Int_t ncurspos = 0;
616     TString textrem;
617     stringcopy(textrem,text,curspos,text.Length());
618     text.Resize(curspos);
619     if ( !strcmp(text.Data(),"") ) {
620     stringstream ntext;
621     ntext.str("");
622     ntext << gSystem->ExpandPathName("$HOME");
623     text = ntext.str().c_str();
624     curspos=ntext.str().length();
625     };
626     char *test = gSystem->ExpandPathName(text.Data());
627     const char *dir = gSystem->DirName(test);
628     const char *base = gSystem->BaseName(test);
629     TString lbase = base;
630     Int_t lenbase = lbase.Length();
631     TSystemDirectory *tsd = new TSystemDirectory("",dir);
632     TSystemFile *file;
633     TList *lsmatch = new TList;
634     Int_t numf = 0;
635     Int_t numgo = 0;
636     Int_t charmac = 0;
637     TString tbase;
638     Int_t k = 0;
639     stringstream newtext;
640     TSystemFile *mfile;
641     TSystemFile nfile;
642     TList *lsf = new TList;
643     const char *ctbase;
644     if ( !tsd->GetListOfFiles() ){
645     gVirtualX->Bell(0);
646     goto end;
647     };
648     lsf = tsd->GetListOfFiles();
649     file = (TSystemFile*)lsf->First();
650     //
651     while( (TSystemFile*)lsf->After(file) ){
652     numf++;
653     file = (TSystemFile*)lsf->After(file);
654     if ( !strncmp(file->GetName(),base,lenbase) ){
655     numgo++;
656     lsmatch->AddLast(file);
657     const char *ctbase = file->GetName();
658     tbase = ctbase;
659     charmac = tbase.Length();
660     };
661     };
662     newtext.str("");
663     if ( numgo > 0 ){
664     mfile = (TSystemFile*)lsmatch->First();
665     ctbase = mfile->GetName();
666     while ( (!strcmp(ctbase,"..") || !strcmp(ctbase,".")) && (TSystemFile*)lsmatch->After(mfile) ) {
667     mfile = (TSystemFile*)lsmatch->After(mfile);
668     ctbase = mfile->GetName();
669     };
670     tbase = ctbase;
671     base = ctbase;
672     charmac = tbase.Length();;
673     while( (TSystemFile*)lsmatch->After(mfile) ){
674     mfile = (TSystemFile*)lsmatch->After(mfile);
675     ctbase = mfile->GetName();
676     while ( (!strcmp(ctbase,"..") || !strcmp(ctbase,".")) && (TSystemFile*)lsmatch->After(mfile) ) {
677     mfile = (TSystemFile*)lsmatch->After(mfile);
678     ctbase = mfile->GetName();
679     };
680     tbase = ctbase;
681     k = 0;
682     for ( Int_t i=lenbase; i<=tbase.Length(); i++){
683     if ( !strncmp(tbase.Data(),base,i) && strcmp(tbase.Data(),base) ){
684     k = i;
685     };
686     };
687     if ( k <= charmac){
688     charmac = k;
689     };
690     };
691 mocchiut 1.4 gVirtualX->Bell(0);
692 mocchiut 1.3 };
693     if ( !charmac ) {
694     gVirtualX->Bell(0);
695     goto end;
696     };
697     tbase.Resize(charmac);
698     if ( !strcmp(dir,"") || !strcmp(dir,"/") ){
699     newtext << "/" << tbase.Data();
700     } else {
701     newtext << dir << "/" << tbase.Data();
702     };
703     nfile = TSystemFile(tbase.Data(),dir);
704     if ( nfile.IsDirectory() && numgo == 1 ) newtext << "/";
705     ncurspos = newtext.str().length();
706     if ( textrem.Length() ) newtext << textrem.Data();
707     entry->SetText(newtext.str().c_str());
708     entry->SetCursorPosition(ncurspos);
709     end:
710     lsf->Clear();
711     lsmatch->Clear();
712     }
713    
714     void PAMevcontrol::saveas() {
715     TString text = fText4->GetText();
716     Int_t sel=fCombo->GetSelected();
717     TString ty;
718     switch (sel){
719     case (0):
720     ty = ".ps";
721     break;
722     case (1):
723     ty = ".eps";
724     break;
725     case (2):
726     ty = ".gif";
727     break;
728     case (3):
729     ty = ".jpg";
730     break;
731     case (4):
732     ty = ".tiff";
733     break;
734     case (5):
735     ty = ".xpm";
736     break;
737     case (6):
738     ty = ".pdf";
739     break;
740     case (7):
741     ty = ".xml";
742     break;
743     case (8):
744     ty = ".png";
745     break;
746     case (9):
747     ty = ".svg";
748     break;
749     case (10):
750     ty = ".root";
751     break;
752     case (11):
753     ty = ".C";
754     break;
755     };
756     if ( sel == 0 ) ty = ".ps";
757     stringstream name;
758     if ( strcmp(text.Data(),"") ){
759     name.str("");
760     name << text.Data();
761     name << ty.Data();
762     thefigure->SaveAs(name.str().c_str());
763     name.str("");
764     name << " Saved as ";
765     name << text.Data();
766     name << ty.Data();
767     DIALOG(0,name.str().c_str());
768     printf(" Saved as %s%s \n",text.Data(),ty.Data());
769     };
770     }
771    
772     void PAMevcontrol::increment(float val) {
773     fHProg1->SetPosition(val);
774     fHProg1->DoRedraw();
775     gSystem->ProcessEvents();
776     }
777    
778     void PAMevcontrol::forcel0() {
779     if ( cvar->fl0 ) {
780     cvar->fl0 = false;
781     } else {
782     cvar->fl0 = true;
783     };
784     cvar->alrforc = false;
785     cvar->i--;
786     cvar->nevents = 0;
787     cvar->firstevno = 0;
788     cvar->lastevno = 0;
789     cvar->refresh = true;
790     }
791    
792     void PAMevcontrol::clearselfi(){
793     fText2->SetText("");
794     }
795    
796     void PAMevcontrol::upgrnamfi(){
797     fText4->SetText(cvar->svas.Data());
798     fText4->SetCursorPosition(fText4->GetMaxLength());
799     }
800    
801     void PAMevcontrol::jumpto() {
802     TGTextEntry *entry = (TGTextEntry*)gTQSender;
803     TString text = entry->GetText();
804     Int_t j;
805     j = atoi(text.Data());
806     if ( cvar->jumprog ){
807     if ( j < 1 || j > cvar->nevents ) {
808     printf("\n You can choose between 1 and %i \n",(int)cvar->nevents);
809     stringstream warning;
810     warning.str("");
811     warning << "You can choose between 1 and ";
812     warning << (int)cvar->nevents;
813     DIALOG(1,warning.str().c_str());
814     } else {
815     stringstream warning;
816     warning.str("");
817     warning << "Jumping to progressive number ";
818     warning << j;
819     DIALOG(0,warning.str().c_str());
820     printf("\n Jumping to progressive number %i\n\n",j);
821     cvar->i = j-2;
822     cvar->goon = true;
823     };
824     } else {
825     if ( j < cvar->firstevno || j > cvar->lastevno ) {
826     printf("\n You can choose between %i and %i \n",cvar->firstevno,cvar->lastevno);
827     stringstream warning;
828     warning.str("");
829     warning << "You can choose between ";
830     warning << cvar->firstevno;
831     warning << " and ";
832     warning << cvar->lastevno;
833     DIALOG(1,warning.str().c_str());
834     } else {
835     stringstream warning;
836     warning.str("");
837     warning << "Jumping to event number ";
838     warning << j;
839     DIALOG(0,warning.str().c_str());
840     printf("\n Jumping to event number %i\n\n",j);
841     cvar->jumpto = j;
842     cvar->jumpen = true;
843     cvar->goon = true;
844     };
845     };
846     entry->SetText("");
847     }
848    
849     void PAMevcontrol::radioevent() {
850     cvar->jumprog = false;
851     }
852    
853     void PAMevcontrol::radioprog() {
854     cvar->jumprog = true;
855     }
856    
857     void PAMevcontrol::radiocolor() {
858     if ( !cvar->goon ){
859     if ( cvar->bw ) {
860     cvar->bw = 0;
861     cvar->i--;
862     cvar->goon = true;
863     };
864     };
865     }
866    
867     void PAMevcontrol::radiobw() {
868     if ( !cvar->goon ){
869     if ( !cvar->bw ) {
870     cvar->bw = 1;
871     cvar->i--;
872     cvar->goon = true;
873     };
874     };
875     }
876    
877     void PAMevcontrol::radiotrack() {
878     if ( cvar->tracknds4 ) {
879     cvar->tracknds4 = 0;
880     } else {
881     cvar->tracknds4 = 1;
882     };
883     cvar->i--;
884     cvar->goon = true;
885     }
886    
887     void PAMevcontrol::chktof() {
888     if ( cvar->TOF ) {
889     cvar->TOF = 0;
890     } else {
891     cvar->TOF = 1;
892     };
893     cvar->i--;
894     cvar->nevents = 0;
895     cvar->firstevno = 0;
896     cvar->lastevno = 0;
897     cvar->refresh = true;
898     }
899    
900     void PAMevcontrol::chkac() {
901     if ( cvar->AC ) {
902     cvar->AC = 0;
903     } else {
904     cvar->AC = 1;
905     };
906     cvar->i--;
907     cvar->nevents = 0;
908     cvar->firstevno = 0;
909     cvar->lastevno = 0;
910     cvar->refresh = true;
911     }
912    
913     void PAMevcontrol::chktrk() {
914     if ( cvar->TRK ) {
915     cvar->TRK = 0;
916     } else {
917     cvar->TRK = 1;
918     };
919     cvar->i--;
920     cvar->nevents = 0;
921     cvar->firstevno = 0;
922     cvar->lastevno = 0;
923     cvar->refresh = true;
924     }
925    
926     void PAMevcontrol::chkcalo() {
927     if ( cvar->CALO ) {
928     cvar->CALO = 0;
929     } else {
930     cvar->CALO = 1;
931     };
932     cvar->i--;
933     cvar->nevents = 0;
934     cvar->firstevno = 0;
935     cvar->lastevno = 0;
936     cvar->refresh = true;
937     }
938    
939     void PAMevcontrol::chks4() {
940     if ( cvar->S4 ) {
941     cvar->S4 = 0;
942     } else {
943     cvar->S4 = 1;
944     };
945     cvar->i--;
946     cvar->nevents = 0;
947     cvar->firstevno = 0;
948     cvar->lastevno = 0;
949     cvar->refresh = true;
950     }
951    
952     void PAMevcontrol::chknd() {
953     if ( cvar->ND ) {
954     cvar->ND = 0;
955     } else {
956     cvar->ND = 1;
957     };
958     cvar->i--;
959     cvar->nevents = 0;
960     cvar->firstevno = 0;
961     cvar->lastevno = 0;
962     cvar->refresh = true;
963     }
964    
965     void PAMevcontrol::chkinfo() {
966     if ( cvar->INFOS ) {
967     cvar->INFOS = 0;
968     } else {
969     cvar->INFOS = 1;
970     };
971     cvar->i--;
972     cvar->goon = true;
973     }
974    
975     void PAMevcontrol::chknames() {
976     if ( cvar->VINFOS ) {
977     cvar->VINFOS = 0;
978     } else {
979     cvar->VINFOS = 1;
980     };
981     cvar->i--;
982     cvar->goon = true;
983     }
984    
985     void PAMevcontrol::chkpalette() {
986     if ( cvar->PALETTE ) {
987     cvar->PALETTE = 0;
988     } else {
989     cvar->PALETTE = 1;
990     };
991     cvar->i--;
992     cvar->goon = true;
993     }
994    
995     void PAMevcontrol::next() {
996     if ( cvar->i == cvar->nevents-1 ) {
997     printf("This is the last event, you can't go forward! \n");
998     DIALOG(1,"This is the last event!");
999     } else {
1000     cvar->goon = true;
1001     cvar->doflag = 1;
1002     };
1003     }
1004    
1005     void PAMevcontrol::stop() {
1006     DIALOG(1,"Stop searching");
1007     cvar->doflag = 3;
1008     }
1009    
1010     void PAMevcontrol::prev() {
1011     if ( cvar->i > 0 ) {
1012     printf("WARNING: going backward!\n\n");
1013     cvar->doflag = 2;
1014     cvar->goon = true;
1015     } else {
1016     printf("This is the first event, you can't go backward! \n");
1017     DIALOG(1,"This is the first event!");
1018     };
1019     }
1020    
1021     void PAMevcontrol::Close() {
1022     Cleanup();
1023     CloseWindow();
1024     }
1025    
1026     void PAMevcontrol::Terminate() {
1027     Close();
1028     gApplication->Terminate(0);
1029     }
1030    
1031     PAMevcontrol::~PAMevcontrol() {
1032     // Clean up used widgets: frames, buttons, layouthints
1033     Cleanup();
1034     delete this;
1035     }
1036    
1037 mocchiut 1.1 //**********************************************************************************
1038     // LEVEL0 SUBROUTINES //
1039     //**********************************************************************************
1040    
1041     void ShowCaloRAW(Int_t i, TTree *otr, Variables & var){
1042    
1043     pamela::calorimeter::CalorimeterEvent *de = 0;
1044     otr->SetBranchAddress("Calorimeter.Event", &de);
1045     if ( !var.nosig ) otr->GetEntry(i);
1046    
1047     //
1048     // Book the histograms:
1049     //
1050     //
1051     stringstream delex;
1052     delex.str("");
1053     delex << "x-view event " << (i+1);
1054     stringstream deley;
1055     deley.str("");
1056     deley << "y-view event " << (i+1);
1057     gDirectory->Delete(delex.str().c_str());
1058     gDirectory->Delete(deley.str().c_str());
1059     TH2F *Xview = new TH2F(delex.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
1060     TH2F *Yview = new TH2F(deley.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
1061     Xview->GetYaxis()->SetLabelColor(10);
1062     Yview->GetYaxis()->SetLabelColor(10);
1063     //
1064     // figures:
1065     //
1066     Int_t bgcolor = 10;
1067     TPad *pd1 = new TPad("calox","This is pad1",var.xxvc-0.154*var.sfx,var.yxvc-0.3645*var.sfy,var.xxvc+0.154*var.sfx,var.yxvc-0.1200*var.sfy,bgcolor);
1068     TPad *pd2 = new TPad("caloy","This is pad2",var.xyvc-0.154*var.sfx,var.yyvc-0.3645*var.sfy,var.xyvc+0.154*var.sfx,var.yyvc-0.1200*var.sfy,bgcolor);
1069    
1070     pd1->SetFillStyle(4000);
1071     pd1->SetFillColor(0);
1072     pd1->SetFrameFillStyle(4000);
1073     pd2->SetFillStyle(4000);
1074     pd2->SetFillColor(0);
1075     pd2->SetFrameFillStyle(4000);
1076    
1077     TLatex *t=new TLatex();
1078     t->SetTextFont(32);
1079     t->SetTextColor(1);
1080     t->SetTextSize(0.03);
1081     t->SetTextAlign(12);
1082     pd1->Range(0.,0.,1.,1.);
1083     pd2->Range(0.,0.,1.,1.);
1084     pd1->SetTicks();
1085     pd2->SetTicks();
1086     pd1->Draw();
1087     pd2->Draw();
1088    
1089     pd1->cd();
1090     gStyle->SetOptStat(0);
1091     Xview->GetYaxis()->SetTitleOffset(0.5);
1092     Xview->SetFillColor(bgcolor);
1093     Xview->Fill(1.,1.,1.);
1094     Xview->Draw("box");
1095     pd1->Update();
1096     pd2->cd();
1097     gStyle->SetOptStat(0);
1098     Yview->GetYaxis()->SetTitleOffset(0.5);
1099     Yview->SetFillColor(bgcolor);
1100     Yview->Fill(1.,1.,1.);
1101     Yview->Draw("box");
1102     pd2->Update();
1103    
1104     //
1105     // run over views and planes
1106     //
1107     stringstream xevent;
1108     stringstream yevent;
1109     for (Int_t m = 0; m < 22; m++){
1110     for (Int_t l = 0; l < 2; l++){
1111     //
1112     // determine the section number
1113     //
1114     Int_t se = 5;
1115     if ( !l && m%2 == 0 ){
1116     se = 3;
1117     };
1118     if ( !l && m%2 != 0 ){
1119     se = 2;
1120     };
1121     if ( l && m%2 == 0 ){
1122     se = 1;
1123     };
1124     if ( l && m%2 != 0 ){
1125     se = 0;
1126     };
1127     //
1128     // determine what kind of event we are going to analyze
1129     //
1130     bool isCOMP = 0;
1131     bool isFULL = 0;
1132     if ( de->stwerr[se] & (1 << 16) ) isCOMP = 1;
1133     if ( de->stwerr[se] & (1 << 17) ) isFULL = 1;
1134     //
1135     // run over strips
1136     //
1137     if ( isCOMP || isFULL ) {
1138     for (Int_t n = 0; n < 96; n++){
1139     if ( de->dexyc[l][m][n] > 0. && !var.nosig ){
1140     xevent.str("");
1141     yevent.str("");
1142     xevent << "x-view event " << n;
1143     xevent << " " << m;
1144     xevent << " " << l;
1145     yevent << "y-view event " << n;
1146     yevent << " " << m;
1147     yevent << " " << l;
1148     gDirectory->Delete(xevent.str().c_str());
1149     gDirectory->Delete(yevent.str().c_str());
1150     TH2F *Xview = new TH2F(xevent.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
1151     TH2F *Yview = new TH2F(yevent.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
1152 mocchiut 1.3 Int_t colo;
1153     if ( var.bw ){
1154     colo = 17;
1155     } else {
1156     colo = 38;
1157     };
1158 mocchiut 1.1 Xview->SetFillColor(colo);
1159     Yview->SetFillColor(colo);
1160     if ( l == 0 ) {
1161     Xview->Fill(n,21-m,1.);
1162     pd1->cd();
1163     Xview->Draw("box same");
1164     };
1165     if ( l == 1 ) {
1166     Yview->Fill(95-n,21-m,1.);
1167     pd2->cd();
1168     Yview->Draw("box same");
1169     };
1170     };
1171     };
1172     };
1173     };
1174     };
1175     pd1->Update();
1176     pd2->Update();
1177     var.qtot=0;
1178     var.nstrip=0;
1179     }
1180    
1181     void ShowND(Int_t evno, TTree *otr, Variables & var){
1182 mocchiut 1.3 Int_t tmpSize;
1183 mocchiut 1.1 Int_t yUpperTrig = 0;
1184     Int_t yUpperBk = 0;
1185     Int_t yBottomBk = 0;
1186     pamela::neutron::NeutronEvent *ne = 0;
1187     pamela::neutron::NeutronRecord *nr = 0;
1188     otr->SetBranchAddress("Neutron.Event", &ne);
1189     //
1190     if ( !var.nosig ) otr->GetEntry(evno);
1191     //
1192     tmpSize = ne->Records->GetEntries();
1193     for (Int_t j = 0; j < tmpSize; j++){
1194     nr = (pamela::neutron::NeutronRecord*)ne->Records->At(j);
1195     yUpperTrig += (int)nr->trigPhysics;
1196     yUpperBk += (int)nr->upperBack;
1197     yBottomBk += (int)nr->bottomBack;
1198     }
1199    
1200     var.trup = yUpperTrig;
1201     var.bkup = yUpperBk;
1202     var.bkbo = yBottomBk;
1203    
1204     if ( var.nosig ){
1205     yUpperTrig = 0;
1206     yUpperBk = 0;
1207     yBottomBk = 0;
1208     }
1209     Int_t ucolo = 10;
1210     if ( var.bw ){
1211     if ( yUpperTrig == 1 ){
1212     ucolo = 17;
1213     }
1214     if ( yUpperTrig == 2 ){
1215     ucolo = 15;
1216     }
1217     if ( yUpperTrig > 2 && yUpperTrig < 7 ){
1218     ucolo = 14;
1219     }
1220     if ( yUpperTrig > 6 && yUpperTrig < 15 ){
1221     ucolo = 13;
1222     }
1223     if ( yUpperTrig >= 14 ){
1224     ucolo = 12;
1225     };
1226     } else {
1227     if ( yUpperTrig == 1 ){
1228     ucolo = 38;
1229     }
1230     if ( yUpperTrig == 2 ){
1231     ucolo = 4;
1232     }
1233     if ( yUpperTrig > 2 && yUpperTrig < 7 ){
1234     ucolo = 3;
1235     }
1236     if ( yUpperTrig > 6 && yUpperTrig < 15 ){
1237     ucolo = 2;
1238     }
1239     if ( yUpperTrig >= 14 ){
1240     ucolo = 6;
1241     };
1242     };
1243     //
1244     // figures:
1245     //
1246     if ( true ){
1247     Float_t xc1[5]={ -0.300, 0.300, 0.300, -0.300, -0.300 };
1248     Float_t yc1[5]={ -0.47-0.04, -0.47-0.04, -0.47+2.*0.075-0.04, -0.47+2.*0.075-0.04, -0.47-0.04};
1249     //
1250     // Upper X-view
1251     //
1252     Float_t xc[5];
1253     Float_t yc[5];
1254     for (Int_t i = 0; i<5 ; i++) {
1255     xc[i]= var.xxvc + xc1[i]*var.nds4;
1256     yc[i] = var.yxvc + yc1[i]*var.sfy;
1257     };
1258     TPolyLine *fnd2x = new TPolyLine(5,xc,yc);
1259     fnd2x->SetLineColor(1);
1260     fnd2x->SetFillColor(ucolo);
1261     fnd2x->SetLineWidth(1);
1262     fnd2x->Draw("f");
1263     fnd2x->Draw();
1264     };
1265     if ( true ){
1266     Float_t xc1[5]={ -0.275, 0.275, 0.275, -0.275, -0.275 };
1267     Float_t yc1[5]={ -0.47-0.04-0.075, -0.47-0.04-0.075, -0.47+0.075-0.04, -0.47+0.075-0.04, -0.47-0.04-0.075};
1268     //
1269     // Upper Y-view
1270     //
1271     Float_t xc[5];
1272     Float_t yc[5];
1273     for (Int_t i = 0; i<5 ; i++) {
1274     xc[i]= var.xyvc + xc1[i]*var.nds4;
1275     yc[i] = var.yyvc + (yc1[i]+0.075)*var.sfy;
1276     };
1277     TPolyLine *fnd2y = new TPolyLine(5,xc,yc);
1278     fnd2y->SetLineColor(1);
1279     fnd2y->SetFillColor(ucolo);
1280     fnd2y->SetLineWidth(1);
1281     fnd2y->Draw("f");
1282     fnd2y->Draw();
1283     };
1284     }
1285    
1286     void ShowTRKL0(Int_t evno, TTree *otr, Variables & var){
1287     //
1288     pamela::tracker::TrackerEvent *trk = 0;
1289     otr->SetBranchAddress("Tracker.Event", &trk);
1290     if ( !var.nosig ) otr->GetEntry(evno);
1291     //
1292     // a matrix of pads for each view x and y
1293     //
1294     TPad *trkpad[12];
1295     for (Int_t n = 0; n<12; n++){
1296     stringstream spd;
1297     spd.str("");
1298     spd << "pd1" << n;
1299     gDirectory->Delete(spd.str().c_str());
1300     spd.str("");
1301     spd << "pd2" << n;
1302     gDirectory->Delete(spd.str().c_str());
1303     spd.str("");
1304     spd << "pd3" << n;
1305     gDirectory->Delete(spd.str().c_str());
1306     spd.str("");
1307     spd << "pd4" << n;
1308     gDirectory->Delete(spd.str().c_str());
1309     spd.str("");
1310     spd << "pd5" << n;
1311     gDirectory->Delete(spd.str().c_str());
1312     spd.str("");
1313     spd << "pd6" << n;
1314     gDirectory->Delete(spd.str().c_str());
1315     spd.str("");
1316     stringstream sbd;
1317     sbd.str("");
1318     Int_t magcol = 0;
1319     TPad *mag1 = 0;
1320     TPad *mag2 = 0;
1321     if ( n%2 ) {
1322     Float_t posx = var.xxvc;
1323     Float_t posy = var.yxvc + (0.29 - 0.089*((n/2.)-1.))*var.sfy;
1324     spd.str("");
1325     sbd.str("");
1326     spd << "pd1" << n;
1327     sbd << "bd1" << n;
1328     trkpad[n] = new TPad(spd.str().c_str(),sbd.str().c_str(),posx-0.081*var.sfx,posy,posx+0.081*var.sfx,posy+0.089*var.sfy,10);
1329     trkpad[n]->SetFillStyle(4000);
1330     trkpad[n]->SetFillColor(0);
1331     trkpad[n]->SetFrameFillStyle(4000);
1332     trkpad[n]->Draw();
1333     if ( n != 1 ) {
1334     if ( var.bw ) {
1335     magcol = 1;
1336     } else {
1337     magcol = 45;
1338     };
1339     spd.str("");
1340     sbd.str("");
1341     spd << "pd2" << n;
1342     sbd << "bd2" << n;
1343     mag1 = new TPad(spd.str().c_str(),sbd.str().c_str(),posx-(0.039+0.081)*var.sfx,posy+0.004*var.sfy,posx-0.081*var.sfx,posy+0.088*var.sfy,magcol);
1344     if ( var.bw ) mag1->SetFillStyle(3001);
1345     mag1->Draw();
1346     spd.str("");
1347     sbd.str("");
1348     spd << "pd3" << n;
1349     sbd << "bd3" << n;
1350     mag2 = new TPad(spd.str().c_str(),sbd.str().c_str(),posx+0.081*var.sfx,posy+0.004*var.sfy,posx+(0.081+0.039)*var.sfx,posy+0.088*var.sfy,magcol);
1351     if ( var.bw ) mag2->SetFillStyle(3001);
1352     mag2->Draw();
1353     };
1354     } else {
1355     Float_t posx = var.xyvc;
1356     Float_t posy = var.yyvc + (0.29 - 0.089 * (((n+1.)/2.)-1.))*var.sfy;
1357     spd.str("");
1358     sbd.str("");
1359     spd << "pd4" << n;
1360     sbd << "bd4" << n;
1361     trkpad[n] = new TPad(spd.str().c_str(),sbd.str().c_str(),posx-0.07*var.sfx,posy,posx+0.07*var.sfx,posy+0.089*var.sfy,10);
1362     trkpad[n]->SetFillStyle(4000);
1363     trkpad[n]->SetFillColor(0);
1364     trkpad[n]->SetFrameFillStyle(4000);
1365     trkpad[n]->Draw();
1366     if ( n != 0 ) {
1367     if ( var.bw ) {
1368     magcol = 1;
1369     } else {
1370     magcol = 45;
1371     };
1372     spd.str("");
1373     sbd.str("");
1374     spd << "pd5" << n;
1375     sbd << "bd5" << n;
1376     mag1 = new TPad(spd.str().c_str(),sbd.str().c_str(),posx-(0.048+0.066)*var.sfx,posy+0.004*var.sfy,posx-0.066*var.sfx,posy+0.088*var.sfy,magcol);
1377     if ( var.bw ) mag1->SetFillStyle(3001);
1378     mag1->Draw();
1379     spd.str("");
1380     sbd.str("");
1381     spd << "pd6" << n;
1382     sbd << "bd6" << n;
1383     mag2 = new TPad(spd.str().c_str(),sbd.str().c_str(),posx+0.066*var.sfx,posy+0.004*var.sfy,posx+(0.066+0.048)*var.sfx,posy+0.088*var.sfy,magcol);
1384     if ( var.bw ) mag2->SetFillStyle(3001);
1385     mag2->Draw();
1386     };
1387     };
1388     };
1389     TPad *trplv;
1390     gDirectory->Delete("trkplv");
1391     trplv = new TPad("trkplv","trkplv",var.xcat-0.066*var.sfx,var.ycat-0.081*var.sfy,var.xcat+0.066*var.sfx,var.ycat+0.081*var.sfy,10);
1392     trplv->SetFillStyle(4000);
1393     trplv->SetFillColor(0);
1394     trplv->SetFrameFillStyle(4000);
1395     trplv->Draw();
1396     //
1397     Int_t sigcol1 = 17;
1398     Int_t sigcol2 = 15;
1399     Int_t linecol = 13;
1400     if ( var.bw ) {
1401     sigcol1 = 17;
1402     sigcol2 = 15;
1403     linecol = 13;
1404     } else {
1405     sigcol1 = 32;
1406     sigcol2 = 38;
1407     linecol = 42;
1408     };
1409     TLine *linea = 0;
1410     TLine *linea1x = 0;
1411     TLine *linea2x = 0;
1412     TLine *linea1y = 0;
1413     Float_t x = 0.;
1414     for (Int_t l = 0; l<12; l++){
1415     trkpad[l]->cd();
1416     if ( l%2 ) {
1417     trkpad[l]->Range(0.,0.,3100.,1.);
1418     linea = new TLine(0.,0.01,3100.,0.01);
1419     linea1x = new TLine(1033.,0.01,1033,0.030);
1420     linea2x = new TLine(2066.,0.01,2066,0.030);
1421     } else {
1422     trkpad[l]->Range(0.,0.,2076.,1.);
1423     linea = new TLine(0.,0.01,2076.,0.01);
1424     linea1y = new TLine(1038.,0.01,1038,0.030);
1425     };
1426     linea->SetLineWidth(2);
1427     linea->SetLineColor(linecol);
1428     linea->Draw();
1429     if ( l%2 ) {
1430     linea1x->SetLineWidth(1);
1431     linea1x->SetLineColor(1);
1432     linea1x->Draw();
1433     linea2x->SetLineWidth(1);
1434     linea2x->SetLineColor(1);
1435     linea2x->Draw();
1436     } else {
1437     linea1y->SetLineWidth(1);
1438     linea1y->SetLineColor(1);
1439     linea1y->Draw();
1440     };
1441     //
1442     Int_t planeno = trk->DSPnumber[l]-1;
1443     if ( planeno < 0 || planeno > 11 ) planeno = 0;
1444     if ( planeno >= 0 && !var.nosig ) {
1445     if ( (planeno+1)%2 ){
1446     trkpad[planeno]->cd();
1447     trkpad[planeno]->Range(0.,0.,2076.,1.);
1448     for (Int_t m = 0; m<3; m++){
1449     if ( trk->signcluster[l][m] != 0. ){
1450     if ( planeno == 10 ) {
1451     x = 1024 - trk->addrcluster[l][m];
1452     } else {
1453     x = trk->addrcluster[l][m];
1454     };
1455     linea = new TLine(14.+x,0.01,14.+x,0.3);
1456     linea->SetLineWidth(2);
1457     linea->SetLineColor(sigcol1);
1458     linea->Draw();
1459     x += 1024.;
1460     linea = new TLine(14.+x,0.01,14.+x,0.3);
1461     linea->SetLineWidth(2);
1462     linea->SetLineColor(sigcol2);
1463     linea->Draw();
1464     var.ncly++;
1465     };
1466     };
1467     } else {
1468     trkpad[planeno]->cd();
1469     trkpad[planeno]->Range(0.,0.,3100.,1.);
1470     for (Int_t m = 0; m<3; m++){
1471     if ( trk->signcluster[l][m] != 0. ){
1472     x = trk->addrcluster[l][m] + 1024. * m;
1473     linea = new TLine(14.+x,0.01,14.+x,0.3);
1474     linea->SetLineWidth(2);
1475     linea->SetLineColor(sigcol2);
1476     linea->Draw();
1477     var.nclx++;
1478     };
1479     };
1480     };
1481     };
1482     };
1483     //
1484     // Show track in the plane view!
1485     //
1486     Float_t xh[6];
1487     Float_t yh1[6];
1488     Float_t yh2[6];
1489     Float_t mag[6];
1490     for (Int_t l = 0; l<6; l++ ){
1491     xh[l] = 0.;
1492     yh1[l] = 0.;
1493     yh2[l] = 0.;
1494     mag[l] = 0.;
1495     };
1496     Int_t ncro = 0;
1497     //
1498     for (Int_t l = 0; l<12; l++ ){
1499     Float_t xsig = 0.;
1500     Float_t ysig = 0.;
1501     Int_t planeno = trk->DSPnumber[l]-1;
1502     for (Int_t e = 0; e<12;e++){
1503     Int_t planeno2 = trk->DSPnumber[e]-1;
1504     if ( planeno == planeno2-1 ){
1505     if ( planeno < 0 || planeno > 11 ) planeno = 0;
1506     if ( planeno >= 0 && !var.nosig ) {
1507     mag[ncro] = ((float)planeno+1.)/5.;
1508     if ( (planeno+1)%2 ){
1509     for (Int_t m = 0; m<3; m++){
1510     if ( trk->signcluster[l][m] != 0. ){
1511     if ( planeno == 10 ) {
1512     x = 1024 - trk->addrcluster[l][m];
1513     } else {
1514     x = trk->addrcluster[l][m];
1515     };
1516     x += 1024.;
1517     if ( trk->signcluster[l][m]> ysig ){
1518     ysig = trk->signcluster[l][m];
1519     yh1[ncro] = x-1024.;
1520     yh2[ncro] = x;
1521     };
1522     };
1523     };
1524     for (Int_t m = 0; m<3; m++){
1525     if ( trk->signcluster[e][m] != 0. ){
1526     x = trk->addrcluster[e][m] + 1024. * m;
1527     if ( trk->signcluster[e][m]> xsig && !( planeno == 0 && x > 2800) ){
1528     xsig = trk->signcluster[e][m];
1529     xh[ncro] = x;
1530     };
1531     };
1532     };
1533     } else {
1534     for (Int_t m = 0; m<3; m++){
1535     if ( trk->signcluster[l][m] != 0. ){
1536     x = trk->addrcluster[l][m] + 1024. * m;
1537     if ( trk->signcluster[l][m]> xsig && !( planeno == 0 && x > 2800) ){
1538     xsig = trk->signcluster[l][m];
1539     xh[ncro] = x;
1540     };
1541     };
1542     };
1543     if ( (planeno+1)%2 ){
1544     for (Int_t m = 0; m<3; m++){
1545     if ( trk->signcluster[e][m] != 0. ){
1546     if ( planeno == 10 ) {
1547     x = 1024 - trk->addrcluster[e][m];
1548     } else {
1549     x = trk->addrcluster[e][m];
1550     };
1551     x += 1024.;
1552     if ( trk->signcluster[e][m]> ysig ){
1553     ysig = trk->signcluster[e][m];
1554     yh1[ncro] = x-1024.;
1555     yh2[ncro] = x;
1556     };
1557     };
1558     };
1559     };
1560     };
1561     if ( ysig > 0. && xsig > 0. ) {
1562     ncro++;
1563     };
1564     };
1565     };
1566     };
1567     };
1568     //
1569     // Draw crosses
1570 mocchiut 1.3 //
1571     if ( ncro && var.AC ) {
1572 mocchiut 1.1 trplv->cd();
1573     trplv->Range(0.,0.,2076.,3100.);
1574     for ( Int_t i = 0; i<ncro; i++){
1575     //
1576     Float_t cdx = (55./mag[i])*var.sfx;
1577     Float_t cdy = (55./mag[i])*var.sfy;
1578     Float_t lwx = (1.9)*var.sfy;
1579     Float_t lwy = (1.9)*var.sfx;
1580     //
1581     linea = new TLine(yh1[i]-lwx/2.,xh[i]-cdy,yh1[i]-lwx/2.,xh[i]+cdy);
1582     linea->SetLineWidth((int)lwx);
1583     linea->SetLineColor(sigcol1);
1584     linea->Draw();
1585     linea = new TLine(yh1[i]-cdx,xh[i]-lwy/2.,yh1[i]+cdx,xh[i]-lwy/2.);
1586     linea->SetLineWidth((int)lwy);
1587     linea->SetLineColor(sigcol1);
1588     linea->Draw();
1589     //
1590     linea = new TLine(yh2[i]-lwx/2.,xh[i]-cdy,yh2[i]-lwx/2.,xh[i]+cdy);
1591     linea->SetLineWidth((int)lwx);
1592     linea->SetLineColor(sigcol2);
1593     linea->Draw();
1594     linea = new TLine(yh2[i]-cdy,xh[i]-lwy/2.,yh2[i]+cdx,xh[i]-lwy/2.);
1595     linea->SetLineWidth((int)lwy);
1596     linea->SetLineColor(sigcol2);
1597     linea->Draw();
1598     };
1599     };
1600     }
1601    
1602     void ShowAC(Int_t i, TTree *otr, Variables & var, Int_t lev){
1603     //
1604     Int_t hitmapA = 0;
1605     Int_t hitmapB = 0;
1606     Int_t hitstatusA = 0;
1607     Int_t hitstatusB = 0;
1608     if ( lev == 0 ){
1609     pamela::anticounter::AnticounterEvent *ace = 0;
1610     otr->SetBranchAddress("Anticounter.Event", &ace);
1611     if ( !var.nosig ) otr->GetEntry(i);
1612     hitmapA = ace->hitmap[0];
1613     hitmapB = ace->hitmap[1];
1614     if ( lev == 0 ){
1615     hitstatusA = 65535;
1616     hitstatusB = 65535;
1617     } else {
1618     hitstatusA = ace->status[0];
1619     hitstatusB = ace->status[1];
1620     };
1621     };
1622     if ( lev == 1 ){
1623     AnticounterLevel1 *ace1 = new AnticounterLevel1();
1624     otr->SetBranchAddress("AcLevel1.Event", &ace1);
1625     if ( !var.nosig ) otr->GetEntry(i);
1626     hitmapA = ace1->hitmap[0];
1627     hitmapB = ace1->hitmap[1];
1628     if ( lev == 0 ){
1629     hitstatusA = 65535;
1630     hitstatusB = 65535;
1631     } else {
1632     hitstatusA = ace1->hitstatus[0];
1633     hitstatusB = ace1->hitstatus[1];
1634     };
1635     };
1636     //
1637     if ( var.nosig ){
1638     hitmapA = 0;
1639     hitmapB = 0;
1640     hitstatusA = 0;
1641     hitstatusB = 0;
1642     };
1643     //
1644     Float_t cas1 = 0.;
1645     Float_t cas2 = 0.;
1646     Float_t cas3 = 0.;
1647     Float_t cas4 = 0.;
1648     Float_t cas1b = 0.;
1649     Float_t cas2b = 0.;
1650     Float_t cas3b = 0.;
1651     Float_t cas4b = 0.;
1652     //
1653     Float_t cat1 = 0.;
1654     Float_t cat2 = 0.;
1655     Float_t cat3 = 0.;
1656     Float_t cat4 = 0.;
1657     Float_t cat1b = 0.;
1658     Float_t cat2b = 0.;
1659     Float_t cat3b = 0.;
1660     Float_t cat4b = 0.;
1661     //
1662     Float_t card1 = 0.;
1663     Float_t card2 = 0.;
1664     Float_t card3 = 0.;
1665     Float_t card4 = 0.;
1666     Float_t card1b = 0.;
1667     Float_t card2b = 0.;
1668     Float_t card3b = 0.;
1669     Float_t card4b = 0.;
1670     //
1671     Float_t intime = -0.25;
1672     Float_t outtime = -0.375;
1673     if ( var.bw ){
1674     intime = -0.25;
1675     outtime = -0.375;
1676     } else {
1677     intime = 1.;
1678     outtime = -4.;
1679     };
1680     //
1681     // main board
1682     //
1683     if ( hitmapA & (1<<0) ) {
1684     card4 = intime;
1685     if ( !(hitstatusA & (1<<0)) ) card4 = outtime ;
1686     var.hcard++;
1687     }
1688     if ( hitmapA & (1<<1) ) {
1689     cat2 = intime;
1690     if ( !(hitstatusA & (1<<1)) ) cat2 = outtime ;
1691     var.hcat++;
1692     }
1693     if ( hitmapA & (1<<2) ) {
1694     cas1 = intime;
1695     if ( !(hitstatusA & (1<<2)) ) cas1 = outtime ;
1696     var.hcas++;
1697     }
1698     //
1699     if ( hitmapA & (1<<4) ) {
1700     card2 = intime;
1701     if ( !(hitstatusA & (1<<4)) ) card2 = outtime ;
1702     var.hcard++;
1703     }
1704     if ( hitmapA & (1<<5) ) {
1705     cat4 = intime;
1706     if ( !(hitstatusA & (1<<5)) ) cat4 = outtime ;
1707     var.hcat++;
1708     }
1709     if ( hitmapA & (1<<6) ) {
1710     cas4 = intime;
1711     if ( !(hitstatusA & (1<<6)) ) cas4 = outtime ;
1712     var.hcas++;
1713     }
1714     //
1715     if ( hitmapA & (1<<8) ) {
1716     card3 = intime;
1717     if ( !(hitstatusA & (1<<8)) ) card3 = outtime ;
1718     var.hcard++;
1719     }
1720     if ( hitmapA & (1<<9) ) {
1721     cat3 = intime;
1722     if ( !(hitstatusA & (1<<9)) ) cat3 = outtime ;
1723     var.hcat++;
1724     }
1725     if ( hitmapA & (1<<10) ) {
1726     cas3 = intime;
1727     if ( !(hitstatusA & (1<<10)) ) cas3 = outtime ;
1728     var.hcas++;
1729     }
1730     //
1731     if ( hitmapA & (1<<12) ) {
1732     card1 = intime;
1733     if ( !(hitstatusA & (1<<12)) ) card1 = outtime ;
1734     var.hcard++;
1735     }
1736     if ( hitmapA & (1<<13) ) {
1737     cat1 = intime;
1738     if ( !(hitstatusA & (1<<13)) ) cat1 = outtime ;
1739     var.hcat++;
1740     }
1741     if ( hitmapA & (1<<14) ) {
1742     cas2 = intime;
1743     if ( !(hitstatusA & (1<<14)) ) cas2 = outtime ;
1744     var.hcas++;
1745     }
1746    
1747     //
1748     // extra board
1749     //
1750     if ( hitmapB & (1<<0) ) {
1751     card4b = intime;
1752     if ( !(hitstatusB & (1<<0)) ) card4b = outtime ;
1753     var.hcard++;
1754     }
1755     if ( hitmapB & (1<<1) ) {
1756     cat2b = intime;
1757     if ( !(hitstatusB & (1<<1)) ) cat2b = outtime ;
1758     var.hcat++;
1759     }
1760     if ( hitmapB & (1<<2) ) {
1761     cas1b = intime;
1762     if ( !(hitstatusB & (1<<2)) ) cas1b = outtime;
1763     var.hcas++;
1764     }
1765     //
1766     if ( hitmapB & (1<<4) ) {
1767     card2b = intime;
1768     if ( !(hitstatusB & (1<<4)) ) card2b = outtime ;
1769     var.hcard++;
1770     }
1771     if ( hitmapB & (1<<5) ) {
1772     cat4b = intime;
1773     if ( !(hitstatusB & (1<<5)) ) cat4b = outtime ;
1774     var.hcat++;
1775     }
1776     if ( hitmapB & (1<<6) ) {
1777     cas4b = intime;
1778     if ( !(hitstatusB & (1<<6)) ) cas4b = outtime ;
1779     var.hcas++;
1780     }
1781     //
1782     if ( hitmapB & (1<<8) ) {
1783     card3b = intime;
1784     if ( !(hitstatusB & (1<<8)) ) card3b = outtime ;
1785     var.hcard++;
1786     }
1787     if ( hitmapB & (1<<9) ) {
1788     cat3b = intime;
1789     if ( !(hitstatusB & (1<<9)) ) cat3b = outtime ;
1790     var.hcat++;
1791     }
1792     if ( hitmapB & (1<<10) ) {
1793     cas3b = intime;
1794     if ( !(hitstatusB & (1<<10)) ) cas3b = outtime ;
1795     var.hcas++;
1796     }
1797     //
1798     if ( hitmapB & (1<<12) ) {
1799     card1b = intime;
1800     if ( !(hitstatusB & (1<<12)) ) card1b = outtime ;
1801     var.hcard++;
1802     }
1803     if ( hitmapB & (1<<13) ) {
1804     cat1b = intime;
1805     if ( !(hitstatusB & (1<<13)) ) cat1b = outtime ;
1806     var.hcat++;
1807     }
1808     if ( hitmapB & (1<<14) ) {
1809     cas2b = intime;
1810     if ( !(hitstatusB & (1<<14)) ) cas2b = outtime ;
1811     var.hcas++;
1812     };
1813     Int_t colo = 0;
1814     //
1815     // CAS height and width
1816     //
1817     Float_t csh = 0.194*var.sfy;
1818     Float_t csw = 0.008*var.sfx;
1819     Float_t ctw = 0.008;
1820    
1821     //
1822     // CAS2 -0.039-0.081 |TRX TRY
1823     //
1824     if ( true ){
1825     Float_t xofs = var.xxvc -(0.039+0.081+0.0273)*var.sfx;
1826     Float_t yofs = var.yxvc + 0.09*var.sfy ;
1827     Double_t x[4] = {xofs-csw,xofs,xofs,xofs-csw};
1828     Double_t y[4] = {yofs-csh,yofs-csh,yofs+csh,yofs-csh};
1829     TPolyLine *fcas2 = new TPolyLine(4,x,y);
1830     fcas2->SetLineColor(1);
1831     colo = (int)(10. - cas2 * 8.);
1832     fcas2->SetFillColor(colo);
1833     fcas2->SetLineWidth(1);
1834     fcas2->Draw("f");
1835     fcas2->Draw();
1836     };
1837     if ( true ){
1838     Float_t xofs = var.xxvc -(0.039 +0.081 +0.0273)*var.sfx;
1839     Float_t yofs = var.yxvc + 0.09*var.sfy ;
1840     Double_t x[4] = {xofs-csw,xofs-csw,xofs,xofs-csw};
1841     Double_t y[4] = {yofs+csh,yofs-csh,yofs+csh,yofs+csh};
1842     TPolyLine *fcas2b = new TPolyLine(4,x,y);
1843     fcas2b->SetLineColor(1);
1844     colo = (int)(10. - cas2b * 8.);
1845     fcas2b->SetFillColor(colo);
1846     fcas2b->SetLineWidth(1);
1847     fcas2b->Draw("f");
1848     fcas2b->Draw();
1849     };
1850     //
1851     // CAS1 -0.039+0.081 TRX| TRY
1852     //
1853     if ( true ){
1854     Float_t xofs = var.xxvc + (0.039 +0.081+0.0273)*var.sfx +csw;
1855     Float_t yofs = var.yxvc + 0.09*var.sfy ;
1856     Double_t x[4] = {xofs-csw,xofs-csw,xofs,xofs-csw};
1857     Double_t y[4] = {yofs-csh,yofs+csh,yofs-csh,yofs-csh};
1858     TPolyLine *fcas1 = new TPolyLine(4,x,y);
1859     fcas1->SetLineColor(1);
1860     colo = (int)(10. - cas1 * 8.);
1861     fcas1->SetFillColor(colo);
1862     fcas1->SetLineWidth(1);
1863     fcas1->Draw("f");
1864     fcas1->Draw();
1865     };
1866     if ( true ){
1867     Float_t xofs = var.xxvc + (0.039 +0.081+0.0273)*var.sfx +csw;
1868     Float_t yofs = var.yxvc + 0.09*var.sfy ;
1869     Double_t x[4] = {xofs-csw,xofs,xofs,xofs-csw};
1870     Double_t y[4] = {yofs+csh,yofs+csh,yofs-csh,yofs+csh};
1871     TPolyLine *fcas1b = new TPolyLine(4,x,y);
1872     fcas1b->SetLineColor(1);
1873     colo = (int)(10. - cas1b * 8.);
1874     fcas1b->SetFillColor(colo);
1875     fcas1b->SetLineWidth(1);
1876     fcas1b->Draw("f");
1877     fcas1b->Draw();
1878     };
1879     //
1880     // CAS4 -0.039-0.081 TRX |TRY
1881     //
1882     if ( true ){
1883     Float_t xofs = var.xyvc - (0.048 +0.066 +0.0273)*var.sfx;
1884     Float_t yofs = var.yyvc + 0.09*var.sfy ;
1885     Double_t x[4] = {xofs-csw,xofs,xofs,xofs-csw};
1886     Double_t y[4] = {yofs-csh,yofs-csh,yofs+csh,yofs-csh};
1887     TPolyLine *fcas4 = new TPolyLine(4,x,y);
1888     fcas4->SetLineColor(1);
1889     colo = (int)(10. - cas4 * 8.);
1890     fcas4->SetFillColor(colo);
1891     fcas4->SetLineWidth(1);
1892     fcas4->Draw("f");
1893     fcas4->Draw();
1894     };
1895     if ( true ){
1896     Float_t xofs = var.xyvc - (0.048 +0.066 +0.0273)*var.sfx;
1897     Float_t yofs = var.yyvc + 0.09*var.sfy ;
1898     Double_t x[4] = {xofs-csw,xofs-csw,xofs,xofs-csw};
1899     Double_t y[4] = {yofs+csh,yofs-csh,yofs+csh,yofs+csh};
1900     TPolyLine *fcas4b = new TPolyLine(4,x,y);
1901     fcas4b->SetLineColor(1);
1902     colo = (int)(10. - cas4b * 8.);
1903     fcas4b->SetFillColor(colo);
1904     fcas4b->SetLineWidth(1);
1905     fcas4b->Draw("f");
1906     fcas4b->Draw();
1907     };
1908    
1909     //
1910     // CAS3 -0.039+0.081 TRX TRY|
1911     //
1912     if ( true ){
1913     Float_t xofs = var.xyvc + (0.048 +0.066+0.0273)*var.sfx +csw;
1914     Float_t yofs = var.yyvc + 0.09*var.sfy ;
1915     Double_t x[4] = {xofs-csw,xofs-csw,xofs,xofs-csw};
1916     Double_t y[4] = {yofs-csh,yofs+csh,yofs-csh,yofs-csh};
1917     TPolyLine *fcas3 = new TPolyLine(4,x,y);
1918     fcas3->SetLineColor(1);
1919     colo = (int)(10. - cas3 * 8.);
1920     fcas3->SetFillColor(colo);
1921     fcas3->SetLineWidth(1);
1922     fcas3->Draw("f");
1923     fcas3->Draw();
1924     };
1925     if ( true ){
1926     Float_t xofs = var.xyvc + (0.048 +0.066+0.0273)*var.sfx +csw;
1927     Float_t yofs = var.yyvc + 0.09*var.sfy ;
1928     Double_t x[4] = {xofs-csw,xofs,xofs,xofs-csw};
1929     Double_t y[4] = {yofs+csh,yofs+csh,yofs-csh,yofs+csh};
1930     TPolyLine *fcas3b = new TPolyLine(4,x,y);
1931     fcas3b->SetLineColor(1);
1932     colo = (int)(10. - cas3b * 8.);
1933     fcas3b->SetFillColor(colo);
1934     fcas3b->SetLineWidth(1);
1935     fcas3b->Draw("f");
1936     fcas3b->Draw();
1937     };
1938    
1939     //
1940     // CAT coordinate system
1941     //
1942     Float_t xcat = var.xcat;
1943     Float_t ycat = var.ycat;
1944     Float_t pmt1 = 0.0356;
1945     Float_t pmt2 = 0.038;
1946     Float_t xpmt1 = -0.149*var.sfx;
1947     Float_t ypmt1 = 0.251*var.sfy;
1948     Float_t apmt1 = atan((11.*var.sfy)/(14.*var.sfx));
1949     Float_t xpmt2 = -0.257*var.sfx;
1950     Float_t ypmt2 = 0.158*var.sfy;
1951     Float_t apmt2 = atan((11.*var.sfx)/(15.*var.sfy));
1952     //
1953     Int_t cattime = 13;
1954     Int_t catnoti = 12;
1955     if ( var.bw ){
1956     cattime = 13;
1957     catnoti = 12;
1958     } else {
1959     cattime = 2;
1960     catnoti = 42;
1961     };
1962     //
1963     if ( true ){
1964     // PMTs
1965     Float_t xc1[5]={ 0., 0.014*var.sfx, 0.014*var.sfx-var.sfx*var.sfx*pmt1*cos(apmt1), -var.sfx*var.sfx*pmt1*cos(apmt1), 0.};
1966     Float_t yc1[5]={ 0., 0.011*var.sfy, 0.011*var.sfy+var.sfy*var.sfy*pmt1*sin(apmt1), var.sfy*var.sfy*pmt1*sin(apmt1), 0.};
1967     Float_t xc2[5]={ 0., 0.011*var.sfx, 0.011*var.sfx-pmt2*var.sfx*var.sfx*cos(apmt2), -pmt2*var.sfx*var.sfx*cos(apmt2), 0.};
1968     Float_t yc2[5]={ 0., 0.015*var.sfy, 0.015*var.sfy+var.sfy*pmt2*var.sfy*sin(apmt2), var.sfy*pmt2*var.sfy*sin(apmt2), 0.};
1969     // SCINTs
1970     Float_t xcc1[10]={-0.149, -0.090165, -0.090165, -0.149, -0.242, -0.257, -0.212, -0.257, -0.242, -0.149};
1971     Float_t ycc1[10]={ 0.169, 0.108165, -0.108165, -0.169, -0.169, -0.158, 0., 0.158, 0.169, 0.169};
1972     Float_t xcc2[10]={-0.149, -0.149, -0.138, 0., 0.138, 0.149, 0.149, 0.090165, -0.090165, -0.149};
1973     Float_t ycc2[10]={ 0.169, 0.251, 0.265, 0.220, 0.265, 0.251, 0.169, 0.108165, 0.108165, 0.169};
1974     //
1975     // CAT sections
1976     //
1977     if ( true ){
1978     Float_t xofs = var.xxvc -0.108165*var.sfx;
1979     Float_t yofs = var.yxvc + 0.3725*var.sfy ;
1980     Double_t xx[5] = {xofs,xofs-0.112*var.sfx,xofs-0.112*var.sfx,xofs,xofs};
1981     Double_t yy[5] = {yofs,yofs,yofs+ctw,yofs+ctw,yofs};
1982     TPolyLine *fcat3 = new TPolyLine(5,xx,yy);
1983     fcat3->SetLineColor(1);
1984     if ( cat3 != 0. || cat3b != 0. ){
1985     if ( cat3 > 0 || cat3b > 0 || cat3 == -0.25 || cat3b == -0.25 ){
1986     colo = cattime;
1987     } else {
1988     colo = catnoti;
1989     };
1990     } else {
1991     colo = 10;
1992     };
1993     fcat3->SetFillColor(colo);
1994     fcat3->SetLineWidth(1);
1995     fcat3->Draw("f");
1996     fcat3->Draw();
1997     };
1998     if ( true ){
1999     Float_t xofs = var.xxvc +0.108165*var.sfx;
2000     Float_t yofs = var.yxvc + 0.3725 *var.sfy;
2001     Double_t xx[5] = {xofs,xofs+0.112*var.sfx,xofs+0.112*var.sfx,xofs,xofs};
2002     Double_t yy[5] = {yofs,yofs,yofs+ctw,yofs+ctw,yofs};
2003     TPolyLine *fcat4 = new TPolyLine(5,xx,yy);
2004     fcat4->SetLineColor(1);
2005     if ( cat4 != 0. || cat4b != 0. ){
2006     if ( cat4 > 0 || cat4b > 0 || cat4 == -.25 || cat4b == -.25 ){
2007     colo = cattime;
2008     } else {
2009     colo = catnoti;
2010     };
2011     } else {
2012     colo = 10;
2013     };
2014     fcat4->SetFillColor(colo);
2015     fcat4->SetLineWidth(1);
2016     fcat4->Draw("f");
2017     fcat4->Draw();
2018     };
2019     if ( true ){
2020     Float_t xofs = var.xyvc + 0.090165*var.sfx;
2021     Float_t yofs = var.yyvc + 0.3725*var.sfy ;
2022     Double_t xx[5] = {xofs,xofs+0.122*var.sfx,xofs+0.122*var.sfx,xofs,xofs};
2023     Double_t yy[5] = {yofs,yofs,yofs+ctw,yofs+ctw,yofs};
2024     TPolyLine *fcat1 = new TPolyLine(5,xx,yy);
2025     fcat1->SetLineColor(1);
2026     if ( cat1 != 0. || cat1b != 0. ){
2027     if ( cat1 > 0 || cat1b > 0 || cat1 ==-.25 || cat1b ==-.25 ){
2028     colo = cattime;
2029     } else {
2030     colo = catnoti;
2031     };
2032     } else {
2033     colo = 10;
2034     };
2035     fcat1->SetFillColor(colo);
2036     fcat1->SetLineWidth(1);
2037     fcat1->Draw("f");
2038     fcat1->Draw();
2039     };
2040     if ( true ){
2041     Float_t xofs = var.xyvc - 0.090165*var.sfx;
2042     Float_t yofs = var.yyvc + 0.3725*var.sfy ;
2043     Double_t xx[5] = {xofs,xofs-0.122*var.sfx,xofs-0.122*var.sfx,xofs,xofs};
2044     Double_t yy[5] = {yofs,yofs,yofs+ctw,yofs+ctw,yofs};
2045     TPolyLine *fcat2 = new TPolyLine(5,xx,yy);
2046     fcat2->SetLineColor(1);
2047     if ( cat2 != 0. || cat2b != 0. ){
2048     if ( cat2 > 0 || cat2b > 0 || cat2 ==-.25 || cat2b ==-.25 ){
2049     colo = cattime;
2050     } else {
2051     colo = catnoti;
2052     };
2053     } else {
2054     colo = 10;
2055     };
2056     fcat2->SetFillColor(colo);
2057     fcat2->SetLineWidth(1);
2058     fcat2->Draw("f");
2059     fcat2->Draw();
2060     };
2061     //
2062     // CAT1
2063     //
2064     Float_t xcc[10];
2065     Float_t ycc[10];
2066     if ( true ){
2067     for (Int_t i = 0; i<10 ; i++) {
2068     xcc[i]= xcat - xcc1[i]*var.sfx;
2069     ycc[i] = ycat + ycc1[i]*var.sfy;
2070     };
2071     TPolyLine *fcat1 = new TPolyLine(10,xcc,ycc);
2072     fcat1->SetLineColor(1);
2073     colo = 10;
2074     if ( cat1 != 0. || cat1b != 0. ) {
2075     if ( cat1 > 0 || cat1b > 0 || cat1 ==-.25 || cat1b ==-.25 ){
2076     colo = cattime;
2077     } else {
2078     colo = catnoti;
2079     };
2080     };
2081     fcat1->SetFillColor(colo);
2082     fcat1->SetLineWidth(1);
2083     fcat1->Draw("f");
2084     fcat1->Draw();
2085     };
2086     //
2087     // CAT2
2088     //
2089     if ( true ){
2090     for (Int_t i = 0; i<10 ; i++) {
2091     xcc[i]= xcat + xcc1[i]*var.sfx;
2092     ycc[i] = ycat + ycc1[i]*var.sfy;
2093     };
2094     TPolyLine *fcat2 = new TPolyLine(10,xcc,ycc);
2095     fcat2->SetLineColor(1);
2096     colo = 10;
2097     if ( cat2 != 0. || cat2b != 0. ) {
2098     if ( cat2 > 0 || cat2b > 0 || cat2 ==-.25 || cat2b ==-.25 ){
2099     colo = cattime;
2100     } else {
2101     colo = catnoti;
2102     };
2103     };
2104     fcat2->SetFillColor(colo);
2105     fcat2->SetLineWidth(1);
2106     fcat2->Draw("f");
2107     fcat2->Draw();
2108     };
2109     //
2110     // CAT3
2111     //
2112     if ( true ){
2113     for (Int_t i = 0; i<10 ; i++) {
2114     xcc[i]= xcat + xcc2[i]*var.sfx;
2115     ycc[i] = ycat - ycc2[i]*var.sfy;
2116     };
2117     TPolyLine *fcat3 = new TPolyLine(10,xcc,ycc);
2118     fcat3->SetLineColor(1);
2119     colo = 10;
2120     if ( cat3 != 0. || cat3b != 0. ) {
2121     if ( cat3 > 0 || cat3b > 0 || cat3 == -.25 || cat3b ==-.25 ){
2122     colo = cattime;
2123     } else {
2124     colo = catnoti;
2125     };
2126     };
2127     fcat3->SetFillColor(colo);
2128     fcat3->SetLineWidth(1);
2129     fcat3->Draw("f");
2130     fcat3->Draw();
2131     };
2132     //
2133     // CAT4
2134     //
2135     if ( true ){
2136     for (Int_t i = 0; i<10 ; i++) {
2137     xcc[i]= xcat + xcc2[i]*var.sfx;
2138     ycc[i] = ycat + ycc2[i]*var.sfy;
2139     };
2140     TPolyLine *fcat4 = new TPolyLine(10,xcc,ycc);
2141     fcat4->SetLineColor(1);
2142     colo = 10;
2143     if ( cat4 != 0. || cat4b != 0. ) {
2144     if ( cat4 > 0 || cat4b > 0 || cat4 == -.25 || cat4b ==-.25 ){
2145     colo = cattime;
2146     } else {
2147     colo = catnoti;
2148     };
2149     };
2150     fcat4->SetFillColor(colo);
2151     fcat4->SetLineWidth(1);
2152     fcat4->Draw("f");
2153     fcat4->Draw();
2154     };
2155     //
2156     // CAT1 PMTs
2157     //
2158     Float_t xc[5];
2159     Float_t yc[5];
2160     if ( true ){
2161     for (Int_t i = 0; i<5 ; i++) {
2162     xc[i]= xcat - xpmt2 - xc1[i];
2163     yc[i] = ycat + ypmt2 + yc1[i];
2164     };
2165     TPolyLine *fcat1 = new TPolyLine(5,xc,yc);
2166     fcat1->SetLineColor(1);
2167     colo = (int)(10. - cat1 * 8.);
2168     fcat1->SetFillColor(colo);
2169     fcat1->SetLineWidth(1);
2170     fcat1->Draw("f");
2171     fcat1->Draw();
2172     };
2173     if ( true ){
2174     for (Int_t i = 0; i<5 ; i++) {
2175     xc[i]= xcat - xpmt2 - xc1[i];
2176     yc[i] = ycat - ypmt2 - yc1[i];
2177     };
2178     TPolyLine *fcat1b = new TPolyLine(5,xc,yc);
2179     fcat1b->SetLineColor(1);
2180     colo = (int)(10. - cat1b * 8.);
2181     fcat1b->SetFillColor(colo);
2182     fcat1b->SetLineWidth(1);
2183     fcat1b->Draw("f");
2184     fcat1b->Draw();
2185     };
2186     //
2187     // CAT2 PMTs
2188     //
2189     if ( true ){
2190     for (Int_t i = 0; i<5 ; i++) {
2191     xc[i]= xcat + xpmt2 + xc1[i];
2192     yc[i] = ycat + ypmt2 + yc1[i];
2193     };
2194     TPolyLine *fcat2 = new TPolyLine(5,xc,yc);
2195     fcat2->SetLineColor(1);
2196     colo = (int)(10. - cat2 * 8.);
2197     fcat2->SetFillColor(colo);
2198     fcat2->SetLineWidth(1);
2199     fcat2->Draw("f");
2200     fcat2->Draw();
2201     };
2202     if ( true ){
2203     for (Int_t i = 0; i<5 ; i++) {
2204     xc[i]= xcat + xpmt2 + xc1[i];
2205     yc[i] = ycat - ypmt2 - yc1[i];
2206     };
2207     TPolyLine *fcat2b = new TPolyLine(5,xc,yc);
2208     fcat2b->SetLineColor(1);
2209     colo = (int)(10. - cat2b * 8.);
2210     fcat2b->SetFillColor(colo);
2211     fcat2b->SetLineWidth(1);
2212     fcat2b->Draw("f");
2213     fcat2b->Draw();
2214     };
2215     //
2216     // CAT3 PMTs
2217     //
2218     if ( true ){
2219     for (Int_t i = 0; i<5 ; i++) {
2220     xc[i]= xcat + xpmt1 + xc2[i];
2221     yc[i] = ycat - ypmt1 - yc2[i];
2222     };
2223     TPolyLine *fcat3b = new TPolyLine(5,xc,yc);
2224     fcat3b->SetLineColor(1);
2225     colo = (int)(10. - cat3b * 8.);
2226     fcat3b->SetFillColor(colo);
2227     fcat3b->SetLineWidth(1);
2228     fcat3b->Draw("f");
2229     fcat3b->Draw();
2230     };
2231     if ( true ){
2232     for (Int_t i = 0; i<5 ; i++) {
2233     xc[i]= xcat - xpmt1 - xc2[i];
2234     yc[i] = ycat - ypmt1 - yc2[i];
2235     };
2236     TPolyLine *fcat3 = new TPolyLine(5,xc,yc);
2237     fcat3->SetLineColor(1);
2238     colo = (int)(10. - cat3 * 8.);
2239     fcat3->SetFillColor(colo);
2240     fcat3->SetLineWidth(1);
2241     fcat3->Draw("f");
2242     fcat3->Draw();
2243     };
2244     //
2245     // CAT4 PMTs
2246     //
2247     if ( true ){
2248     for (Int_t i = 0; i<5 ; i++) {
2249     xc[i]= xcat + xpmt1 + xc2[i];
2250     yc[i] = ycat + ypmt1 + yc2[i];
2251     };
2252     TPolyLine *fcat4b = new TPolyLine(5,xc,yc);
2253     fcat4b->SetLineColor(1);
2254     colo = (int)(10. - cat4b * 8.);
2255     fcat4b->SetFillColor(colo);
2256     fcat4b->SetLineWidth(1);
2257     fcat4b->Draw("f");
2258     fcat4b->Draw();
2259     };
2260     if ( true ){
2261     for (Int_t i = 0; i<5 ; i++) {
2262     xc[i]= xcat - xpmt1 - xc2[i];
2263     yc[i] = ycat + ypmt1 + yc2[i];
2264     };
2265     TPolyLine *fcat4 = new TPolyLine(5,xc,yc);
2266     fcat4->SetLineColor(1);
2267     colo = (int)(10. - cat4 * 8.);
2268     fcat4->SetFillColor(colo);
2269     fcat4->SetLineWidth(1);
2270     fcat4->Draw("f");
2271     fcat4->Draw();
2272     };
2273     };
2274     if ( true ){
2275     //
2276     // CAS plane view:
2277     //
2278     Float_t xofs = -0.025;
2279     Float_t yofs = 0.039 +0.081+0.0273;
2280     Float_t csy = 0.33/2.;
2281     Float_t pmofs = 0.004;
2282     Float_t csw2 = 0.008;
2283     Float_t xc1[5] = { xofs-csy, xofs-csy, xofs+csy, xofs+csy, xofs-csy};
2284     Float_t yc1[5] = { yofs, yofs+csw2, yofs+csw2, yofs, yofs};
2285    
2286     Float_t xc2[5] = { xofs-csy-csw2, xofs-csy-csw2, xofs-csy, xofs-csy, xofs-csy-csw2};
2287     Float_t yc2[5] = { yofs+pmofs, yofs+pmofs+csw2, yofs+pmofs+csw2, yofs+pmofs, yofs+pmofs};
2288     Float_t xc3[5] = { xofs-csy-csw2, xofs-csy-csw2, xofs-csy, xofs-csy, xofs-csy-csw2};
2289     Float_t yc3[5] = { yofs+pmofs, yofs+pmofs-csw2, yofs+pmofs-csw2, yofs+pmofs, yofs+pmofs};
2290    
2291     //
2292     // CAS1
2293     //
2294     Float_t xc[5];
2295     Float_t yc[5];
2296     for (Int_t i = 0; i<5 ; i++) {
2297     xc[i]= xcat + xc1[i]*var.sfx;
2298     yc[i] = ycat + yc1[i]*var.sfy;
2299     };
2300     TPolyLine *pcass1 = new TPolyLine(5,xc,yc);
2301     pcass1->SetLineColor(1);
2302     colo = 10;
2303     if ( cas1 != 0. || cas1b != 0. ) {
2304     if ( cas1 > 0 || cas1b > 0 || cas1 ==-.25 || cas1b ==-.25){
2305     colo = cattime;
2306     } else {
2307     colo = catnoti;
2308     };
2309     };
2310     if ( colo != 10 ) pcass1->SetFillStyle(3001);
2311     pcass1->SetFillColor(colo);
2312     pcass1->SetLineWidth(1);
2313     pcass1->SetLineStyle(2);
2314     pcass1->Draw("f");
2315     pcass1->Draw();
2316     //
2317     for (Int_t i = 0; i<5 ; i++) {
2318     xc[i]= xcat + xc2[i]*var.sfx;
2319     yc[i] = ycat + yc2[i]*var.sfy;
2320     };
2321     TPolyLine *pcasp1b = new TPolyLine(5,xc,yc);
2322     pcasp1b->SetLineColor(1);
2323     colo = (int)(10. - cas1b * 8.);
2324     if ( colo != 10 ) pcasp1b->SetFillStyle(3001);
2325     pcasp1b->SetFillColor(colo);
2326     pcasp1b->SetLineWidth(1);
2327     pcasp1b->SetLineStyle(2);
2328     pcasp1b->Draw("f");
2329     pcasp1b->Draw();
2330     //
2331     for (Int_t i = 0; i<5 ; i++) {
2332     xc[i]= xcat + xc3[i]*var.sfx;
2333     yc[i] = ycat + yc3[i]*var.sfy;
2334     };
2335     TPolyLine *pcasp1 = new TPolyLine(5,xc,yc);
2336     pcasp1->SetLineColor(1);
2337     colo = (int)(10. - cas1 * 8.);
2338     if ( colo != 10 ) pcasp1->SetFillStyle(3001);
2339     pcasp1->SetFillColor(colo);
2340     pcasp1->SetLineWidth(1);
2341     pcasp1->SetLineStyle(2);
2342     pcasp1->Draw("f");
2343     pcasp1->Draw();
2344     //
2345     // CAS2
2346     //
2347     for (Int_t i = 0; i<5 ; i++) {
2348     xc[i]= xcat - xc1[i]*var.sfx;
2349     yc[i] = ycat - yc1[i]*var.sfy;
2350     };
2351     TPolyLine *pcass2 = new TPolyLine(5,xc,yc);
2352     pcass2->SetLineColor(1);
2353     colo = 10;
2354     if ( cas2 != 0. || cas2b != 0. ) {
2355     if ( cas2 > 0 || cas2b > 0 || cas2 ==-.25 || cas2b ==-.25 ){
2356     colo = cattime;
2357     } else {
2358     colo = catnoti;
2359     };
2360     };
2361     if ( colo != 10 ) pcass2->SetFillStyle(3001);
2362     pcass2->SetFillColor(colo);
2363     pcass2->SetLineWidth(1);
2364     pcass2->SetLineStyle(2);
2365     pcass2->Draw("f");
2366     pcass2->Draw();
2367     //
2368     for (Int_t i = 0; i<5 ; i++) {
2369     xc[i]= xcat - xc2[i]*var.sfx;
2370     yc[i] = ycat - yc2[i]*var.sfy;
2371     };
2372     TPolyLine *pcasp2b = new TPolyLine(5,xc,yc);
2373     pcasp2b->SetLineColor(1);
2374     colo = (int)(10. - cas2b * 8.);
2375     if ( colo != 10 ) pcasp2b->SetFillStyle(3001);
2376     pcasp2b->SetFillColor(colo);
2377     pcasp2b->SetLineWidth(1);
2378     pcasp2b->SetLineStyle(2);
2379     pcasp2b->Draw("f");
2380     pcasp2b->Draw();
2381     //
2382     for (Int_t i = 0; i<5 ; i++) {
2383     xc[i]= xcat - xc3[i]*var.sfx;
2384     yc[i] = ycat - yc3[i]*var.sfy;
2385     };
2386     TPolyLine *pcasp2 = new TPolyLine(5,xc,yc);
2387     pcasp2->SetLineColor(1);
2388     colo = (int)(10. - cas2 * 8.);
2389     pcasp2->SetFillColor(colo);
2390     if ( colo != 10 ) pcasp2->SetFillStyle(3001);
2391     pcasp2->SetLineWidth(1);
2392     pcasp2->SetLineStyle(2);
2393     pcasp2->Draw("f");
2394     pcasp2->Draw();
2395    
2396     };
2397     if ( true ){
2398     Float_t xofs = 0.048 +0.066+0.0273;
2399     Float_t yofs = 0.02;
2400     Float_t csy = 0.33/2.;
2401     Float_t pmofs = 0.004;
2402     Float_t csw2 = 0.008;
2403     Float_t xc1[5] = { xofs, xofs+csw2, xofs+csw2, xofs, xofs};
2404     Float_t yc1[5] = { yofs-csy, yofs-csy, yofs+csy, yofs+csy, yofs-csy};
2405     Float_t xc2[5] = { xofs+pmofs, xofs+pmofs+csw2, xofs+pmofs+csw2, xofs+pmofs, xofs+pmofs};
2406     Float_t yc2[5] = { yofs+csy+csw2, yofs+csy+csw2, yofs+csy, yofs+csy, yofs+csy+csw2};
2407     Float_t xc3[5] = { xofs+pmofs, xofs+pmofs-csw2, xofs+pmofs-csw2, xofs+pmofs, xofs+pmofs};
2408     Float_t yc3[5] = { yofs+csy+csw2, yofs+csy+csw2, yofs+csy, yofs+csy, yofs+csy+csw2};
2409     //
2410     // CAS3
2411     //
2412     Float_t xc[5];
2413     Float_t yc[5];
2414     for (Int_t i = 0; i<5 ; i++) {
2415     xc[i]= xcat + xc1[i]*var.sfx;
2416     yc[i] = ycat + yc1[i]*var.sfy;
2417     };
2418     TPolyLine *pcass3 = new TPolyLine(5,xc,yc);
2419     pcass3->SetLineColor(1);
2420     colo = 10;
2421     if ( cas3 != 0. || cas3b != 0. ) {
2422     if ( cas3 > 0 || cas3b > 0 || cas3 ==-.25 || cas3b ==-.25){
2423     colo = cattime;
2424     } else {
2425     colo = catnoti;
2426     };
2427     };
2428     if ( colo != 10 ) pcass3->SetFillStyle(3001);
2429     pcass3->SetFillColor(colo);
2430     pcass3->SetLineWidth(1);
2431     pcass3->SetLineStyle(2);
2432     pcass3->Draw("f");
2433     pcass3->Draw();
2434     //
2435     for (Int_t i = 0; i<5 ; i++) {
2436     xc[i]= xcat + xc2[i]*var.sfx;
2437     yc[i] = ycat + yc2[i]*var.sfy;
2438     };
2439     TPolyLine *pcasp3b = new TPolyLine(5,xc,yc);
2440     pcasp3b->SetLineColor(1);
2441     colo = (int)(10. - cas3b * 8.);
2442     if ( colo != 10 ) pcasp3b->SetFillStyle(3001);
2443     pcasp3b->SetFillColor(colo);
2444     pcasp3b->SetLineWidth(1);
2445     pcasp3b->SetLineStyle(2);
2446     pcasp3b->Draw("f");
2447     pcasp3b->Draw();
2448     //
2449     for (Int_t i = 0; i<5 ; i++) {
2450     xc[i]= xcat + xc3[i]*var.sfx;
2451     yc[i] = ycat + yc3[i]*var.sfy;
2452     };
2453     TPolyLine *pcasp3 = new TPolyLine(5,xc,yc);
2454     pcasp3->SetLineColor(1);
2455     colo = (int)(10. - cas3 * 8.);
2456     pcasp3->SetFillColor(colo);
2457     if ( colo != 10 ) pcasp3->SetFillStyle(3001);
2458     pcasp3->SetLineWidth(1);
2459     pcasp3->SetLineStyle(2);
2460     pcasp3->Draw("f");
2461     pcasp3->Draw();
2462     //
2463     // CAS4
2464     //
2465     for (Int_t i = 0; i<5 ; i++) {
2466     xc[i]= xcat - xc1[i]*var.sfx;
2467     yc[i] = ycat - yc1[i]*var.sfy;
2468     };
2469     TPolyLine *pcass4 = new TPolyLine(5,xc,yc);
2470     pcass4->SetLineColor(1);
2471     colo = 10;
2472     if ( cas4 != 0. || cas4b != 0. ) {
2473     if ( cas4 > 0 || cas4b > 0 || cas4 ==-.25 || cas4b ==-.25 ){
2474     colo = cattime;
2475     } else {
2476     colo = catnoti;
2477     };
2478     };
2479     pcass4->SetFillColor(colo);
2480     if ( colo != 10 ) pcass4->SetFillStyle(3001);
2481     pcass4->SetLineWidth(1);
2482     pcass4->SetLineStyle(2);
2483     pcass4->Draw("f");
2484     pcass4->Draw();
2485     //
2486     for (Int_t i = 0; i<5 ; i++) {
2487     xc[i]= xcat - xc2[i]*var.sfx;
2488     yc[i] = ycat - yc2[i]*var.sfy;
2489     };
2490     TPolyLine *pcasp4 = new TPolyLine(5,xc,yc);
2491     pcasp4->SetLineColor(1);
2492     colo = (int)(10. - cas4 * 8.);
2493     pcasp4->SetFillColor(colo);
2494     if ( colo != 10 ) pcasp4->SetFillStyle(3001);
2495     pcasp4->SetLineWidth(1);
2496     pcasp4->SetLineStyle(2);
2497     pcasp4->Draw("f");
2498     pcasp4->Draw();
2499     //
2500     for (Int_t i = 0; i<5 ; i++) {
2501     xc[i]= xcat - xc3[i]*var.sfx;
2502     yc[i] = ycat - yc3[i]*var.sfy;
2503     };
2504     TPolyLine *pcasp4b = new TPolyLine(5,xc,yc);
2505     pcasp4b->SetLineColor(1);
2506     colo = (int)(10. - cas4b * 8.);
2507     pcasp4b->SetFillColor(colo);
2508     if ( colo != 10 ) pcasp4b->SetFillStyle(3001);
2509     pcasp4b->SetLineWidth(1);
2510     pcasp4b->SetLineStyle(2);
2511     pcasp4b->Draw("f");
2512     pcasp4b->Draw();
2513     };
2514     Float_t alfa = 1.2020334;
2515     Float_t lcrd = 0.1815/2.;
2516     Float_t wcrd = 0.008;
2517     if ( true ){
2518     //
2519     // CARD plane view:
2520     //
2521     Float_t xc1[5] = { -0.090165, -0.090165, -0.082165, -0.082165, -0.090165};
2522     Float_t yc1[5] = { -0.100, 0.092, 0.092, -0.100, -0.100};
2523     Float_t xc2[5] = { -0.094165, -0.094165, -0.086165, -0.086165, -0.094165};
2524     Float_t yc2[5] = { 0.092, 0.100, 0.100, 0.092, 0.092};
2525     Float_t xc3[5] = { -0.086165, -0.086165, -0.078165, -0.078165, -0.086165};
2526     Float_t yc3[5] = { 0.092, 0.100, 0.100, 0.092, 0.092};
2527     //
2528     // CARD1
2529     //
2530     Float_t xc[5];
2531     Float_t yc[5];
2532     for (Int_t i = 0; i<5 ; i++) {
2533     xc[i]= xcat + xc1[i]*var.sfx;
2534     yc[i] = ycat + yc1[i]*var.sfy;
2535     };
2536     TPolyLine *pcars1 = new TPolyLine(5,xc,yc);
2537     pcars1->SetLineColor(1);
2538     colo = 10;
2539     if ( card1 != 0. || card1b != 0. ) {
2540     if ( card1 > 0 || card1b > 0 || card1 ==-.25 || card1b ==-.25 ){
2541     colo = cattime;
2542     } else {
2543     colo = catnoti;
2544     };
2545     };
2546     pcars1->SetFillColor(colo);
2547     pcars1->SetLineWidth(1);
2548     pcars1->Draw("f");
2549     pcars1->Draw();
2550     //
2551     for (Int_t i = 0; i<5 ; i++) {
2552     xc[i]= xcat + xc2[i]*var.sfx;
2553     yc[i] = ycat + yc2[i]*var.sfy;
2554     };
2555     TPolyLine *pcarp1b = new TPolyLine(5,xc,yc);
2556     pcarp1b->SetLineColor(1);
2557     colo = (int)(10. - card1b * 8.);
2558     pcarp1b->SetFillColor(colo);
2559     pcarp1b->SetLineWidth(1);
2560     pcarp1b->Draw("f");
2561     pcarp1b->Draw();
2562     //
2563     for (Int_t i = 0; i<5 ; i++) {
2564     xc[i] = xcat + xc3[i]*var.sfx;
2565     yc[i] = ycat + yc3[i]*var.sfy;
2566     };
2567     TPolyLine *pcarp1 = new TPolyLine(5,xc,yc);
2568     pcarp1->SetLineColor(1);
2569     colo = (int)(10. - card1 * 8.);
2570     pcarp1->SetFillColor(colo);
2571     pcarp1->SetLineWidth(1);
2572     pcarp1->Draw("f");
2573     pcarp1->Draw();
2574     //
2575     // CARD4
2576     //
2577     for (Int_t i = 0; i<5 ; i++) {
2578     xc[i]= xcat - xc1[i]*var.sfx;
2579     yc[i] = ycat - yc1[i]*var.sfy;
2580     };
2581     TPolyLine *pcars4 = new TPolyLine(5,xc,yc);
2582     pcars4->SetLineColor(1);
2583     colo = 10;
2584     if ( card4 != 0. || card4b != 0. ) {
2585     if ( card4 > 0 || card4b > 0 || card4 ==-.25 || card4b ==-.25){
2586     colo = cattime;
2587     } else {
2588     colo = catnoti;
2589     };
2590     };
2591     pcars4->SetFillColor(colo);
2592     pcars4->SetLineWidth(1);
2593     pcars4->Draw("f");
2594     pcars4->Draw();
2595     //
2596     for (Int_t i = 0; i<5 ; i++) {
2597     xc[i]= xcat - xc2[i]*var.sfx;
2598     yc[i] = ycat - yc2[i]*var.sfy;
2599     };
2600     TPolyLine *pcarp4b = new TPolyLine(5,xc,yc);
2601     pcarp4b->SetLineColor(1);
2602     colo = (int)(10. - card4b * 8.);
2603     pcarp4b->SetFillColor(colo);
2604     pcarp4b->SetLineWidth(1);
2605     pcarp4b->Draw("f");
2606     pcarp4b->Draw();
2607     //
2608     for (Int_t i = 0; i<5 ; i++) {
2609     xc[i]= xcat - xc3[i]*var.sfx;
2610     yc[i] = ycat - yc3[i]*var.sfy;
2611     };
2612     TPolyLine *pcarp4 = new TPolyLine(5,xc,yc);
2613     pcarp4->SetLineColor(1);
2614     colo = (int)(10. - card4 * 8.);
2615     pcarp4->SetFillColor(colo);
2616     pcarp4->SetLineWidth(1);
2617     pcarp4->Draw("f");
2618     pcarp4->Draw();
2619     };
2620     if ( true ){
2621     Float_t xc1[5] = { -0.074, 0.074, 0.074, -0.074, -0.074};
2622     Float_t yc1[5] = { 0.108165, 0.108165, 0.100165, 0.100165, 0.108165};
2623     Float_t xc2[5] = { 0.074, 0.082, 0.082, 0.074, 0.074};
2624     Float_t yc2[5] = { 0.112165, 0.112165, 0.104165, 0.104165, 0.112165};
2625     Float_t xc3[5] = { 0.074, 0.082, 0.082, 0.074, 0.074};
2626     Float_t yc3[5] = { 0.104165, 0.104165, 0.096165, 0.096165, 0.104165};
2627     //
2628     // CARD2
2629     //
2630     Float_t xc[5];
2631     Float_t yc[5];
2632     for (Int_t i = 0; i<5 ; i++) {
2633     xc[i]= xcat - (xc1[i]-0.0025)*var.sfx;
2634     yc[i] = ycat - yc1[i]*var.sfy;
2635     };
2636     TPolyLine *pcars2 = new TPolyLine(5,xc,yc);
2637     pcars2->SetLineColor(1);
2638     colo = 10;
2639     if ( card2 != 0. || card2b != 0.) {
2640     if ( card2 > 0 || card2b > 0 || card2 ==-.25 || card2b ==-.25 ){
2641     colo = cattime;
2642     } else {
2643     colo = catnoti;
2644     };
2645     };
2646     pcars2->SetFillColor(colo);
2647     pcars2->SetLineWidth(1);
2648     pcars2->Draw("f");
2649     pcars2->Draw();
2650     //
2651     for (Int_t i = 0; i<5 ; i++) {
2652     xc[i]= xcat - (xc2[i]-0.0025)*var.sfx;
2653     yc[i] = ycat - yc2[i]*var.sfy;
2654     };
2655     TPolyLine *pcarp2 = new TPolyLine(5,xc,yc);
2656     pcarp2->SetLineColor(1);
2657     colo = (int)(10. - card2 * 8.);
2658     pcarp2->SetFillColor(colo);
2659     pcarp2->SetLineWidth(1);
2660     pcarp2->Draw("f");
2661     pcarp2->Draw();
2662     //
2663     for (Int_t i = 0; i<5 ; i++) {
2664     xc[i]= xcat - (xc3[i]-0.0025)*var.sfx;
2665     yc[i] = ycat - yc3[i]*var.sfy;
2666     };
2667     TPolyLine *pcarp2b = new TPolyLine(5,xc,yc);
2668     pcarp2b->SetLineColor(1);
2669     colo = (int)(10. - card2b * 8.);
2670     pcarp2b->SetFillColor(colo);
2671     pcarp2b->SetLineWidth(1);
2672     pcarp2b->Draw("f");
2673     pcarp2b->Draw();
2674     //
2675     // CARD3
2676     //
2677     for (Int_t i = 0; i<5 ; i++) {
2678     xc[i]= xcat + (xc1[i]-0.0025)*var.sfx;
2679     yc[i] = ycat + yc1[i]*var.sfy;
2680     };
2681     TPolyLine *pcars3 = new TPolyLine(5,xc,yc);
2682     pcars3->SetLineColor(1);
2683     colo = 10;
2684     if ( card3 != 0. || card3b != 0. ) {
2685     if ( card3 > 0 || card3b > 0 || card3==-.25 || card3b ==-.25){
2686     colo = cattime;
2687     } else {
2688     colo = catnoti;
2689     };
2690     };
2691     pcars3->SetFillColor(colo);
2692     pcars3->SetLineWidth(1);
2693     pcars3->Draw("f");
2694     pcars3->Draw();
2695     //
2696     for (Int_t i = 0; i<5 ; i++) {
2697     xc[i]= xcat + (xc2[i]-0.0025)*var.sfx;
2698     yc[i] = ycat + yc2[i]*var.sfy;
2699     };
2700     TPolyLine *pcarp3 = new TPolyLine(5,xc,yc);
2701     pcarp3->SetLineColor(1);
2702     colo = (int)(10. - card3 * 8.);
2703     pcarp3->SetFillColor(colo);
2704     pcarp3->SetLineWidth(1);
2705     pcarp3->Draw("f");
2706     pcarp3->Draw();
2707     //
2708     for (Int_t i = 0; i<5 ; i++) {
2709     xc[i]= xcat + (xc3[i]-0.0025)*var.sfx;
2710     yc[i] = ycat + yc3[i]*var.sfy;
2711     };
2712     TPolyLine *pcarp3b = new TPolyLine(5,xc,yc);
2713     pcarp3b->SetLineColor(1);
2714     colo = (int)(10. - card3b * 8.);
2715     pcarp3b->SetFillColor(colo);
2716     pcarp3b->SetLineWidth(1);
2717     pcarp3b->Draw("f");
2718     pcarp3b->Draw();
2719    
2720     //
2721     // CARD - X-view
2722     //
2723     Float_t cardcx = 0.143168*var.sfx;
2724     Float_t cardcy = 0.1475*var.sfy;
2725     Float_t acrdx[4] = {-lcrd*cos(alfa), lcrd*cos(alfa), -lcrd*cos(alfa)+wcrd*sin(alfa), -lcrd*cos(alfa)};
2726     Float_t acrdy[4] = {-lcrd*sin(alfa), lcrd*sin(alfa), -lcrd*sin(alfa)-wcrd*cos(alfa), -lcrd*sin(alfa)};
2727     Float_t bcrdx[4] = { lcrd*cos(alfa), lcrd*cos(alfa)+wcrd*sin(alfa), -lcrd*cos(alfa)+wcrd*sin(alfa), lcrd*cos(alfa)};
2728     Float_t bcrdy[4] = { lcrd*sin(alfa), lcrd*sin(alfa)-wcrd*cos(alfa), -lcrd*sin(alfa)-wcrd*cos(alfa), lcrd*sin(alfa)};
2729    
2730     //
2731     // CARD3 X/ Y
2732     //
2733     Float_t xcc[4];
2734     Float_t ycc[4];
2735     for (Int_t i = 0; i<4 ; i++) {
2736     xcc[i] = cardcx + var.xxvc + acrdx[i]*var.sfx;
2737     ycc[i] = cardcy + var.yxvc + (0.36 + acrdy[i])*var.sfy;
2738     };
2739     TPolyLine *fcard3 = new TPolyLine(4,xcc,ycc);
2740     fcard3->SetLineColor(1);
2741     colo = (int)(10. - card3 * 8.);
2742     fcard3->SetFillColor(colo);
2743     fcard3->SetLineWidth(1);
2744     fcard3->Draw("f");
2745     fcard3->Draw();
2746     //
2747     for (Int_t i = 0; i<4 ; i++) {
2748     xcc[i] = cardcx + var.xxvc + bcrdx[i]*var.sfx;
2749     ycc[i] = cardcy + var.yxvc + (0.36 + bcrdy[i])*var.sfy;
2750     };
2751     TPolyLine *fcard3b = new TPolyLine(4,xcc,ycc);
2752     fcard3b->SetLineColor(1);
2753     colo = (int)(10. - card3b * 8.);
2754     fcard3b->SetFillColor(colo);
2755     fcard3b->SetLineWidth(1);
2756     fcard3b->Draw("f");
2757     fcard3b->Draw();
2758    
2759     //
2760     // CARD2 \X Y
2761     //
2762     for (Int_t i = 0; i<4 ; i++) {
2763     xcc[i] = -cardcx + var.xxvc - acrdx[i]*var.sfx;
2764     ycc[i] = cardcy + var.yxvc + (0.36 + acrdy[i])*var.sfy;
2765     };
2766     TPolyLine *fcard2 = new TPolyLine(4,xcc,ycc);
2767     fcard2->SetLineColor(1);
2768     colo = (int)(10. - card2 * 8.);
2769     fcard2->SetFillColor(colo);
2770     fcard2->SetLineWidth(1);
2771     fcard2->Draw("f");
2772     fcard2->Draw();
2773     //
2774     for (Int_t i = 0; i<4 ; i++) {
2775     xcc[i] = -cardcx + var.xxvc - bcrdx[i]*var.sfx;
2776     ycc[i] = cardcy + var.yxvc + (0.36 + bcrdy[i])*var.sfy;
2777     };
2778     TPolyLine *fcard2b = new TPolyLine(4,xcc,ycc);
2779     fcard2b->SetLineColor(1);
2780     colo = (int)(10. - card2b * 8.);
2781     fcard2b->SetFillColor(colo);
2782     fcard2b->SetLineWidth(1);
2783     fcard2b->Draw("f");
2784     fcard2b->Draw();
2785     };
2786    
2787     if ( true ){
2788     Float_t acrdx[4] = {-lcrd*cos(alfa), lcrd*cos(alfa), -lcrd*cos(alfa)+wcrd*sin(alfa), -lcrd*cos(alfa)};
2789     Float_t acrdy[4] = {-lcrd*sin(alfa), lcrd*sin(alfa), -lcrd*sin(alfa)-wcrd*cos(alfa), -lcrd*sin(alfa)};
2790     Float_t bcrdx[4] = { lcrd*cos(alfa), lcrd*cos(alfa)+wcrd*sin(alfa), -lcrd*cos(alfa)+wcrd*sin(alfa), lcrd*cos(alfa)};
2791     Float_t bcrdy[4] = { lcrd*sin(alfa), lcrd*sin(alfa)-wcrd*cos(alfa), -lcrd*sin(alfa)-wcrd*cos(alfa), lcrd*sin(alfa)};
2792     //
2793     // CARD - Y-view
2794     //
2795     Float_t cardcx = 0.12*var.sfx;
2796     Float_t cardcy = 0.1475*var.sfy;
2797     //
2798     // CARD4 X Y/
2799     //
2800     Float_t xcc[4];
2801     Float_t ycc[4];
2802     for (Int_t i = 0; i<4 ; i++) {
2803     xcc[i] = cardcx + var.xyvc + acrdx[i]*var.sfx;
2804     ycc[i] = cardcy + var.yyvc + (0.36 + acrdy[i])*var.sfy;
2805     };
2806     TPolyLine *fcard4 = new TPolyLine(4,xcc,ycc);
2807     fcard4->SetLineColor(1);
2808     colo = (int)(10. - card4 * 8.);
2809     fcard4->SetFillColor(colo);
2810     fcard4->SetLineWidth(1);
2811     fcard4->Draw("f");
2812     fcard4->Draw();
2813     //
2814     for (Int_t i = 0; i<4 ; i++) {
2815     xcc[i] = cardcx + var.xyvc + bcrdx[i]*var.sfx;
2816     ycc[i] = cardcy + var.yyvc + (0.36 + bcrdy[i])*var.sfy;
2817     };
2818     TPolyLine *fcard4b = new TPolyLine(4,xcc,ycc);
2819     fcard4b->SetLineColor(1);
2820     colo = (int)(10. - card4b * 8.);
2821     fcard4b->SetFillColor(colo);
2822     fcard4b->SetLineWidth(1);
2823     fcard4b->Draw("f");
2824     fcard4b->Draw();
2825    
2826     //
2827     // CARD1 X \Y
2828     //
2829     for (Int_t i = 0; i<4 ; i++) {
2830     xcc[i] = -cardcx + var.xyvc - acrdx[i]*var.sfx;
2831     ycc[i] = cardcy + var.yyvc + (0.36 + acrdy[i])*var.sfy;
2832     };
2833     TPolyLine *fcard1 = new TPolyLine(4,xcc,ycc);
2834     fcard1->SetLineColor(1);
2835     colo = (int)(10. - card1 * 8.);
2836     fcard1->SetFillColor(colo);
2837     fcard1->SetLineWidth(1);
2838     fcard1->Draw("f");
2839     fcard1->Draw();
2840     //
2841     for (Int_t i = 0; i<4 ; i++) {
2842     xcc[i] = -cardcx + var.xyvc - bcrdx[i]*var.sfx;
2843     ycc[i] = cardcy + var.yyvc + (0.36 + bcrdy[i])*var.sfy;
2844     };
2845     TPolyLine *fcard1b = new TPolyLine(4,xcc,ycc);
2846     fcard1b->SetLineColor(1);
2847     colo = (int)(10. - card1b * 8.);
2848     fcard1b->SetFillColor(colo);
2849     fcard1b->SetLineWidth(1);
2850     fcard1b->Draw("f");
2851     fcard1b->Draw();
2852     };
2853     }
2854    
2855     void ShowTOF(Int_t j, TTree *otr, Variables & var){
2856     //
2857     // get the trigger infos
2858     //
2859     pamela::trigger::TriggerEvent *trigger = 0;
2860     otr->SetBranchAddress("Trigger.Event", &trigger);
2861     if ( !var.nosig ) otr->GetEntry(j);
2862     //
2863    
2864     //
2865     // on day these variables will contain the MIP value for each paddle
2866     //
2867     Float_t ms11a[8] = {0.,0.,0.,0.,0.,0.,0.,0.};
2868     Float_t ms12a[6] = {0.,0.,0.,0.,0.,0.};
2869     Float_t ms21a[2] = {0.,0.};
2870     Float_t ms22a[2] = {0.,0.};
2871     Float_t ms31a[3] = {0.,0.,0.};
2872     Float_t ms32a[3] = {0.,0.,0.};
2873     Float_t ms11b[8] = {0.,0.,0.,0.,0.,0.,0.,0.};
2874     Float_t ms12b[6] = {0.,0.,0.,0.,0.,0.};
2875     Float_t ms21b[2] = {0.,0.};
2876     Float_t ms22b[2] = {0.,0.};
2877     Float_t ms31b[3] = {0.,0.,0.};
2878     Float_t ms32b[3] = {0.,0.,0.};
2879     //
2880     // TDC info for each PMT
2881     //
2882     Float_t mt11[2][8];
2883     Float_t mt12[2][6];
2884     Float_t mt21[2][2];
2885     Float_t mt22[2][2];
2886     Float_t mt31[2][3];
2887     Float_t mt32[2][3];
2888     //
2889     Int_t S3 = 0;
2890     Int_t S2 = 0;
2891     Int_t S12 = 0;
2892     Int_t S11 = 0;
2893     if ( !var.nosig ) {
2894     S3 = trigger->patterntrig[2];
2895     S2 = trigger->patterntrig[3];
2896     S12 = trigger->patterntrig[4];
2897     S11 = trigger->patterntrig[5];
2898     };
2899     //
2900     for ( Int_t i = 0; i<8; i++ ) {
2901     if ( S11 & (1<<i) ){
2902     ms11a[i] = 1.;
2903     }
2904     if ( S11 & (1<<(i+8) ) ){
2905     ms11b[i] = 1.;
2906     }
2907     };
2908     for ( Int_t i = 0; i<6; i++ ) {
2909     if ( S12 & (1<<i) ) {
2910     ms12a[i] = 1.;
2911     }
2912     if ( S12 & (1<<(i+6)) ) {
2913     ms12b[i] = 1.;
2914     }
2915     };
2916     Int_t ii = 2;
2917     for ( Int_t i = 0; i<2; i++ ) {
2918     ii--;
2919     if ( S2 & (1<<i) ) {
2920     ms21a[ii] = 1.;
2921     }
2922     if ( S2 & (1<<(i+2)) ) {
2923     ms21b[ii] = 1.;
2924     }
2925     };
2926     for ( Int_t i = 4; i<6; i++ ) {
2927     if ( S2 & (1<<i) ) {
2928     ms22a[i-4] = 1.;
2929     }
2930     if ( S2 & (1<<(i+2)) ) {
2931     ms22b[i-4] = 1.;
2932     }
2933     };
2934     for ( Int_t i = 0; i<3; i++ ) {
2935     if ( S3 & (1<<i) ) {
2936     ms31a[i] = 1.;
2937     }
2938     if ( S3 & (1<<(i+3)) ) {
2939     ms31b[i] = 1.;
2940     }
2941     };
2942     for ( Int_t i = 6; i<9; i++ ) {
2943     if ( S3 & (1<<i) ) {
2944     ms32a[i-6] = 1.;
2945     }
2946     if ( S3 & (1<<(i+3)) ) {
2947     ms32b[i-6] = 1.;
2948     }
2949     };
2950     //
2951     Int_t colo;
2952     Int_t ocolo;
2953     Float_t xs2x = var.xxvc;
2954     Float_t ys2x = var.yxvc + 0.36*var.sfy;
2955     Float_t xs2y = var.xyvc;
2956     Float_t ys2y = var.yyvc + 0.36*var.sfy;
2957     Float_t ws2 = 0.005;
2958     Float_t ws13 = 0.007;
2959     Int_t noadc = 12;
2960     if ( var.bw ){
2961     noadc=12;
2962     } else {
2963     noadc=41;
2964     };
2965     //
2966     // S11 X-view
2967     //
2968     // A
2969     Float_t s11p = 0.051;
2970     ocolo = 10;
2971     TPolyLine *ftof11xa[8];
2972     for ( Int_t j=0; j<8; j++){
2973     Float_t xc1[4]={ (s11p*j), (s11p*j), s11p*(j+1), (s11p*j)};
2974     Float_t yc1[4]={ 0., ws13, ws13, 0.};
2975     Float_t xc[4];
2976     Float_t yc[4];
2977     for (Int_t i = 0; i<4 ; i++) {
2978     xc[i]= xs2x + (-0.204+xc1[i])*var.sfx;
2979     yc[i] = ys2x + (0.295+yc1[i])*var.sfy;
2980     };
2981     ftof11xa[j] = new TPolyLine(4,xc,yc);
2982     ftof11xa[j]->SetLineColor(1);
2983     if ( var.bw ){
2984     colo = -1;
2985     } else {
2986     colo = 1;
2987     };
2988     ColorMIP(ms11a[j],colo);
2989     //
2990     if ( colo != 10 ) ocolo = colo;
2991     if ( mt11[0][j] == 4095. ) colo = noadc;
2992     //
2993     ftof11xa[j]->SetFillColor(colo);
2994     ftof11xa[j]->SetLineWidth(1);
2995     ftof11xa[j]->Draw("f");
2996     ftof11xa[j]->Draw();
2997     };
2998     // B
2999     s11p = 0.051;
3000     TPolyLine *ftof11xb[8];
3001     for ( Int_t j=0; j<8; j++){
3002     Float_t xc1[4]={ (s11p*j), s11p*(j+1), s11p*(j+1), (s11p*j)};
3003     Float_t yc1[4]={ 0., 0., ws13, 0.};
3004     Float_t xc[4];
3005     Float_t yc[4];
3006     for (Int_t i = 0; i<4 ; i++) {
3007     xc[i]= xs2x + (-0.204+xc1[i])*var.sfx;
3008     yc[i] = ys2x + (0.295+yc1[i])*var.sfy;
3009     };
3010     ftof11xb[j] = new TPolyLine(4,xc,yc);
3011     ftof11xb[j]->SetLineColor(1);
3012     if ( var.bw ){
3013     colo = -1;
3014     } else {
3015     colo = 1;
3016     };
3017     ColorMIP(ms11b[j],colo);
3018     //
3019     if ( colo != 10 ) ocolo = colo;
3020     if ( mt11[1][j] == 4095. ) colo = noadc;
3021     //
3022     ftof11xb[j]->SetFillColor(colo);
3023     ftof11xb[j]->SetLineWidth(1);
3024     ftof11xb[j]->Draw("f");
3025     ftof11xb[j]->Draw();
3026     };
3027    
3028     //
3029     // S11 Y-view
3030     //
3031     if ( true ){
3032     Float_t nxc1[5]={ -0.165, 0.165, 0.165, -0.165, -0.165};
3033     Float_t nyc1[5]={ 0., 0., ws13, ws13, 0.};
3034     Float_t nxc[5];
3035     Float_t nyc[5];
3036     for (Int_t i = 0; i<5 ; i++) {
3037     nxc[i]= xs2y + nxc1[i]*var.sfx;
3038     nyc[i] = ys2y + (0.295+nyc1[i])*var.sfy;
3039     };
3040     TPolyLine *ftof11y = new TPolyLine(5,nxc,nyc);
3041     ftof11y->SetLineColor(1);
3042     ftof11y->SetFillColor(ocolo);
3043     ftof11y->SetLineWidth(1);
3044     ftof11y->Draw("f");
3045     ftof11y->Draw();
3046     };
3047    
3048     //
3049     // S12 Y-view
3050     //
3051     // A
3052     Float_t s12p = 0.055;
3053     ocolo = 10;
3054     TPolyLine *ftof12ya[6];
3055     for ( Int_t j=0; j<6; j++){
3056     Float_t xc1[4]={ (s12p*j), s12p*(j), s12p*(j+1), (s12p*j)};
3057     Float_t yc1[4]={ -ws13, 0., 0., -ws13};
3058     Float_t xc[4];
3059     Float_t yc[4];
3060     for (Int_t i = 0; i<4 ; i++) {
3061     xc[i]= xs2y + (-0.165+xc1[i])*var.sfx;
3062     yc[i] = ys2y + (0.295+yc1[i])*var.sfy;
3063     };
3064     ftof12ya[j] = new TPolyLine(4,xc,yc);
3065     ftof12ya[j]->SetLineColor(1);
3066     if ( var.bw ){
3067     colo = -1;
3068     } else {
3069     colo = 1;
3070     };
3071     ColorMIP(ms12a[j],colo);
3072     //
3073     if ( colo != 10 ) ocolo = colo;
3074     if ( mt12[0][j] == 4095. ) colo = noadc;
3075     //
3076     ftof12ya[j]->SetFillColor(colo);
3077     ftof12ya[j]->SetLineWidth(1);
3078     ftof12ya[j]->Draw("f");
3079     ftof12ya[j]->Draw();
3080     };
3081     // B
3082     s12p = 0.055;
3083     TPolyLine *ftof12yb[6];
3084     for ( Int_t j=0; j<6; j++){
3085     Float_t xc1[4]={ (s12p*j), s12p*(j+1), s12p*(j+1), (s12p*j)};
3086     Float_t yc1[4]={ -ws13, -ws13, 0., -ws13};
3087     Float_t xc[4];
3088     Float_t yc[4];
3089     for (Int_t i = 0; i<4 ; i++) {
3090     xc[i]= xs2y + (-0.165+xc1[i])*var.sfx;
3091     yc[i] = ys2y + (0.295+yc1[i])*var.sfy;
3092     };
3093     ftof12yb[j] = new TPolyLine(4,xc,yc);
3094     ftof12yb[j]->SetLineColor(1);
3095     if ( var.bw ){
3096     colo = -1;
3097     } else {
3098     colo = 1;
3099     };
3100     ColorMIP(ms12b[j],colo);
3101     //
3102     if ( colo != 10 ) ocolo = colo;
3103     if ( mt12[1][j] == 4095. ) colo = noadc;
3104     //
3105     ftof12yb[j]->SetFillColor(colo);
3106     ftof12yb[j]->SetLineWidth(1);
3107     ftof12yb[j]->Draw("f");
3108     ftof12yb[j]->Draw();
3109     };
3110     //
3111     // S12 X-view
3112     //
3113     if ( true ){
3114     Float_t nxc1[5]={ -0.204, 0.204, 0.204, -0.204, -0.204};
3115     Float_t nyc1[5]={ 0., 0., -ws13, -ws13, 0.};
3116     Float_t nxc[5];
3117     Float_t nyc[5];
3118     for (Int_t i = 0; i<5 ; i++) {
3119     nxc[i]= xs2x + nxc1[i]*var.sfx;
3120     nyc[i] = ys2x + (0.295+nyc1[i])*var.sfy;
3121     };
3122     TPolyLine *ftof12x = new TPolyLine(5,nxc,nyc);
3123     ftof12x->SetLineColor(1);
3124     ftof12x->SetFillColor(ocolo);
3125     ftof12x->SetLineWidth(1);
3126     ftof12x->Draw("f");
3127     ftof12x->Draw();
3128     };
3129    
3130     //
3131     // S21 Y-view
3132     //
3133     // A
3134     Float_t s21p = 0.075;
3135     ocolo = 10;
3136     TPolyLine *ftof21ya[2];
3137     for ( Int_t j=0; j<2; j++){
3138     Float_t xc1[4]={ s21p*(j-1), s21p*(j-1), s21p*j, s21p*(j-1)};
3139     Float_t yc1[4]={ 0., ws2, ws2, 0.};
3140     Float_t xc[4];
3141     Float_t yc[4];
3142     for (Int_t i = 0; i<4 ; i++) {
3143     xc[i]= xs2y + xc1[i]*var.sfx;
3144     yc[i] = ys2y + yc1[i]*var.sfy;
3145     };
3146     ftof21ya[j] = new TPolyLine(4,xc,yc);
3147     ftof21ya[j]->SetLineColor(1);
3148     if ( var.bw ){
3149     colo = -1;
3150     } else {
3151     colo = 1;
3152     };
3153     ColorMIP(ms21a[j],colo);
3154     //
3155     if ( colo != 10 ) ocolo = colo;
3156     if ( mt21[0][j] == 4095. ) colo = noadc;
3157     //
3158     ftof21ya[j]->SetFillColor(colo);
3159     ftof21ya[j]->SetLineWidth(1);
3160     ftof21ya[j]->Draw("f");
3161     ftof21ya[j]->Draw();
3162     };
3163     // B
3164     s21p = 0.075;
3165     TPolyLine *ftof21yb[2];
3166     for ( Int_t j=0; j<2; j++){
3167     Float_t xc1[4]={ s21p*(j-1), s21p*j, s21p*j, s21p*(j-1)};
3168     Float_t yc1[4]={ 0., 0., ws2, 0.};
3169     Float_t xc[4];
3170     Float_t yc[4];
3171     for (Int_t i = 0; i<4 ; i++) {
3172     xc[i]= xs2y + xc1[i]*var.sfx;
3173     yc[i] = ys2y + yc1[i]*var.sfy;
3174     };
3175     ftof21yb[j] = new TPolyLine(4,xc,yc);
3176     ftof21yb[j]->SetLineColor(1);
3177     if ( var.bw ){
3178     colo = -1;
3179     } else {
3180     colo = 1;
3181     };
3182     ColorMIP(ms21b[j],colo);
3183     //
3184     if ( colo != 10 ) ocolo = colo;
3185     if ( mt21[1][j] == 4095. ) colo = noadc;
3186     //
3187     ftof21yb[j]->SetFillColor(colo);
3188     ftof21yb[j]->SetLineWidth(1);
3189     ftof21yb[j]->Draw("f");
3190     ftof21yb[j]->Draw();
3191     };
3192     //
3193     // S21 X-view
3194     //
3195     if ( true ){
3196     Float_t nxc1[5]={ -0.09, 0.09, 0.09, -0.09, -0.09};
3197     Float_t nyc1[5]={ 0., 0., ws2, ws2, 0.};
3198     Float_t nxc[5];
3199     Float_t nyc[5];
3200     for (Int_t i = 0; i<5 ; i++) {
3201     nxc[i]= xs2x + nxc1[i]*var.sfx;
3202     nyc[i] = ys2x + nyc1[i]*var.sfy;
3203     };
3204     TPolyLine *ftof21x = new TPolyLine(5,nxc,nyc);
3205     ftof21x->SetLineColor(1);
3206     ftof21x->SetFillColor(ocolo);
3207     ftof21x->SetLineWidth(1);
3208     ftof21x->Draw("f");
3209     ftof21x->Draw();
3210     };
3211     //
3212     // S22 X-view
3213     //
3214     // A
3215     Float_t s22p = 0.090;
3216     ocolo = 10;
3217     TPolyLine *ftof22xa[2];
3218     for ( Int_t j=0; j<2; j++){
3219     Float_t xc1[4]={ s22p*(j-1), s22p*(j-1), s22p*j, s22p*(j-1)};
3220     Float_t yc1[4]={ -ws2, 0., 0., -ws2};
3221     Float_t xc[4];
3222     Float_t yc[4];
3223     for (Int_t i = 0; i<4 ; i++) {
3224     xc[i]= xs2x + xc1[i]*var.sfx;
3225     yc[i] = ys2x + yc1[i]*var.sfy;
3226     };
3227     ftof22xa[j] = new TPolyLine(4,xc,yc);
3228     ftof22xa[j]->SetLineColor(1);
3229     if ( var.bw ){
3230     colo = -1;
3231     } else {
3232     colo = 1;
3233     };
3234     ColorMIP(ms22a[j],colo);
3235     //
3236     if ( colo != 10 ) ocolo = colo;
3237     if ( mt22[0][j] == 4095. ) colo = noadc;
3238     //
3239     ftof22xa[j]->SetFillColor(colo);
3240     ftof22xa[j]->SetLineWidth(1);
3241     ftof22xa[j]->Draw("f");
3242     ftof22xa[j]->Draw();
3243     };
3244     // B
3245     s22p = 0.090;
3246     TPolyLine *ftof22xb[2];
3247     for ( Int_t j=0; j<2; j++){
3248     Float_t xc1[4]={ s22p*(j-1), s22p*j, s22p*j, s22p*(j-1)};
3249     Float_t yc1[4]={ -ws2, -ws2, 0., -ws2};
3250     Float_t xc[4];
3251     Float_t yc[4];
3252     for (Int_t i = 0; i<4 ; i++) {
3253     xc[i]= xs2x + xc1[i]*var.sfx;
3254     yc[i] = ys2x + yc1[i]*var.sfy;
3255     };
3256     ftof22xb[j] = new TPolyLine(4,xc,yc);
3257     ftof22xb[j]->SetLineColor(1);
3258     if ( var.bw ){
3259     colo = -1;
3260     } else {
3261     colo = 1;
3262     };
3263     ColorMIP(ms22b[j],colo);
3264     //
3265     if ( colo != 10 ) ocolo = colo;
3266     if ( mt22[1][j] == 4095. ) colo = noadc;
3267     //
3268     ftof22xb[j]->SetFillColor(colo);
3269     ftof22xb[j]->SetLineWidth(1);
3270     ftof22xb[j]->Draw("f");
3271     ftof22xb[j]->Draw();
3272     };
3273     //
3274     // S22 Y-view
3275     //
3276     if ( true ){
3277     Float_t nxc1[5]={ -0.075, 0.075, 0.075, -0.075, -0.075};
3278     Float_t nyc1[5]={ 0., 0., -ws2, -ws2, 0.};
3279     Float_t nxc[5];
3280     Float_t nyc[5];
3281     for (Int_t i = 0; i<5 ; i++) {
3282     nxc[i]= xs2y + nxc1[i]*var.sfx;
3283     nyc[i] = ys2y + nyc1[i]*var.sfy;
3284     };
3285     TPolyLine *ftof22y = new TPolyLine(5,nxc,nyc);
3286     ftof22y->SetLineColor(1);
3287     ftof22y->SetFillColor(ocolo);
3288     ftof22y->SetLineWidth(1);
3289     ftof22y->Draw("f");
3290     ftof22y->Draw();
3291     };
3292    
3293     //
3294     // S31 X-view
3295     //
3296     // A
3297     Float_t s31p = 0.060;
3298     ocolo = 10;
3299     TPolyLine *ftof31xa[3];
3300     for ( Int_t j=0; j<3; j++){
3301     Float_t xc1[4]={ (s31p*j), (s31p*j), s31p*(j+1), (s31p*j)};
3302     Float_t yc1[4]={ 0., ws13, ws13, 0.};
3303     Float_t xc[4];
3304     Float_t yc[4];
3305     for (Int_t i = 0; i<4 ; i++) {
3306     xc[i]= xs2x + (-0.090+xc1[i])*var.sfx;
3307     yc[i] = ys2x + (-0.488+yc1[i])*var.sfy;
3308     };
3309     ftof31xa[j] = new TPolyLine(4,xc,yc);
3310     ftof31xa[j]->SetLineColor(1);
3311     if ( var.bw ){
3312     colo = -1;
3313     } else {
3314     colo = 1;
3315     };
3316     ColorMIP(ms31a[j],colo);
3317     //
3318     if ( colo != 10 ) ocolo = colo;
3319     if ( mt31[0][j] == 4095. ) colo = noadc;
3320     //
3321     ftof31xa[j]->SetFillColor(colo);
3322     ftof31xa[j]->SetLineWidth(1);
3323     ftof31xa[j]->Draw("f");
3324     ftof31xa[j]->Draw();
3325     };
3326     // B
3327     s31p = 0.060;
3328     TPolyLine *ftof31xb[3];
3329     for ( Int_t j=0; j<3; j++){
3330     Float_t xc1[4]={ (s31p*j), s31p*(j+1), s31p*(j+1), (s31p*j)};
3331     Float_t yc1[4]={ 0., 0., ws13, 0.};
3332     Float_t xc[4];
3333     Float_t yc[4];
3334     for (Int_t i = 0; i<4 ; i++) {
3335     xc[i]= xs2x + (-0.090+xc1[i])*var.sfx;
3336     yc[i] = ys2x + (-0.488+yc1[i])*var.sfy;
3337     };
3338     ftof31xb[j] = new TPolyLine(4,xc,yc);
3339     ftof31xb[j]->SetLineColor(1);
3340     if ( var.bw ){
3341     colo = -1;
3342     } else {
3343     colo = 1;
3344     };
3345     ColorMIP(ms31b[j],colo);
3346     //
3347     if ( colo != 10 ) ocolo = colo;
3348     if ( mt31[1][j] == 4095. ) colo = noadc;
3349     //
3350     ftof31xb[j]->SetFillColor(colo);
3351     ftof31xb[j]->SetLineWidth(1);
3352     ftof31xb[j]->Draw("f");
3353     ftof31xb[j]->Draw();
3354     };
3355     //
3356     // S31 Y-view
3357     //
3358     if ( true ){
3359     Float_t nxc1[5]={ -0.075, 0.075, 0.075, -0.075, -0.075};
3360     Float_t nyc1[5]={ 0., 0., ws13, ws13, 0.};
3361     Float_t nxc[5];
3362     Float_t nyc[5];
3363     for (Int_t i = 0; i<5 ; i++) {
3364     nxc[i]= xs2y + nxc1[i]*var.sfx;
3365     nyc[i] = ys2y + (-0.488+nyc1[i])*var.sfy;
3366     };
3367     TPolyLine *ftof31y = new TPolyLine(5,nxc,nyc);
3368     ftof31y->SetLineColor(1);
3369     ftof31y->SetFillColor(ocolo);
3370     ftof31y->SetLineWidth(1);
3371     ftof31y->Draw("f");
3372     ftof31y->Draw();
3373     };
3374     //
3375     // S32 Y-view
3376     //
3377     Float_t s32p = 0.050;
3378     ocolo = 10;
3379     TPolyLine *ftof32ya[3];
3380     for ( Int_t j=0; j<3; j++){
3381     Float_t xc1[4]={ (s32p*j), (s32p*j), s32p*(j+1), (s32p*j)};
3382     Float_t yc1[4]={ -ws13, 0., 0., -ws13};
3383     Float_t xc[4];
3384     Float_t yc[4];
3385     for (Int_t i = 0; i<4 ; i++) {
3386     xc[i]= xs2y + (-0.075+xc1[i])*var.sfx;
3387     yc[i] = ys2y + (-0.488+yc1[i])*var.sfy;
3388     };
3389     ftof32ya[j] = new TPolyLine(4,xc,yc);
3390     ftof32ya[j]->SetLineColor(1);
3391     if ( var.bw ){
3392     colo = -1;
3393     } else {
3394     colo = 1;
3395     };
3396     ColorMIP(ms32a[j],colo);
3397     //
3398     if ( colo != 10 ) ocolo = colo;
3399     if ( mt32[0][j] == 4095. ) colo = noadc;
3400     //
3401     ftof32ya[j]->SetFillColor(colo);
3402     ftof32ya[j]->SetLineWidth(1);
3403     ftof32ya[j]->Draw("f");
3404     ftof32ya[j]->Draw();
3405     };
3406     s32p = 0.050;
3407     TPolyLine *ftof32yb[3];
3408     for ( Int_t j=0; j<3; j++){
3409     Float_t xc1[4]={ (s32p*j), s32p*(j+1), s32p*(j+1), (s32p*j)};
3410     Float_t yc1[4]={ -ws13, -ws13, 0., -ws13};
3411     Float_t xc[4];
3412     Float_t yc[4];
3413     for (Int_t i = 0; i<4 ; i++) {
3414     xc[i]= xs2y + (-0.075+xc1[i])*var.sfx;
3415     yc[i] = ys2y + (-0.488+yc1[i])*var.sfy;
3416     };
3417     ftof32yb[j] = new TPolyLine(4,xc,yc);
3418     ftof32yb[j]->SetLineColor(1);
3419     if ( var.bw ){
3420     colo = -1;
3421     } else {
3422     colo = 1;
3423     };
3424     ColorMIP(ms32b[j],colo);
3425     //
3426     if ( colo != 10 ) ocolo = colo;
3427     if ( mt32[1][j] == 4095. ) colo = noadc;
3428     //
3429     ftof32yb[j]->SetFillColor(colo);
3430     ftof32yb[j]->SetLineWidth(1);
3431     ftof32yb[j]->Draw("f");
3432     ftof32yb[j]->Draw();
3433     };
3434     //
3435     // S32 X-view
3436     //
3437     if ( true ){
3438     Float_t nxc1[5]={ -0.09, 0.09, 0.09, -0.09, -0.09};
3439     Float_t nyc1[5]={ 0., 0., -ws13, -ws13, 0.};
3440     Float_t nxc[5];
3441     Float_t nyc[5];
3442     for (Int_t i = 0; i<5 ; i++) {
3443     nxc[i]= xs2x + nxc1[i]*var.sfx;
3444     nyc[i] = ys2x + (-0.488+nyc1[i])*var.sfy;
3445     };
3446     TPolyLine *ftof32x = new TPolyLine(5,nxc,nyc);
3447     ftof32x->SetLineColor(1);
3448     ftof32x->SetFillColor(ocolo);
3449     ftof32x->SetLineWidth(1);
3450     ftof32x->Draw("f");
3451     ftof32x->Draw();
3452     };
3453     }
3454    
3455     void ShowS4L0(Int_t i, TTree *otr, Variables & var){
3456    
3457     pamela::trigger::TriggerEvent *trigger = 0;
3458     otr->SetBranchAddress("Trigger.Event", &trigger);
3459     if ( !var.nosig ) otr->GetEntry(i);
3460    
3461     Float_t ms4[3] = {0.,0.,0.};
3462     Int_t S4 = 0;
3463     if ( !var.nosig ) {
3464     S4 = trigger->patterntrig[1];
3465     };
3466     //
3467     for ( Int_t i = 0; i<3; i++ ) {
3468     if ( S4 & (1<<0) ) ms4[i] = 1.;
3469     };
3470     //
3471     Int_t colo;
3472     Float_t xs4x = var.xxvc;
3473     Float_t ys4x = var.yxvc - 0.3250*var.sfy; //25
3474     Float_t xs4y = var.xyvc;
3475     Float_t ys4y = var.yyvc - 0.3250*var.sfy;
3476     Float_t ws4 = 0.010;
3477    
3478     //
3479     // Y-view
3480     //
3481     Float_t s4p = 0.1606667;
3482     Int_t ocolo = 0;
3483     TPolyLine *fs4y[3];
3484     for ( Int_t j=0; j<3; j++){
3485     Float_t xc1[5]={ (s4p*j), s4p*(j+1), s4p*(j+1), (s4p*j), (s4p*j)};
3486     Float_t yc1[5]={ 0., 0., ws4, ws4, 0.};
3487     Float_t xc[5];
3488     Float_t yc[5];
3489     for (Int_t i = 0; i<5 ; i++) {
3490     xc[i]= xs4y + (-0.241+xc1[i])*var.nds4;
3491     yc[i] = ys4y + (yc1[i]-0.03)*var.sfy;
3492     };
3493     fs4y[j] = new TPolyLine(5,xc,yc);
3494     fs4y[j]->SetLineColor(1);
3495     if ( var.bw ){
3496     colo = -1;
3497     } else {
3498     colo = 1;
3499     };
3500     ColorMIP(ms4[j],colo);
3501     //
3502     if ( colo != 10 ) ocolo = colo;
3503     //
3504     fs4y[j]->SetFillColor(colo);
3505     fs4y[j]->SetLineWidth(1);
3506     fs4y[j]->Draw("f");
3507     fs4y[j]->Draw();
3508     };
3509     //
3510     // X-view
3511     //
3512     Float_t xc1[5]={ -0.241, 0.241, 0.241, -0.241, -0.241};
3513     Float_t yc1[5]={ 0., 0., ws4, ws4, 0.};
3514     Float_t xc[5];
3515     Float_t yc[5];
3516     for (Int_t i = 0; i<5 ; i++) {
3517     xc[i]= xs4x + xc1[i]*var.nds4;
3518     yc[i] = ys4x + (yc1[i]-0.03)*var.sfy;
3519     };
3520     TPolyLine *fs4x = new TPolyLine(5,xc,yc);
3521     fs4x->SetLineColor(1);
3522     fs4x->SetFillColor(ocolo);
3523     fs4x->SetLineWidth(1);
3524     fs4x->Draw("f");
3525     fs4x->Draw();
3526     }
3527    
3528     //**********************************************************************************
3529     // LEVEL1 SUBROUTINES //
3530     //**********************************************************************************
3531    
3532     void ShowS4L1(Int_t i, TTree *otr, Variables & var){
3533    
3534     pamela::S4::S4Event *s4 = 0;
3535     otr->SetBranchAddress("S4.Event", &s4);
3536     if ( !var.nosig ) otr->GetEntry(i);
3537    
3538     Float_t ms4[3] = {0.,0.,0.};
3539     Int_t data = 0;
3540     if ( !var.nosig ) {
3541     data = s4->S4_DATA;
3542     };
3543     //
3544     Float_t calibdata;
3545     if ( !s4->unpackError && data > 31 ){
3546     calibdata = ((Float_t)data - 32.) * 0.5;
3547     } else {
3548     calibdata = 0.;
3549     };
3550     var.s4sig = calibdata;
3551     //
3552     for ( Int_t j = 0; j<3; j++ ) {
3553     ms4[j] = calibdata;
3554     };
3555     Int_t colo;
3556     Float_t xs4x = var.xxvc;
3557     Float_t ys4x = var.yxvc - 0.3250*var.sfy;
3558     Float_t xs4y = var.xyvc;
3559     Float_t ys4y = var.yyvc - 0.3250*var.sfy;
3560     Float_t ws4 = 0.010;
3561     //
3562     // Y-view
3563     //
3564     Float_t s4p = 0.1606667;
3565     Int_t ocolo = 0;
3566     TPolyLine *fs4y[3];
3567     for ( Int_t j=0; j<3; j++){
3568     Float_t xc1[5]={ (s4p*j), s4p*(j+1), s4p*(j+1), (s4p*j), (s4p*j)};
3569     Float_t yc1[5]={ 0., 0., ws4, ws4, 0.};
3570     Float_t xc[5];
3571     Float_t yc[5];
3572     for (Int_t i = 0; i<5 ; i++) {
3573     xc[i]= xs4y + (-0.241+xc1[i])*var.nds4;
3574     yc[i] = ys4y + (yc1[i]-0.03)*var.sfy;
3575     };
3576     fs4y[j] = new TPolyLine(5,xc,yc);
3577     fs4y[j]->SetLineColor(1);
3578     if ( var.bw ){
3579     colo = -1;
3580     } else {
3581     colo = 1;
3582     };
3583     ColorMIP(ms4[j],colo);
3584     //
3585     if ( colo != 10 ) ocolo = colo;
3586     //
3587     fs4y[j]->SetFillColor(colo);
3588     fs4y[j]->SetLineWidth(1);
3589     fs4y[j]->Draw("f");
3590     fs4y[j]->Draw();
3591     };
3592     //
3593     // X-view
3594     //
3595     Float_t xc1[5]={ -0.241, 0.241, 0.241, -0.241, -0.241};
3596     Float_t yc1[5]={ 0., 0., ws4, ws4, 0.};
3597     Float_t xc[5];
3598     Float_t yc[5];
3599     for (Int_t i = 0; i<5 ; i++) {
3600     xc[i]= xs4x + xc1[i]*var.nds4;
3601     yc[i] = ys4x + (yc1[i]-0.03)*var.sfy;
3602     };
3603     TPolyLine *fs4x = new TPolyLine(5,xc,yc);
3604     fs4x->SetLineColor(1);
3605     fs4x->SetFillColor(ocolo);
3606     fs4x->SetLineWidth(1);
3607     fs4x->Draw("f");
3608     fs4x->Draw();
3609     }
3610    
3611     void ShowCaloL1(Int_t i, TTree *otr, Variables & var){
3612     //
3613     CalorimeterLevel1 *calo = new CalorimeterLevel1();
3614     otr->SetBranchAddress("CaloLevel1.Event", &calo);
3615     if ( !var.nosig ) otr->GetEntry(i);
3616     //
3617     // Book the histograms:
3618     //
3619     //
3620     stringstream xview;
3621     stringstream yview;
3622     xview.str("");
3623     yview.str("");
3624     xview << "x-view event " << (i+1);
3625     yview << "y-view event " << (i+1);
3626     gDirectory->Delete(xview.str().c_str());
3627     gDirectory->Delete(yview.str().c_str());
3628     TH2F *Xview = new TH2F(xview.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
3629     TH2F *Yview = new TH2F(yview.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
3630     Xview->GetYaxis()->SetLabelColor(10);
3631     Yview->GetYaxis()->SetLabelColor(10);
3632     //
3633     // figures:
3634     //
3635     Int_t bgcolor = 10;
3636     TPad *pd1 = new TPad("calox","This is pad1",var.xxvc-0.154*var.sfx,var.yxvc-0.3645*var.sfy,var.xxvc+0.154*var.sfx,var.yxvc-0.1200*var.sfy,bgcolor);
3637     TPad *pd2 = new TPad("caloy","This is pad2",var.xyvc-0.154*var.sfx,var.yyvc-0.3645*var.sfy,var.xyvc+0.154*var.sfx,var.yyvc-0.1200*var.sfy,bgcolor);
3638    
3639     pd1->SetFillStyle(4000);
3640     pd1->SetFillColor(0);
3641     pd1->SetFrameFillStyle(4000);
3642     pd2->SetFillStyle(4000);
3643     pd2->SetFillColor(0);
3644     pd2->SetFrameFillStyle(4000);
3645    
3646     TLatex *t=new TLatex();
3647     t->SetTextFont(32);
3648     t->SetTextColor(1);
3649     t->SetTextSize(0.03);
3650     t->SetTextAlign(12);
3651     pd1->Range(0.,0.,1.,1.);
3652     pd2->Range(0.,0.,1.,1.);
3653     pd1->SetTicks();
3654     pd2->SetTicks();
3655     pd1->Draw();
3656     pd2->Draw();
3657    
3658     pd1->cd();
3659     gStyle->SetOptStat(0);
3660     Xview->GetYaxis()->SetTitleOffset(0.5);
3661     Xview->SetFillColor(bgcolor);
3662     Xview->Fill(1.,1.,1.);
3663     Xview->Draw("box");
3664     pd1->Update();
3665     pd2->cd();
3666     gStyle->SetOptStat(0);
3667     Yview->GetYaxis()->SetTitleOffset(0.5);
3668     Yview->SetFillColor(bgcolor);
3669     Yview->Fill(1.,1.,1.);
3670     Yview->Draw("box");
3671     pd2->Update();
3672    
3673     //
3674     // run over views and planes
3675     //
3676     stringstream xvev;
3677     stringstream yvev;
3678     for (Int_t m = 0; m < 22; m++){
3679     for (Int_t l = 0; l < 2; l++){
3680     for (Int_t n = 0; n < 96; n++){
3681     if ( calo->estrip[l][m][n] > 0.7 ) {
3682     //
3683     // OK, now in estrip we have the energy deposit in MIP of all the strips for this event (at the end of loops of course)
3684     //
3685     // if ( l == 0 && m == 21 ) printf(" xpos n=%i calo bottom: %f \n",n,(n*2.44-117.12)/10.);
3686     Int_t colo;
3687     if ( var.bw ){
3688     colo = -1;
3689     } else {
3690     colo = 1;
3691     };
3692     ColorMIP(calo->estrip[l][m][n],colo);
3693     if ( l == 0 && !var.nosig ) {
3694     xvev.str("");
3695     xvev << "x-view event " << n;
3696     xvev << " " << m;
3697     xvev << " " << l;
3698     gDirectory->Delete(xvev.str().c_str());
3699     TH2F *Xview = new TH2F(xvev.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
3700     Xview->SetFillColor(colo);
3701     Xview->Fill(n,21-m,1.);
3702     pd1->cd();
3703     Xview->Draw("box same");
3704     };
3705     if ( l == 1 && !var.nosig ) {
3706     yvev.str("");
3707     yvev << "y-view event " << n;
3708     yvev << " " << m;
3709     yvev << " " << l;
3710     gDirectory->Delete(yvev.str().c_str());
3711     TH2F *Yview = new TH2F(yvev.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
3712     Yview->SetFillColor(colo);
3713     Yview->Fill(95-n,21-m,1.);
3714     pd2->cd();
3715     Yview->Draw("box same");
3716     };
3717     };
3718     };
3719     };
3720     };
3721     pd1->Update();
3722     pd2->Update();
3723     var.qtot=(int)calo->qtot;
3724     var.nstrip=(int)calo->nstrip;
3725     }
3726    
3727 mocchiut 1.3 void ShowTRKL1(Int_t evno, TTree *ttr1, Variables & var, PAMevcontrol *pamgui){
3728 mocchiut 1.1 //
3729     Int_t syncro = 1;
3730     Int_t itr = evno;
3731     Int_t trnevents = ttr1->GetEntries();
3732     Int_t nodata = 0;
3733     Int_t pktnum = 0;
3734     Int_t obt = 0;
3735     trkcalosync: struct Tracklev1 trk;
3736     struct CTracklev1 ev2;
3737     settrklev1(ttr1,trk);
3738     if ( itr >= trnevents ){
3739     printf(" WARNING: no more tracker level1 data.\n");
3740 mocchiut 1.3 pamgui->DIALOG(1," No more tracker level1 data ");
3741 mocchiut 1.1 nodata = 1;
3742     goto goon;
3743     };
3744     if ( !var.nosig ) ttr1->GetEntry(itr);
3745     accesstrklev1(trk,ev2);
3746     pktnum = var.headc;
3747     obt = var.etime;
3748     if ( pktnum != ev2.pkt_num1 || obt != ev2.obt1 ){
3749     if ( pktnum > ev2.pkt_num1 || obt > ev2.obt1 ){
3750     itr++;
3751 mocchiut 1.3 if ( syncro ){
3752     printf(" WARNING: lost sync! try to recover... \n");
3753     pamgui->DIALOG(1," Lost sync! try to recover ");
3754     };
3755 mocchiut 1.1 syncro = 0;
3756     goto trkcalosync;
3757     };
3758     if ( pktnum < ev2.pkt_num1 || obt < ev2.obt1 ){
3759     printf(" WARNING: no tracker level2 data. \n");
3760 mocchiut 1.3 pamgui->DIALOG(1," No more tracker level2 data ");
3761 mocchiut 1.1 nodata = 1;
3762     goto goon;
3763     };
3764     };
3765     //
3766 mocchiut 1.3 if ( !syncro ) {
3767     printf(" ...synchronization recovered! \n");
3768     pamgui->DIALOG(0," Synchronization recovered! ");
3769     };
3770 mocchiut 1.1 syncro = 1;
3771     //
3772     goon: struct Trklev1 ev;
3773     ev.good1 = (Bool_t)ev2.good1;
3774     ev.nev1 = ev2.nev1;
3775 mocchiut 1.3 ev.whic_calib1 = ev2.whic_calib1;
3776     ev.swcode1 = ev2.swcode1;
3777 mocchiut 1.1 ev.pkt_type1 = ev2.pkt_type1;
3778     ev.pkt_num1 = ev2.pkt_num1;
3779     ev.obt1 = ev2.obt1;
3780 mocchiut 1.3 ev.cpu_crc1 = (Bool_t)ev2.cpu_crc1;
3781 mocchiut 1.1 ev.nclstr1 = ev2.nclstr1;
3782     ev.totcllength = ev2.totcllength;
3783     for ( Int_t ii = 0 ; ii<8500; ii++){
3784     ev.clsignal[ii] = ev2.clsignal[ii];
3785     };
3786     for ( Int_t ii = 0 ; ii<500 ; ii++){
3787     ev.view[ii] = (Int_t)ev2.view[ii];
3788     ev.ladder[ii] = (Int_t)ev2.ladder[ii];
3789     ev.maxs[ii] = (Int_t)ev2.maxs[ii];
3790     ev.mult[ii] = (Int_t)ev2.mult[ii];
3791     ev.dedx[ii] = (Float_t)ev2.dedx[ii];
3792     ev.indstart[ii] = (Int_t)ev2.indstart[ii];
3793     ev.indmax[ii] = (Int_t)ev2.indmax[ii];
3794     };
3795     for ( Int_t ii = 0 ; ii<12 ; ii++){
3796 mocchiut 1.3 ev.crc1[ii] = ev2.crc1[ii];
3797 mocchiut 1.1 for ( Int_t ij = 0 ; ij<24 ; ij++){
3798     ev.cnev[ij][ii] = ev2.cnev[ii][ij];
3799     };
3800     };
3801     for ( Int_t ii = 0 ; ii<12 ; ii++){
3802     for ( Int_t ij = 0 ; ij<3072 ; ij++){
3803     ev.sigma_matrix[ij][ii] = var.DSPsig_par[ii][ij];
3804     };
3805     };
3806     //
3807     // find the cluster, position and signal with the external fortran routine. We must pass the common.
3808     //
3809     if ( !nodata ){
3810     projectlev1(ev);
3811     } else {
3812     ev.nclstr1 = 0;
3813     };
3814     //
3815     // a matrix of pads for each view x and y
3816     //
3817     TPad *trkpad[12];
3818     Int_t magcol = 0;
3819     TPad *mag1 = 0;
3820     TPad *mag2 = 0;
3821     for (Int_t n = 0; n<12; n++){
3822     stringstream spd;
3823     spd.str("");
3824     spd << "pd1" << n;
3825     gDirectory->Delete(spd.str().c_str());
3826     spd.str("");
3827     spd << "pd2" << n;
3828     gDirectory->Delete(spd.str().c_str());
3829     spd.str("");
3830     spd << "pd3" << n;
3831     gDirectory->Delete(spd.str().c_str());
3832     spd.str("");
3833     spd << "pd4" << n;
3834     gDirectory->Delete(spd.str().c_str());
3835     spd.str("");
3836     spd << "pd5" << n;
3837     gDirectory->Delete(spd.str().c_str());
3838     spd.str("");
3839     spd << "pd6" << n;
3840     gDirectory->Delete(spd.str().c_str());
3841     stringstream bpd;
3842     bpd.str("");
3843     if ( n%2 ) {
3844     Float_t posx = var.xxvc;
3845     Float_t posy = var.yxvc + (0.29 - 0.089*((n/2.)-1.))*var.sfy;
3846     spd.str("");
3847     spd << "pd1" << n;
3848     bpd.str("");
3849     bpd << "bd1" << n;
3850     trkpad[n] = new TPad(spd.str().c_str(),bpd.str().c_str(),posx-0.081*var.sfx,posy,posx+0.081*var.sfx,posy+0.089*var.sfy,10);
3851     trkpad[n]->SetFillStyle(4000);
3852     trkpad[n]->SetFillColor(0);
3853     trkpad[n]->SetFrameFillStyle(4000);
3854     trkpad[n]->Draw();
3855     if ( n != 1 ) {
3856     if ( var.bw ) {
3857     magcol = 1;
3858     } else {
3859     magcol = 45;
3860     };
3861     spd.str("");
3862     spd << "pd2" << n;
3863     bpd.str("");
3864     bpd << "bd2" << n;
3865     mag1 = new TPad(spd.str().c_str(),bpd.str().c_str(),posx-(0.039+0.081)*var.sfx,posy+0.004*var.sfy,posx-0.081*var.sfx,posy+0.088*var.sfy,magcol);
3866     if ( var.bw ) mag1->SetFillStyle(3001);
3867     mag1->Draw();
3868     spd.str("");
3869     spd << "pd3" << n;
3870     bpd.str("");
3871     bpd << "bd3" << n;
3872     mag2 = new TPad(spd.str().c_str(),bpd.str().c_str(),posx+0.081*var.sfx,posy+0.004*var.sfy,posx+(0.081+0.039)*var.sfx,posy+0.088*var.sfy,magcol);
3873     if ( var.bw ) mag2->SetFillStyle(3001);
3874     mag2->Draw();
3875     };
3876     } else {
3877     Float_t posx = var.xyvc;
3878     Float_t posy = var.yyvc + (0.29 - 0.089 * (((n+1.)/2.)-1.))*var.sfy;
3879     spd.str("");
3880     spd << "pd4" << n;
3881     bpd.str("");
3882     bpd << "bd4" << n;
3883     trkpad[n] = new TPad(spd.str().c_str(),bpd.str().c_str(),posx-0.07*var.sfx,posy,posx+0.07*var.sfx,posy+0.089*var.sfy,10);
3884     trkpad[n]->SetFillStyle(4000);
3885     trkpad[n]->SetFillColor(0);
3886     trkpad[n]->SetFrameFillStyle(4000);
3887     trkpad[n]->Draw();
3888     if ( n != 0 ) {
3889     if ( var.bw ) {
3890     magcol = 1;
3891     } else {
3892     magcol = 45;
3893     };
3894     spd.str("");
3895     spd << "pd5" << n;
3896     bpd.str("");
3897     bpd << "bd5" << n;
3898     mag1 = new TPad(spd.str().c_str(),bpd.str().c_str(),posx-(0.048+0.066)*var.sfx,posy+0.004*var.sfy,posx-0.066*var.sfx,posy+0.088*var.sfy,magcol);
3899     if ( var.bw ) mag1->SetFillStyle(3001);
3900     mag1->Draw();
3901     spd.str("");
3902     spd << "pd6" << n;
3903     bpd.str("");
3904     bpd << "bd6" << n;
3905     mag2 = new TPad(spd.str().c_str(),bpd.str().c_str(),posx+0.066*var.sfx,posy+0.004*var.sfy,posx+(0.066+0.048)*var.sfx,posy+0.088*var.sfy,magcol);
3906     if ( var.bw ) mag2->SetFillStyle(3001);
3907     mag2->Draw();
3908     };
3909     };
3910     };
3911     TPad *trplv;
3912     gDirectory->Delete("trkplv");
3913     trplv = new TPad("trkplv","trkplv",var.xcat-0.07*var.sfx,var.ycat-0.081*var.sfy,var.xcat+0.07*var.sfx,var.ycat+0.081*var.sfy,10);
3914     trplv->SetFillStyle(4000);
3915     trplv->SetFillColor(0);
3916     trplv->SetFrameFillStyle(4000);
3917     trplv->Draw();
3918     Int_t sigcol1 = 17;
3919     Int_t sigcol2 = 15;
3920     Int_t linecol = 13;
3921     if ( var.bw ) {
3922     sigcol1 = 17;
3923     sigcol2 = 15;
3924     linecol = 13;
3925     } else {
3926     sigcol1 = 32;
3927     sigcol2 = 38;
3928     linecol = 42;
3929     };
3930     //
3931     TLine *linea = 0;
3932     TLine *linea1x = 0;
3933     TLine *linea2x = 0;
3934     TLine *linea1y = 0;
3935     for (Int_t l = 0; l<12; l++){
3936     trkpad[l]->cd();
3937     if ( l%2 ) {
3938     trkpad[l]->Range(-8.1,0.,8.1,1000.);
3939     linea = new TLine(-8.1,10.,8.1,10.);
3940     linea1x = new TLine(-2.7,10.,-2.7,30.);
3941     linea2x = new TLine(2.7,10.,2.7,30.);
3942     } else {
3943     trkpad[l]->Range(-7.05,0.,7.05,1000.);
3944     linea = new TLine(-7.05,10.,7.05,10.);
3945     linea1y = new TLine(0.,10.,0.,30.);
3946     };
3947 mocchiut 1.2 linea->SetLineWidth(2);
3948 mocchiut 1.1 linea->SetLineColor(linecol);
3949     linea->Draw();
3950     if ( l%2 ) {
3951     linea1x->SetLineWidth(1);
3952     linea1x->SetLineColor(1);
3953     linea1x->Draw();
3954     linea2x->SetLineWidth(1);
3955     linea2x->SetLineColor(1);
3956     linea2x->Draw();
3957     } else {
3958     linea1y->SetLineWidth(1);
3959     linea1y->SetLineColor(1);
3960     linea1y->Draw();
3961     };
3962     //
3963     };
3964     Int_t planeno = 0;
3965     if ( !var.nosig ){
3966     planeno = 0;
3967     Float_t x = 0.;
3968     Float_t y = 0.;
3969     for (Int_t l = 0; l<ev.nclstr1; l++){
3970     for (Int_t m = 0; m<2; m++){
3971     if ( ev.clz[l][m] != 0. ){
3972     if ( ev.clz[l][m] > 20. ) planeno = 1 - m;
3973     if ( ev.clz[l][m] < 20. && ev.clz[l][m] > 10. ) planeno = 3 - m;
3974     if ( ev.clz[l][m] < 10. && ev.clz[l][m] > 0. ) planeno = 5 - m;
3975     if ( ev.clz[l][m] < 0. && ev.clz[l][m] > -10. ) planeno = 7 - m;
3976     if ( ev.clz[l][m] <-10. && ev.clz[l][m] >-20. ) planeno = 9 - m;
3977     if ( ev.clz[l][m] < -20. ) planeno = 11 - m;
3978     //
3979     if ( (planeno+1)%2 ){
3980     trkpad[planeno]->cd();
3981     trkpad[planeno]->Range(-7.05,0.,7.05,1000.);
3982     if ( ev.cls[l][m] != 0. ){
3983     x = ev.clp[l][1];
3984     y = ev.cls[l][m];
3985     linea = new TLine(x,0.,x,y);
3986     linea->SetLineWidth(3);
3987     linea->SetLineColor(sigcol1);
3988     linea->Draw();
3989     //
3990     x = ev.clp[l][2];
3991     linea = new TLine(x,0.,x,y);
3992     linea->SetLineWidth(3);
3993     linea->SetLineColor(sigcol2);
3994     linea->Draw();
3995     var.ncly++;
3996     };
3997     } else {
3998     trkpad[planeno]->cd();
3999     trkpad[planeno]->Range(-8.1,0.,8.1,1000.);
4000     if ( ev.cls[l][m] != 0. ){
4001     x = ev.clp[l][0];
4002     y = ev.cls[l][m];
4003     linea = new TLine(x,0.,x,y);
4004     linea->SetLineWidth(3);
4005     linea->SetLineColor(sigcol2);
4006     linea->Draw();
4007     var.nclx++;
4008     };
4009     };
4010     };
4011     };
4012     };
4013     };
4014     //
4015     // Show track in the plane view!
4016     //
4017     Float_t xh[6];
4018     Float_t yh1[6];
4019     Float_t yh2[6];
4020     Float_t mag[6];
4021     Float_t xsig[6];
4022     Float_t ysig[6];
4023     Int_t mask[6];
4024     for (Int_t l = 0; l<6; l++ ){
4025     xh[l] = 0.;
4026     yh1[l] = 0.;
4027     yh2[l] = 0.;
4028     mag[l] = 0.;
4029     xsig[l] = 0.;
4030     ysig[l] = 0.;
4031     mask[l] = 0;
4032     };
4033     Int_t ncro = 0;
4034     //
4035     // return;
4036     //
4037     for (Int_t l = 0; l<ev.nclstr1; l++){
4038     for (Int_t m = 0; m<2; m++){
4039     if ( ev.clz[l][m] != 0. ){
4040     if ( ev.clz[l][m] > 20. ) {
4041     planeno = 1 - m;
4042     ncro = 0;
4043     };
4044     if ( ev.clz[l][m] < 20. && ev.clz[l][m] > 10. ) {
4045     planeno = 3 - m;
4046     ncro = 1;
4047     };
4048     if ( ev.clz[l][m] < 10. && ev.clz[l][m] > 0. ) {
4049     planeno = 5 - m;
4050     ncro = 2;
4051     };
4052     if ( ev.clz[l][m] < 0. && ev.clz[l][m] > -10. ) {
4053     planeno = 7 - m;
4054     ncro = 3;
4055     };
4056     if ( ev.clz[l][m] <-10. && ev.clz[l][m] >-20. ) {
4057     planeno = 9 - m;
4058     ncro = 4;
4059     };
4060     if ( ev.clz[l][m] < -20. ) {
4061     planeno = 11 - m;
4062     ncro = 5;
4063     }
4064     //
4065     mag[ncro] = ((float)planeno+1.)/5.;
4066     if ( (planeno+1)%2 ){
4067     if ( ev.cls[l][m] > ysig[ncro] ){
4068     ysig[ncro] = ev.cls[l][m];
4069     yh1[ncro] = ev.clp[l][1];
4070     yh2[ncro] = ev.clp[l][2];
4071     };
4072     } else {
4073     if ( ev.cls[l][m] > xsig[ncro] ){
4074     xsig[ncro] = ev.cls[l][m];
4075     xh[ncro] = ev.clp[l][0];
4076     };
4077     };
4078     if ( ysig[ncro] > 0. && xsig[ncro] > 0. ) {
4079     mask[ncro] = 1;
4080     };
4081     };
4082     };
4083     };
4084     //
4085     // Draw crosses
4086     //
4087 mocchiut 1.3 if ( var.AC ) {
4088     trplv->cd();
4089     trplv->Range(-7.05,-8.1,7.05,8.1);
4090     for ( Int_t i = 0; i<6; i++){
4091     if ( mask[i] ){
4092     //
4093     Float_t cdx = (0.55/mag[i])*var.sfx;
4094     Float_t cdy = (0.55/mag[i])*var.sfy;
4095     Float_t lwx = (0.019)*var.sfy;
4096     Float_t lwy = (0.019)*var.sfx;
4097     //
4098     linea = new TLine(yh1[i]-lwx/2.,xh[i]-cdy,yh1[i]-lwx/2.,xh[i]+cdy);
4099     linea->SetLineWidth((int)lwx);
4100     linea->SetLineColor(sigcol1);
4101     linea->Draw();
4102     linea = new TLine(yh1[i]-cdx,xh[i]-lwy/2.,yh1[i]+cdx,xh[i]-lwy/2.);
4103     linea->SetLineWidth((int)lwy);
4104     linea->SetLineColor(sigcol1);
4105     linea->Draw();
4106     //
4107     linea = new TLine(yh2[i]-lwx/2.,xh[i]-cdy,yh2[i]-lwx/2.,xh[i]+cdy);
4108     linea->SetLineWidth((int)lwx);
4109     linea->SetLineColor(sigcol2);
4110     linea->Draw();
4111     linea = new TLine(yh2[i]-cdy,xh[i]-lwy/2.,yh2[i]+cdx,xh[i]-lwy/2.);
4112     linea->SetLineWidth((int)lwy);
4113     linea->SetLineColor(sigcol2);
4114     linea->Draw();
4115     };
4116 mocchiut 1.1 };
4117     };
4118     }
4119    
4120     void ShowTOFGENL1(Int_t j, TTree *otr, Variables & var){
4121     //
4122     // the channels MAP:
4123     //
4124     Int_t ch11a[8] = { 3, 3, 3, 3, 0, 0, 1, 1};
4125     Int_t hb11a[8] = { 0, 2, 4, 6, 9, 11, 1, 3};
4126     Int_t ch11b[8] = { 1, 1, 1, 1, 0, 0, 0, 0};
4127     Int_t hb11b[8] = { 5, 7, 11, 9, 7, 5, 3, 1};
4128    
4129     Int_t ch12a[6] = { 2, 2, 2, 2, 2, 2};
4130     Int_t hb12a[6] = { 1, 3, 5, 7, 9, 11};
4131     Int_t ch12b[6] = { 3, 3, 3, 3, 3, 3};
4132     Int_t hb12b[6] = { 11, 9, 7, 5, 3, 1};
4133    
4134     Int_t ch21a[2] = { 0, 0};
4135     Int_t hb21a[2] = { 0, 4};
4136     Int_t ch21b[2] = { 1, 0};
4137     Int_t hb21b[2] = { 8, 6};
4138    
4139     Int_t ch22a[2] = { 0, 0};
4140     Int_t hb22a[2] = { 2, 8};
4141     Int_t ch22b[2] = { 1, 0};
4142     Int_t hb22b[2] = { 10, 10};
4143    
4144     Int_t ch31a[3] = { 1, 2, 2};
4145     Int_t hb31a[3] = { 6, 8, 10};
4146     Int_t ch31b[3] = { 1, 1, 1};
4147     Int_t hb31b[3] = { 4, 2, 0};
4148    
4149     Int_t ch32a[3] = { 2, 2, 3};
4150     Int_t hb32a[3] = { 0, 4, 8};
4151     Int_t ch32b[3] = { 2, 2, 3};
4152     Int_t hb32b[3] = { 2, 6, 10};
4153    
4154     //
4155     pamela::tof::TofEvent *tof = 0;
4156     otr->SetBranchAddress("Tof.Event", &tof);
4157     if ( !var.nosig ) otr->GetEntry(j);
4158     //
4159     // ADC values
4160     //
4161     Float_t ms11a[8] = {0.,0.,0.,0.,0.,0.,0.,0.};
4162     Float_t ms12a[6] = {0.,0.,0.,0.,0.,0.};
4163     Float_t ms21a[2] = {0.,0.};
4164     Float_t ms22a[2] = {0.,0.};
4165     Float_t ms31a[3] = {0.,0.,0.};
4166     Float_t ms32a[3] = {0.,0.,0.};
4167     Float_t ms11b[8] = {0.,0.,0.,0.,0.,0.,0.,0.};
4168     Float_t ms12b[6] = {0.,0.,0.,0.,0.,0.};
4169     Float_t ms21b[2] = {0.,0.};
4170     Float_t ms22b[2] = {0.,0.};
4171     Float_t ms31b[3] = {0.,0.,0.};
4172     Float_t ms32b[3] = {0.,0.,0.};
4173     //
4174     Float_t xp11[8];
4175     Float_t A11[8] = {-19.,-9.6,-25.7,-13.1,-30.9,-21.1,-11.7,-15.9};
4176     Float_t B11[8] = {-2.6,-2.6,-2.3,-2.4,-2.4,-2.8,-2.75,-2.5};
4177     Float_t E11[8] = {2.6,2.6,2.6,2.6,2.6,2.6,2.6,2.6};
4178     Float_t xp12[6];
4179     Float_t A12[6] = {11.6,16.6,5.9,-22.2,-18.0,-14.2};
4180     Float_t B12[6] = {-2.309,-2.424,-1.958,-2.092,-2.241,-2.144};
4181     Float_t E12[6] = {2.6,2.6,2.6,2.6,2.6,2.6};
4182     Float_t xp21[2];
4183     Float_t A21[2] = {12.5, 21.7};
4184     Float_t B21[2] = {-1.492,-1.519};
4185     Float_t E21[2] = {2.2,2.2};
4186     Float_t xp22[2];
4187     Float_t A22[2] = {-27.0, -45.8};
4188     Float_t B22[2] = {-1.897,-1.477};
4189     Float_t E22[2] = {2.9,2.9};
4190     Float_t xp31[3];
4191     Float_t A31[3] = {-25.1, -41.4, -33.9};
4192     Float_t B31[3] = {-3.374,-3.793,-3.495};
4193     Float_t E31[3] = {1.2,1.2,1.2};
4194     Float_t xp32[3];
4195     Float_t A32[3] = {1.3, 3.9, -22.0};
4196     Float_t B32[3] = {-3.134,-3.526,-3.417};
4197     Float_t E32[3] = {2.3,2.3,2.3};
4198     //
4199     // TDC info for each PMT
4200     //
4201     Float_t mt11[2][8];
4202     Float_t mt12[2][6];
4203     Float_t mt21[2][2];
4204     Float_t mt22[2][2];
4205     Float_t mt31[2][3];
4206     Float_t mt32[2][3];
4207     Int_t noadc = 12;
4208     if ( var.bw ){
4209     noadc = 12;
4210     } else {
4211     noadc = 41;
4212     };
4213     //
4214     Int_t ii = 0;
4215     if ( var.nosig ) goto draw;
4216     for ( Int_t i = 0; i<8; i++ ) {
4217     mt11[0][i] = tof->tdc[ch11a[i]][hb11a[i]];
4218     mt11[1][i] = tof->tdc[ch11b[i]][hb11b[i]];
4219     ms11a[i] = tof->adc[ch11a[i]][hb11a[i]];
4220     ms11b[i] = tof->adc[ch11b[i]][hb11b[i]];
4221     xp11[i] = ( -A11[i] + (mt11[0][i]-mt11[1][i]) / 2. ) / B11[i] ;
4222     if ( ms11a[i] == 4095. ) {
4223     ms11a[i] = 0.;
4224     } else {
4225     ms11a[i] = 1.;
4226     };
4227     if ( ms11b[i] == 4095. ) {
4228     ms11b[i] = 0.;
4229     } else {
4230     ms11b[i] = 1.;
4231     };
4232     };
4233     for ( Int_t i = 0; i<6; i++ ) {
4234     mt12[0][i] = tof->tdc[ch12a[i]][hb12a[i]];
4235     mt12[1][i] = tof->tdc[ch12b[i]][hb12b[i]];
4236     ms12a[i] = tof->adc[ch12a[i]][hb12a[i]];
4237     ms12b[i] = tof->adc[ch12b[i]][hb12b[i]];
4238     xp12[i] = ( -A12[i] + (mt12[0][i]-mt12[1][i]) / 2. ) / B12[i] ;
4239     if ( ms12a[i] == 4095. ){
4240     ms12a[i] = 0.;
4241     } else {
4242     ms12a[i] = 1.;
4243     };
4244     if ( ms12b[i] == 4095. ){
4245     ms12b[i] = 0.;
4246     } else {
4247     ms12b[i] = 1.;
4248     };
4249     };
4250     ii = 2;
4251     for ( Int_t i = 0; i<2; i++ ) {
4252     ii--;
4253     mt21[0][ii] = tof->tdc[ch21a[i]][hb21a[i]];
4254     mt21[1][ii] = tof->tdc[ch21b[i]][hb21b[i]];
4255     ms21a[ii] = tof->adc[ch21a[i]][hb21a[i]];
4256     ms21b[ii] = tof->adc[ch21b[i]][hb21b[i]];
4257     xp21[ii] = ( -A21[ii] + (mt21[0][ii]-mt21[1][ii]) / 2. ) / B21[ii] ;
4258     if ( ms21a[ii] == 4095. ){
4259     ms21a[ii] = 0.;
4260     } else {
4261     ms21a[ii] = 1.;
4262     };
4263     if ( ms21b[ii] == 4095. ){
4264     ms21b[ii] = 0.;
4265     } else {
4266     ms21b[ii] = 1.;
4267     };
4268     };
4269     for ( Int_t i = 0; i<2; i++ ) {
4270     mt22[0][i] = tof->tdc[ch22a[i]][hb22a[i]];
4271     mt22[1][i] = tof->tdc[ch22b[i]][hb22b[i]];
4272     ms22a[i] = tof->adc[ch22a[i]][hb22a[i]];
4273     ms22b[i] = tof->adc[ch22b[i]][hb22b[i]];
4274     xp22[i] = ( -A22[i] + (mt22[0][i]-mt22[1][i]) / 2. ) / B22[i] ;
4275     if ( ms22a[i] == 4095. ){
4276     ms22a[i] = 0.;
4277     } else {
4278     ms22a[i] = 1.;
4279     };
4280     if ( ms22b[i] == 4095. ){
4281     ms22b[i] = 0.;
4282     } else {
4283     ms22b[i] = 1.;
4284     };
4285     };
4286     for ( Int_t i = 0; i<3; i++ ) {
4287     mt31[0][i] = tof->tdc[ch31a[i]][hb31a[i]];
4288     mt31[1][i] = tof->tdc[ch31b[i]][hb31b[i]];
4289     ms31a[i] = tof->adc[ch31a[i]][hb31a[i]];
4290     ms31b[i] = tof->adc[ch31b[i]][hb31b[i]];
4291     xp31[i] = ( -A31[i] + (mt31[0][i]-mt31[1][i]) / 2. ) / B31[i] ;
4292     if ( ms31a[i] == 4095. ){
4293     ms31a[i] = 0.;
4294     } else {
4295     ms31a[i] = 1.;
4296     };
4297     if ( ms31b[i] == 4095. ){
4298     ms31b[i] = 0.;
4299     } else {
4300     ms31b[i] = 1.;
4301     };
4302     };
4303     for ( Int_t i = 0; i<3; i++ ) {
4304     mt32[0][i] = tof->tdc[ch32a[i]][hb32a[i]];
4305     mt32[1][i] = tof->tdc[ch32b[i]][hb32b[i]];
4306     ms32a[i] = tof->adc[ch32a[i]][hb32a[i]];
4307     ms32b[i] = tof->adc[ch32b[i]][hb32b[i]];
4308     xp32[i] = ( -A32[i] + (mt32[0][i]-mt32[1][i]) / 2. ) / B32[i] ;
4309     if ( ms32a[i] == 4095. ){
4310     ms32a[i] = 0.;
4311     } else {
4312     ms32a[i] = 1.;
4313     };
4314     if ( ms32b[i] == 4095. ){
4315     ms32b[i] = 0.;
4316     } else {
4317     ms32b[i] = 1.;
4318     };
4319     };
4320     //
4321     draw: Int_t colo = 0;
4322     Int_t ocolo = 0;
4323     Float_t xs2x = var.xxvc;
4324     Float_t ys2x = var.yxvc + 0.36*var.sfy;
4325     Float_t xs2y = var.xyvc;
4326     Float_t ys2y = var.yyvc + 0.36*var.sfy;
4327     Float_t ws2 = 0.005;
4328     Float_t ws13 = 0.007;
4329     //
4330     // S11 X-view
4331     //
4332     Float_t s11p = 0.051;
4333     ocolo = 10;
4334     TPolyLine *ftof11x[8];
4335     for ( Int_t j=0; j<8; j++){
4336     Float_t nxc1[5]={ (s11p*j), (s11p*j), s11p*(j+1), s11p*(j+1), (s11p*j)};
4337     Float_t nyc1[5]={ 0., ws13, ws13, 0., 0.};
4338     Float_t nxc[5];
4339     Float_t nyc[5];
4340     for (Int_t i = 0; i<5 ; i++) {
4341     nxc[i]= xs2x + (-0.204+nxc1[i])*var.sfx;
4342     nyc[i] = ys2x + (0.295+nyc1[i])*var.sfy;
4343     };
4344     ftof11x[j] = new TPolyLine(5,nxc,nyc);
4345     ftof11x[j]->SetLineColor(1);
4346     if ( var.bw ){
4347     colo = -1;
4348     } else {
4349     colo = 1;
4350     };
4351     ColorMIP(ms11a[j]+ms11b[j],colo);
4352     //
4353     if ( colo != 10 ) ocolo = colo;
4354     //
4355     ftof11x[j]->SetFillColor(colo);
4356     ftof11x[j]->SetLineWidth(1);
4357     ftof11x[j]->Draw("f");
4358     ftof11x[j]->Draw();
4359     };
4360     //
4361     // S11 Y-view
4362     //
4363     Float_t nxc1[5]={ -0.165, 0.165, 0.165, -0.165, -0.165};
4364     Float_t nyc1[5]={ 0., 0., ws13, ws13, 0.};
4365     Float_t nxc[5];
4366     Float_t nyc[5];
4367     for (Int_t i = 0; i<5 ; i++) {
4368     nxc[i]= xs2y + nxc1[i]*var.sfx;
4369     nyc[i] = ys2y + (0.295+nyc1[i])*var.sfy;
4370     };
4371     TPolyLine *ftof11y = new TPolyLine(5,nxc,nyc);
4372     ftof11y->SetFillStyle(4000);
4373     ftof11y->SetFillColor(0);
4374     ftof11y->SetLineColor(1);
4375     ftof11y->SetLineWidth(1);
4376     ftof11y->Draw("f");
4377     ftof11y->Draw();
4378     TPolyLine *sftof11[8];
4379     for ( Int_t j=0; j<8; j++){
4380     if ( (mt11[0][j]<4095. || mt11[1][j]<4095.) && !var.nosig ){
4381     if ( ocolo == 10 ) ocolo = noadc;
4382     Float_t lowp = (xp11[j]-E11[j])/100.;
4383     Float_t higp = (xp11[j]+E11[j])/100.;
4384     if ( lowp < -0.164 ) lowp = -0.164;
4385     if ( higp > 0.164 ) higp = 0.164;
4386     if ( lowp < higp ){
4387     Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
4388     Float_t nyc1[5]={ 0.0015, 0.0015, ws13-0.0015, ws13-0.0015, 0.0015};
4389     Float_t nxc[5];
4390     Float_t nyc[5];
4391     for (Int_t i = 0; i<5 ; i++) {
4392     nxc[i]= xs2y + nxc1[i]*var.sfx;
4393     nyc[i] = ys2y + (0.295+nyc1[i])*var.sfy;
4394     };
4395     sftof11[j] = new TPolyLine(5,nxc,nyc);
4396     sftof11[j]->SetLineColor(ocolo);
4397     sftof11[j]->SetFillColor(ocolo);
4398     sftof11[j]->SetLineWidth(1);
4399     sftof11[j]->Draw("f");
4400     sftof11[j]->Draw();
4401     };
4402     };
4403     };
4404    
4405     //
4406     // S12 Y-view
4407     //
4408     Float_t s12p = 0.055;
4409     ocolo = 10;
4410     TPolyLine *ftof12y[6];
4411     for ( Int_t j=0; j<6; j++){
4412     Float_t nxc1[5]={ (s12p*j), (s12p*j), s12p*(j+1), s12p*(j+1), (s12p*j)};
4413     Float_t nyc1[5]={ -ws13, 0., 0., -ws13, -ws13};
4414     Float_t nxc[5];
4415     Float_t nyc[5];
4416     for (Int_t i = 0; i<5 ; i++) {
4417     nxc[i]= xs2y + (-0.165+nxc1[i])*var.sfx;
4418     nyc[i] = ys2y + (0.295+nyc1[i])*var.sfy;
4419     };
4420     ftof12y[j] = new TPolyLine(5,nxc,nyc);
4421     ftof12y[j]->SetLineColor(1);
4422     if ( var.bw ){
4423     colo = -1;
4424     } else {
4425     colo = 1;
4426     };
4427     ColorMIP(ms12a[j]+ms12b[j],colo);
4428     //
4429     if ( colo != 10 ) ocolo = colo;
4430     //
4431     ftof12y[j]->SetFillColor(colo);
4432     ftof12y[j]->SetLineWidth(1);
4433     ftof12y[j]->Draw("f");
4434     ftof12y[j]->Draw();
4435     };
4436     //
4437     // S12 X-view
4438     //
4439     if ( true ){
4440     Float_t nxc1[5]={ -0.204, 0.204, 0.204, -0.204, -0.204};
4441     Float_t nyc1[5]={ 0., 0., -ws13, -ws13, 0.};
4442     Float_t nxc[5];
4443     Float_t nyc[5];
4444     for (Int_t i = 0; i<5 ; i++) {
4445     nxc[i]= xs2x + nxc1[i]*var.sfx;
4446     nyc[i] = ys2x + (0.295+nyc1[i])*var.sfy;
4447     };
4448     TPolyLine *ftof12x = new TPolyLine(5,nxc,nyc);
4449     ftof12x->SetLineColor(1);
4450     ftof12x->SetFillStyle(4000);
4451     ftof12x->SetFillColor(0);
4452     ftof12x->SetLineWidth(1);
4453     ftof12x->Draw("f");
4454     ftof12x->Draw();
4455     TPolyLine *sftof12[6];
4456     for ( Int_t j=0; j<6; j++){
4457     if ( (mt12[0][j]<4095. || mt12[1][j]<4095.) && !var.nosig ){
4458     if ( ocolo == 10 ) ocolo = noadc;
4459     Float_t lowp = (xp12[j]-E12[j])/100.;
4460     Float_t higp = (xp12[j]+E12[j])/100.;
4461     if ( lowp < -0.203 ) lowp = -0.203;
4462     if ( higp > 0.203 ) higp = 0.203;
4463     if ( lowp < higp ){
4464     Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
4465     Float_t nyc1[5]={ -0.0015, -0.0015, -ws13+0.0015, -ws13+0.0015, -0.0015};
4466     Float_t nxc[5];
4467     Float_t nyc[5];
4468     for (Int_t i = 0; i<5 ; i++) {
4469     nxc[i]= xs2x + nxc1[i]*var.sfx;
4470     nyc[i] = ys2x + (0.295+nyc1[i])*var.sfy;
4471     };
4472     sftof12[j] = new TPolyLine(5,nxc,nyc);
4473     sftof12[j]->SetLineColor(ocolo);
4474     sftof12[j]->SetFillColor(ocolo);
4475     sftof12[j]->SetLineWidth(1);
4476     sftof12[j]->Draw("f");
4477     sftof12[j]->Draw();
4478     };
4479     };
4480     };
4481     };
4482     //
4483    
4484     //
4485     // S21 Y-view
4486     //
4487     Float_t s21p = 0.075;
4488     ocolo = 10;
4489     TPolyLine *ftof21y[2];
4490     for ( Int_t j=0; j<2; j++){
4491     Float_t nxc1[5]={ s21p*(j-1), s21p*(j-1), s21p*j,s21p*j, s21p*(j-1)};
4492     Float_t nyc1[5]={ 0., ws2, ws2, 0., 0.};
4493     Float_t nxc[5];
4494     Float_t nyc[5];
4495     for (Int_t i = 0; i<5 ; i++) {
4496     nxc[i]= xs2y + nxc1[i]*var.sfx;
4497     nyc[i] = ys2y + nyc1[i]*var.sfy;
4498     };
4499     ftof21y[j] = new TPolyLine(5,nxc,nyc);
4500     ftof21y[j]->SetLineColor(1);
4501     if ( var.bw ){
4502     colo = -1;
4503     } else {
4504     colo = 1;
4505     };
4506     ColorMIP(ms21a[j]+ms21b[j],colo);
4507     //
4508     if ( colo != 10 ) ocolo = colo;
4509     //
4510     ftof21y[j]->SetFillColor(colo);
4511     ftof21y[j]->SetLineWidth(1);
4512     ftof21y[j]->Draw("f");
4513     ftof21y[j]->Draw();
4514     };
4515     //
4516     // S21 X-view
4517     //
4518     if ( true ){
4519     Float_t nxc1[5]={ -0.09, 0.09, 0.09, -0.09, -0.09};
4520     Float_t nyc1[5]={ 0., 0., ws2, ws2, 0.};
4521     Float_t nxc[5];
4522     Float_t nyc[5];
4523     for (Int_t i = 0; i<5 ; i++) {
4524     nxc[i]= xs2x + nxc1[i]*var.sfx;
4525     nyc[i] = ys2x + nyc1[i]*var.sfy;
4526     };
4527     TPolyLine *ftof21x = new TPolyLine(5,nxc,nyc);
4528     ftof21x->SetLineColor(1);
4529     ftof21x->SetFillStyle(4000);
4530     ftof21x->SetFillColor(0);
4531     ftof21x->SetLineWidth(1);
4532     ftof21x->Draw("f");
4533     ftof21x->Draw();
4534     TPolyLine *sftof21[2];
4535     for ( Int_t j=0; j<2; j++){
4536     if ( (mt21[0][j]<4095. || mt21[1][j]<4095.) && !var.nosig ){
4537     if ( ocolo == 10 ) ocolo = noadc;
4538     Float_t lowp = (xp21[j]-E21[j])/100.;
4539     Float_t higp = (xp21[j]+E21[j])/100.;
4540     if ( lowp < -0.089 ) lowp = -0.089;
4541     if ( higp > 0.089 ) higp = 0.089;
4542     if ( lowp < higp ){
4543     Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
4544     Float_t nyc1[5]={ 0.0015, 0.0015, ws2-0.0015, ws2-0.0015, 0.};
4545     Float_t nxc[5];
4546     Float_t nyc[5];
4547     for (Int_t i = 0; i<5 ; i++) {
4548     nxc[i]= xs2x + nxc1[i]*var.sfx;
4549     nyc[i] = ys2x + nyc1[i]*var.sfy;
4550     };
4551     sftof21[j] = new TPolyLine(5,nxc,nyc);
4552     sftof21[j]->SetLineColor(ocolo);
4553     sftof21[j]->SetFillColor(ocolo);
4554     sftof21[j]->SetLineWidth(1);
4555     sftof21[j]->Draw("f");
4556     sftof21[j]->Draw();
4557     };
4558     };
4559     };
4560     };
4561     //
4562    
4563     //
4564     // S22 X-view
4565     //
4566     Float_t s22p = 0.090;
4567     ocolo = 10;
4568     TPolyLine *ftof22x[2];
4569     for ( Int_t j=0; j<2; j++){
4570     Float_t nxc1[5]={ s22p*(j-1), s22p*(j-1), s22p*j, s22p*j, s22p*(j-1)};
4571     Float_t nyc1[5]={ -ws2, 0., 0., -ws2, -ws2};
4572     Float_t nxc[5];
4573     Float_t nyc[5];
4574     for (Int_t i = 0; i<5 ; i++) {
4575     nxc[i]= xs2x + nxc1[i]*var.sfx;
4576     nyc[i] = ys2x + nyc1[i]*var.sfy;
4577     };
4578     ftof22x[j] = new TPolyLine(5,nxc,nyc);
4579     ftof22x[j]->SetLineColor(1);
4580     if ( var.bw ){
4581     colo = -1;
4582     } else {
4583     colo = 1;
4584     };
4585     ColorMIP(ms22a[j]+ms22b[j],colo);
4586     //
4587     if ( colo != 10 ) ocolo = colo;
4588     //
4589     ftof22x[j]->SetFillColor(colo);
4590     ftof22x[j]->SetLineWidth(1);
4591     ftof22x[j]->Draw("f");
4592     ftof22x[j]->Draw();
4593     };
4594     //
4595     // S22 Y-view
4596     //
4597     if ( true ){
4598     Float_t nxc1[5]={ -0.075, 0.075, 0.075, -0.075, -0.075};
4599     Float_t nyc1[5]={ 0., 0., -ws2, -ws2, 0.};
4600     Float_t nxc[5];
4601     Float_t nyc[5];
4602     for (Int_t i = 0; i<5 ; i++) {
4603     nxc[i]= xs2y + nxc1[i]*var.sfx;
4604     nyc[i] = ys2y + nyc1[i]*var.sfy;
4605     };
4606     TPolyLine *ftof22y = new TPolyLine(5,nxc,nyc);
4607     ftof22y->SetLineColor(1);
4608     ftof22y->SetFillStyle(4000);
4609     ftof22y->SetFillColor(0);
4610     ftof22y->SetLineWidth(1);
4611     ftof22y->Draw("f");
4612     ftof22y->Draw();
4613     TPolyLine *sftof22[2];
4614     for ( Int_t j=0; j<2; j++){
4615     if ( (mt22[0][j]<4095. || mt22[1][j]<4095.) && !var.nosig ){
4616     if ( ocolo == 10 ) ocolo = noadc;
4617     Float_t lowp = (xp22[j]-E22[j])/100.;
4618     Float_t higp = (xp22[j]+E22[j])/100.;
4619     if ( lowp < -0.074 ) lowp = -0.074;
4620     if ( higp > 0.074 ) higp = 0.074;
4621     if ( lowp < higp ){
4622     Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
4623     Float_t nyc1[5]={ -0.0015, -0.0015, -ws2+0.0015, -ws2+0.0015, -0.0015};
4624     Float_t nxc[5];
4625     Float_t nyc[5];
4626     for (Int_t i = 0; i<5 ; i++) {
4627     nxc[i]= xs2y + nxc1[i]*var.sfx;
4628     nyc[i] = ys2y + nyc1[i]*var.sfy;
4629     };
4630     sftof22[j] = new TPolyLine(5,nxc,nyc);
4631     sftof22[j]->SetLineColor(ocolo);
4632     sftof22[j]->SetFillColor(ocolo);
4633     sftof22[j]->SetLineWidth(1);
4634     sftof22[j]->Draw("f");
4635     sftof22[j]->Draw();
4636     };
4637     };
4638     };
4639     };
4640     //
4641    
4642     //
4643     // S31 X-view
4644     //
4645     Float_t s31p = 0.060;
4646     ocolo = 10;
4647     TPolyLine *ftof31x[3];
4648     for ( Int_t j=0; j<3; j++){
4649     Float_t nxc1[5]={ (s31p*j), (s31p*j), s31p*(j+1), s31p*(j+1), (s31p*j)};
4650     Float_t nyc1[5]={ 0., ws13, ws13, 0., 0.};
4651     Float_t nxc[5];
4652     Float_t nyc[5];
4653     for (Int_t i = 0; i<5 ; i++) {
4654     nxc[i]= xs2x + (-0.090+nxc1[i])*var.sfx;
4655     nyc[i] = ys2x + (-0.488+nyc1[i])*var.sfy;
4656     };
4657     ftof31x[j] = new TPolyLine(5,nxc,nyc);
4658     ftof31x[j]->SetLineColor(1);
4659     if ( var.bw ){
4660     colo = -1;
4661     } else {
4662     colo = 1;
4663     };
4664     ColorMIP(ms31a[j]+ms31b[j],colo);
4665     //
4666     if ( colo != 10 ) ocolo = colo;
4667     //
4668     ftof31x[j]->SetFillColor(colo);
4669     ftof31x[j]->SetLineWidth(1);
4670     ftof31x[j]->Draw("f");
4671     ftof31x[j]->Draw();
4672     };
4673     //
4674     // S31 Y-view
4675     //
4676     if ( true ){
4677     Float_t nxc1[5]={ -0.075, 0.075, 0.075, -0.075, -0.075};
4678     Float_t nyc1[5]={ 0., 0., ws13, ws13, 0.};
4679     Float_t nxc[5];
4680     Float_t nyc[5];
4681     for (Int_t i = 0; i<5 ; i++) {
4682     nxc[i]= xs2y + nxc1[i]*var.sfx;
4683     nyc[i] = ys2y + (-0.488+nyc1[i])*var.sfy;
4684     };
4685     TPolyLine *ftof31y = new TPolyLine(5,nxc,nyc);
4686     ftof31y->SetLineColor(1);
4687     ftof31y->SetFillStyle(4000);
4688     ftof31y->SetFillColor(0);
4689     ftof31y->SetLineWidth(1);
4690     ftof31y->Draw("f");
4691     ftof31y->Draw();
4692     TPolyLine *sftof31[3];
4693     for ( Int_t j=0; j<3; j++){
4694     if ( (mt31[0][j]<4095. || mt31[1][j]<4095.) && !var.nosig){
4695     if ( ocolo == 10 ) ocolo = noadc;
4696     Float_t lowp = (xp31[j]-E31[j])/100.;
4697     Float_t higp = (xp31[j]+E31[j])/100.;
4698     if ( lowp < -0.074 ) lowp = -0.074;
4699     if ( higp > 0.074 ) higp = 0.074;
4700     if ( lowp < higp ){
4701     Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
4702     Float_t nyc1[5]={ 0.0015, 0.0015, ws13-0.0015, ws13-0.0015, 0.0015};
4703     Float_t nxc[5];
4704     Float_t nyc[5];
4705     for (Int_t i = 0; i<5 ; i++) {
4706     nxc[i]= xs2y + nxc1[i]*var.sfx;
4707     nyc[i] = ys2y + (-0.488+nyc1[i])*var.sfy;
4708     };
4709     sftof31[j] = new TPolyLine(5,nxc,nyc);
4710     sftof31[j]->SetLineColor(ocolo);
4711     sftof31[j]->SetFillColor(ocolo);
4712     sftof31[j]->SetLineWidth(1);
4713     sftof31[j]->Draw("f");
4714     sftof31[j]->Draw();
4715     };
4716     };
4717     };
4718     };
4719     //
4720    
4721     //
4722     // S32 Y-view
4723     //
4724     Float_t s32p = 0.050;
4725     ocolo = 10;
4726     TPolyLine *ftof32y[3];
4727     for ( Int_t j=0; j<3; j++){
4728     Float_t nxc1[5]={ (s32p*j), (s32p*j), s32p*(j+1),s32p*(j+1), (s32p*j)};
4729     Float_t nyc1[5]={ -ws13, 0., 0., -ws13, -ws13};
4730     Float_t nxc[5];
4731     Float_t nyc[5];
4732     for (Int_t i = 0; i<5 ; i++) {
4733     nxc[i]= xs2y + (-0.075+nxc1[i])*var.sfx;
4734     nyc[i] = ys2y + (-0.488+nyc1[i])*var.sfy;
4735     };
4736     ftof32y[j] = new TPolyLine(5,nxc,nyc);
4737     ftof32y[j]->SetLineColor(1);
4738     if ( var.bw ){
4739     colo = -1;
4740     } else {
4741     colo = 1;
4742     };
4743     ColorMIP(ms32a[j]+ms32b[j],colo);
4744     //
4745     if ( colo != 10 ) ocolo = colo;
4746     //
4747     ftof32y[j]->SetFillColor(colo);
4748     ftof32y[j]->SetLineWidth(1);
4749     ftof32y[j]->Draw("f");
4750     ftof32y[j]->Draw();
4751     };
4752     //
4753     // S32 X-view
4754     //
4755     if ( true ){
4756     Float_t nxc1[5]={ -0.09, 0.09, 0.09, -0.09, -0.09};
4757     Float_t nyc1[5]={ 0., 0., -ws13, -ws13, 0.};
4758     Float_t nxc[5];
4759     Float_t nyc[5];
4760     for (Int_t i = 0; i<5 ; i++) {
4761     nxc[i]= xs2x + nxc1[i]*var.sfx;
4762     nyc[i] = ys2x + (-0.488+nyc1[i])*var.sfy;
4763     };
4764     TPolyLine *ftof32x = new TPolyLine(5,nxc,nyc);
4765     ftof32x->SetLineColor(1);
4766     ftof32x->SetLineWidth(1);
4767     ftof32x->SetFillStyle(4000);
4768     ftof32x->SetFillColor(0);
4769     ftof32x->Draw("f");
4770     ftof32x->Draw();
4771     TPolyLine *sftof32[3];
4772     for ( Int_t j=0; j<3; j++){
4773     if ( (mt32[0][j]<4095. || mt32[1][j]<4095.) && !var.nosig ){
4774     if ( ocolo == 10 ) ocolo = noadc;
4775     Float_t lowp = (xp32[j]-E32[j])/100.;
4776     Float_t higp = (xp32[j]+E32[j])/100.;
4777     if ( lowp < -0.089 ) lowp = -0.089;
4778     if ( higp > 0.089 ) higp = 0.089;
4779     if ( lowp < higp ){
4780     Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
4781     Float_t nyc1[5]={ -0.0015, -0.0015, -ws13+0.0015, -ws13+0.0015, -0.0015};
4782     Float_t nxc[5];
4783     Float_t nyc[5];
4784     for (Int_t i = 0; i<5 ; i++) {
4785     nxc[i]= xs2x + nxc1[i]*var.sfx;
4786     nyc[i] = ys2x + (-0.488+nyc1[i])*var.sfy;
4787     };
4788     sftof32[j] = new TPolyLine(5,nxc,nyc);
4789     sftof32[j]->SetLineColor(ocolo);
4790     sftof32[j]->SetFillColor(ocolo);
4791     sftof32[j]->SetLineWidth(1);
4792     sftof32[j]->Draw("f");
4793     sftof32[j]->Draw();
4794     };
4795     };
4796     };
4797     };
4798     //
4799     }
4800    
4801 mocchiut 1.3 void ShowTOFL1(Int_t j, TTree *toftr, Variables & var, PAMevcontrol *pamgui){
4802 mocchiut 1.1 //
4803     for (Int_t i=0 ; i<5; i++){
4804     var.beta[i] = 0.;
4805     };
4806     //
4807     struct Toflev1 ntof;
4808     settoflev1(toftr,ntof);
4809     //
4810     Int_t syncro = 1;
4811     Int_t itr = j;
4812     Int_t trnevents = toftr->GetEntries();
4813     Int_t pktnum = 0;
4814     Int_t obt = 0;
4815     trkcalosync: if ( itr >= trnevents ){
4816     printf(" WARNING: no more tof level1 data.\n");
4817 mocchiut 1.3 pamgui->DIALOG(1," No more tof level1 data ");
4818 mocchiut 1.1 return;
4819 mocchiut 1.3 } else {
4820     if ( !var.nosig ) toftr->GetEntry(itr);
4821 mocchiut 1.1 };
4822     pktnum = var.headc;
4823     obt = var.etime;
4824     if ( pktnum != ntof.pkt_num || obt != ntof.obt ){
4825     if ( pktnum > ntof.pkt_num || obt > ntof.obt ){
4826     itr++;
4827 mocchiut 1.3 if ( syncro ){
4828     printf(" WARNING: lost sync! try to recover... \n");
4829     pamgui->DIALOG(1," Lost sync! try to recover ");
4830     };
4831 mocchiut 1.1 syncro = 0;
4832     goto trkcalosync;
4833     };
4834     if ( pktnum < ntof.pkt_num || obt < ntof.obt ){
4835     printf(" WARNING: no tof level1 data. \n");
4836 mocchiut 1.3 pamgui->DIALOG(1," No more tof level1 data ");
4837 mocchiut 1.1 return;
4838     };
4839     };
4840     //
4841 mocchiut 1.3 if ( !syncro ){
4842     printf(" ...synchronization recovered! \n");
4843     pamgui->DIALOG(0," Synchronization recovered! ");
4844     };
4845 mocchiut 1.1 syncro = 1;
4846     //
4847     if ( !var.nosig ) {
4848     for (Int_t i=0 ; i<5; i++){
4849     if ( ntof.beta[i] < 100.) var.beta[i] = ntof.beta[i];
4850     };
4851     };
4852     struct CToflev1 tof;
4853     accesstoflev1(ntof,tof);
4854     //
4855     // the channels MAP:
4856     //
4857     Int_t ch11a[8] = { 3, 3, 3, 3, 0, 0, 1, 1};
4858     Int_t hb11a[8] = { 0, 2, 4, 6, 9, 11, 1, 3};
4859     Int_t ch11b[8] = { 1, 1, 1, 1, 0, 0, 0, 0};
4860     Int_t hb11b[8] = { 5, 7, 11, 9, 7, 5, 3, 1};
4861    
4862     Int_t ch12a[6] = { 2, 2, 2, 2, 2, 2};
4863     Int_t hb12a[6] = { 1, 3, 5, 7, 9, 11};
4864     Int_t ch12b[6] = { 3, 3, 3, 3, 3, 3};
4865     Int_t hb12b[6] = { 11, 9, 7, 5, 3, 1};
4866    
4867     Int_t ch21a[2] = { 0, 0};
4868     Int_t hb21a[2] = { 0, 4};
4869     Int_t ch21b[2] = { 1, 0};
4870     Int_t hb21b[2] = { 8, 6};
4871    
4872     Int_t ch22a[2] = { 0, 0};
4873     Int_t hb22a[2] = { 2, 8};
4874     Int_t ch22b[2] = { 1, 0};
4875     Int_t hb22b[2] = { 10, 10};
4876    
4877     Int_t ch31a[3] = { 1, 2, 2};
4878     Int_t hb31a[3] = { 6, 8, 10};
4879     Int_t ch31b[3] = { 1, 1, 1};
4880     Int_t hb31b[3] = { 4, 2, 0};
4881    
4882     Int_t ch32a[3] = { 2, 2, 3};
4883     Int_t hb32a[3] = { 0, 4, 8};
4884     Int_t ch32b[3] = { 2, 2, 3};
4885     Int_t hb32b[3] = { 2, 6, 10};
4886    
4887     //
4888     Float_t E11 = 2.6;
4889     Float_t E12 = 2.6;
4890     Float_t E21 = 2.2;
4891     Float_t E22 = 2.9;
4892     Float_t E31 = 1.2;
4893     Float_t E32 = 2.3;
4894    
4895     //
4896     // ADC values
4897     //
4898     Float_t ms11a[8] = {0.,0.,0.,0.,0.,0.,0.,0.};
4899     Float_t ms12a[6] = {0.,0.,0.,0.,0.,0.};
4900     Float_t ms21a[2] = {0.,0.};
4901     Float_t ms22a[2] = {0.,0.};
4902     Float_t ms31a[3] = {0.,0.,0.};
4903     Float_t ms32a[3] = {0.,0.,0.};
4904     Float_t ms11b[8] = {0.,0.,0.,0.,0.,0.,0.,0.};
4905     Float_t ms12b[6] = {0.,0.,0.,0.,0.,0.};
4906     Float_t ms21b[2] = {0.,0.};
4907     Float_t ms22b[2] = {0.,0.};
4908     Float_t ms31b[3] = {0.,0.,0.};
4909     Float_t ms32b[3] = {0.,0.,0.};
4910     //
4911     Float_t xp11 = 0.;
4912     Float_t xp12 = 0.;
4913     Float_t xp21 = 0.;
4914     Float_t xp22 = 0.;
4915     Float_t xp31 = 0.;
4916     Float_t xp32 = 0.;
4917     //
4918     Int_t noadc = 12;
4919     if ( var.bw ){
4920     noadc = 12;
4921     } else {
4922     noadc = 41;
4923     };
4924     //
4925     Int_t ii = 2;
4926     //
4927     if ( var.nosig ) goto draw;
4928     xp11 = tof.ytof[0];
4929     for ( Int_t i = 0; i<8; i++ ) {
4930     if ( tof.adc_c[ch11a[i]][hb11a[i]] < 1000. ){
4931     ms11a[i] = tof.adc_c[ch11a[i]][hb11a[i]]/2.;
4932     };
4933     if ( tof.adc_c[ch11b[i]][hb11b[i]] < 1000. ){
4934     ms11b[i] = tof.adc_c[ch11b[i]][hb11b[i]]/2.;
4935     };
4936     };
4937     xp12 = tof.xtof[0];
4938     for ( Int_t i = 0; i<6; i++ ) {
4939     if ( tof.adc_c[ch12a[i]][hb12a[i]] < 1000. ) ms12a[i] = tof.adc_c[ch12a[i]][hb12a[i]]/2.;
4940     if ( tof.adc_c[ch12b[i]][hb12b[i]] < 1000. ) ms12b[i] = tof.adc_c[ch12b[i]][hb12b[i]]/2.;
4941     };
4942     xp21 = tof.xtof[1];
4943     ii = 2;
4944     for ( Int_t i = 0; i<2; i++ ) {
4945     ii--;
4946     if ( tof.adc_c[ch21a[i]][hb21a[i]] < 1000. ) ms21a[ii] = tof.adc_c[ch21a[i]][hb21a[i]]/2.;
4947     if ( tof.adc_c[ch21b[i]][hb21b[i]] < 1000. ) ms21b[ii] = tof.adc_c[ch21b[i]][hb21b[i]]/2.;
4948     };
4949     xp22 = tof.ytof[1];
4950     for ( Int_t i = 0; i<2; i++ ) {
4951     if ( tof.adc_c[ch22a[i]][hb22a[i]] < 1000. ) ms22a[i] = tof.adc_c[ch22a[i]][hb22a[i]]/2.;
4952     if ( tof.adc_c[ch22b[i]][hb22b[i]] < 1000. ) ms22b[i] = tof.adc_c[ch22b[i]][hb22b[i]]/2.;
4953     };
4954     xp31 = tof.ytof[2];
4955     for ( Int_t i = 0; i<3; i++ ) {
4956     if ( tof.adc_c[ch31a[i]][hb31a[i]] < 1000. ) ms31a[i] = tof.adc_c[ch31a[i]][hb31a[i]]/2.;
4957     if ( tof.adc_c[ch31b[i]][hb31b[i]] < 1000. ) ms31b[i] = tof.adc_c[ch31b[i]][hb31b[i]]/2.;
4958     };
4959     xp32 = tof.xtof[2];
4960     for ( Int_t i = 0; i<3; i++ ) {
4961     if ( tof.adc_c[ch32a[i]][hb32a[i]] < 1000. ) ms32a[i] = tof.adc_c[ch32a[i]][hb32a[i]]/2.;
4962     if ( tof.adc_c[ch32b[i]][hb32b[i]] < 1000. ) ms32b[i] = tof.adc_c[ch32b[i]][hb32b[i]]/2.;
4963     };
4964     //
4965     draw:
4966     //
4967     Int_t colo;
4968     Int_t ocolo;
4969     Float_t xs2x = var.xxvc;
4970     Float_t ys2x = var.yxvc + 0.36*var.sfy;
4971     Float_t xs2y = var.xyvc;
4972     Float_t ys2y = var.yyvc + 0.36*var.sfy;
4973     Float_t ws2 = 0.005;
4974     Float_t ws13 = 0.007;
4975     //
4976     // S11 X-view
4977     //
4978     Float_t s11p = 0.051;
4979     ocolo = 10;
4980     TPolyLine *ftof11x[8];
4981     for ( Int_t j=0; j<8; j++){
4982     Float_t nxc1[5]={ (s11p*j), (s11p*j), s11p*(j+1), s11p*(j+1), (s11p*j)};
4983     Float_t nyc1[5]={ 0., ws13, ws13, 0., 0.};
4984     Float_t nxc[5];
4985     Float_t nyc[5];
4986     for (Int_t i = 0; i<5 ; i++) {
4987     nxc[i]= xs2x + (-0.204+nxc1[i])*var.sfx;
4988     nyc[i] = ys2x + (0.295+nyc1[i])*var.sfy;
4989     };
4990     ftof11x[j] = new TPolyLine(5,nxc,nyc);
4991     ftof11x[j]->SetLineColor(1);
4992     if ( var.bw ){
4993     colo = -1;
4994     } else {
4995     colo = 1;
4996     };
4997     ColorTOFMIP(ms11a[j]+ms11b[j],colo);
4998     //
4999     if ( colo != 10 ) ocolo = colo;
5000     //
5001     ftof11x[j]->SetFillColor(colo);
5002     ftof11x[j]->SetLineWidth(1);
5003     ftof11x[j]->Draw("f");
5004     ftof11x[j]->Draw();
5005     };
5006     //
5007     // S11 Y-view
5008     //
5009     if ( true ){
5010     Float_t nxc1[5]={ -0.165, 0.165, 0.165, -0.165, -0.165};
5011     Float_t nyc1[5]={ 0., 0., ws13, ws13, 0.};
5012     Float_t nxc[5];
5013     Float_t nyc[5];
5014     for (Int_t i = 0; i<5 ; i++) {
5015     nxc[i]= xs2y + nxc1[i]*var.sfx;
5016     nyc[i] = ys2y + (0.295+nyc1[i])*var.sfy;
5017     };
5018     TPolyLine *ftof11y = new TPolyLine(5,nxc,nyc);
5019     ftof11y->SetFillStyle(4000);
5020     ftof11y->SetFillColor(0);
5021     ftof11y->SetLineColor(1);
5022     ftof11y->SetLineWidth(1);
5023     ftof11y->Draw("f");
5024     ftof11y->Draw();
5025     TPolyLine *sftof11;
5026     if ( !var.nosig ){
5027     if ( ocolo == 10 ) ocolo = noadc;
5028     Float_t lowp = (xp11-E11)/100.;
5029     Float_t higp = (xp11+E11)/100.;
5030     if ( lowp < -0.164 ) lowp = -0.164;
5031     if ( higp > 0.164 ) higp = 0.164;
5032     if ( lowp < higp ){
5033     Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
5034     Float_t nyc1[5]={ 0.0015, 0.0015, ws13-0.0015, ws13-0.0015, 0.0015};
5035     Float_t nxc[5];
5036     Float_t nyc[5];
5037     for (Int_t i = 0; i<5 ; i++) {
5038     nxc[i]= xs2y + nxc1[i]*var.sfx;
5039     nyc[i] = ys2y + (0.295+nyc1[i])*var.sfy;
5040     };
5041     sftof11 = new TPolyLine(5,nxc,nyc);
5042     sftof11->SetLineColor(ocolo);
5043     sftof11->SetFillColor(ocolo);
5044     sftof11->SetLineWidth(1);
5045     sftof11->Draw("f");
5046     sftof11->Draw();
5047     };
5048     };
5049     };
5050    
5051     //
5052     // S12 Y-view
5053     //
5054     Float_t s12p = 0.055;
5055     ocolo = 10;
5056     TPolyLine *ftof12y[6];
5057     for ( Int_t j=0; j<6; j++){
5058     Float_t nxc1[5]={ (s12p*j), (s12p*j), s12p*(j+1), s12p*(j+1), (s12p*j)};
5059     Float_t nyc1[5]={ -ws13, 0., 0., -ws13, -ws13};
5060     Float_t nxc[5];
5061     Float_t nyc[5];
5062     for (Int_t i = 0; i<5 ; i++) {
5063     nxc[i]= xs2y + (-0.165+nxc1[i])*var.sfx;
5064     nyc[i] = ys2y + (0.295+nyc1[i])*var.sfy;
5065     };
5066     ftof12y[j] = new TPolyLine(5,nxc,nyc);
5067     ftof12y[j]->SetLineColor(1);
5068     if ( var.bw ){
5069     colo = -1;
5070     } else {
5071     colo = 1;
5072     };
5073     ColorTOFMIP(ms12a[j]+ms12b[j],colo);
5074     //
5075     if ( colo != 10 ) ocolo = colo;
5076     //
5077     ftof12y[j]->SetFillColor(colo);
5078     ftof12y[j]->SetLineWidth(1);
5079     ftof12y[j]->Draw("f");
5080     ftof12y[j]->Draw();
5081     };
5082     //
5083     // S12 X-view
5084     //
5085     if ( true ){
5086     Float_t nxc1[5]={ -0.204, 0.204, 0.204, -0.204, -0.204};
5087     Float_t nyc1[5]={ 0., 0., -ws13, -ws13, 0.};
5088     Float_t nxc[5];
5089     Float_t nyc[5];
5090     for (Int_t i = 0; i<5 ; i++) {
5091     nxc[i]= xs2x + nxc1[i]*var.sfx;
5092     nyc[i] = ys2x + (0.295+nyc1[i])*var.sfy;
5093     };
5094     TPolyLine *ftof12x = new TPolyLine(5,nxc,nyc);
5095     ftof12x->SetLineColor(1);
5096     ftof12x->SetFillStyle(4000);
5097     ftof12x->SetFillColor(0);
5098     ftof12x->SetLineWidth(1);
5099     ftof12x->Draw("f");
5100     ftof12x->Draw();
5101     TPolyLine *sftof12;
5102     if ( !var.nosig ){
5103     if ( ocolo == 10 ) ocolo = noadc;
5104     Float_t lowp = (xp12-E12)/100.;
5105     Float_t higp = (xp12+E12)/100.;
5106     if ( lowp < -0.203 ) lowp = -0.203;
5107     if ( higp > 0.203 ) higp = 0.203;
5108     if ( lowp < higp ){
5109     Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
5110     Float_t nyc1[5]={ -0.0015, -0.0015, -ws13+0.0015, -ws13+0.0015, -0.0015};
5111     Float_t nxc[5];
5112     Float_t nyc[5];
5113     for (Int_t i = 0; i<5 ; i++) {
5114     nxc[i]= xs2x + nxc1[i]*var.sfx;
5115     nyc[i] = ys2x + (0.295+nyc1[i])*var.sfy;
5116     };
5117     sftof12 = new TPolyLine(5,nxc,nyc);
5118     sftof12->SetLineColor(ocolo);
5119     sftof12->SetFillColor(ocolo);
5120     sftof12->SetLineWidth(1);
5121     sftof12->Draw("f");
5122     sftof12->Draw();
5123     };
5124     };
5125     };
5126     //
5127    
5128     //
5129     // S21 Y-view
5130     //
5131     Float_t s21p = 0.075;
5132     ocolo = 10;
5133     TPolyLine *ftof21y[2];
5134     for ( Int_t j=0; j<2; j++){
5135     Float_t nxc1[5]={ s21p*(j-1), s21p*(j-1), s21p*j,s21p*j, s21p*(j-1)};
5136     Float_t nyc1[5]={ 0., ws2, ws2, 0., 0.};
5137     Float_t nxc[5];
5138     Float_t nyc[5];
5139     for (Int_t i = 0; i<5 ; i++) {
5140     nxc[i]= xs2y + nxc1[i]*var.sfx;
5141     nyc[i] = ys2y + nyc1[i]*var.sfy;
5142     };
5143     ftof21y[j] = new TPolyLine(5,nxc,nyc);
5144     ftof21y[j]->SetLineColor(1);
5145     if ( var.bw ){
5146     colo = -1;
5147     } else {
5148     colo = 1;
5149     };
5150     ColorTOFMIP(ms21a[j]+ms21b[j],colo);
5151     //
5152     if ( colo != 10 ) ocolo = colo;
5153     //
5154     ftof21y[j]->SetFillColor(colo);
5155     ftof21y[j]->SetLineWidth(1);
5156     ftof21y[j]->Draw("f");
5157     ftof21y[j]->Draw();
5158     };
5159     //
5160     // S21 X-view
5161     //
5162     if ( true ){
5163     Float_t nxc1[5]={ -0.09, 0.09, 0.09, -0.09, -0.09};
5164     Float_t nyc1[5]={ 0., 0., ws2, ws2, 0.};
5165     Float_t nxc[5];
5166     Float_t nyc[5];
5167     for (Int_t i = 0; i<5 ; i++) {
5168     nxc[i]= xs2x + nxc1[i]*var.sfx;
5169     nyc[i] = ys2x + (0.0+nyc1[i])*var.sfy;
5170     };
5171     TPolyLine *ftof21x = new TPolyLine(5,nxc,nyc);
5172     ftof21x->SetLineColor(1);
5173     ftof21x->SetFillStyle(4000);
5174     ftof21x->SetFillColor(0);
5175     ftof21x->SetLineWidth(1);
5176     ftof21x->Draw("f");
5177     ftof21x->Draw();
5178     TPolyLine *sftof21;
5179     if ( !var.nosig ){
5180     if ( ocolo == 10 ) ocolo = noadc;
5181     Float_t lowp = (xp21-E21)/100.;
5182     Float_t higp = (xp21+E21)/100.;
5183     if ( lowp < -0.089 ) lowp = -0.089;
5184     if ( higp > 0.089 ) higp = 0.089;
5185     if ( lowp < higp ){
5186     Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
5187     Float_t nyc1[5]={ 0.0015, 0.0015, ws2-0.0015, ws2-0.0015, 0.};
5188     Float_t nxc[5];
5189     Float_t nyc[5];
5190     for (Int_t i = 0; i<5 ; i++) {
5191     nxc[i]= xs2x + nxc1[i]*var.sfx;
5192     nyc[i] = ys2x + (0.0+nyc1[i])*var.sfy;
5193     };
5194     sftof21 = new TPolyLine(5,nxc,nyc);
5195     sftof21->SetLineColor(ocolo);
5196     sftof21->SetFillColor(ocolo);
5197     sftof21->SetLineWidth(1);
5198     sftof21->Draw("f");
5199     sftof21->Draw();
5200     };
5201     };
5202     };
5203     //
5204    
5205     //
5206     // S22 X-view
5207     //
5208     Float_t s22p = 0.090;
5209     ocolo = 10;
5210     TPolyLine *ftof22x[2];
5211     for ( Int_t j=0; j<2; j++){
5212     Float_t nxc1[5]={ s22p*(j-1), s22p*(j-1), s22p*j, s22p*j, s22p*(j-1)};
5213     Float_t nyc1[5]={ -ws2, 0., 0., -ws2, -ws2};
5214     Float_t nxc[5];
5215     Float_t nyc[5];
5216     for (Int_t i = 0; i<5 ; i++) {
5217     nxc[i]= xs2x + nxc1[i]*var.sfx;
5218     nyc[i] = ys2x + (0.0+nyc1[i])*var.sfy;
5219     };
5220     ftof22x[j] = new TPolyLine(5,nxc,nyc);
5221     ftof22x[j]->SetLineColor(1);
5222     if ( var.bw ){
5223     colo = -1;
5224     } else {
5225     colo = 1;
5226     };
5227     ColorTOFMIP(ms22a[j]+ms22b[j],colo);
5228     //
5229     if ( colo != 10 ) ocolo = colo;
5230     //
5231     ftof22x[j]->SetFillColor(colo);
5232     ftof22x[j]->SetLineWidth(1);
5233     ftof22x[j]->Draw("f");
5234     ftof22x[j]->Draw();
5235     };
5236     //
5237     // S22 Y-view
5238     //
5239     if ( true ){
5240     Float_t nxc1[5]={ -0.075, 0.075, 0.075, -0.075, -0.075};
5241     Float_t nyc1[5]={ 0., 0., -ws2, -ws2, 0.};
5242     Float_t nxc[5];
5243     Float_t nyc[5];
5244     for (Int_t i = 0; i<5 ; i++) {
5245     nxc[i]= xs2y + nxc1[i]*var.sfx;
5246     nyc[i] = ys2y + (0.0+nyc1[i])*var.sfy;
5247     };
5248     TPolyLine *ftof22y = new TPolyLine(5,nxc,nyc);
5249     ftof22y->SetLineColor(1);
5250     ftof22y->SetFillStyle(4000);
5251     ftof22y->SetFillColor(0);
5252     ftof22y->SetLineWidth(1);
5253     ftof22y->Draw("f");
5254     ftof22y->Draw();
5255     TPolyLine *sftof22;
5256     if ( !var.nosig ){
5257     if ( ocolo == 10 ) ocolo = noadc;
5258     Float_t lowp = (xp22-E22)/100.;
5259     Float_t higp = (xp22+E22)/100.;
5260     if ( lowp < -0.074 ) lowp = -0.074;
5261     if ( higp > 0.074 ) higp = 0.074;
5262     if ( lowp < higp ){
5263     Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
5264     Float_t nyc1[5]={ -0.0015, -0.0015, -ws2+0.0015, -ws2+0.0015, -0.0015};
5265     Float_t nxc[5];
5266     Float_t nyc[5];
5267     for (Int_t i = 0; i<5 ; i++) {
5268     nxc[i]= xs2y + nxc1[i]*var.sfx;
5269     nyc[i] = ys2y + (0.0+nyc1[i])*var.sfy;
5270     };
5271     sftof22 = new TPolyLine(5,nxc,nyc);
5272     sftof22->SetLineColor(ocolo);
5273     sftof22->SetFillColor(ocolo);
5274     sftof22->SetLineWidth(1);
5275     sftof22->Draw("f");
5276     sftof22->Draw();
5277     };
5278     };
5279     };
5280     //
5281    
5282     //
5283     // S31 X-view
5284     //
5285     Float_t s31p = 0.060;
5286     ocolo = 10;
5287     TPolyLine *ftof31x[3];
5288     for ( Int_t j=0; j<3; j++){
5289     Float_t nxc1[5]={ (s31p*j), (s31p*j), s31p*(j+1), s31p*(j+1), (s31p*j)};
5290     Float_t nyc1[5]={ 0., ws13, ws13, 0., 0.};
5291     Float_t nxc[5];
5292     Float_t nyc[5];
5293     for (Int_t i = 0; i<5 ; i++) {
5294     nxc[i]= xs2x + (-0.090+nxc1[i])*var.sfx;
5295     nyc[i] = ys2x + (-0.488+nyc1[i])*var.sfy;
5296     };
5297     ftof31x[j] = new TPolyLine(5,nxc,nyc);
5298     ftof31x[j]->SetLineColor(1);
5299     if ( var.bw ){
5300     colo = -1;
5301     } else {
5302     colo = 1;
5303     };
5304     ColorTOFMIP(ms31a[j]+ms31b[j],colo);
5305     //
5306     if ( colo != 10 ) ocolo = colo;
5307     //
5308     ftof31x[j]->SetFillColor(colo);
5309     ftof31x[j]->SetLineWidth(1);
5310     ftof31x[j]->Draw("f");
5311     ftof31x[j]->Draw();
5312     };
5313     //
5314     // S31 Y-view
5315     //
5316     if ( true ){
5317     Float_t nxc1[5]={ -0.075, 0.075, 0.075, -0.075, -0.075};
5318     Float_t nyc1[5]={ 0., 0., ws13, ws13, 0.};
5319     Float_t nxc[5];
5320     Float_t nyc[5];
5321     for (Int_t i = 0; i<5 ; i++) {
5322     nxc[i]= xs2y + nxc1[i]*var.sfx;
5323     nyc[i] = ys2y + (-0.488+nyc1[i])*var.sfy;
5324     };
5325     TPolyLine *ftof31y = new TPolyLine(5,nxc,nyc);
5326     ftof31y->SetLineColor(1);
5327     ftof31y->SetFillStyle(4000);
5328     ftof31y->SetFillColor(0);
5329     ftof31y->SetLineWidth(1);
5330     ftof31y->Draw("f");
5331     ftof31y->Draw();
5332     TPolyLine *sftof31;
5333     if ( !var.nosig ){
5334     if ( ocolo == 10 ) ocolo = noadc;
5335     Float_t lowp = (xp31-E31)/100.;
5336     Float_t higp = (xp31+E31)/100.;
5337     if ( lowp < -0.074 ) lowp = -0.074;
5338     if ( higp > 0.074 ) higp = 0.074;
5339     if ( lowp < higp ){
5340     Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
5341     Float_t nyc1[5]={ 0.0015, 0.0015, ws13-0.0015, ws13-0.0015, 0.0015};
5342     Float_t nxc[5];
5343     Float_t nyc[5];
5344     for (Int_t i = 0; i<5 ; i++) {
5345     nxc[i]= xs2y + nxc1[i]*var.sfx;
5346     nyc[i] = ys2y + (-0.488+nyc1[i])*var.sfy;
5347     };
5348     sftof31 = new TPolyLine(5,nxc,nyc);
5349     sftof31->SetLineColor(ocolo);
5350     sftof31->SetFillColor(ocolo);
5351     sftof31->SetLineWidth(1);
5352     sftof31->Draw("f");
5353     sftof31->Draw();
5354     };
5355     };
5356     };
5357     //
5358    
5359     //
5360     // S32 Y-view
5361     //
5362     Float_t s32p = 0.050;
5363     ocolo = 10;
5364     TPolyLine *ftof32y[3];
5365     for ( Int_t j=0; j<3; j++){
5366     Float_t nxc1[5]={ (s32p*j), (s32p*j), s32p*(j+1),s32p*(j+1), (s32p*j)};
5367     Float_t nyc1[5]={ -ws13, 0., 0., -ws13, -ws13};
5368     Float_t nxc[5];
5369     Float_t nyc[5];
5370     for (Int_t i = 0; i<5 ; i++) {
5371     nxc[i]= xs2y + (-0.075+nxc1[i])*var.sfx;
5372     nyc[i] = ys2y + (-0.488+nyc1[i])*var.sfy;
5373     };
5374     ftof32y[j] = new TPolyLine(5,nxc,nyc);
5375     ftof32y[j]->SetLineColor(1);
5376     if ( var.bw ){
5377     colo = -1;
5378     } else {
5379     colo = 1;
5380     };
5381     ColorTOFMIP(ms32a[j]+ms32b[j],colo);
5382     //
5383     if ( colo != 10 ) ocolo = colo;
5384     //
5385     ftof32y[j]->SetFillColor(colo);
5386     ftof32y[j]->SetLineWidth(1);
5387     ftof32y[j]->Draw("f");
5388     ftof32y[j]->Draw();
5389     };
5390     //
5391     // S32 X-view
5392     //
5393     if ( true ){
5394     Float_t nxc1[5]={ -0.09, 0.09, 0.09, -0.09, -0.09};
5395     Float_t nyc1[5]={ 0., 0., -ws13, -ws13, 0.};
5396     Float_t nxc[5];
5397     Float_t nyc[5];
5398     for (Int_t i = 0; i<5 ; i++) {
5399     nxc[i]= xs2x + nxc1[i]*var.sfx;
5400     nyc[i] = ys2x + (-0.488+nyc1[i])*var.sfy;
5401     };
5402     TPolyLine *ftof32x = new TPolyLine(5,nxc,nyc);
5403     ftof32x->SetLineColor(1);
5404     ftof32x->SetLineWidth(1);
5405     ftof32x->SetFillStyle(4000);
5406     ftof32x->SetFillColor(0);
5407     ftof32x->Draw("f");
5408     ftof32x->Draw();
5409     TPolyLine *sftof32;
5410     if ( !var.nosig ){
5411     if ( ocolo == 10 ) ocolo = noadc;
5412     Float_t lowp = (xp32-E32)/100.;
5413     Float_t higp = (xp32+E32)/100.;
5414     if ( lowp < -0.089 ) lowp = -0.089;
5415     if ( higp > 0.089 ) higp = 0.089;
5416     if ( lowp < higp ){
5417     Float_t nxc1[5]={ lowp, higp, higp, lowp, lowp};
5418     Float_t nyc1[5]={ -0.0015, -0.0015, -ws13+0.0015, -ws13+0.0015, -0.0015};
5419     Float_t nxc[5];
5420     Float_t nyc[5];
5421     for (Int_t i = 0; i<5 ; i++) {
5422     nxc[i]= xs2x + nxc1[i]*var.sfx;
5423     nyc[i] = ys2x + (-0.488+nyc1[i])*var.sfy;
5424     };
5425     sftof32 = new TPolyLine(5,nxc,nyc);
5426     sftof32->SetLineColor(ocolo);
5427     sftof32->SetFillColor(ocolo);
5428     sftof32->SetLineWidth(1);
5429     sftof32->Draw("f");
5430     sftof32->Draw();
5431     };
5432     };
5433     };
5434     //
5435     }
5436    
5437     //**********************************************************************************
5438     // LEVEL2 SUBROUTINES //
5439     //**********************************************************************************
5440    
5441 mocchiut 1.3 void ShowTRACK(Int_t evno, TTree *ttr, Variables & var, PAMevcontrol *pamgui){
5442 mocchiut 1.1 //
5443     var.rig = 0.;
5444     var.chi2 = 0.;
5445     struct Tracklev2 trk;
5446     settrklev2(ttr,trk);
5447     //
5448     Int_t trcol = 10;
5449     Int_t syncro = 1;
5450     Int_t itr = evno;
5451     Int_t trnevents = ttr->GetEntries();
5452     Int_t pktnum = 0;
5453     Int_t obt = 0;
5454     trkcalosync: if ( itr >= trnevents ){
5455     printf(" WARNING: no more tracker level2 data.\n");
5456 mocchiut 1.3 pamgui->DIALOG(1," No more tracker level2 data ");
5457 mocchiut 1.1 return;
5458     };
5459     if ( !var.nosig ) ttr->GetEntry(itr);
5460     pktnum = var.headc;
5461     obt = var.etime;
5462     if ( pktnum != trk.pkt_num || obt != trk.obt ){
5463     if ( pktnum > trk.pkt_num || obt > trk.obt ){
5464     itr++;
5465 mocchiut 1.3 if ( syncro ) {
5466     printf(" WARNING: lost sync! try to recover... \n");
5467     pamgui->DIALOG(1," Lost sync! try to recover ");
5468     };
5469 mocchiut 1.1 syncro = 0;
5470     goto trkcalosync;
5471     };
5472     if ( pktnum < trk.pkt_num || obt < trk.obt ){
5473     printf(" WARNING: no tracker level2 data. \n");
5474 mocchiut 1.3 pamgui->DIALOG(1," No more tracker level2 data ");
5475 mocchiut 1.1 return;
5476     };
5477     };
5478     //
5479 mocchiut 1.3 if ( !syncro ){
5480     printf(" ...synchronization recovered! \n");
5481     pamgui->DIALOG(0," Synchronization recovered! ");
5482     };
5483 mocchiut 1.1 //
5484     if ( trk.ntrk > 0 ){
5485     Int_t l = 0;
5486     Int_t tobeinc = 0;
5487     while ( l<trk.ntrk ) {
5488     //
5489     Int_t npoint = 100;
5490     Double_t zin[100];
5491     Double_t xout[100];
5492     Double_t yout[100];
5493     Double_t al_p[5];
5494     Int_t ifail = 0;
5495     //
5496     Float_t tx[100];
5497     Float_t ty[100];
5498     Float_t ptx1[50];
5499     Float_t pty1[50];
5500     Float_t ptx2[50];
5501     Float_t pty2[50];
5502     Float_t tx1[15];
5503     Float_t ty1[15];
5504     Float_t tzx[100];
5505     Float_t tzy[100];
5506     Float_t tzx1[15];
5507     Float_t tzy1[15];
5508     //
5509     // if there is track ambiguity in y choose the track with the smaller chi2
5510     //
5511     if ( trk.image[l] != 0 ){
5512     Float_t chiA = trk.chi2[l];
5513     Float_t chiB = trk.chi2[trk.image[l]-1];
5514     if ( chiA > chiB ) {
5515     l = trk.image[l]-1;
5516     tobeinc = 2;
5517     };
5518     tobeinc = 1;
5519     };
5520     for ( Int_t e = 0; e < 100 ; e++) {
5521     xout[e] = 0.;
5522     yout[e] = 0.;
5523     //
5524     tx[e] = 0.;
5525     ty[e] = 0.;
5526     tzx[e] = 0.;
5527     tzy[e] = 0.;
5528     if ( e < 50 ){
5529     ptx1[e] = 0.;
5530     pty1[e] = 0.;
5531     ptx2[e] = 0.;
5532     pty2[e] = 0.;
5533     if ( e < 15 ){
5534     tx1[e] = 0.;
5535     ty1[e] = 0.;
5536     tzx1[e] = 0.;
5537     tzy1[e] = 0.;
5538     };
5539     };
5540     //
5541     if ( e < 5 ) {
5542     al_p[e] = (Double_t)trk.al[l][e];
5543     };
5544     zin[e] = 60. - (124./99.)*(float)e;
5545     };
5546     //
5547     zin[85] = -45.5;
5548     //
5549     ctrack(npoint,zin,xout,yout,al_p,ifail);
5550     //
5551     //
5552     if ( !ifail ){
5553     if ( l == 0 || ( l == 1 && tobeinc ==2 ) ){
5554     if ( trk.al[l][4] != 0. ) {
5555     var.rig = 1./trk.al[l][4];
5556     var.chi2 = trk.chi2[l];
5557     } else {
5558     var.rig = 0.;
5559     var.chi2 = 0.;
5560     };
5561     };
5562     //
5563     for ( Int_t e = 0; e < npoint ; e++) {
5564     tx[e] = ((float)xout[e]/100.)*var.sfx + var.xxvc;
5565     ty[e] = ((float)yout[e]/100.)*var.sfx + var.xyvc;
5566     // printf("tx %i %f \n",e,tx[e]);
5567     //printf("xout %i %f \n",e,xout[e]);
5568     if ( e < 50 ) {
5569     ptx1[e] = ((float)yout[e]/100.)*var.sfx + var.xcat;
5570     pty1[e] = ((float)xout[e]/100.)*var.sfy + var.ycat;
5571     } else {
5572     ptx2[e-50] = ((float)yout[e]/100.)*var.sfx + var.xcat;
5573     pty2[e-50] = ((float)xout[e]/100.)*var.sfy + var.ycat;
5574     };
5575     if ( e > 84 ) {
5576     tx1[e-85] = ((float)xout[e]/100.)*var.nds4 + var.xxvc;
5577     ty1[e-85] = ((float)yout[e]/100.)*var.nds4 + var.xyvc;
5578     tzx1[e-85] = (0.112)*var.sfy+((float)zin[e]/100.)*var.sfy + var.yxvc;
5579     tzy1[e-85] = (0.112)*var.sfy+((float)zin[e]/100.)*var.sfy + var.yyvc;
5580     };
5581     tzx[e] = (0.112)*var.sfy+((float)zin[e]/100.)*var.sfy + var.yxvc;
5582     tzy[e] = (0.112)*var.sfy+((float)zin[e]/100.)*var.sfy + var.yyvc;
5583     };
5584     //
5585     // From S1 to CALO
5586     //
5587     if ( var.bw ){
5588     trcol = 17-l;
5589     } else {
5590     trcol = 50-l;
5591     };
5592     TPolyLine *trackx = new TPolyLine(86,tx,tzx);
5593     trackx->SetLineColor(trcol);
5594     trackx->SetLineWidth(1);
5595     trackx->Draw();
5596     TPolyLine *tracky = new TPolyLine(86,ty,tzy);
5597     tracky->SetLineColor(trcol);
5598     tracky->SetLineWidth(1);
5599     tracky->Draw();
5600     //
5601     // ND and S4
5602     //
5603     if ( var.tracknds4 ){
5604     TPolyLine *trackx1 = new TPolyLine(15,tx1,tzx1);
5605     trackx1->SetLineColor(trcol);
5606     trackx1->SetLineWidth(1);
5607     trackx1->Draw();
5608     TPolyLine *tracky1 = new TPolyLine(15,ty1,tzy1);
5609     tracky1->SetLineColor(trcol);
5610     tracky1->SetLineWidth(1);
5611     tracky1->Draw();
5612     };
5613     //
5614     // Plane View
5615     //
5616 mocchiut 1.3 if ( var.AC ){
5617     TPolyLine *trackp1 = new TPolyLine(50,ptx1,pty1);
5618     trackp1->SetLineColor(trcol);
5619     trackp1->SetLineWidth(1);
5620     trackp1->Draw();
5621     TPolyLine *trackp2 = new TPolyLine(50,ptx2,pty2);
5622     trackp2->SetLineColor(trcol);
5623     trackp2->SetLineWidth(1);
5624     trackp2->SetLineStyle(3);
5625     trackp2->Draw();
5626     };
5627 mocchiut 1.2 //
5628     // Dots on measured points
5629     //
5630     TEllipse *elli;
5631     Float_t x;
5632     Float_t y;
5633     Float_t z1;
5634     Float_t z2;
5635 mocchiut 1.3 Int_t dcol;
5636     if ( var.bw ){
5637     dcol = 12;
5638     } else {
5639     dcol = 2;
5640     };
5641 mocchiut 1.2 for (Int_t g = 0; g<6; g++){
5642 mocchiut 1.3 if ( trk.xgood[l][g] ) {
5643     x = trk.xm[l][g]*var.sfx/100. + var.xxvc;
5644     z1 = (trk.zm[l][g]+11.2)*var.sfy/100. + var.yxvc;
5645     elli = new TEllipse(x,z1,0.004,0.004,0.,-180.);
5646     elli->SetFillStyle(1001);
5647     elli->SetFillColor(dcol);
5648     elli->Draw();
5649     };
5650     if ( trk.ygood[l][g] ) {
5651     y = trk.ym[l][g]*var.sfx/100. + var.xyvc;
5652     z2 = (trk.zm[l][g]+11.2)*var.sfy/100. + var.yyvc;
5653     elli = new TEllipse(y,z2,0.004,0.004,0.,-180.);
5654     elli->SetFillStyle(1001);
5655     elli->SetFillColor(dcol);
5656     elli->Draw();
5657     };
5658 mocchiut 1.2 };
5659     //
5660     //
5661 mocchiut 1.1 } else {
5662 mocchiut 1.3 pamgui->DIALOG(1," Failed in determining the track! ");
5663 mocchiut 1.1 printf(" WARNING: failed in determining the track! \n");
5664     };
5665     l++;
5666     if ( tobeinc ) {
5667     l++;
5668     tobeinc = 0;
5669     };
5670     };
5671     };
5672     }
5673    
5674     //**********************************************************************************
5675     // OTHER SUBROUTINES **
5676     //**********************************************************************************
5677    
5678     void ShowCaloL0(TString filename, Int_t i, Calib & calib, Int_t b[4], Float_t mip[2][22][96], TTree *otr, Variables & var){
5679     struct Evento evento;
5680     Int_t tot0 = 0;
5681     Int_t tot1 = 0;
5682     Int_t tot2 = 0;
5683     Int_t nstrip = 0;
5684     Float_t qtot = 0.;
5685     pamela::calorimeter::CalorimeterEvent *de = 0;
5686     otr->SetBranchAddress("Calorimeter.Event", &de);
5687     if ( !var.nosig ) otr->GetEntry(i);
5688     //
5689     // Define variables
5690     //
5691     Int_t etime = var.etime;
5692     Float_t estrip[2][22][96], ener, basel,sdexy[2][22][96],sdexyc[2][22][96];
5693     Int_t badstrip = 0;
5694     qtot = 0.;
5695     nstrip = 0;
5696     //
5697     // Book the histograms:
5698     //
5699     //
5700     stringstream xvev;
5701     stringstream yvev;
5702     xvev.str("");
5703     yvev.str("");
5704     xvev << "x-view event " << (i+1);
5705     yvev << "y-view event " << (i+1);
5706     gDirectory->Delete(xvev.str().c_str());
5707     gDirectory->Delete(yvev.str().c_str());
5708     TH2F *Xview = new TH2F(xvev.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
5709     TH2F *Yview = new TH2F(yvev.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
5710     Xview->GetYaxis()->SetLabelColor(10);
5711     Yview->GetYaxis()->SetLabelColor(10);
5712     //
5713     // figures:
5714     //
5715     Int_t bgcolor = 10;
5716     TPad *pd1 = new TPad("calox","This is pad1",var.xxvc-0.154*var.sfx,var.yxvc-0.3645*var.sfy,var.xxvc+0.154*var.sfx,var.yxvc-0.1200*var.sfy,bgcolor);
5717     TPad *pd2 = new TPad("caloy","This is pad2",var.xyvc-0.154*var.sfx,var.yyvc-0.3645*var.sfy,var.xyvc+0.154*var.sfx,var.yyvc-0.1200*var.sfy,bgcolor);
5718    
5719     pd1->SetFillStyle(4000);
5720     pd1->SetFillColor(0);
5721     pd1->SetFrameFillStyle(4000);
5722     pd2->SetFillStyle(4000);
5723     pd2->SetFillColor(0);
5724     pd2->SetFrameFillStyle(4000);
5725    
5726     TLatex *t=new TLatex();
5727     t->SetTextFont(32);
5728     t->SetTextColor(1);
5729     t->SetTextSize(0.03);
5730     t->SetTextAlign(12);
5731     pd1->Range(0.,0.,1.,1.);
5732     pd2->Range(0.,0.,1.,1.);
5733     pd1->SetTicks();
5734     pd2->SetTicks();
5735     pd1->Draw();
5736     pd2->Draw();
5737    
5738     pd1->cd();
5739     gStyle->SetOptStat(0);
5740     Xview->GetYaxis()->SetTitleOffset(0.5);
5741     Xview->SetFillColor(bgcolor);
5742     Xview->Fill(1.,1.,1.);
5743     Xview->Draw("box");
5744     pd1->Update();
5745     pd2->cd();
5746     gStyle->SetOptStat(0);
5747     Yview->GetYaxis()->SetTitleOffset(0.5);
5748     Yview->SetFillColor(bgcolor);
5749     Yview->Fill(1.,1.,1.);
5750     Yview->Draw("box");
5751     pd2->Update();
5752     //
5753     // for each event check that the calibration we are using are still within calibration limits, if not call the next calibration
5754     //
5755     for (Int_t s = 0; s < 4; s++){
5756     if ( calib.ttime[s][b[s]+1] && calib.time[s][b[s]] ){
5757     while ( etime > calib.time[s][b[s]] && calib.time[s][b[s]] != 0 ){
5758     printf(" CALORIMETER: \n" );
5759     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]);
5760     printf(" END CALORIMETER. \n\n" );
5761     b[s]++;
5762     CaloPede(filename,s,calib.ttime[s][b[s]],calib);
5763     };
5764     };
5765     };
5766     //
5767     // do whatever you want with data
5768     //
5769     evento.iev = de->iev;
5770     //
5771     // run over views and planes
5772     //
5773     stringstream xve;
5774     stringstream yve;
5775     for (Int_t l = 0; l < 2; l++){
5776     for (Int_t m = 0; m < 22; m++){
5777     //
5778     // determine the section number
5779     //
5780     Int_t se = 5;
5781     if (l == 0 && m%2 == 0) se = 3;
5782     if (l == 0 && m%2 != 0) se = 2;
5783     if (l == 1 && m%2 == 0) se = 1;
5784     if (l == 1 && m%2 != 0) se = 0;
5785     //
5786     // determine what kind of event we are going to analyze
5787     //
5788     bool isCOMP = 0;
5789     bool isFULL = 0;
5790     bool isRAW = 0;
5791     if ( de->stwerr[se] & (1 << 16) ) isCOMP = 1;
5792     if ( de->stwerr[se] & (1 << 17) ) isFULL = 1;
5793     if ( de->stwerr[se] & (1 << 3) ) isRAW = 1;
5794     //
5795     // save the prevoius energy deposit and calibration in sbase, sdexy, sdexyc
5796     //
5797     Int_t pre = -1;
5798     if ( isRAW ){
5799     for (Int_t nn = 0; nn < 96; nn++){
5800     if ( nn%16 == 0 ) pre++;
5801     evento.base[l][m][pre] = calib.calbase[l][m][pre];
5802     sdexy[l][m][nn] = evento.dexy[l][m][nn];
5803     evento.dexy[l][m][nn] = de->dexy[l][m][nn] ;
5804     sdexyc[l][m][nn] = evento.dexyc[l][m][nn];
5805     evento.dexyc[l][m][nn] = de->dexyc[l][m][nn] ;
5806     };
5807     };
5808     //
5809     // run over strips
5810     //
5811     Int_t done = 0;
5812     Int_t rdone = 0;
5813     Int_t fdone = 0;
5814     pre = -1;
5815     for (Int_t n =0 ; n < 96; n++){
5816     if ( n%16 == 0 ) {
5817     pre++;
5818     done = 0;
5819     rdone = 0;
5820     fdone = 0;
5821     };
5822     //
5823     // baseline check and calculation
5824     //
5825     if ( !isRAW ) {
5826     //
5827     // if it isn't raw and we haven't checked yet, check that the baseline is fine, if not calculate it with a relaxed algorithm.
5828     //
5829     if ( !done ){
5830     evento.base[l][m][pre] = de->base[l][m][pre] ;
5831     evento.dexyc[l][m][n] = de->dexyc[l][m][n] ;
5832     };
5833     } else {
5834     //
5835     // if it is a raw event and we haven't checked yet, calculate the baseline. Then check that the baseline is fine,
5836     // if not calculate it with relaxed algorithm.
5837     //
5838     if ( !rdone ){
5839     CaloFindBaseRaw(calib,evento,l,m,pre);
5840     tot1++;
5841     rdone = 1;
5842     };
5843     };
5844     //
5845     // no suitable new baseline, use old ones
5846     //
5847     if ( !done && (evento.base[l][m][pre] == 31000. || evento.base[l][m][pre] == 0.) ){
5848     tot0++;
5849     evento.base[l][m][pre] = calib.sbase[l][m][pre];
5850     Int_t upnn = n+16;
5851     if ( upnn > 96 ) upnn = 96;
5852     for ( Int_t nn = n; nn<upnn; nn++ ){
5853     evento.dexyc[l][m][nn] = de->dexyc[l][m][nn] ;
5854     };
5855     CaloCompressData(calib,evento,l,m,pre);
5856     done = 1;
5857     };
5858     //
5859     // if here we don't have a valid baseline we will skip the event.
5860     //
5861     if ( evento.base[l][m][pre] == 31000. ) tot2++;
5862     //
5863     // CALIBRATION ALGORITHM
5864     //
5865     basel = evento.base[l][m][pre];
5866     ener = evento.dexyc[l][m][n];
5867     estrip[l][m][n] = 0.;
5868     if ( basel>0 && basel < 30000. && ener > 0. ){
5869     estrip[l][m][n] = (ener - calib.calped[l][m][n] - basel)/mip[l][m][n] ;
5870     //
5871     // OK, now in estrip we have the energy deposit in MIP of all the strips for this event (at the end of loops of course)
5872     //
5873     xve.str("");
5874     yve.str("");
5875     xve << "x-view event " << n;
5876     xve << " " << m;
5877     xve << " " << l;
5878     yve << "y-view event " << n;
5879     yve << " " << m;
5880     yve << " " << l;
5881     gDirectory->Delete(xve.str().c_str());
5882     gDirectory->Delete(yve.str().c_str());
5883     TH2F *Xview = new TH2F(xve.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
5884     TH2F *Yview = new TH2F(yve.str().c_str(),"",96,-0.5,95.5,22,-0.5,21.5);
5885     if ( estrip[l][m][n] > 0.7 && !var.nosig ){
5886     Int_t colo;
5887     if ( var.bw ){
5888     colo = -1;
5889     } else {
5890     colo = 1;
5891     };
5892     ColorMIP(estrip[l][m][n],colo);
5893     Xview->SetFillColor(colo);
5894     Yview->SetFillColor(colo);
5895     if ( l == 0 ) {
5896     Xview->Fill(n,21-m,1.);
5897     pd1->cd();
5898     Xview->Draw("box same");
5899     };
5900     if ( l == 1 ) {
5901     Yview->Fill(95-n,21-m,1.);
5902     pd2->cd();
5903     Yview->Draw("box same");
5904     };
5905     };
5906     if ( estrip[l][m][n] > 0.7 && calib.calgood[l][m][n] != 0 ) badstrip++;
5907     if ( estrip[l][m][n] > 0.7 && calib.calgood[l][m][n] == 0 ) {
5908     qtot += estrip[l][m][n];
5909     nstrip++;
5910     };
5911     };
5912     calib.sbase[l][m][pre] = evento.base[l][m][pre];
5913     };
5914     };
5915     };
5916     pd1->Update();
5917     pd2->Update();
5918     var.qtot=(int)qtot;
5919     var.nstrip=nstrip;
5920     }
5921    
5922    
5923     void ShowPalette(Int_t bw){
5924 mocchiut 1.3 Float_t xp = 0.40;
5925 mocchiut 1.1 Float_t yp = 0.02;
5926 mocchiut 1.3 Float_t xw = 0.2325;
5927 mocchiut 1.1 Float_t yh = 0.19;
5928 mocchiut 1.3 // Float_t xp = 0.33;
5929     //Float_t yp = 0.02;
5930     //Float_t xw = 0.35;
5931     //Float_t yh = 0.19;
5932 mocchiut 1.1 Double_t xx[5] = {xp, xp+xw, xp+xw, xp, xp};
5933     Double_t yy[5] = {yp, yp, yp+yh, yp+yh, yp};
5934     TPolyLine *fpale = new TPolyLine(5,xx,yy);
5935     fpale->SetLineColor(1);
5936     fpale->SetLineWidth(1);
5937     fpale->Draw();
5938     TLatex *txt=new TLatex();
5939     txt->SetTextSize(0.01);
5940     txt->DrawLatex(xp+0.005,yp+yh-0.015,"PALETTE");
5941     txt->DrawLatex(xp+0.005,yp+yh-0.04,"TOF, CALO, S4 [MIP]:");
5942 mocchiut 1.3 // Float_t xwc = (xp+0.01)/6.;
5943     Float_t xwc = (xw-0.01)/6.;
5944     Float_t axwc = xwc+0.02;
5945 mocchiut 1.1 Float_t yhc = 0.03;
5946     Int_t colo = 0;
5947     Float_t yc = 0.135;
5948     TPolyLine *fc1[6];
5949     if ( bw ){
5950     for ( Int_t j=0; j<6; j++){
5951 mocchiut 1.3 // Float_t xc = 0.335+(j*xwc);
5952     Float_t xc = 0.005+xp+(j*xwc);
5953 mocchiut 1.1 Double_t xx[5] = {xc, xc+xwc, xc+xwc, xc, xc};
5954     Double_t yy[5] = {yc, yc, yc+yhc, yc+yhc, yc};
5955     fc1[j] = new TPolyLine(5,xx,yy);
5956     fc1[j]->SetLineColor(1);
5957     if ( j == 0 ) {
5958     colo = 10;
5959     };
5960     if ( j == 1 ) {
5961     colo = 17;
5962     };
5963     if ( j == 2 ) {
5964     colo = 15;
5965     };
5966     if ( j == 3 ) {
5967     colo = 14;
5968     };
5969     if ( j == 4 ) {
5970     colo = 13;
5971     };
5972     if ( j == 5 ) {
5973     colo = 12;
5974     };
5975     fc1[j]->SetFillColor(colo);
5976     fc1[j]->SetLineWidth(1);
5977     fc1[j]->Draw("f");
5978     fc1[j]->Draw();
5979     if ( j == 0 ) {
5980     txt->DrawLatex(xc+0.005,yc+0.01,"0");
5981     };
5982     if ( j == 1 ) {
5983     txt->DrawLatex(xc+0.005,yc+0.01,"0 - 2");
5984     };
5985     if ( j == 2 ) {
5986     txt->DrawLatex(xc+0.005,yc+0.01,"2 - 10");
5987     };
5988     if ( j == 3 ) {
5989     txt->DrawLatex(xc+0.005,yc+0.01,"10 - 100");
5990     };
5991     if ( j == 4 ) {
5992     txt->DrawLatex(xc+0.005,yc+0.01,"100 - 500");
5993     };
5994     if ( j == 5 ) {
5995     txt->DrawLatex(xc+0.005,yc+0.01,"> 500");
5996     };
5997     };
5998    
5999     txt->DrawLatex(xp+0.005,yp+yh-0.095,"ND [neutrons]:");
6000     Float_t yc = 0.08;
6001     TPolyLine *fc2[6];
6002     for ( Int_t j=0; j<6; j++){
6003 mocchiut 1.3 Float_t xc = 0.005+xp+(j*xwc);
6004 mocchiut 1.1 Double_t xx[5] = {xc, xc+xwc, xc+xwc, xc, xc};
6005     Double_t yy[5] = {yc, yc, yc+yhc, yc+yhc, yc};
6006     fc2[j] = new TPolyLine(5,xx,yy);
6007     fc2[j]->SetLineColor(1);
6008     if ( j == 0 ) {
6009     colo = 10;
6010     };
6011     if ( j == 1 ) {
6012     colo = 17;
6013     };
6014     if ( j == 2 ) {
6015     colo = 15;
6016     };
6017     if ( j == 3 ) {
6018     colo = 14;
6019     };
6020     if ( j == 4 ) {
6021     colo = 13;
6022     };
6023     if ( j == 5 ) {
6024     colo = 12;
6025     };
6026     fc2[j]->SetFillColor(colo);
6027     fc2[j]->SetLineWidth(1);
6028     fc2[j]->Draw("f");
6029     fc2[j]->Draw();
6030     if ( j == 0 ) {
6031     txt->DrawLatex(xc+0.005,yc+0.01,"0");
6032     };
6033     if ( j == 1 ) {
6034     txt->DrawLatex(xc+0.005,yc+0.01," 1 ");
6035     };
6036     if ( j == 2 ) {
6037     txt->DrawLatex(xc+0.005,yc+0.01," 2 ");
6038     };
6039     if ( j == 3 ) {
6040     txt->DrawLatex(xc+0.005,yc+0.01," 3 - 6 ");
6041     };
6042     if ( j == 4 ) {
6043     txt->DrawLatex(xc+0.005,yc+0.01," 7 - 14 ");
6044     };
6045     if ( j == 5 ) {
6046     txt->DrawLatex(xc+0.005,yc+0.01,"> 14");
6047     };
6048     };
6049     //
6050     txt->DrawLatex(xp+0.005,yp+yh-0.15,"AC:");
6051     yc = 0.025;
6052     TPolyLine *fc3[3];
6053     for ( Int_t j=0; j<3; j++){
6054 mocchiut 1.3 Float_t xc = 0.005+xp+(j*axwc);
6055     Double_t xx[5] = {xc, xc+axwc, xc+axwc, xc, xc};
6056 mocchiut 1.1 Double_t yy[5] = {yc, yc, yc+yhc, yc+yhc, yc};
6057     fc3[j] = new TPolyLine(5,xx,yy);
6058     fc3[j]->SetLineColor(1);
6059     if ( j == 0 ) {
6060     colo = 10;
6061     };
6062     if ( j == 1 ) {
6063     colo = 13;
6064     };
6065     if ( j == 2 ) {
6066     colo = 12;
6067     };
6068     fc3[j]->SetFillColor(colo);
6069     fc3[j]->SetLineWidth(1);
6070     fc3[j]->Draw("f");
6071     fc3[j]->Draw();
6072     if ( j == 0 ) {
6073     txt->DrawLatex(xc+0.005,yc+0.01," NOT HIT ");
6074     };
6075     if ( j == 1 ) {
6076     txt->DrawLatex(xc+0.005,yc+0.01," HIT trigger");
6077     };
6078     if ( j == 2 ) {
6079     txt->SetTextSize(0.0095);
6080     txt->DrawLatex(xc+0.001,yc+0.011," HIT background");
6081     txt->SetTextSize(0.01);
6082     };
6083     };
6084     } else {
6085     for ( Int_t j=0; j<6; j++){
6086 mocchiut 1.3 Float_t xc = 0.005+xp+(j*xwc);
6087 mocchiut 1.1 Double_t xx[5] = {xc, xc+xwc, xc+xwc, xc, xc};
6088     Double_t yy[5] = {yc, yc, yc+yhc, yc+yhc, yc};
6089     fc1[j] = new TPolyLine(5,xx,yy);
6090     fc1[j]->SetLineColor(1);
6091     if ( j == 0 ) {
6092     colo = 10;
6093     };
6094     if ( j == 1 ) {
6095     colo = 38;
6096     };
6097     if ( j == 2 ) {
6098     colo = 4;
6099     };
6100     if ( j == 3 ) {
6101     colo = 3;
6102     };
6103     if ( j == 4 ) {
6104     colo = 2;
6105     };
6106     if ( j == 5 ) {
6107     colo = 6;
6108     };
6109     fc1[j]->SetFillColor(colo);
6110     fc1[j]->SetLineWidth(1);
6111     fc1[j]->Draw("f");
6112     fc1[j]->Draw();
6113     if ( j == 0 ) {
6114     txt->DrawLatex(xc+0.005,yc+0.01,"0");
6115     };
6116     if ( j == 1 ) {
6117     txt->DrawLatex(xc+0.005,yc+0.01,"0 - 2");
6118     };
6119     if ( j == 2 ) {
6120     txt->DrawLatex(xc+0.005,yc+0.01,"2 - 10");
6121     };
6122     if ( j == 3 ) {
6123     txt->DrawLatex(xc+0.005,yc+0.01,"10 - 100");
6124     };
6125     if ( j == 4 ) {
6126     txt->DrawLatex(xc+0.005,yc+0.01,"100 - 500");
6127     };
6128     if ( j == 5 ) {
6129     txt->DrawLatex(xc+0.005,yc+0.01,"> 500");
6130     };
6131     };
6132    
6133     txt->DrawLatex(xp+0.005,yp+yh-0.095,"ND [neutrons]:");
6134     Float_t yc = 0.08;
6135     TPolyLine *fc2[6];
6136     for ( Int_t j=0; j<6; j++){
6137 mocchiut 1.3 Float_t xc = 0.005+xp+(j*xwc);
6138 mocchiut 1.1 Double_t xx[5] = {xc, xc+xwc, xc+xwc, xc, xc};
6139     Double_t yy[5] = {yc, yc, yc+yhc, yc+yhc, yc};
6140     fc2[j] = new TPolyLine(5,xx,yy);
6141     fc2[j]->SetLineColor(1);
6142     if ( j == 0 ) {
6143     colo = 10;
6144     };
6145     if ( j == 1 ) {
6146     colo = 38;
6147     };
6148     if ( j == 2 ) {
6149     colo = 4;
6150     };
6151     if ( j == 3 ) {
6152     colo = 3;
6153     };
6154     if ( j == 4 ) {
6155     colo = 2;
6156     };
6157     if ( j == 5 ) {
6158     colo = 6;
6159     };
6160     fc2[j]->SetFillColor(colo);
6161     fc2[j]->SetLineWidth(1);
6162     fc2[j]->Draw("f");
6163     fc2[j]->Draw();
6164     if ( j == 0 ) {
6165     txt->DrawLatex(xc+0.005,yc+0.01,"0");
6166     };
6167     if ( j == 1 ) {
6168     txt->DrawLatex(xc+0.005,yc+0.01," 1 ");
6169     };
6170     if ( j == 2 ) {
6171     txt->DrawLatex(xc+0.005,yc+0.01," 2 ");
6172     };
6173     if ( j == 3 ) {
6174     txt->DrawLatex(xc+0.005,yc+0.01," 3 - 6 ");
6175     };
6176     if ( j == 4 ) {
6177     txt->DrawLatex(xc+0.005,yc+0.01," 7 - 14 ");
6178     };
6179     if ( j == 5 ) {
6180     txt->DrawLatex(xc+0.005,yc+0.01,"> 14");
6181     };
6182     };
6183     //
6184     txt->DrawLatex(xp+0.005,yp+yh-0.15,"AC:");
6185     yc = 0.025;
6186     TPolyLine *fc3[3];
6187     for ( Int_t j=0; j<3; j++){
6188 mocchiut 1.3 Float_t xc = 0.005+xp+(j*axwc);
6189     Double_t xx[5] = {xc, xc+axwc, xc+axwc, xc, xc};
6190 mocchiut 1.1 Double_t yy[5] = {yc, yc, yc+yhc, yc+yhc, yc};
6191     fc3[j] = new TPolyLine(5,xx,yy);
6192     fc3[j]->SetLineColor(1);
6193     if ( j == 0 ) {
6194     colo = 10;
6195     };
6196     if ( j == 1 ) {
6197     colo = 2;
6198     };
6199     if ( j == 2 ) {
6200     colo = 42;
6201     };
6202     fc3[j]->SetFillColor(colo);
6203     fc3[j]->SetLineWidth(1);
6204     fc3[j]->Draw("f");
6205     fc3[j]->Draw();
6206     if ( j == 0 ) {
6207     txt->DrawLatex(xc+0.005,yc+0.01," NOT HIT ");
6208     };
6209     if ( j == 1 ) {
6210     txt->DrawLatex(xc+0.005,yc+0.01," HIT trigger");
6211     };
6212     if ( j == 2 ) {
6213     txt->SetTextSize(0.0095);
6214     txt->DrawLatex(xc+0.001,yc+0.011," HIT background");
6215     txt->SetTextSize(0.01);
6216     };
6217     };
6218     };
6219     }
6220    
6221     void DrawX(Float_t cx, Float_t cy, Float_t si, Variables & var){
6222     if ( true ){
6223     Float_t x[2] = {-si*var.sfx,si*var.sfx};
6224     Float_t y[2] = {-si*var.sfy,si*var.sfy};
6225     Float_t xb[2];
6226     Float_t yb[2];
6227     for (Int_t i = 0; i<2 ; i++){
6228     xb[i] = x[i]+cx;
6229     yb[i] = y[i]+cy;
6230     };
6231     TLine *x2 = new TLine(xb[0],yb[0],xb[1],yb[1]);
6232     x2->SetLineColor(1);
6233     x2->SetLineWidth(1);
6234     x2->Draw();
6235     };
6236     if ( true ){
6237     Float_t x[2] = {-si*var.sfx,si*var.sfx};
6238     Float_t y[2] = {si*var.sfy,-si*var.sfy};
6239     Float_t xa[2];
6240     Float_t ya[2];
6241     for (Int_t i = 0; i<2 ; i++){
6242     xa[i] = x[i]+cx;
6243     ya[i] = y[i]+cy;
6244     };
6245     TLine *x1 = new TLine(xa[0],ya[0],xa[1],ya[1]);
6246     x1->SetLineColor(1);
6247     x1->SetLineWidth(1);
6248     x1->Draw();
6249     };
6250     }
6251    
6252     //
6253     // MAIN ROUTINE
6254     //
6255     void ShowEvent(TString filename="help", TString selfile="", Int_t ctrlword = 509, Int_t FORCELEV = -1, Int_t fromevent = 0, Int_t toevent = 0, TString outDir = ""){
6256     TString calcalibfile = "";
6257     TString startingdir = gSystem->WorkingDirectory();
6258     const char* startingdir2 = gSystem->WorkingDirectory();
6259     TString path;
6260     stringcopy(path,startingdir2);
6261     #if defined (__CINT__)
6262     emicheckLib();
6263     const char *pamlib=gSystem->Getenv("PAM_LIB");
6264     stringstream lolib;
6265     lolib.str("");
6266     lolib << pamlib << "/EVpathtoc_c.so";
6267     gSystem->Load(lolib.str().c_str());
6268     //
6269     if (!TClassTable::GetDict("CalorimeterLevel1")){
6270     const char *pamlib2 = gSystem->ExpandPathName("$PAM_LIB");
6271     stringstream liblo;
6272     liblo.str("");
6273     liblo << pamlib2 << "/caloclasses_h.so";
6274     gSystem->Load(liblo.str().c_str());
6275     }
6276     #endif
6277     #if !defined (__CINT__)
6278     TApplication app("app",0,0);
6279     #endif
6280     const char *pam_calib = pathtocalibration();
6281     stringstream calfile;
6282     calfile.str("");
6283     calfile << pam_calib << "/CaloADC2MIP.root";
6284 mocchiut 1.3 Int_t selection = 0;
6285     Bool_t firsttime = true;
6286     //
6287     //
6288     restart:
6289     gROOT->GetListOfCanvases()->Delete();
6290     gDirectory->GetList()->Delete();
6291     //
6292     struct Variables var;
6293     Bool_t loadselfs = true;
6294     Bool_t popup = false;
6295     PAMevcontrol *pamgui = 0;
6296     var.restart = false;
6297     var.waitforever = false;
6298     var.jumprog = true;
6299     var.jumpen = false;
6300     // Int_t njumpen = 0;
6301 mocchiut 1.1 struct Levels level;
6302     //
6303     const char *name= filename;
6304     if ( filename == "" || !strcmp(name,"help") ){
6305 mocchiut 1.3 // ShowHelp();
6306     // return;
6307     var.waitforever = true;
6308     };
6309     //
6310     Float_t mip[2][22][96];
6311     Int_t okcalo = 0;
6312     TTree *ctree = 0;
6313     TFile *chfile;
6314     CalorimeterCalibration *ccalo = 0;
6315     Long64_t cnevents = 0;
6316     //
6317     var.goon = false;
6318     var.refresh = false;
6319     var.fl0 = false;
6320    
6321     if ( FORCELEV == 0 ) var.fl0 = true;
6322     //
6323     // Define some variables
6324     //
6325     Int_t OBT = 0;
6326     Int_t DOBT = 0;
6327     Int_t ifout = 0;
6328     Int_t OOBT = 0;
6329     //
6330     // here windows dimension (based on the computer screen size) and position and dimension of figures
6331     //
6332     Int_t xw, yw;
6333     UInt_t ww, hw;
6334     gVirtualX->GetWindowSize(gClient->GetRoot()->GetId(),xw,yw,ww,hw);
6335     Float_t winx = (float)ww*0.80;
6336     Float_t winy = (float)hw*0.80; // 95
6337     Float_t winrap = winx/winy;
6338     TCanvas *figure = new TCanvas("PAMELA event viewer", "PAMELA event viewer",(int)winx,(int)winy);
6339     // GetCanvas->SetBit(kNotEditable);
6340     //
6341     var.bw = 0;
6342     // var.xxvc = 0.17;
6343     var.xxvc = 0.20;
6344     var.yxvc = 0.44;
6345     // var.xyvc = 0.83;
6346     var.xyvc = 0.815;
6347     var.yyvc = 0.44;
6348     //
6349     var.sfx = 0.81/winrap;
6350     var.sfy = 0.81;
6351     //
6352     //var.nds4 = 0.4;
6353     var.nds4 = var.sfx;
6354     var.xcat = 0.515;
6355     //var.xcat = 0.56;
6356     var.ycat = 0.74;
6357     //
6358     var.tracknds4 = 1;
6359     //
6360     var.thefilename = filename.Data();
6361     var.thefilter = selfile.Data();
6362     //
6363     // book the canvas
6364     //
6365     TLatex *text=new TLatex();
6366     stringstream testo;
6367     stringstream testo2;
6368     stringstream testo3;
6369     figure->Range(0.,0.,1.,1.);
6370     gStyle->SetOptDate(0);
6371     gStyle->SetOptStat(0);
6372     gStyle->SetLabelSize(0);
6373     gStyle->SetNdivisions(1,"X");
6374     gStyle->SetNdivisions(1,"Y");
6375     //
6376     stringstream libload;
6377     Int_t doflag = 1;
6378     Int_t thefirst = 1;
6379     Int_t trackdone1 = 0;
6380     Int_t trackdone2 = 0;
6381     Int_t seldone = 0;
6382     Float_t headc = 0.;
6383     Float_t headcold = 0.;
6384     Int_t i = 0;
6385     Int_t isOK = 0;
6386     Int_t jumpto = 0;
6387     struct Calib calib;
6388     Int_t b[4];
6389     Int_t si = 0;
6390     var.selex = false;
6391     var.alrforc = false;
6392     //
6393     // from here to refresh
6394     //
6395     refresh:
6396     //
6397     selfile = var.thefilter.Data();
6398     if ( calcalibfile == "" ) calcalibfile = filename;
6399     if ( outDir == "" ) outDir = filename;
6400     //
6401     if ( var.fl0 == true ) {
6402     FORCELEV = 0;
6403     } else {
6404     if ( var.refresh ) FORCELEV = -1;
6405     };
6406     //
6407     // clear levels!
6408     //
6409     level.calo = -10;
6410     level.calol2 = -10;
6411     level.tof = -10;
6412     level.track = -10;
6413     level.track2 = -10;
6414     level.s4 = -10;
6415     level.ac = -10;
6416     level.nd = -10;
6417     //
6418     TString fififile = getFilename(filename);
6419     const char *file = fififile;
6420     //
6421     //
6422     //
6423     if ( !var.refresh ){
6424     var.SHOWDEC = 0;
6425     var.TOF = 0;
6426     var.AC = 0;
6427     var.TRK = 0;
6428     var.CALO = 0;
6429     var.S4 = 0;
6430     var.ND = 0;
6431     var.INFOS = 0;
6432     var.VINFOS = 0;
6433     var.PALETTE = 0;
6434     if ( ctrlword & (1<<0) ) {
6435     var.PALETTE = 1;
6436     printf("Show Palette\n");
6437     };
6438     if ( ctrlword & (1<<1) ) {
6439     var.VINFOS = 1;
6440     printf("Show Verbose Text Informations\n");
6441     };
6442     if ( ctrlword & (1<<2) ) {
6443     var.INFOS = 1;
6444     printf("Show Text Informations\n");
6445     };
6446     if ( ctrlword & (1<<3) ) {
6447     var.ND = 1;
6448     };
6449     if ( ctrlword & (1<<4) ) {
6450     var.S4 = 1;
6451     };
6452     if ( ctrlword & (1<<5) ) {
6453     var.CALO = 1;
6454     };
6455     if ( ctrlword & (1<<6) ) {
6456     var.TRK = 1;
6457     };
6458     if ( ctrlword & (1<<7) ) {
6459     var.AC = 1;
6460     };
6461     if ( ctrlword & (1<<8) ) {
6462     var.TOF = 1;
6463     };
6464     if ( ctrlword & (1<<9) ) {
6465     var.SHOWDEC = 1;
6466     fromevent = 1;
6467     toevent = 1;
6468     printf("\n ** WARNING! YOU HAVE CHOSEN TO SHOW ONLY DETECTORS AND NO SIGNALS! **\n\n");
6469     gSystem->Exec("sleep 5");
6470     };
6471     };
6472     //
6473     // Pop up the GUI
6474     //
6475     if ( !popup ) {
6476     pamgui = new PAMevcontrol(gClient->GetRoot(),400,800,var,*figure);
6477     popup = true;
6478     };
6479     if ( firsttime ){
6480     firsttime = false;
6481     if ( filename == "" ) pamgui->DIALOG(0," Insert the filename and press load to start ");
6482     };
6483     //
6484     while( var.waitforever ) {
6485     if ( !gROOT->GetListOfCanvases()->FindObject(figure) ) {
6486     pamgui->Close();
6487     gSystem->ProcessEvents();
6488     gApplication->Terminate(0);
6489     };
6490     gSystem->ProcessEvents();
6491 mocchiut 1.4 gSystem->Sleep(10);
6492 mocchiut 1.3 };
6493     if ( var.restart ){
6494     filename = var.thefilename.Data();
6495     pamgui->Close();
6496     goto restart;
6497 mocchiut 1.1 };
6498     //
6499     //
6500     //
6501 mocchiut 1.3 if ( FORCELEV != -1 ) {
6502     printf("\n WARNING: FORCING LEVEL%i DATA \n\n",FORCELEV);
6503     if ( !var.alrforc ) {
6504     pamgui->DIALOG(1," Forcing LEVEL0 data ");
6505     var.alrforc = true;
6506     };
6507     };
6508 mocchiut 1.1 //
6509     // LOAD SELECTION FILE
6510 mocchiut 1.3 //
6511 mocchiut 1.1 if ( selfile == "" ){
6512 mocchiut 1.3 if ( !var.selex && selection ) pamgui->DIALOG(0," Selection file unloaded ");
6513     var.selex = true;
6514 mocchiut 1.1 selection = 0;
6515 mocchiut 1.3 #if !defined (__CINT__)
6516     if ( !var.refresh ) {
6517     gROOT->Reset();
6518     stringstream paminc;
6519     paminc.str("");
6520     const char *testinc = gSystem->Getenv("PAM_INC");
6521     if ( !testinc ) {
6522     const char *pam_calib = pathtocalibration();
6523     paminc << pam_calib << "../include/";
6524     } else {
6525     paminc << testinc;
6526     };
6527     stringstream carica;
6528     carica.str("");
6529     carica << paminc.str().c_str() << "/eventviewer.h";
6530     gROOT->LoadMacro(carica.str().c_str());
6531     };
6532     #endif
6533 mocchiut 1.1 } else {
6534     #if !defined (__CINT__)
6535 mocchiut 1.3 //
6536     // if running the compiled program we must load header files for the selection macros!
6537     //
6538     // if ( !var.refresh ) {
6539     if ( loadselfs ) {
6540     loadselfs = false;
6541     gROOT->Reset();
6542     stringstream paminc;
6543     paminc.str("");
6544     const char *testinc = gSystem->Getenv("PAM_INC");
6545     if ( !testinc ){
6546 mocchiut 1.1 const char *pam_calib = pathtocalibration();
6547     paminc << pam_calib << "../include/";
6548 mocchiut 1.3 } else {
6549 mocchiut 1.1 paminc << testinc;
6550 mocchiut 1.3 };
6551     stringstream carica;
6552     carica.str("");
6553     carica << paminc.str().c_str() << "/eventviewer.h";
6554     gROOT->LoadMacro(carica.str().c_str());
6555     carica.str("");
6556     carica << paminc.str().c_str() << "/trklev1struct.h";
6557     gROOT->LoadMacro(carica.str().c_str());
6558     carica.str("");
6559     carica << paminc.str().c_str() << "/ctrkstruct.h";
6560     gROOT->LoadMacro(carica.str().c_str());
6561     carica.str("");
6562     carica << paminc.str().c_str() << "/ctrkinclude.h";
6563     gROOT->LoadMacro(carica.str().c_str());
6564     carica.str("");
6565     carica << paminc.str().c_str() << "/ctofstruct.h";
6566     gROOT->LoadMacro(carica.str().c_str());
6567     carica.str("");
6568     carica << paminc.str().c_str() << "/ctofinclude.h";
6569     gROOT->LoadMacro(carica.str().c_str());
6570 mocchiut 1.1 };
6571     #endif
6572     //
6573     // load the selection macro
6574     //
6575     selection = gROOT->LoadMacro(selfile);
6576     if ( selection ){
6577 mocchiut 1.3 stringstream dialog;
6578     dialog.str("");
6579     dialog << var.thefilter.Data();
6580     dialog << " : no such file!";
6581     pamgui->DIALOG(2,dialog.str().c_str());
6582 mocchiut 1.1 printf("\n\n ERROR! cannot read the selection file you give me as input! \n");
6583     selection = 0;
6584     printf("\n WARNING! no selection file loaded! \n\n");
6585 mocchiut 1.3 pamgui->DIALOG(1," No selection file loaded! ");
6586     pamgui->clearselfi();
6587 mocchiut 1.1 } else {
6588     printf("\n\n Selection file loaded \n\n The first event will be shown anyway. \n\n");
6589 mocchiut 1.3 if ( !var.selex ) pamgui->DIALOG(0," Selection file successfully loaded ");
6590     var.selex = true;
6591 mocchiut 1.1 selection = 1;
6592     };
6593     };
6594     //
6595 mocchiut 1.3 // LOAD FILES
6596 mocchiut 1.1 //
6597     //
6598     Int_t trk1noev = 0;
6599     Int_t trk2noev = 0;
6600     Int_t tofnoev = 0;
6601     // open files
6602     TFile *headerFile = 0;
6603     TFile *triggerFile = 0;
6604     TFile *caloFile = 0;
6605     TFile *trackerFile = 0;
6606     TFile *trackerFile2 = 0;
6607     TFile *neutronFile = 0;
6608     TFile *acFile = 0;
6609     TFile *s4File = 0;
6610     TFile *tofFile = 0;
6611     TFile *tofFileL1 = 0;
6612     TTree *toftr = 0;
6613     //
6614 mocchiut 1.3 // check if user has given as input a correct path
6615     //
6616     ifstream myfile;
6617     stringstream hfile;
6618     TString textslash;
6619     Int_t minus = 0;
6620     stringcopy(textslash,filename,filename.Length()-1,filename.Length());
6621     if ( !strcmp(textslash.Data(),"/") ){
6622     minus = 1;
6623     } else {
6624     minus = 0;
6625     };
6626     TString textrem;
6627     stringcopy(textrem,filename,filename.Length()-minus-15,filename.Length()-minus);
6628     hfile.str("");
6629     hfile << filename.Data();
6630     hfile << "/Physics/";
6631     hfile << textrem.Data();
6632     hfile << ".Physics.Header.root";
6633     myfile.open(hfile.str().c_str());
6634     if ( !myfile ){
6635     printf("ERROR: no Header file, exiting...\n");
6636     hfile << " - No header file! ";
6637     pamgui->DIALOG(2,hfile.str().c_str());
6638     var.waitforever = true;
6639     goto refresh;
6640     };
6641     myfile.close();
6642     //
6643     // ok, open header file
6644     //
6645 mocchiut 1.1 headerFile = emigetFile(filename, "Physics", "Header");
6646     if ( !headerFile ){
6647     printf("ERROR: no Header file, exiting...\n");
6648 mocchiut 1.3 pamgui->DIALOG(2," No header file! ");
6649     var.waitforever = true;
6650     goto refresh;
6651 mocchiut 1.1 };
6652     TTree *otr = (TTree*)headerFile->Get("Pscu");
6653     printf("Get the Header informations\n");
6654     //
6655     triggerFile = emigetFile(filename, "Trigger");
6656     if ( !triggerFile ){
6657     printf("ERROR: no Trigger file, exiting...\n");
6658 mocchiut 1.3 pamgui->DIALOG(2," No trigger file! ");
6659     var.waitforever = true;
6660     goto refresh;
6661 mocchiut 1.1 };
6662     otr->AddFriend("Trigger", triggerFile);
6663     printf("Get the Trigger informations\n");
6664     //
6665     TTree *ttr = 0;
6666     TTree *ttr1 = 0;
6667     Int_t STRACK = 0;
6668     Int_t TRKLEV = 0;
6669     Int_t ACLEV = 0;
6670     TFile *trackhead = 0;
6671     TFile *trackcalibFile1 = 0;
6672     TTree *ctrk = 0;
6673     TFile *trackcalibFile2 = 0;
6674     TFile *trackerFile2b = 0;
6675 mocchiut 1.3 if ( var.TRK ) {
6676     if ( FORCELEV == 0 ){
6677     trackerFile2 = emigetFile(filename, "Tracker");
6678     if ( !trackerFile2 ){
6679     printf("WARNING: no Tracker file! \n");
6680     pamgui->DIALOG(1," No tracker file! ");
6681     var.TRK = 0;
6682     } else {
6683     otr->AddFriend("Tracker", trackerFile2);
6684     printf("Show the Tracker detector, LEVEL0 data \n");
6685     TRKLEV = 0;
6686     };
6687     } else {
6688     trackerFile = emigetFile(filename, "Physics.Level2", "Tracker");
6689     if ( !trackerFile ){
6690     //
6691     trackhead = emigetFile(filename, "CalibTrk1", "Header");
6692     ctrk = (TTree*)trackhead->Get("Pscu");
6693     //
6694     trackerFile = emigetFile(filename, "Physics.Level1", "Tracker");
6695     trackcalibFile1 = emigetFile(filename, "CalibTrk1");
6696     trackcalibFile2 = emigetFile(filename, "CalibTrk2");
6697     //
6698     if ( !trackerFile || !trackcalibFile1 || !trackcalibFile2 || !trackhead ){
6699     trackerFile = emigetFile(filename, "Tracker");
6700     if ( !trackerFile ){
6701     printf("WARNING: no Tracker file! \n");
6702     pamgui->DIALOG(1," No tracker file! ");
6703     var.TRK = 0;
6704 mocchiut 1.1 } else {
6705 mocchiut 1.3 otr->AddFriend("Tracker", trackerFile);
6706     printf("Show the Tracker detector, LEVEL0 data \n");
6707     TRKLEV = 0;
6708     };
6709     } else {
6710     ttr1 = (TTree*)trackerFile->Get("TrkLevel1");
6711     ctrk->AddFriend("CalibTrk1", trackcalibFile1);
6712     ctrk->AddFriend("CalibTrk2", trackcalibFile2);
6713     printf("Show the Tracker detector, LEVEL1 data \n");
6714     TRKLEV = 1;
6715     trk1noev = ttr1->GetEntries();
6716     };
6717     } else {
6718     ttr = (TTree*)trackerFile->Get("TrkLevel2");
6719     trk2noev = ttr->GetEntries();
6720     printf("Get the track informations (LEVEL2 Tracker data!)\n");
6721     STRACK = 1;
6722     //
6723     trackhead = emigetFile(filename, "CalibTrk2", "Header");
6724     ctrk = (TTree*)trackhead->Get("Pscu");
6725     //
6726     trackerFile2b = emigetFile(filename, "Physics.Level1", "Tracker");
6727     trackcalibFile1 = emigetFile(filename, "CalibTrk1");
6728     trackcalibFile2 = emigetFile(filename, "CalibTrk2");
6729     //
6730     if ( !trackerFile2b || !trackcalibFile1 || !trackcalibFile2 || !trackhead ){
6731     printf(" WARNING: no LEVEL1 Tracker data, load LEVEL0 data \n");
6732     trackerFile2b = emigetFile(filename, "Tracker");
6733     if ( !trackerFile2b ){
6734     printf("WARNING: no Tracker file! \n");
6735     pamgui->DIALOG(1," No tracker file! ");
6736     var.TRK = 0;
6737 mocchiut 1.1 } else {
6738 mocchiut 1.3 otr->AddFriend("Tracker", trackerFile2b);
6739     printf("Show the Tracker detector, LEVEL0 data \n");
6740     TRKLEV = 0;
6741     };
6742     } else {
6743     ttr1 = (TTree*)trackerFile2b->Get("TrkLevel1");
6744     ctrk->AddFriend("CalibTrk1", trackcalibFile1);
6745     ctrk->AddFriend("CalibTrk2", trackcalibFile2);
6746     printf("Show the Tracker detector, LEVEL1 data \n");
6747     TRKLEV = 1;
6748     trk1noev = ttr1->GetEntries();
6749     };
6750     };
6751     };
6752     level.track = TRKLEV;
6753     level.track2 = STRACK;
6754     } else {
6755     level.track = -10;
6756     level.track2 = -10;
6757 mocchiut 1.1 };
6758     //
6759     Int_t CALOLEV = 0;
6760 mocchiut 1.3 if ( var.CALO ) {
6761 mocchiut 1.1 if ( FORCELEV == 0 ){
6762     caloFile = emigetFile(filename, "Calorimeter");
6763     if ( !caloFile ){
6764     printf("WARNING: no calorimeter file! \n");
6765 mocchiut 1.3 pamgui->DIALOG(1," No calorimeter file! ");
6766     var.CALO = 0;
6767 mocchiut 1.1 } else {
6768     otr->AddFriend("Calorimeter", caloFile);
6769     printf("Show the Calorimeter detector, LEVEL0 data \n");
6770     };
6771     CALOLEV = -1;
6772     } else {
6773     caloFile = emigetFile(filename, "Physics.Level1", "Calorimeter");
6774     if ( !caloFile ){
6775     caloFile = emigetFile(filename, "Calorimeter");
6776     if ( !caloFile ){
6777     printf("WARNING: no calorimeter file! \n");
6778 mocchiut 1.3 pamgui->DIALOG(1," No calorimeter file! ");
6779     var.CALO = 0;
6780 mocchiut 1.1 } else {
6781     otr->AddFriend("Calorimeter", caloFile);
6782     printf("Show the Calorimeter detector, try to generate LEVEL1 data \n");
6783     };
6784     CALOLEV = 0;
6785     } else {
6786     otr->AddFriend("CaloLevel1", caloFile);
6787     printf("Show the Calorimeter detector, LEVEL1 data \n");
6788     CALOLEV = 1;
6789     };
6790     };
6791 mocchiut 1.3 level.calo = CALOLEV;
6792     level.calol2 = -10;
6793     } else {
6794     level.calo = -10;
6795     level.calol2 = -10;
6796 mocchiut 1.1 };
6797     //
6798 mocchiut 1.3 if ( var.ND ) {
6799 mocchiut 1.1 neutronFile = emigetFile(filename, "Neutron");
6800     if ( !neutronFile ){
6801     printf("WARNING: no neutron detector file! \n");
6802 mocchiut 1.3 pamgui->DIALOG(1," No neutron detector file! ");
6803     var.ND = 0;
6804 mocchiut 1.1 } else {
6805     otr->AddFriend("Neutron", neutronFile);
6806     printf("Show the Neutron detector, LEVEL0 data \n");
6807     };
6808 mocchiut 1.3 level.nd = 0;
6809     } else {
6810     level.nd = -10;
6811 mocchiut 1.1 };
6812     //
6813 mocchiut 1.3 if ( var.AC ) {
6814 mocchiut 1.1 if ( FORCELEV == 0 ){
6815     acFile = emigetFile(filename, "Anticounter");
6816     if ( !acFile ){
6817     printf("WARNING: no AC file! \n");
6818 mocchiut 1.3 pamgui->DIALOG(1," No anticounters file! ");
6819     var.AC = 0;
6820 mocchiut 1.1 } else {
6821     otr->AddFriend("Anticounter", acFile);
6822     printf("Show the Anticoincidence detector, LEVEL 0 data\n");
6823     ACLEV = 0;
6824     };
6825     } else {
6826     acFile = emigetFile(filename, "Physics.Level1", "Anticounter");
6827     if ( !acFile ){
6828     acFile = emigetFile(filename, "Anticounter");
6829     if ( !acFile ){
6830     printf("WARNING: no AC file! \n");
6831 mocchiut 1.3 pamgui->DIALOG(1," No anticounters file! ");
6832     var.AC = 0;
6833 mocchiut 1.1 } else {
6834     otr->AddFriend("Anticounter", acFile);
6835     printf("Show the Anticoincidence detector, LEVEL 0 data\n");
6836     ACLEV = 0;
6837     };
6838     } else {
6839     otr->AddFriend("AcLevel1", acFile);
6840     printf("Show the Anticoincidence detector, LEVEL 1 data\n");
6841     ACLEV = 1;
6842     };
6843     };
6844 mocchiut 1.3 level.ac = ACLEV;
6845     } else {
6846     level.ac = -10;
6847 mocchiut 1.1 };
6848     Int_t S4LEV = 0;
6849 mocchiut 1.3 if ( var.S4 ) {
6850 mocchiut 1.1 s4File = emigetFile(filename, "S4");
6851     if ( !s4File ){
6852     printf("WARNING: no S4 file! \n");
6853 mocchiut 1.3 pamgui->DIALOG(1," No S4 file! ");
6854     var.S4 = 0;
6855 mocchiut 1.1 } else {
6856     otr->AddFriend("S4", s4File);
6857     if ( FORCELEV != 0 ){
6858     printf("Show the S4 detector, try to generate LEVEL1 data \n");
6859     S4LEV = 1;
6860     } else {
6861     printf("Show the S4 detector, LEVEL0 data \n");
6862     S4LEV = 0;
6863     };
6864     };
6865 mocchiut 1.3 level.s4 = S4LEV;
6866     } else {
6867     level.s4 = -10;
6868 mocchiut 1.1 };
6869     //
6870     Int_t TOFLEV = 0;
6871 mocchiut 1.3 if ( var.TOF ) {
6872 mocchiut 1.1 if ( FORCELEV != 0 ){
6873     tofFileL1 = emigetFile(filename, "Physics.Level1","TofTrigger");
6874     if ( !tofFileL1 ){
6875     tofFile = emigetFile(filename, "Tof");
6876     if ( !tofFile ){
6877     printf("WARNING: no TOF file! \n");
6878 mocchiut 1.3 pamgui->DIALOG(1," No TOF file! ");
6879 mocchiut 1.1 printf("Show the Time of Flight detector, LEVEL0 (trigger board) data\n");
6880 mocchiut 1.3 // var.TOF = 0;
6881 mocchiut 1.1 TOFLEV = 0;
6882     } else {
6883     otr->AddFriend("Tof", tofFile);
6884     printf("Show the Time of Flight, try to generate LEVEL1 data \n");
6885     TOFLEV = 10;
6886     };
6887     } else {
6888     toftr = (TTree*)tofFileL1->Get("TofLevel1");
6889     printf("Show the Time of Flight, LEVEL1 data \n");
6890     TOFLEV = 1;
6891     tofnoev = toftr->GetEntries();
6892     };
6893     } else {
6894     printf("Show the Time of Flight detector, LEVEL0 data\n");
6895     TOFLEV = 0;
6896     };
6897 mocchiut 1.3 level.tof = TOFLEV;
6898     } else {
6899     level.tof = -10;
6900 mocchiut 1.1 };
6901     //
6902     printf("\n");
6903     //
6904     pamela::PscuHeader *ph = 0;
6905     pamela::EventHeader *eh = 0;
6906     pamela::trigger::TriggerEvent *trig = 0;
6907     Long64_t nevents = otr->GetEntries();
6908     //
6909     printf(" The file contains %i physics events \n",(int)nevents);
6910     //
6911     if (nevents<=0) {
6912     headerFile->Close();
6913     triggerFile->Close();
6914 mocchiut 1.3 if ( var.TRK ) trackerFile->Close();
6915     if ( var.CALO )caloFile->Close();
6916     if ( var.ND ) neutronFile->Close();
6917     if ( var.AC ) acFile->Close();
6918     if ( var.TOF ) tofFile->Close();
6919     if ( var.S4 ) s4File->Close();
6920 mocchiut 1.1 printf("The file is empty, exiting...\n");
6921 mocchiut 1.3 pamgui->DIALOG(0," The file contains no physics data! ");
6922     var.waitforever = true;
6923     goto refresh;
6924 mocchiut 1.1 }
6925     //
6926 mocchiut 1.3 if ( var.SHOWDEC ){
6927 mocchiut 1.1 var.nosig = 1;
6928     } else {
6929     var.nosig = 0;
6930     };
6931     //
6932     // READ the CALORIMETER ADC to MIP conversion table (if trying to generate level1 data)
6933     //
6934 mocchiut 1.3 if ( !var.refresh ){
6935     if ( !CALOLEV && var.CALO ){
6936 mocchiut 1.1 chfile = new TFile(calfile.str().c_str(),"READ","Calorimeter CALIBRATION data");
6937     if ( chfile->IsZombie() ){
6938 mocchiut 1.3 printf(" WARNING: no calorimeter calibration file! \n Using 26 as conversion factor for all strips. \n");
6939     okcalo = 0;
6940 mocchiut 1.1 } else {
6941 mocchiut 1.3 okcalo = 1;
6942     ctree = (TTree*)chfile->Get("CaloADC");
6943     ctree->SetBranchAddress("Event", &ccalo);
6944     //
6945     cnevents = ctree->GetEntries();
6946     ctree->GetEntry(cnevents-1);
6947 mocchiut 1.1 };
6948     //
6949     if ( okcalo ) {
6950 mocchiut 1.3 for (Int_t m = 0; m < 2 ; m++ ){
6951     for (Int_t k = 0; k < 22; k++ ){
6952     for (Int_t l = 0; l < 96; l++ ){
6953     if ( (ccalo->fp[1][m][k][l] > 20. && ccalo->fp[1][m][k][l] < 32.) || ccalo->mask[m][k][l] == 1. ) {
6954     if ( ccalo->mip[m][k][l] != 0. ){
6955     mip[m][k][l] = ccalo->mip[m][k][l];
6956     } else {
6957     mip[m][k][l] = 26. ;
6958     };
6959     } else {
6960     mip[m][k][l] = 26. ;
6961 mocchiut 1.1 };
6962 mocchiut 1.3 };
6963 mocchiut 1.1 };
6964 mocchiut 1.3 };
6965 mocchiut 1.1 } else {
6966 mocchiut 1.3 for (Int_t m = 0; m < 2 ; m++ ){
6967     for (Int_t k = 0; k < 22; k++ ){
6968 mocchiut 1.1 for (Int_t l = 0; l < 96; l++ ){
6969 mocchiut 1.3 mip[m][k][l] = 26. ;
6970 mocchiut 1.1 };
6971     };
6972 mocchiut 1.3 };
6973 mocchiut 1.1 };
6974     chfile->Close();
6975 mocchiut 1.3 };
6976 mocchiut 1.1 };
6977     //
6978     // Check that given input are inside the boundary conditions
6979     //
6980 mocchiut 1.3 if ( fromevent > toevent && toevent ){
6981 mocchiut 1.1 printf("It must be fromevent < toevent \n");
6982     return;
6983     };
6984     if ( fromevent > nevents+1 || fromevent < 0 ) {
6985     printf("You can choose fromevent between 0 (all) and %i \n",(int)nevents+1);
6986     return;
6987     };
6988     if ( toevent > nevents+1 || toevent < 0 ) {
6989     printf("You can choose toevent between 0 (all) and %i \n",(int)nevents+1);
6990     return;
6991     };
6992     Int_t minevent = 0;
6993     Int_t maxevent = nevents - 1;
6994     if ( fromevent == 0 ) {
6995     minevent = 0;
6996     maxevent = nevents - 1;
6997     } else {
6998     minevent = fromevent - 1;
6999     if ( toevent > 0 ){
7000     maxevent = toevent-1;
7001     } else {
7002     maxevent = fromevent-1;
7003     };
7004     };
7005     //
7006     //
7007     otr->SetBranchAddress("Header", &eh);
7008     otr->GetEntry(maxevent);
7009     ph = eh->GetPscuHeader();
7010     Int_t lastevno = (int)ph->GetCounter();
7011     otr->GetEntry(minevent);
7012     ph = eh->GetPscuHeader();
7013     Int_t firstevno = (int)ph->GetCounter();
7014 mocchiut 1.3 if ( !var.refresh ) i = minevent;
7015     var.refresh = false;
7016 mocchiut 1.1 /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
7017     // MAIN LOOP STARTS HERE: run over all the events
7018     /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
7019 mocchiut 1.3 // while ( i < maxevent+1 ){
7020     while ( 1 ){
7021     //
7022     // update progress bar
7023     //
7024     if ( popup ) pamgui->increment((float)(i+1)*100./(float)nevents);
7025 mocchiut 1.1 //
7026     // clear canvas and variables
7027     //
7028     var.beta[0] = 0.;
7029     var.beta[1] = 0.;
7030     var.beta[2] = 0.;
7031     var.beta[3] = 0.;
7032     var.beta[4] = 0.;
7033     var.s4sig = 0.;
7034     var.nstrip = 0;
7035     var.qtot = 0;
7036     var.nclx = 0;
7037     var.ncly = 0;
7038     var.trup = 0;
7039     var.bkup = 0;
7040     var.bkbo = 0;
7041     var.hcas = 0;
7042     var.hcat = 0;
7043     var.hcard = 0;
7044     //
7045     // call the filter to select events (if filter file is given)
7046     //
7047     if ( jumpto ){
7048     otr->SetBranchAddress("Header", &eh);
7049     otr->GetEntry(i);
7050     ph = eh->GetPscuHeader();
7051     Int_t cjumpto = (int)ph->GetCounter();
7052     if ( cjumpto == jumpto ) jumpto = 0;
7053 mocchiut 1.3 if ( jumpto && (i == maxevent || i == si) ) {
7054     if ( var.jumpen && i == maxevent ) {
7055     i = -1;
7056     var.jumpen = false;
7057     } else {
7058     i = si;
7059     printf(" WARNING: NO EVENT WITH EVENT NUMBER %i \n",jumpto);
7060     stringstream dialog;
7061     dialog.str("");
7062     dialog << " No event with event number ";
7063     dialog << jumpto;
7064     pamgui->DIALOG(1,dialog.str().c_str());
7065     jumpto = 0;
7066     };
7067 mocchiut 1.1 };
7068     };
7069     //
7070 mocchiut 1.3 isOK = 0;
7071     if ( !selection || ( i == minevent && !seldone) || ( i == minevent || i == maxevent )){
7072     if ( i == minevent && selection && seldone && doflag==2) pamgui->DIALOG(1," Stop searching, first event reached ");
7073     if ( i == maxevent && selection ) pamgui->DIALOG(1," Stop searching, last event reached ");
7074     isOK = 1;
7075 mocchiut 1.1 seldone = 1;
7076     } else {
7077 mocchiut 1.3 isOK = 0;
7078 mocchiut 1.1 #if defined (__CINT__)
7079 mocchiut 1.3 isOK = filter(i,otr,ttr,level);
7080 mocchiut 1.1 #endif
7081     #if !defined (__CINT__)
7082     stringstream cintcom;
7083     cintcom.str("");
7084     cintcom << "Int_t *i = (Int_t*)0x" << hex;
7085     cintcom << &i;
7086     gROOT->ProcessLine(cintcom.str().c_str());
7087     gROOT->ProcessLine("Int_t a = *i;");
7088     cintcom.str("");
7089     cintcom << "TTree *otr = (TTree*)0x" << hex;
7090     cintcom << otr;
7091     gROOT->ProcessLine(cintcom.str().c_str());
7092     cintcom.str("");
7093     cintcom << "TTree *ttr = (TTree*)0x" << hex;
7094     cintcom << ttr;
7095     gROOT->ProcessLine(cintcom.str().c_str());
7096     cintcom.str("");
7097     cintcom << "struct Levels &level = (struct Levels &)0x" << hex;
7098     cintcom << &level;
7099     gROOT->ProcessLine(cintcom.str().c_str());
7100 mocchiut 1.3 isOK = gApplication->ProcessLine("filter((Int_t)a,(TTree *)otr,(TTree *)ttr,(Levels &)level);");
7101 mocchiut 1.1 #endif
7102     seldone = 1;
7103     printf("Scanning data: %d%c done",100*(i-minevent)/(maxevent-minevent),37);
7104     fflush(stdout);
7105     };
7106     //
7107     // if the event is selected go on
7108     //
7109 mocchiut 1.3 if ( isOK && !jumpto ) {
7110     if ( var.doflag == 3 ) selection = 1;
7111 mocchiut 1.1 printf("\n");
7112 mocchiut 1.4 //
7113     figure->SetEditable(kTRUE);
7114     //
7115 mocchiut 1.1 figure->Clear();
7116     figure->SetFillColor(10);
7117     figure->cd();
7118     //
7119     // Get Orbital Time information and header event number
7120     //
7121     otr->SetBranchAddress("Header", &eh);
7122     if ( !var.nosig) otr->GetEntry(i);
7123     ph = eh->GetPscuHeader();
7124     headcold = headc;
7125     headc = ph->GetCounter();
7126     var.headc = (int)ph->GetCounter();
7127     OBT = ph->GetOrbitalTime();
7128     DOBT = OBT - OOBT;
7129     OOBT = OBT;
7130     if ( i == minevent || DOBT < 0 || (headc-headcold-1)!=0 ) DOBT = 0;
7131     var.etime = OBT;
7132     //
7133     // who gave the trigger?
7134     //
7135     otr->SetBranchAddress("Trigger.Event", &trig);
7136     if ( !var.nosig) otr->GetEntry(i);
7137     Int_t calotrig = 0;
7138     if ( trig->patterntrig[0] ) calotrig = 1;
7139     Int_t toftrig = 0;
7140     if ( trig->patterntrig[2] || trig->patterntrig[3] || trig->patterntrig[4] || trig->patterntrig[5] ) toftrig = 1;
7141     Int_t s4pulser = 0;
7142     if ( trig->patterntrig[1] & (1<<0) ) s4pulser = 1;
7143     //
7144     // TOF and calorimeter when giving a trigger will always set this flag since the time window of the signal is greater than 100 ns.
7145     // S4 sometimes could not set the flag even if the trigger is given. This is a workaround to fix this "bug":
7146     //
7147     if ( !calotrig && !toftrig ) s4pulser = 1;
7148     //
7149     Int_t trigconf = trig->trigconf;
7150     stringstream trc;
7151     trc.str("");
7152     if ( trigconf & (1<<0) ) trc << "TOF1";
7153     if ( trigconf & (1<<1) ) trc << " TOF2";
7154     if ( trigconf & (1<<2) ) trc << " TOF3";
7155     if ( trigconf & (1<<3) ) trc << " TOF4";
7156     if ( trigconf & (1<<4) ) trc << " TOF5";
7157     if ( trigconf & (1<<5) ) trc << " TOF6";
7158     if ( trigconf & (1<<6) ) trc << " TOF7";
7159     if ( trigconf & (1<<7) ) trc << " S4";
7160     if ( trigconf & (1<<8) ) trc << " CALO";
7161     if ( trigconf & (1<<9) ) trc << " CALIB_ON";
7162     TString trcs(trc.str().c_str());
7163     //
7164     // show TOF
7165     //
7166 mocchiut 1.3 if ( var.TOF ){
7167 mocchiut 1.1 figure->cd();
7168     if ( TOFLEV == 0 ){
7169     ShowTOF(i,otr,var);
7170     level.tof = 0;
7171     };
7172     if ( TOFLEV == 10 ){
7173     ShowTOFGENL1(i,otr,var);
7174     level.tof = 0;
7175     };
7176     if ( TOFLEV == 1 ){
7177 mocchiut 1.3 ShowTOFL1(i,toftr,var,pamgui);
7178 mocchiut 1.1 level.tof = 1;
7179     };
7180     };
7181     //
7182     // show anticounters
7183     //
7184 mocchiut 1.3 if ( var.AC ){
7185 mocchiut 1.1 figure->cd();
7186     if ( ACLEV == 0 ){
7187     ShowAC(i,otr,var,0);
7188     level.ac = 0;
7189     };
7190     if ( ACLEV == 1 ){
7191     ShowAC(i,otr,var,1);
7192     level.ac = 1;
7193     };
7194     };
7195     //
7196     // show S4
7197     //
7198 mocchiut 1.3 if ( var.S4 ){
7199 mocchiut 1.1 figure->cd();
7200     if ( S4LEV == 0 ){
7201     ShowS4L0(i,otr,var);
7202     level.s4 = 0;
7203     };
7204     if ( S4LEV == 1 ){
7205     ShowS4L1(i,otr,var);
7206     level.s4 = 1;
7207     };
7208     };
7209     //
7210     //
7211     // show neutron detector
7212     //
7213 mocchiut 1.3 if ( var.ND ){
7214 mocchiut 1.1 figure->cd();
7215     ShowND(i,otr,var);
7216     level.nd = 0;
7217     };
7218     //
7219     // show tracker
7220     //
7221 mocchiut 1.3 if ( var.TRK ){
7222 mocchiut 1.1 //
7223     // if we have level2 data show the track
7224     //
7225     if ( STRACK == 1 ) {
7226     if ( i == minevent && !trackdone1 ) {
7227     //
7228     // Load tracker libraries to read the magnetic field and compute the paritcle trajectory
7229     //
7230     trackdone1 = 1;
7231     #if defined (__CINT__)
7232     printf("\n\n TRACKER: loading shared libraries...\n");
7233     const char *pam_lib=gSystem->Getenv("PAM_LIB");
7234     libload.str("");
7235     libload << pam_lib << "/libtrack";
7236     gSystem->Load(libload.str().c_str());
7237     libload.str("");
7238     libload << pam_lib << "/libtrack_C";
7239     gSystem->Load(libload.str().c_str());
7240     libload.str("");
7241     libload << pam_lib << "/libreadb2maps";
7242     gSystem->Load(libload.str().c_str());
7243     libload.str("");
7244     libload << pam_lib << "/libreadb2maps_C";
7245     gSystem->Load(libload.str().c_str());
7246     libload.str("");
7247     printf(" ...done!\n\n");
7248     #endif
7249     //
7250     // Read the magnetic field map (two files), here it goes the path AND name of one of them.
7251     //
7252     printf("\n\n TRACKER: loading the magnetic field maps...\n\n\n");
7253     const char *pam_calib = pathtocalibration();
7254     stringstream bdir;
7255     bdir.str("");
7256     bdir << pam_calib << ".";
7257     creadB(bdir.str().c_str());
7258     //
7259     printf(" ...done! \n");
7260     };
7261     level.track2 = 1;
7262     figure->cd();
7263 mocchiut 1.3 ShowTRACK(i,ttr,var,pamgui);
7264     } else {
7265     level.track2 = 0;
7266 mocchiut 1.1 };
7267     //
7268     // show level1 data
7269     //
7270     figure->cd();
7271     if ( TRKLEV == 1 ) {
7272     if ( i == minevent && !trackdone2 ) {
7273     trackdone2 = 1;
7274     #if defined (__CINT__)
7275     printf("\n\n TRACKER: loading level1 libraries...\n");
7276     const char *pam_lib=gSystem->Getenv("PAM_LIB");
7277     printf("\n Opening libptlev1.so \n");
7278     libload.str("");
7279     libload << pam_lib << "/libptlevel1";
7280     gSystem->Load(libload.str().c_str());
7281     libload.str("");
7282     printf("\n Opening libptlev1_C.so \n\n");
7283     libload.str("");
7284     libload << pam_lib << "/libptlevel1_C";
7285     gSystem->Load(libload.str().c_str());
7286     libload.str("");
7287     printf(" ...done! \n\n");
7288     #endif
7289     //
7290     pamela::CalibTrk1Event *te1 = 0;
7291     ctrk->SetBranchAddress("CalibTrk1.Event", &te1);
7292     if ( ctrk->GetEntries() > 0 ){
7293     ctrk->GetEntry(0);
7294     for ( Int_t ii = 0 ; ii<6 ; ii++){
7295     for ( Int_t ij = 0 ; ij<3072 ; ij++){
7296     var.DSPsig_par[ii][ij] = te1->DSPsig_par[ii][ij];
7297     };
7298     };
7299     pamela::CalibTrk2Event *te2 = 0;
7300     ctrk->SetBranchAddress("CalibTrk2.Event", &te2);
7301     ctrk->GetEntry(0);
7302     for ( Int_t ii = 6 ; ii<12 ; ii++){
7303     for ( Int_t ij = 0 ; ij<3072 ; ij++){
7304     var.DSPsig_par[ii][ij] = te2->DSPsig_par[ii-6][ij];
7305     };
7306     };
7307     } else {
7308     for ( Int_t ii = 0 ; ii<12 ; ii++){
7309     for ( Int_t ij = 0 ; ij<3072 ; ij++){
7310     if ( ii > 5 ) var.DSPsig_par[ii][ij] = 8.;
7311     if ( ii < 6 ) var.DSPsig_par[ii][ij] = 3.;
7312     };
7313     };
7314     };
7315     };
7316 mocchiut 1.3 ShowTRKL1(i,ttr1,var,pamgui);
7317 mocchiut 1.1 };
7318     //
7319     // if everything fails, show at least level0 data
7320     //
7321     if ( TRKLEV == 0 ) ShowTRKL0(i,otr,var);
7322     figure->Modified();
7323     figure->Update();
7324     level.track = TRKLEV;
7325     };
7326     //
7327     // show calorimeter
7328     //
7329 mocchiut 1.3 if ( var.CALO ){
7330 mocchiut 1.1 figure->cd();
7331     //
7332     // if we have LEVEL1 data
7333     //
7334     if ( CALOLEV == 1 ) ShowCaloL1(i,otr,var);
7335     //
7336     // if we have only LEVEL0 data try to generate event by event LEVEL1 data
7337     //
7338     if ( CALOLEV == 0 ) {
7339     if ( !thefirst ) {
7340     ShowCaloL0(calcalibfile,i,calib,b,mip,otr,var);
7341     } else {
7342     printf("\n\n CALORIMETER: looking for calibration data...\n");
7343     thefirst = 0;
7344     Calo1stcalib(calcalibfile,calib,b);
7345     //
7346     // check calibration
7347     //
7348     Int_t calibex = 0;
7349     Int_t stop = 0;
7350     for (Int_t s=0; s<4;s++){
7351     if ( b[s] > 4 ) b[s] = 0;
7352     stop = 0;
7353     for (Int_t d = 0; d<48; d++){
7354     if ( calib.ttime[s][d] != 0 ) calibex++;
7355     if ( calib.time[s][0] != 0 ){
7356     if ( calib.time[s][d+1] == 0 ) {
7357     if ( !stop ){
7358     stop = 1;
7359     };
7360     };
7361     };
7362     };
7363     };
7364     printf(" ...done! \n\n\n");
7365     if ( calibex < 1 ) {
7366     printf(" No calorimeter calibrations! Switching to raw mode visualitation \n Only COMPRESS and FULL mode acquisition are supported \n\n");
7367     CALOLEV = -1;
7368     } else {
7369     ShowCaloL0(calcalibfile,i,calib,b,mip,otr,var);
7370     };
7371     };
7372     };
7373     //
7374     // if everything fail, show level0 data
7375     //
7376     if ( CALOLEV == -1 ) {
7377     ShowCaloRAW(i,otr,var);
7378     };
7379     if ( var.nosig ){
7380     var.qtot = 0;
7381     var.nstrip = 0;
7382     };
7383     level.calo = CALOLEV;
7384     };
7385     figure->cd();
7386     //
7387     // SHOW INFOS
7388     //
7389 mocchiut 1.3 if ( var.INFOS ){
7390 mocchiut 1.1 figure->cd();
7391     text->SetTextAngle(0);
7392     text->SetTextFont(32);
7393     text->SetTextColor(1);
7394     text->SetTextSize(0.025); // 0.02
7395     text->SetTextAlign(12);
7396     Float_t txthi = 0.47;
7397     testo.str("");
7398     testo << "File: " << file;
7399     testo << " - Event number: " << (int)headc;
7400     text->DrawLatex(0.33,txthi,testo.str().c_str());
7401     txthi -= 0.03;
7402     testo.str("");
7403     testo << "Progressive number: " << (i+1);
7404     if ( s4pulser ){
7405     testo << " - S4 trigger - ";
7406     };
7407     if ( calotrig ){
7408     testo << " - CALO trigger - ";
7409     };
7410     text->DrawLatex(0.33,txthi,testo.str().c_str());
7411     txthi -= 0.03;
7412     testo2.str("");
7413     testo2 << "On Board Time: " << (int)OBT;
7414     if ( DOBT > 0 ) {
7415     testo2 << " (delta: " << (int)DOBT;
7416     testo2 << ")";
7417     };
7418     testo2 << " [ms]";
7419     text->DrawLatex(0.33,txthi,testo2.str().c_str());
7420     txthi -= 0.03;
7421     text->SetTextSize(0.020); // 0.015
7422     const char *trc2 = trcs;
7423     testo3.str("");
7424     testo3 << "TRIGGER: " << trc2;
7425     text->DrawLatex(0.33,txthi,testo3.str().c_str());
7426     txthi -= 0.03;
7427     testo3.str("");
7428     testo3 << "AC: CARD hit = " << var.hcard;
7429     testo3 << " CAT hit = " << var.hcat;
7430     testo3 << " CAS hit = " << var.hcas;
7431     text->DrawLatex(0.33,txthi,testo3.str().c_str());
7432     txthi -= 0.03;
7433     testo3.str("");
7434     if ( STRACK ){
7435     testo3 << "TRK: RIG = " << setprecision(3) << var.rig;
7436     testo3 << " [GV] CHI2 = " << setprecision(3) << var.chi2;
7437     } else {
7438     testo3 << "TRK: NCLX = "<< var.nclx;
7439     testo3 << " NCLY = "<<var.ncly;
7440     };
7441     text->DrawLatex(0.33,txthi,testo3.str().c_str());
7442     txthi -= 0.03;
7443     testo3.str("");
7444     testo3 << "CALO: NSTRIP = " << var.nstrip;
7445     testo3 << " QTOT = "<<var.qtot << " [MIP]";
7446     text->DrawLatex(0.33,txthi,testo3.str().c_str());
7447     txthi -= 0.03;
7448     testo3.str("");
7449 mocchiut 1.3 testo3 << "S4: ";// << setprecision(2);
7450 mocchiut 1.1 testo3 << var.s4sig << " [MIP] TOF: #beta(1,...,5) = (";
7451     testo3 << setprecision(3) << var.beta[0];
7452     testo3 << ",";
7453     testo3 << setprecision(3) << var.beta[1];
7454     testo3 << ",";
7455     testo3 << setprecision(3) << var.beta[2];
7456     testo3 << ",";
7457     testo3 << setprecision(3) << var.beta[3];
7458     testo3 << ",";
7459     testo3 << setprecision(3) << var.beta[4];
7460     testo3 << ")";
7461     text->DrawLatex(0.33,txthi,testo3.str().c_str());
7462     txthi -= 0.03;
7463     testo3.str("");
7464 mocchiut 1.3 testo3 << "ND: Trig: " << var.trup;
7465     testo3 << " - Bckgr: upper = " << var.bkup;
7466 mocchiut 1.1 testo3 << " lower = " << var.bkbo;
7467     text->DrawLatex(0.33,txthi,testo3.str().c_str());
7468     txthi -= 0.03;
7469     text->SetTextSize(0.01);
7470     text->DrawLatex(var.xxvc-0.025*var.sfx,var.yxvc-0.519*var.sfy,"CPU SIDE");
7471     text->SetTextAngle(90);
7472     text->DrawLatex(var.xyvc+0.17*var.sfx,var.yyvc+0.075*var.sfy,"CPU SIDE");
7473     text->DrawLatex(var.xyvc-0.17*var.sfx,var.yyvc+0.075*var.sfy,"VME SIDE");
7474 mocchiut 1.3 if ( var.AC ){
7475 mocchiut 1.1 text->SetTextAngle(90);
7476     text->DrawLatex(var.xcat-0.235*var.sfx,var.ycat-0.025*var.sfy,"VME SIDE");
7477     text->DrawLatex(var.xcat+0.235*var.sfx,var.ycat-0.025*var.sfy,"CPU SIDE");
7478     //
7479     text->SetTextAngle(0);
7480     text->SetTextSize(0.015);
7481     TEllipse *elli = new TEllipse(var.xcat+0.219*var.sfx,var.ycat-0.249*var.sfy,0.003,0.003);
7482     elli->Draw();
7483     text->DrawLatex(var.xcat+0.229*var.sfx,var.ycat-0.261*var.sfy,"z");
7484     TArrow *arr;
7485     arr = new TArrow(var.xcat+0.22*var.sfx,var.ycat-0.25*var.sfy,var.xcat+0.22*var.sfx,var.ycat-0.21*var.sfy);
7486     arr->SetArrowSize(0.005);
7487     arr->Draw();
7488     text->DrawLatex(var.xcat+0.229*var.sfx,var.ycat-0.21*var.sfy,"x");
7489     arr = new TArrow(var.xcat+0.22*var.sfx,var.ycat-0.25*var.sfy,var.xcat+0.18*var.sfx,var.ycat-0.25*var.sfy);
7490     arr->SetArrowSize(0.005);
7491     arr->Draw();
7492     text->DrawLatex(var.xcat+0.18*var.sfx,var.ycat-0.261*var.sfy,"y");
7493     text->SetTextSize(0.01);
7494     };
7495     //
7496     // coordinates systems and x/y view labels
7497     //
7498     figure->cd();
7499     text->SetTextAngle(0);
7500     text->SetTextFont(32);
7501     text->SetTextColor(1);
7502     text->SetTextAlign(12);
7503     text->SetTextSize(0.01);
7504     text->DrawLatex(var.xxvc-0.025*var.sfx,var.yxvc+0.67*var.sfy,"X VIEW");
7505     text->DrawLatex(var.xyvc-0.025*var.sfx,var.yyvc+0.67*var.sfy,"Y VIEW");
7506     //
7507     text->SetTextSize(0.015);
7508     text->SetTextFont(2);
7509 mocchiut 1.3 DrawX(var.xxvc-0.25*var.sfx,var.yxvc-0.328*var.sfy,0.005,var); //508
7510 mocchiut 1.1 text->SetTextFont(32);
7511 mocchiut 1.3 text->DrawLatex(var.xxvc-0.266*var.sfx,var.yxvc-0.328*var.sfy,"y");
7512 mocchiut 1.1 TArrow *arr;
7513 mocchiut 1.3 arr = new TArrow(var.xxvc-0.25*var.sfx,var.yxvc-0.328*var.sfy,var.xxvc-0.21*var.sfx,var.yxvc-0.328*var.sfy);
7514 mocchiut 1.1 arr->SetArrowSize(0.005);
7515     arr->Draw();
7516 mocchiut 1.3 text->DrawLatex(var.xxvc-0.21*var.sfx,var.yxvc-0.335*var.sfy,"x");
7517     arr = new TArrow(var.xxvc-0.25*var.sfx,var.yxvc-0.328*var.sfy,var.xxvc-0.25*var.sfx,var.yxvc-0.288*var.sfy);
7518 mocchiut 1.1 arr->SetArrowSize(0.005);
7519     arr->Draw();
7520 mocchiut 1.3 text->DrawLatex(var.xxvc-0.266*var.sfx,var.yxvc-0.288*var.sfy,"z");
7521 mocchiut 1.1 //
7522     text->SetTextSize(0.015);
7523     text->SetTextFont(2);
7524 mocchiut 1.3 DrawX(var.xyvc+0.24*var.sfx,var.yyvc-0.328*var.sfy,0.005,var);
7525 mocchiut 1.1 text->SetTextFont(32);
7526 mocchiut 1.3 text->DrawLatex(var.xyvc+0.25*var.sfx,var.yyvc-0.328*var.sfy,"x");
7527     arr = new TArrow(var.xyvc+0.24*var.sfx,var.yyvc-0.328*var.sfy,var.xyvc+0.2*var.sfx,var.yyvc-0.328*var.sfy);
7528 mocchiut 1.1 arr->SetArrowSize(0.005);
7529     arr->Draw();
7530 mocchiut 1.3 text->DrawLatex(var.xyvc+0.19*var.sfx,var.yyvc-0.335*var.sfy,"y");
7531     arr = new TArrow(var.xyvc+0.24*var.sfx,var.yyvc-0.328*var.sfy,var.xyvc+0.24*var.sfx,var.yyvc-0.288*var.sfy);
7532 mocchiut 1.1 arr->SetArrowSize(0.005);
7533     arr->Draw();
7534 mocchiut 1.3 text->DrawLatex(var.xyvc+0.25*var.sfx,var.yyvc-0.288*var.sfy,"z");
7535 mocchiut 1.1 text->SetTextSize(0.01);
7536 mocchiut 1.3 //
7537     /* text->SetTextSize(0.015); */
7538     /* text->SetTextFont(2); */
7539     /* DrawX(var.xxvc-0.23*var.sfx,var.yxvc-0.508*var.sfy,0.005,var); */
7540     /* text->SetTextFont(32); */
7541     /* text->DrawLatex(var.xxvc-0.246*var.sfx,var.yxvc-0.508*var.sfy,"y"); */
7542     /* TArrow *arr; */
7543     /* arr = new TArrow(var.xxvc-0.23*var.sfx,var.yxvc-0.508*var.sfy,var.xxvc-0.19*var.sfx,var.yxvc-0.508*var.sfy); */
7544     /* arr->SetArrowSize(0.005); */
7545     /* arr->Draw(); */
7546     /* text->DrawLatex(var.xxvc-0.19*var.sfx,var.yxvc-0.515*var.sfy,"x"); */
7547     /* arr = new TArrow(var.xxvc-0.23*var.sfx,var.yxvc-0.508*var.sfy,var.xxvc-0.23*var.sfx,var.yxvc-0.468*var.sfy); */
7548     /* arr->SetArrowSize(0.005); */
7549     /* arr->Draw(); */
7550     /* text->DrawLatex(var.xxvc-0.246*var.sfx,var.yxvc-0.468*var.sfy,"z"); */
7551     /* // */
7552     /* text->SetTextSize(0.015); */
7553     /* text->SetTextFont(2); */
7554     /* DrawX(var.xyvc+0.22*var.sfx,var.yyvc-0.508*var.sfy,0.005,var); */
7555     /* text->SetTextFont(32); */
7556     /* text->DrawLatex(var.xyvc+0.23*var.sfx,var.yyvc-0.508*var.sfy,"x"); */
7557     /* arr = new TArrow(var.xyvc+0.22*var.sfx,var.yyvc-0.508*var.sfy,var.xyvc+0.18*var.sfx,var.yyvc-0.508*var.sfy); */
7558     /* arr->SetArrowSize(0.005); */
7559     /* arr->Draw(); */
7560     /* text->DrawLatex(var.xyvc+0.17*var.sfx,var.yyvc-0.511*var.sfy,"y"); */
7561     /* arr = new TArrow(var.xyvc+0.22*var.sfx,var.yyvc-0.508*var.sfy,var.xyvc+0.22*var.sfx,var.yyvc-0.468*var.sfy); */
7562     /* arr->SetArrowSize(0.005); */
7563     /* arr->Draw(); */
7564     /* text->DrawLatex(var.xyvc+0.23*var.sfx,var.yyvc-0.468*var.sfy,"z"); */
7565     /* text->SetTextSize(0.01); */
7566 mocchiut 1.1 };
7567     //
7568     // SHOW PALETTE
7569     //
7570 mocchiut 1.3 if ( var.PALETTE ) ShowPalette(var.bw);
7571 mocchiut 1.1 //
7572     // SHOW VERBOSE INFOS
7573     //
7574 mocchiut 1.3 if ( var.VINFOS ){
7575 mocchiut 1.1 figure->cd();
7576     text->SetTextAngle(0);
7577     text->SetTextFont(32);
7578     text->SetTextColor(1);
7579     text->SetTextSize(0.01);
7580     text->SetTextAlign(12);
7581 mocchiut 1.3 if ( var.AC ){
7582 mocchiut 1.1 //
7583     // Plane view
7584     //
7585     text->SetTextAngle(90);
7586     text->DrawLatex(var.xcat+0.1*var.sfx,var.ycat-0.015*var.sfy,"CARD4");
7587     text->SetTextAngle(-90);
7588     text->DrawLatex(var.xcat-0.1*var.sfx,var.ycat+0.015*var.sfy,"CARD1");
7589     text->SetTextAngle(0);
7590     text->DrawLatex(var.xcat-0.015*var.sfx,var.ycat-0.116*var.sfy,"CARD2");
7591     text->DrawLatex(var.xcat-0.015*var.sfx,var.ycat+0.116*var.sfy,"CARD3");
7592     text->SetTextAngle(90);
7593     text->DrawLatex(var.xcat+0.13*var.sfx,var.ycat-0.015*var.sfy,"CAS3");
7594     text->SetTextAngle(-90);
7595     text->DrawLatex(var.xcat-0.13*var.sfx,var.ycat+0.015*var.sfy,"CAS4");
7596     text->SetTextAngle(0);
7597     text->DrawLatex(var.xcat-0.015*var.sfx,var.ycat-0.140*var.sfy,"CAS2");
7598     text->DrawLatex(var.xcat-0.015*var.sfx,var.ycat+0.140*var.sfy,"CAS1");
7599     text->DrawLatex(var.xcat+0.17*var.sfx,var.ycat,"CAT1");
7600     text->DrawLatex(var.xcat-0.2*var.sfx,var.ycat,"CAT2");
7601     text->DrawLatex(var.xcat-0.015*var.sfx,var.ycat-0.198*var.sfy,"CAT3");
7602     text->DrawLatex(var.xcat-0.015*var.sfx,var.ycat+0.198*var.sfy,"CAT4");
7603     //
7604     // X and Y views
7605     //
7606     text->DrawLatex(var.xxvc-0.192*var.sfx,var.yxvc-0.08*var.sfy,"CAS2");
7607     text->DrawLatex(var.xxvc+0.17*var.sfx,var.yxvc-0.08*var.sfy,"CAS1");
7608     text->DrawLatex(var.xyvc-0.192*var.sfx,var.yyvc-0.08*var.sfy,"CAS4");
7609     text->DrawLatex(var.xyvc+0.17*var.sfx,var.yyvc-0.08*var.sfy,"CAS3");
7610     text->DrawLatex(var.xxvc-0.192*var.sfx,var.yxvc+0.48*var.sfy,"CARD2");
7611     text->DrawLatex(var.xxvc+0.155*var.sfx,var.yxvc+0.48*var.sfy,"CARD3");
7612     text->DrawLatex(var.xyvc-0.170*var.sfx,var.yyvc+0.48*var.sfy,"CARD1");
7613     text->DrawLatex(var.xyvc+0.13*var.sfx,var.yyvc+0.48*var.sfy,"CARD4");
7614     text->DrawLatex(var.xxvc-0.192*var.sfx,var.yxvc+0.39*var.sfy,"CAT3");
7615     text->DrawLatex(var.xxvc+0.155*var.sfx,var.yxvc+0.39*var.sfy,"CAT4");
7616     text->DrawLatex(var.xyvc-0.170*var.sfx,var.yyvc+0.39*var.sfy,"CAT2");
7617     text->DrawLatex(var.xyvc+0.13*var.sfx,var.yyvc+0.39*var.sfy,"CAT1");
7618     };
7619 mocchiut 1.3 if ( var.CALO ){
7620 mocchiut 1.1 text->SetTextSize(0.020);
7621     text->SetTextAngle(90);
7622     text->DrawLatex(var.xxvc-0.22*var.sfx,var.yxvc-0.290*var.sfy,"Calorimeter");
7623     text->DrawLatex(var.xyvc+0.22*var.sfx,var.yyvc-0.290*var.sfy,"Calorimeter");
7624     text->SetTextSize(0.01);
7625     text->SetTextAngle(0);
7626     };
7627 mocchiut 1.3 if ( var.TRK ){
7628 mocchiut 1.1 text->SetTextSize(0.020);
7629     text->SetTextAngle(90);
7630     text->DrawLatex(var.xxvc-0.22*var.sfx,var.yxvc+0.080*var.sfy,"Tracker");
7631     text->DrawLatex(var.xyvc+0.22*var.sfx,var.yyvc+0.080*var.sfy,"Tracker");
7632     text->SetTextSize(0.01);
7633     text->SetTextAngle(0);
7634     };
7635 mocchiut 1.3 if ( var.ND ){
7636 mocchiut 1.1 text->SetTextSize(0.020);
7637 mocchiut 1.3 // text->SetTextAngle(90);
7638     text->DrawLatex(var.xxvc-0.25*var.sfx,var.yxvc-0.530*var.sfy,"ND");
7639     text->DrawLatex(var.xyvc+0.22*var.sfx,var.yyvc-0.530*var.sfy,"ND");
7640 mocchiut 1.1 text->SetTextSize(0.01);
7641     text->SetTextAngle(0);
7642     };
7643 mocchiut 1.3 if ( var.TOF ){
7644 mocchiut 1.1 text->SetTextSize(0.020);
7645     text->DrawLatex(var.xxvc-0.24*var.sfx,var.yxvc-0.130*var.sfy,"S3");
7646     text->DrawLatex(var.xxvc-0.24*var.sfx,var.yxvc+0.350*var.sfy,"S2");
7647     text->DrawLatex(var.xxvc-0.24*var.sfx,var.yxvc+0.653*var.sfy,"S1");
7648     text->DrawLatex(var.xyvc+0.21*var.sfx,var.yyvc-0.130*var.sfy,"S3");
7649     text->DrawLatex(var.xyvc+0.21*var.sfx,var.yyvc+0.350*var.sfy,"S2");
7650     text->DrawLatex(var.xyvc+0.21*var.sfx,var.yyvc+0.653*var.sfy,"S1");
7651     text->SetTextSize(0.01);
7652     };
7653 mocchiut 1.3 if ( var.S4 ){
7654 mocchiut 1.1 text->SetTextSize(0.020);
7655 mocchiut 1.3 text->DrawLatex(var.xxvc-0.28*var.sfx,var.yxvc-0.350*var.sfy,"S4");
7656     text->DrawLatex(var.xyvc+0.25*var.sfx,var.yyvc-0.350*var.sfy,"S4");
7657 mocchiut 1.1 text->SetTextSize(0.01);
7658     };
7659 mocchiut 1.3 if ( !var.INFOS ){
7660 mocchiut 1.1 text->SetTextSize(0.01);
7661     text->DrawLatex(var.xxvc-0.025*var.sfx,var.yxvc-0.520*var.sfy,"CPU SIDE");
7662     text->SetTextAngle(90);
7663     text->DrawLatex(var.xyvc+0.17*var.sfx,var.yyvc+0.075*var.sfy,"CPU SIDE");
7664     text->DrawLatex(var.xyvc-0.17*var.sfx,var.yyvc+0.075*var.sfy,"VME SIDE");
7665 mocchiut 1.3 if ( var.AC ){
7666 mocchiut 1.1 text->SetTextAngle(90);
7667     text->DrawLatex(var.xcat-0.235*var.sfx,var.ycat-0.025*var.sfy,"VME SIDE");
7668     text->DrawLatex(var.xcat+0.235*var.sfx,var.ycat-0.025*var.sfy,"CPU SIDE");
7669     //
7670     text->SetTextAngle(0);
7671     text->SetTextSize(0.015);
7672     TEllipse *elli = new TEllipse(var.xcat+0.219*var.sfx,var.ycat-0.249*var.sfy,0.003,0.003);
7673     elli->Draw();
7674     text->DrawLatex(var.xcat+0.229*var.sfx,var.ycat-0.261*var.sfy,"z");
7675     TArrow *arr;
7676     arr = new TArrow(var.xcat+0.22*var.sfx,var.ycat-0.25*var.sfy,var.xcat+0.22*var.sfx,var.ycat-0.21*var.sfy);
7677     arr->SetArrowSize(0.005);
7678     arr->Draw();
7679     text->DrawLatex(var.xcat+0.229*var.sfx,var.ycat-0.21*var.sfy,"x");
7680     arr = new TArrow(var.xcat+0.22*var.sfx,var.ycat-0.25*var.sfy,var.xcat+0.18*var.sfx,var.ycat-0.25*var.sfy);
7681     arr->SetArrowSize(0.005);
7682     arr->Draw();
7683     text->DrawLatex(var.xcat+0.18*var.sfx,var.ycat-0.261*var.sfy,"y");
7684     text->SetTextSize(0.01);
7685     };
7686     //
7687     // coordinates systems and x/y view labels
7688     //
7689     figure->cd();
7690     text->SetTextAngle(0);
7691     text->SetTextFont(32);
7692     text->SetTextColor(1);
7693     text->SetTextAlign(12);
7694     text->SetTextSize(0.01);
7695     text->DrawLatex(var.xxvc-0.025*var.sfx,var.yxvc+0.67*var.sfy,"X VIEW");
7696     text->DrawLatex(var.xyvc-0.025*var.sfx,var.yyvc+0.67*var.sfy,"Y VIEW");
7697     //
7698     text->SetTextSize(0.015);
7699     text->SetTextFont(2);
7700 mocchiut 1.3 DrawX(var.xxvc-0.25*var.sfx,var.yxvc-0.328*var.sfy,0.005,var); //508
7701 mocchiut 1.1 text->SetTextFont(32);
7702 mocchiut 1.3 text->DrawLatex(var.xxvc-0.266*var.sfx,var.yxvc-0.328*var.sfy,"y");
7703 mocchiut 1.1 TArrow *arr;
7704 mocchiut 1.3 arr = new TArrow(var.xxvc-0.25*var.sfx,var.yxvc-0.328*var.sfy,var.xxvc-0.21*var.sfx,var.yxvc-0.328*var.sfy);
7705 mocchiut 1.1 arr->SetArrowSize(0.005);
7706     arr->Draw();
7707 mocchiut 1.3 text->DrawLatex(var.xxvc-0.21*var.sfx,var.yxvc-0.335*var.sfy,"x");
7708     arr = new TArrow(var.xxvc-0.25*var.sfx,var.yxvc-0.328*var.sfy,var.xxvc-0.25*var.sfx,var.yxvc-0.288*var.sfy);
7709 mocchiut 1.1 arr->SetArrowSize(0.005);
7710     arr->Draw();
7711 mocchiut 1.3 text->DrawLatex(var.xxvc-0.266*var.sfx,var.yxvc-0.288*var.sfy,"z");
7712 mocchiut 1.1 //
7713     text->SetTextSize(0.015);
7714     text->SetTextFont(2);
7715 mocchiut 1.3 DrawX(var.xyvc+0.24*var.sfx,var.yyvc-0.328*var.sfy,0.005,var);
7716 mocchiut 1.1 text->SetTextFont(32);
7717 mocchiut 1.3 text->DrawLatex(var.xyvc+0.25*var.sfx,var.yyvc-0.328*var.sfy,"x");
7718     arr = new TArrow(var.xyvc+0.24*var.sfx,var.yyvc-0.328*var.sfy,var.xyvc+0.2*var.sfx,var.yyvc-0.328*var.sfy);
7719 mocchiut 1.1 arr->SetArrowSize(0.005);
7720     arr->Draw();
7721 mocchiut 1.3 text->DrawLatex(var.xyvc+0.19*var.sfx,var.yyvc-0.335*var.sfy,"y");
7722     arr = new TArrow(var.xyvc+0.24*var.sfx,var.yyvc-0.328*var.sfy,var.xyvc+0.24*var.sfx,var.yyvc-0.288*var.sfy);
7723 mocchiut 1.1 arr->SetArrowSize(0.005);
7724     arr->Draw();
7725 mocchiut 1.3 text->DrawLatex(var.xyvc+0.25*var.sfx,var.yyvc-0.288*var.sfy,"z");
7726 mocchiut 1.1 text->SetTextSize(0.01);
7727     };
7728     };
7729     //
7730     // update figure
7731     //
7732     figure->Modified();
7733     figure->Update();
7734     figure->cd();
7735 mocchiut 1.4 figure->SetEditable(kFALSE);
7736 mocchiut 1.1 //
7737     // print infos on terminal
7738     //
7739     printf(" File: %s \n",name);
7740     if ( !s4pulser && !calotrig ){
7741     printf(" Event number: %i - Progressive number: %i \n",(int)headc,i+1);
7742     };
7743     if ( s4pulser ){
7744     printf(" Event number: %i - Progressive number: %i - S4 trigger -\n",(int)headc,i+1);
7745     };
7746     if ( calotrig ){
7747     printf(" Event number: %i - Progressive number: %i - CALO trigger -\n",(int)headc,i+1);
7748     };
7749     printf(" On Board Time: %i (delta %i) [ms]\n",OBT,DOBT);
7750     const char *trc2 = trcs;
7751     printf(" TRIGGER: %s \n",trc2);
7752     printf(" AC: CARD hit = %i CAT hit = %i CAS hit = %i \n",var.hcard,var.hcat,var.hcas);
7753     if ( STRACK ){
7754     printf(" TRK: NCLX = %i NCLY = %i RIG = %f [GV] CHI2 = %f \n",var.nclx,var.ncly,var.rig,var.chi2);
7755     } else {
7756     printf(" TRK: NCLX = %i NCLY = %i \n ",var.nclx,var.ncly);
7757     };
7758     printf(" CALO: NSTRIP = %i QTOT = %i [MIP]\n",var.nstrip,var.qtot);
7759     printf(" S4: %.2f [MIP] TOF: beta(1,...,5) = (%.2f,%.2f,%.2f,%.2f,%.2f) \n",var.s4sig,var.beta[0],var.beta[1],var.beta[2],var.beta[3],var.beta[4]);
7760     printf(" ND: Trigger: neutrons = %i - Background: upper = %i lower = %i \n",var.trup,var.bkup,var.bkbo);
7761     //
7762     // Interact with user: do you want to continue, go backward, exit or print the figure?
7763     //
7764     printf("\n\n\n\n\n\n\n\n\n\n");
7765 mocchiut 1.3 si = i;
7766     doflag = 1;
7767     jumpto = 0;
7768     var.i = i;
7769     var.doflag = doflag;
7770     var.jumpto = jumpto;
7771     var.nevents = nevents;
7772     var.lastevno = lastevno;
7773     var.firstevno = firstevno;
7774     //
7775     char *bw;
7776     if ( var.bw ){
7777     bw = "_bw";
7778 mocchiut 1.1 } else {
7779 mocchiut 1.3 bw = "";
7780     };
7781     TString filenm = file;
7782     const string fil = (const char*)filenm;
7783     Int_t posiz = fil.find("dw_");
7784     if ( posiz == -1 ) posiz = fil.find("DW_");
7785     Int_t posiz2 = posiz+13;
7786     TString file2;
7787     stringcopy(file2,filenm,posiz,posiz2);
7788     const char *figrec = file2;
7789     const char *outdir = outDir;
7790     stringstream figsave;
7791     figsave.str("");
7792     figsave << outdir << "/";
7793     figsave << figrec;
7794     figsave << "_ev_";
7795     figsave << (var.i+1);
7796     figsave << bw;
7797     var.svas=figsave.str().c_str();
7798     pamgui->upgrnamfi();
7799     //
7800     var.jumpen = false;
7801     // njumpen = 0;
7802     Int_t ifout = 0;
7803     while( !var.goon && !var.refresh && !var.restart ) {
7804     if ( !gROOT->GetListOfCanvases()->FindObject(figure) ) {
7805     pamgui->Close();
7806     gSystem->ProcessEvents();
7807     gApplication->Terminate(0);
7808     };
7809     gSystem->ProcessEvents();
7810 mocchiut 1.4 gSystem->Sleep(10);
7811 mocchiut 1.3 };
7812     var.goon = false;
7813     if ( var.refresh || var.restart ){
7814     headerFile->Close();
7815     triggerFile->Close();
7816     if ( trackerFile ) trackerFile->Close();
7817     if ( trackerFile2 ) trackerFile2->Close();
7818     if ( caloFile )caloFile->Close();
7819     if ( neutronFile ) neutronFile->Close();
7820     if ( acFile ) acFile->Close();
7821     if ( tofFile ) tofFile->Close();
7822     if ( tofFileL1 ) tofFileL1->Close();
7823     if ( s4File ) s4File->Close();
7824     if ( trackhead ) trackhead->Close();
7825     if ( trackcalibFile1 ) trackcalibFile1->Close();
7826     if ( trackcalibFile2 ) trackcalibFile2->Close();
7827     if ( trackerFile2b ) trackerFile2b->Close();
7828     if ( var.refresh ) goto refresh;
7829     if ( var.restart ){
7830     filename = var.thefilename.Data();
7831     pamgui->Close();
7832     goto restart;
7833     };
7834     };
7835     //
7836     i = var.i;
7837     doflag = var.doflag;
7838     jumpto = var.jumpto;
7839     if ( i != si ) OOBT = 1000000000;
7840     if ( maxevent < i ) {
7841     maxevent = nevents;
7842     printf("WARNING: you have chosen an event number out of the starting range.\n Range extended to %i\n\n",maxevent);
7843 mocchiut 1.1 };
7844 mocchiut 1.3 if ( ifout ) goto theend;
7845 mocchiut 1.1 };
7846     if ( doflag == 2 && i == 0 ) {
7847     printf("\n WARNING: Cannot go backward! Going forward. \n");
7848     doflag = 1;
7849     };
7850     if ( doflag == 2 && i>0 ) i--;
7851     if ( doflag == 1 ) i++;
7852 mocchiut 1.3 if ( var.doflag == 3 ) selection = 0;
7853 mocchiut 1.1 //
7854     // if in selection mode, print out a event progress bar:
7855     //
7856     if ( !selection || i == minevent ){
7857     // do nothing
7858     } else {
7859     if ( (maxevent-minevent) != 0 ){
7860     if((100*(i-minevent)/(maxevent-minevent))<10.){
7861     printf("%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c",8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8);
7862     } else {
7863     printf("%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c",8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8);
7864     };
7865     };
7866     };
7867    
7868     };
7869     //
7870     // END OF THE MAIN LOOP AND OF THE MAIN PROGRAM
7871     //
7872     printf("\n");
7873     theend: if ( !ifout ) printf("\nFinished, exiting... \n\n");
7874     #if defined (__CINT__)
7875     gSystem->ChangeDirectory(path);
7876     if ( trackdone2 ){
7877     unload1();
7878     };
7879     if ( trackdone1 ){
7880     unload2();
7881     };
7882     #endif
7883     printf(" ...done! \n\n");
7884     return;
7885     }

  ViewVC Help
Powered by ViewVC 1.1.23