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

Contents of /calo/flight/FUTILITIES/macros/FCaloCHECKCRC.cxx

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.1 - (show annotations) (download)
Fri Jun 30 12:08:14 2006 UTC (18 years, 6 months ago) by mocchiut
Branch: MAIN
CVS Tags: v1r03, HEAD
Added FCaloCHECKCRC utility

1 //
2 //
3 //
4 //
5 #include <fstream>
6 #include <sstream>
7 #include <TTree.h>
8 #include <TBranch.h>
9 #include <TClassEdit.h>
10 #include <TObject.h>
11 #include <TList.h>
12 #include <TSystem.h>
13 #include <TSystemDirectory.h>
14 #include <TString.h>
15 #include <TFile.h>
16 #include <TClass.h>
17 #include <TCanvas.h>
18 #include <TH1.h>
19 #include <TH1F.h>
20 #include <TH2D.h>
21 #include <TLatex.h>
22 #include <TPad.h>
23 #include <TPaveLabel.h>
24 #include <TChain.h>
25 #include <PamelaRun.h>
26 #include <physics/calorimeter/CalorimeterEvent.h>
27 #include <CalibCalPedEvent.h>
28 //
29
30 short int FCaloCHECKCRC(TString filename1, TString filename2){
31 //
32 // open first file
33 //
34 TFile *File1 = new TFile(filename1.Data());
35 TTree *otr1 = (TTree*)File1->Get("Physics");
36 TBranch *l0head1 = 0;
37 TBranch *l0calo1 = 0;
38 //
39 pamela::calorimeter::CalorimeterEvent *de1 = 0;
40 pamela::PscuHeader *ph1 = 0;
41 pamela::EventHeader *eh1 = 0;
42 //
43 l0head1 = otr1->GetBranch("Header");
44 l0calo1 = otr1->GetBranch("Calorimeter");
45 //
46 otr1->SetBranchAddress("Calorimeter", &de1);
47 otr1->SetBranchAddress("Header", &eh1);
48 //
49 // open second file
50 //
51 TFile *File2 = new TFile(filename2.Data());
52 TTree *otr2 = (TTree*)File2->Get("Physics");
53 TBranch *l0head2 = 0;
54 TBranch *l0calo2 = 0;
55 //
56 pamela::calorimeter::CalorimeterEvent *de2 = 0;
57 pamela::PscuHeader *ph2 = 0;
58 pamela::EventHeader *eh2 = 0;
59 //
60 l0head2 = otr2->GetBranch("Header");
61 l0calo2 = otr2->GetBranch("Calorimeter");
62 //
63 otr2->SetBranchAddress("Calorimeter", &de2);
64 otr2->SetBranchAddress("Header", &eh2);
65 //
66 // Define variables
67 //
68 Long64_t nevents1 = otr1->GetEntries();
69 Long64_t nevents2 = otr2->GetEntries();
70 if ( nevents1 < 1 ) {
71 printf("The file %s is empty!\n",filename1.Data());
72 return(1);
73 };
74 if ( nevents2 < 1 ) {
75 printf("The file %s is empty!\n",filename2.Data());
76 return(2);
77 };
78 //
79 printf("\n Processed events: \n\n");
80 //
81 Int_t c1 = 0;
82 Int_t c2 = 0;
83 Int_t ecount1 = 0;
84 Int_t ecount2 = 0;
85 Int_t etime1 = 0;
86 Int_t etime2 = 0;
87 //
88 Int_t frstbad[4];
89 Int_t scndbad[4];
90 Int_t crcfrstbad[4];
91 Int_t crcscndbad[4];
92 Int_t crcbothbad[4];
93 Int_t frstbadscndgood[4];
94 Int_t frstgoodscndbad[4];
95 Int_t crcfrstbadscndgood[4];
96 Int_t crcfrstgoodscndbad[4];
97 Int_t bothbad[4];
98 Int_t bothgood[4];
99 Int_t samecheck[4];
100 Int_t differentcheck[4];
101 Int_t samecrc[4];
102 Int_t differentcrc[4];
103 //
104 for ( Int_t s=0; s<4; s++){
105 frstbad[s] = 0;
106 scndbad[s] = 0;
107 crcfrstbad[s] = 0;
108 crcscndbad[s] = 0;
109 crcbothbad[s] = 0;
110 frstbadscndgood[s] = 0;
111 frstgoodscndbad[s] = 0;
112 crcfrstbadscndgood[s] = 0;
113 crcfrstgoodscndbad[s] = 0;
114 bothbad[s] = 0;
115 bothgood[s] = 0;
116 samecheck[s] = 0;
117 differentcheck[s] = 0;
118 samecrc[s] = 0;
119 differentcrc[s] = 0;
120 };
121 //
122 // for (Int_t i = 0; i < 3000; i++){
123 //
124 for (Int_t i = 0; i < max(nevents1,nevents2); i++){
125 //
126 if ( i%1000 == 0 && i > 0 ) printf(" %iK \n",i/1000);
127 //
128 // read from the header of the event the absolute time at which it was recorded
129 //
130 if ( c1 < nevents1 ){
131 l0head1->GetEntry(c1);
132 ph1 = eh1->GetPscuHeader();
133 etime1 = ph1->GetOrbitalTime();
134 ecount1 = ph1->GetCounter();
135 };
136 //
137 if ( c2 < nevents2 ){
138 l0head2->GetEntry(c2);
139 ph2 = eh2->GetPscuHeader();
140 etime2 = ph2->GetOrbitalTime();
141 ecount2 = ph2->GetCounter();
142 };
143 //
144 if ( etime2 == etime1 && ecount2 == ecount1 ){
145 if ( c1 < nevents1 ) l0calo1->GetEntry(c1);
146 if ( c2 < nevents2 ) l0calo2->GetEntry(c2);
147 //
148 //
149 //
150 for ( Int_t s=0; s<4; s++){
151 //
152 // sum of frstbadscndgood e frstgoodscndbad gives us how many GOOD events we can have merging the two files (not only CRC errors)
153 //
154 if ( de1->perror[s] != 0 ) frstbad[s]++;
155 if ( de2->perror[s] != 0 ) scndbad[s]++;
156 if ( de1->perror[s] == 132 ) crcfrstbad[s]++;
157 if ( de2->perror[s] == 132 ) crcscndbad[s]++;
158 if ( de1->perror[s] != 0 && de2->perror[2] == 0 ) frstbadscndgood[s]++;
159 if ( de1->perror[s] == 0 && de2->perror[2] != 0 ) frstgoodscndbad[s]++;
160 if ( de1->perror[s] != 0 && de2->perror[2] != 0 ) bothbad[s]++;
161 if ( de1->perror[s] == 0 && de2->perror[2] == 0 ) bothgood[s]++;
162 //
163 if ( de1->perror[s] == 132 && de2->perror[2] == 0 ) crcfrstbadscndgood[s]++;
164 if ( de1->perror[s] == 0 && de2->perror[2] == 132 ) crcfrstgoodscndbad[s]++;
165 if ( de1->perror[s] == 132 && de2->perror[2] == 132 ){
166 crcbothbad[s]++;
167 if ( de1->calselftrig[0] == de2->calselftrig[0] ) samecheck[s]++;
168 if ( de1->calselftrig[0] != de2->calselftrig[0] ) differentcheck[s]++;
169 if ( de1->calselftrig[1] == de2->calselftrig[1] ) samecrc[s]++;
170 if ( de1->calselftrig[1] != de2->calselftrig[1] ) differentcrc[s]++;
171 };
172 };
173 //
174 c1++;
175 c2++;
176 } else {
177 if ( etime2 > etime1 || ecount2 > ecount1 ){
178 if ( c1 < nevents1 ){
179 l0calo1->GetEntry(c1);
180 for ( Int_t s=0; s<4; s++){
181 if ( de1->perror[s] != 0 ) frstbad[s]++;
182 if ( de1->perror[s] != 0 ) crcfrstbad[s]++;
183 if ( de1->perror[s] == 0 ) frstgoodscndbad[s]++;
184 if ( de1->perror[s] == 132 ){
185 crcbothbad[s]++;
186 differentcheck[s]++;
187 differentcrc[s]++;
188 };
189 };
190 };
191 c1++;
192 };
193 if ( etime1 > etime2 || ecount1 > ecount2 ){
194 if ( c2 < nevents2 ){
195 l0calo2->GetEntry(c2);
196 for ( Int_t s=0; s<4; s++){
197 if ( de2->perror[s] != 0 ) scndbad[s]++;
198 if ( de2->perror[s] != 0 ) crcscndbad[s]++;
199 if ( de2->perror[s] == 0 ) frstbadscndgood[s]++;
200 if ( de2->perror[s] == 132 ){
201 crcbothbad[s]++;
202 differentcheck[s]++;
203 differentcrc[s]++;
204 };
205 };
206 };
207 c2++;
208 };
209 };
210 };
211 //
212 printf("\n\n");
213 printf("##############################################################################\n");
214 printf(" File 1: %s \n",filename1.Data());
215 printf(" File 2: %s \n",filename2.Data());
216 printf("##############################################################################\n");
217 for ( Int_t s=0; s<4; s++){
218 printf("################################# SECTION %i ##################################\n",s);
219 printf(" File 1: number of events........... = %i \n",(int)nevents1);
220 printf(" : number of errors........... = %i \n",frstbad[s]);
221 printf(" : number of CRC errors....... = %i \n",crcfrstbad[s]);
222 printf(" File 2: number of events........... = %i \n",(int)nevents2);
223 printf(" : number of errors........... = %i \n",scndbad[s]);
224 printf(" : number of CRC errors....... = %i \n",crcscndbad[s]);
225 printf(" Events bad in both files........... = %i \n",bothbad[s]);
226 printf(" Events good in both files.......... = %i \n",bothgood[s]);
227 printf(" Events good in the first and bad in the second file.............. = %i \n",frstgoodscndbad[s]);
228 printf(" Events bad in the first and good in the second file.............. = %i \n",frstbadscndgood[s]);
229 printf(" Events good in the first and with CRC error in the second file... = %i \n",crcfrstgoodscndbad[s]);
230 printf(" Events with CRC error in the first and good in the second file... = %i \n",crcfrstbadscndgood[s]);
231 printf(" Events with CRC error in both files.............................. = %i \n",crcbothbad[s]);
232 printf(" Events with CRC error in both files and same transmitted CRC..... = %i \n",samecrc[s]);
233 printf(" Events with CRC error in both files and different transmitted CRC = %i \n",differentcrc[s]);
234 printf(" Events with CRC error in both files and same calculated CRC...... = %i \n",samecheck[s]);
235 printf(" Events with CRC error in both files and different calculated CRC. = %i \n",differentcheck[s]);
236 printf(" Merging the two files you will have %i good events \n",bothgood[s]+frstgoodscndbad[s]+frstbadscndgood[s]);
237 printf("##############################################################################\n");
238 };
239 printf("\n\n");
240 //
241 return(0);
242 //
243 }
244
245
246

  ViewVC Help
Powered by ViewVC 1.1.23