/[PAMELA software]/quicklook/tracker/flight/macros/TrkScanQLook.cpp
ViewVC logotype

Annotation of /quicklook/tracker/flight/macros/TrkScanQLook.cpp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.1 - (hide annotations) (download)
Tue Mar 14 16:09:30 2006 UTC (18 years, 9 months ago) by pam-fi
Branch: MAIN
Branch point for: trk-QLook
Initial revision

1 pam-fi 1.1 // change the path "/opt/yoda/include/yoda/event/"
2     // relatively to the install yoda directory
3     #include </opt/yoda/include/yoda/event/PscuHeader.h>
4     #include </opt/yoda/include/yoda/event/EventHeader.h>
5     #include </opt/yoda/include/yoda/event/physics/tracker/TrackerEvent.h>
6     #include </opt/yoda/include/utils/yodaUtility.h>
7     //
8     #include "TrkFunctions.cpp"
9     #include <TPaveText.h>
10     #include <TLatex.h>
11     #include <TCanvas.h>
12     #include <TObjString.h>
13     #include <TGraph.h>
14     #include <iostream>
15     #include <fstream>
16     #include <TStyle.h>
17     #include <TString.h>
18    
19     /**
20     * TrkScanQlook.cpp
21     *
22     * autor: D.Fedele
23     * version 1.0
24     * Parameters:
25     * file - the path to the root file to analyse
26     * outdir - total path of output file
27     * event - the number of the single event to analyse
28     * DSPprint - the number of a particular DSP to draw (0 don't draw)
29     *
30     */
31    
32     void TrkScanQlook(TString file, TString outdir = "",Int_t event = 1,Int_t DSPprint=0){
33    
34     gROOT->Reset();
35    
36     //
37     // obtain information about the data file and select the output file
38     const string filepath=file.Data();
39     Int_t dwpos = filepath.find("DW_");
40     Int_t dwpos1 = filepath.find(".root");
41     TString fpath=(filepath.c_str());
42     TString base,ffile ;
43     stringcopy(ffile,fpath,dwpos,dwpos1);
44     stringcopy(base,fpath,0,dwpos);
45    
46     TString out;
47     if(outdir.Length()==0){
48     out = base;
49     }else{
50     out = outdir;
51     }
52    
53    
54     // Define variables
55     Int_t nevents = otr->GetEntries();
56     if ( nevents <= 0 ) {
57     trackerFile->Close();
58     printf("The file is empty, exiting...\n");
59     return;
60     }
61    
62     pamela::tracker::TrackerEvent *trk=0;
63     pamela::EventHeader *eh=0;
64     pamela::PscuHeader *ph=0;
65    
66    
67     // open files
68     TFile *trackerFile = new TFile(file);
69     if ( !trackerFile ){
70     trackerFile->Close();
71     printf("No tracker file! \n");
72     return;
73     }
74    
75     //Takes the tree and branches
76     TTree *otr = (TTree*)trackerFile->Get("Physics");
77    
78     cout << "\n Number of Entries: " << nevents << endl;
79    
80     cout<<"Scan of Entry "<<event-1<<"\n"<<endl;
81    
82     otr->SetBranchAddress("Header",&eh);
83     otr->SetBranchAddress("Tracker", &trk);
84     otr->GetEntry(event-1);
85     //============================================================================
86    
87     gStyle->SetLabelSize(0.06,"x");
88     gStyle->SetLabelSize(0.06,"y");
89    
90     gStyle->SetTitleFontSize(0.08);
91     gStyle->SetTitleFillColor(10);
92     gStyle->SetTitleFontSize(0.1);
93     gStyle->SetTitleOffset(-1,"Y");
94    
95     gStyle->SetOptStat(0);
96    
97     // draw display area
98    
99     Int_t canvasx=1200;
100     Int_t canvasy=900;
101     stringstream figsav;
102     figsav.str("");
103     figsav<<out<<ffile<<"_TrkScanQlook_ev"<<event+1;
104     TCanvas *c1 = new TCanvas(figsav.str().c_str(),"TrkQLookSCAN",canvasx,canvasy);
105     c1->SetFillColor(10);
106     c1->Range(0,0,1,1);
107     stringstream fromfile;
108     fromfile<<"TrkScanQlook File: "<<ffile<<" ----> Entry "<<event-1;
109     TLatex *t=new TLatex();
110     t->SetTextFont(32);
111     t->SetTextColor(1);
112     t->SetTextAlign(12);
113     t->SetTextSize(0.02);
114     t->DrawLatex(0.02,0.98,fromfile.str().c_str());
115    
116     // draw pads
117     TPad *trkpad[12]; //pad for histos
118     TPaveText *trkpadtext[12]; //pad for header
119     TH1F *histomax[12]; //histos of max signals
120     TH1F *histocomp[12]; //histos of compressed data
121     TH1F *histofull[12]; //histos of full data
122    
123     Double_t posy = 0.95; // up y-coord - top pads
124     Double_t hpad = 0.15; // pad height
125     Double_t posx1=0; // left x-coord - pad column
126     Double_t posx2=0; // right x-coord - pad olumn
127     Double_t posx0=0; // x-coord - column division
128     Double_t wrel = 0.6; // relative x size of first sub-column
129     Double_t marg = 0.004; // margin among pads
130    
131    
132     stringstream title;
133     stringstream hid;
134     for(Int_t n = 0; n<12; n++){
135     if ( (n+1)%2 ) {
136     if(n>1)posy = posy-(marg*2+hpad);
137     posx1 = marg;
138     posx2 = 0.5 - marg;
139     posx0 = 0.5*wrel;
140     } else {
141     posx1 = posx1 + 0.5;
142     posx2 = posx2 + 0.5;
143     posx0 = posx0 + 0.5;
144     };
145    
146     /* -----------> pad for histograms */
147     trkpad[n] = new TPad("pad"," ",posx1,posy-hpad,posx0-marg,posy,18,0,0);
148     trkpad[n]->SetFillColor(19);
149     trkpad[n]->SetFrameFillColor(10);
150     /* -----------> pad for header dump */
151     trkpadtext[n] = new TPaveText((posx0+marg),(posy-hpad),posx2,posy);
152     /* -----------> HISTOGRAMS */
153    
154     title<<"DSP "<<n+1;
155     hid<<"h"<<n;
156     histomax[n] = new TH1F(hid.str().c_str(),title.str().c_str(),3072,0.5,3072.5);
157     hid<<"hh"<<n;
158     histocomp[n] = new TH1F(hid.str().c_str(),title.str().c_str(),3072,0.5,3072.5);
159     hid<<"hhh"<<n;
160     histofull[n] = new TH1F(hid.str().c_str(),title.str().c_str(),3072,0.5,3072.5);
161     title.str("");
162     hid.str("");
163     } //end loop on views
164    
165     // = = = = = = = = = = = = = = = = = = = = = = = = =
166     // create header dump retrieving event info
167     // = = = = = = = = = = = = = = = = = = = = = = = = =
168     Int_t ndsp=0;
169     stringstream message;
170    
171     Double_t whistomax[3072];
172     Double_t whisto[3072];
173     Double_t whistocomp[3072];
174     Double_t whistofull[3072];
175    
176     //=============================================
177     // transmitted words
178     Int_t word = 0;
179     Int_t iword = 0;
180     Int_t TOTDATAlength_check = 0;
181     Int_t ii=0,ifull[12],icomp[12],imax[12],nn=0;
182     trkword thisword;
183    
184     Int_t address,ladder,adcvalue;
185    
186     for(Int_t n = 0; n<12; n++){
187    
188     ndsp = trk->DSPnumber[n];
189     nn = ndsp-1;
190     ifull[nn]=0;
191     icomp[nn]=0;
192     imax[nn]=0;
193    
194     /*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*
195     *
196     * Write event LEVEL0 report
197     *
198     *.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*/
199    
200     trkpadtext[nn]->SetTextFont(40);
201     trkpadtext[nn]->SetFillColor(33);
202     trkpadtext[nn]->SetTextSize(0.012);
203     trkpadtext[nn]->SetTextAlign(13);
204    
205     trkpadtext[nn]->AddText(" ");
206     message<<"DAQ mode --------> "<<trk->DAQmode[n];
207     trkpadtext[nn]->AddText(message.str().c_str());
208     message.str("");
209     message<<"Event number --------> "<<trk->eventn[n];
210     trkpadtext[nn]->AddText(message.str().c_str());
211     message.str("");
212     message<<"13-bit words --------> "<<trk->DATAlength[n];
213     trkpadtext[nn]->AddText(message.str().c_str());
214     message.str("");
215     if (!(nn%2)&&trk->signcluster[n][0]!=0) message<<"L1 add: "<<trk->addrcluster[n][0]<<" - sign: "<<1024-(trk->signcluster[n][0]);
216     else message<<"L1 add: "<<trk->addrcluster[n][0]<<" - sign: "<<(trk->signcluster[n][0]);
217     trkpadtext[nn]->AddText(message.str().c_str());
218     message.str("");
219     if (!(nn%2)&&trk->signcluster[n][1]!=0) message<<"L2 add: "<<trk->addrcluster[n][1]<<" - sign: "<<1024-(trk->signcluster[n][1]);
220     else message<<"L2 add: "<<trk->addrcluster[n][1]<<" - sign: "<<trk->signcluster[n][1];
221     trkpadtext[nn]->AddText(message.str().c_str());
222     message.str("");
223     if (!(nn%2)&&trk->signcluster[n][2]!=0) message<<"L3 add: "<<trk->addrcluster[n][2]<<" - sign: "<<1024-(trk->signcluster[n][2]);
224     else message<<"L3 add: "<<trk->addrcluster[n][2]<<" - sign: "<<trk->signcluster[n][2];
225     trkpadtext[nn]->AddText(message.str().c_str());
226     message.str("");
227     message<<"NCLUST "<<trk->nclust[n]<<" CUTC "<<trk->cutc[n]<<" CUTCL "<<trk->cutcl[n];
228     trkpadtext[nn]->AddText(message.str().c_str());
229     message.str("");
230     message<<"Comp. time "<<trk->compressiontime[n]<<" x 0.051ms = "<<0.051*trk->compressiontime[n]<<" ms";
231     trkpadtext[nn]->AddText(message.str().c_str());
232     message.str("");
233     trkpadtext[nn]->AddText(" ");
234     message<<"FL1-6 --> "<<trk->fl1[n]<<" "<<trk->fl2[n]<<" "<<trk->fl3[n]<<" "<<trk->fl4[n]<<" "<<trk->fl5[n]<<" "<<trk->fl6[n]<<" FC "<<trk->fc[n];
235     trkpadtext[nn]->AddText(message.str().c_str());
236     message.str("");
237     trkpadtext[nn]->AddText(" ");
238     trkpadtext[nn]->AddLine(0,0,0,0);
239     message<<"PNum "<<trk->pnum[n]<<" - BId "<<trk->bid[n]<<" ALARM "<<trk->alarm[n];
240     trkpadtext[nn]->AddText(message.str().c_str());
241     message.str("");
242     message<<"Cmd "<<trk->cmdnum[n]<<" --- Answer length "<<trk->aswr[n]<<" byte";
243     trkpadtext[nn]->AddText(message.str().c_str());
244     message.str("");
245     trkpadtext[nn]->AddText(" ");
246    
247     TOTDATAlength_check = TOTDATAlength_check + trk->DATAlength[n];
248    
249     /*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*
250     *
251     * Plot event LEVEL0 histo
252     *
253     *.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*/
254    
255     //=============================================
256    
257     for(Int_t i = 0; i< 3072; i++){
258     whistomax[i] = -200;
259     whistocomp[i] = -200;
260     whistofull[i] = -200;
261     whisto[i] = -200;
262     }
263    
264     // ===============
265     // trasmitted data
266     // ===============
267    
268     address = 0;
269     ladder = 1;
270     for(Int_t i = 0; i < trk->DATAlength[n] ; i++){
271     word = trk->TrackerData.At(iword);
272     thisword = datadecode(word);
273     iword++;
274     switch (thisword.type){
275    
276     case 0: //ADC value
277     whisto[address] = thisword.decode;
278     address++;
279     // cout << " adr " << address << "\n";
280     break;
281    
282     case 1: //address
283     address = 1024*(ladder-1) + thisword.decode;
284     // cout << " adr " << address << "\n";
285     break;
286    
287     case 2: //end-of-ladder
288     ladder = thisword.decode;
289     // cout << "Ladder " << ladder << "\n";
290     if(ladder==3){
291     // end of compressed data - FILL HISTO
292     //cout << ">>> COMPRESSED data" << "\n";
293     for(ii = 0; ii < 3072; ii++){
294     whistocomp[ii]=whisto[ii];
295     whisto[ii] = -200;
296     }
297     address = 0;
298     ladder = 1;
299     }else if(ladder==6){
300     // end of full data - FILL HISTO
301     //cout << ">>> FULL data" << "\n";
302     for(ii = 0; ii < 3072; ii++){
303     whistofull[ii]=whisto[ii];
304     whisto[ii] = -200;
305     }
306     address = 0;
307     ladder = 1;
308     }else{
309     if(ladder>3) ladder=ladder-3;
310     address= ladder*1024;
311     ladder = ladder + 1;
312     }
313     }
314     }
315    
316    
317     // ===============
318     // maximum signals
319     // ===============
320     if(trk->signcluster[nn][0]!=0) whistomax[ 0+(int)trk->addrcluster[nn][0]] = whistocomp[ 0+(int)trk->addrcluster[nn][0]];
321     if(trk->signcluster[nn][1]!=0) whistomax[1024+(int)trk->addrcluster[nn][1]] = whistocomp[1024+(int)trk->addrcluster[nn][1]];
322     if(trk->signcluster[nn][2]!=0) whistomax[2048+(int)trk->addrcluster[nn][2]] = whistocomp[2048+(int)trk->addrcluster[nn][2]];
323    
324     for(Int_t i = 0; i < 3072; i++){
325     if(whistomax[i]>-200) imax[nn]=1;
326     if(whistocomp[i]>-200) icomp[nn]=1;
327     if(whistofull[i]>-200) ifull[nn]=1;
328     histomax[nn]->Fill((Float_t)i,whistomax[i]);
329     histocomp[nn]->Fill((Float_t)i,whistocomp[i]);
330     histofull[nn]->Fill((Float_t)i,whistofull[i]);
331     }
332     c1->cd();
333     trkpadtext[nn]->Draw();
334     trkpad[nn]->Draw();
335     trkpad[nn]->cd();
336    
337     histocomp[nn]->GetYaxis()->SetRangeUser(-500,4500);
338     histocomp[nn]->SetLineStyle(1);
339     histocomp[nn]->SetLineColor(38);
340     histocomp[nn]->SetFillColor(38);
341     histocomp[nn]->SetLineWidth(1);
342     if(icomp[nn]==1) histocomp[nn]->Draw("9b");
343    
344     histofull[nn]->SetLineColor(40);
345     histofull[nn]->SetFillColor(40);
346     histofull[nn]->SetLineWidth(1);
347     histofull[nn]->SetLineStyle(2);
348     if(ifull[nn]==1) histofull[nn]->Draw("9bsame][");
349    
350     histomax[nn]->SetLineColor(2);
351     histomax[nn]->SetLineWidth(1);
352     histomax[nn]->SetLineStyle(3);
353     if(imax[nn]==1) histomax[nn]->Draw("same][");
354     c1->Update();
355    
356     }//end loop on views
357    
358     if(DSPprint!=0){
359     if(DSPprint<=12){
360     stringstream figsav;
361     figsav.str("");
362     figsav<<out<<ffile<<"_TrkScanQlook_ev"<<event+1<<"-DSP"<<DSPprint;
363     TCanvas *c2 = new TCanvas(figsav.str().c_str(),"TrkQLookSCAN DSP",canvasx,canvasy);
364     c2->SetFillColor(10);
365     c2->Range(0,0,1,1);
366     stringstream fromfile;
367     fromfile<<"TrkScanQlook File: "<<ffile<<" ----> Entry "<<event<<" ------> DSP "<<DSPprint;
368     TLatex *t=new TLatex();
369     t->SetTextFont(32);
370     t->SetTextColor(1);
371     t->SetTextAlign(12);
372     t->SetTextSize(0.02);
373     t->DrawLatex(0.02,0.98,fromfile.str().c_str());
374    
375     c2->cd();
376     gStyle->SetTitleFontSize(0.022);
377     histocomp[DSPprint-1]->GetXaxis()->SetLabelSize(0.015);
378     histocomp[DSPprint-1]->GetYaxis()->SetLabelSize(0.015);
379     if(icomp[DSPprint-1]==1) histocomp[DSPprint-1]->Draw("9b");
380     if(ifull[DSPprint-1]==1) histofull[DSPprint-1]->Draw("9bsame][");
381     if(imax[DSPprint-1]==1) histomax[DSPprint-1]->Draw("same][");
382     c2->Update();
383     }
384     else if(DSPprint>12)
385     printf("The DSP number has to be between 1 and 12\n");
386     }
387    
388     return;
389    
390     }
391    

  ViewVC Help
Powered by ViewVC 1.1.23