/[PAMELA software]/chewbacca/YodaProfiler/src/PamelaDBOperations.cpp
ViewVC logotype

Annotation of /chewbacca/YodaProfiler/src/PamelaDBOperations.cpp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.24 - (hide annotations) (download)
Wed Jul 22 08:16:46 2009 UTC (15 years, 6 months ago) by pizzolot
Branch: MAIN
Changes since 1.23: +1 -1 lines
adapted to root5.24

1 mocchiut 1.1 //
2     #include <iomanip>
3     #include <sstream>
4     //
5     #include <iostream>
6     #include <string>
7     #include <fstream>
8     #include <list>
9     #include <errno.h>
10     //
11     #include <TFile.h>
12     #include <TSystem.h>
13     #include <TSQLResult.h>
14     #include <TSQLRow.h>
15     #include <TTree.h>
16     #include <TGraph.h>
17     #include <TTimeStamp.h>
18     #include <TF1.h>
19     //
20     #include <EventHeader.h>
21     #include <PscuHeader.h>
22     #include <mcmd/McmdEvent.h>
23     #include <mcmd/McmdRecord.h>
24     #include <RunHeaderEvent.h>
25     #include <RunTrailerEvent.h>
26     #include <CalibCalPedEvent.h>
27     #include <CalibCalPulse1Event.h>
28     #include <CalibCalPulse2Event.h>
29     #include <CalibS4Event.h>
30     #include <CalibTrk1Event.h>
31     #include <CalibTrk2Event.h>
32     #include <varDump/VarDumpEvent.h>
33     #include <varDump/VarDumpRecord.h>
34     #include <physics/S4/S4Event.h>
35     //
36     #include <sgp4.h>
37    
38     #include <PamelaDBOperations.h>
39     //
40     using namespace std;
41     using namespace pamela;
42    
43     // Some function to work with cTle stuff.
44     bool compTLE(cTle* tle1, cTle *tle2);
45     float getTleJulian(cTle *);
46     string getTleDatetime(cTle*);
47    
48     /**
49     * Constructor.
50     * @param host hostname for the SQL connection.
51     * @param user username for the SQL connection.
52     * @param password password for the SQL connection.
53     * @param filerawname The path and name to the raw file.
54     * @param filerootname The path and name of the raw file.
55     * @param boot file BOOT number.
56     * @param obt0 file obt0.
57     * @param tsync file timesync.
58     * @param debug debug flag.
59     * @param tlefilename ascii file with TLE 3 line elements.
60     */
61 mocchiut 1.5 PamelaDBOperations::PamelaDBOperations(TString host, TString user, TString password, TString filerawname, TString filerootname, UInt_t boot, UInt_t tsync, UInt_t obt0, Bool_t debug, TString tlefilename, UInt_t dwinput, Bool_t staticp, Bool_t gpamela, Bool_t keepenv){
62 mocchiut 1.1 //
63 mocchiut 1.21 RELAXED = false;
64 mocchiut 1.1 chewbacca = false;
65     chminentry = 0;
66     chID = 0;
67     if ( filerootname.IsDigit() ){
68     if ( debug ) printf(" => using database to process the file \n");
69     chewbacca = true;
70     chID = (UInt_t)filerootname.Atoll();
71     //
72     // are these really necessary?
73     //
74     staticp = false;
75     INSERT_RAW = false;
76     dwinput = 1;
77     //
78     };
79     //
80 mocchiut 1.5 KEEPENV = false;
81     if ( keepenv ) KEEPENV=true;
82 mocchiut 1.1 STATIC=false;
83     if ( staticp ) STATIC=true;
84     //
85     SetConnection(host,user,password);
86     //
87     SetDebugFlag(debug);
88     //
89     glrun = new GL_RUN();
90     //
91     if ( !chewbacca ){
92     if ( !boot ) SetNOBOOT(false);
93     SetTsync(tsync,gpamela);
94     SetBOOTnumber(boot,gpamela);
95     SetObt0(obt0);
96     };
97     //
98     SetTLEPath(tlefilename);
99     //
100     //
101     if ( !chewbacca ) INSERT_RAW =!filerawname.IsNull();
102     if (INSERT_RAW) SetRawName(filerawname);
103     //
104     INSERT_ROOT = !filerootname.IsNull();
105 mocchiut 1.13 if ( INSERT_ROOT ) this->SetRootName(filerootname);
106 mocchiut 1.1 this->SetOrbitNo(dwinput);
107     //
108     this->SetID_RAW(0);
109     this->SetID_ROOT(0);
110    
111     VALIDATE = false;
112    
113     //
114     };
115    
116     /**
117     * Destructor
118     */
119     void PamelaDBOperations::Close(){
120     if( conn && conn->IsConnected() ) conn->Close();
121     delete clean_time;
122     delete glrun;
123     delete this;
124     };
125    
126     //
127     // SETTERS
128     //
129    
130     void PamelaDBOperations::OpenL0File(TString filerootname){
131     if( INSERT_ROOT ){
132     if ( chewbacca ){
133     //
134     // retrieve from the ROOT_TABLE the chewbacca path and filename
135     //
136     stringstream qu;
137     TSQLResult *result = 0;
138     TSQLResult *result2 = 0;
139 mocchiut 1.18 TSQLResult *result3 = 0;
140 mocchiut 1.1 TSQLRow *row = 0;
141     TSQLRow *row2 = 0;
142 mocchiut 1.18 TSQLRow *row3 = 0;
143 mocchiut 1.1 TString chpath;
144     TString chfile;
145     UInt_t ridn = 0;
146     qu.str("");
147 mocchiut 1.21 qu << "SELECT ROOT_ID_N,PKT_NUMBER_INIT,PKT_NUMBER_FINAL,PKT_OBT_INIT,PKT_OBT_FINAL,INSERTED_BY,REAL_TIME_INIT from ROOT_TABLE_MERGING where ID_N=" << chID << ";";
148 mocchiut 1.1 if ( debug ) printf(" chewbacca: query is %s \n",qu.str().c_str());
149     result = conn->Query(qu.str().c_str());
150     if ( result ){
151     row = result->Next();
152     if ( row ){
153     ridn = (UInt_t)atoll(row->GetField(0));
154     chpktmin = (UInt_t)atoll(row->GetField(1));
155     chpktmax = (UInt_t)atoll(row->GetField(2));
156     chobtmin = (UInt_t)atoll(row->GetField(3));
157     chobtmax = (UInt_t)atoll(row->GetField(4));
158 mocchiut 1.5 chiby = (TString)(row->GetField(5));
159 mocchiut 1.21 chrtinit = (UInt_t)atoll(row->GetField(6));
160 mocchiut 1.1 } else {
161     throw -84;
162     };
163     } else {
164     throw -84;
165     };
166     delete result;
167     qu.str("");
168 mocchiut 1.18 qu << "SELECT FOLDER_NAME,FILE_NAME,OBT_TIME_SYNC,LAST_TIME_SYNC_INFO,TIME_OFFSET,BOOT_NUMBER,PKT_NUMBER_INIT,PKT_NUMBER_FINAL,PKT_OBT_INIT,PKT_OBT_FINAL,REAL_TIME_INIT from ROOT_TABLE where ID_N=" << ridn << ";";
169 mocchiut 1.1 if ( debug ) printf(" chewbacca: query is %s \n",qu.str().c_str());
170     result2 = conn->Query(qu.str().c_str());
171     if ( result2 ){
172     row2 = result2->Next();
173     if ( row2 ){
174 mocchiut 1.5 if ( KEEPENV ){
175     chpath = (TString)(row2->GetField(0))+'/';
176     } else {
177     chpath = (TString)gSystem->ExpandPathName(row2->GetField(0))+'/';
178     };
179 mocchiut 1.1 chfile = (TString)(row2->GetField(1));
180     chobtts = (UInt_t)atoll(row2->GetField(2));
181     chlastts = (UInt_t)atoll(row2->GetField(3));
182     chresursts = (UInt_t)atoll(row2->GetField(4));
183     chboot = (UInt_t)atoll(row2->GetField(5));
184     //
185 mocchiut 1.18 if ( !chboot ){
186     qu.str("");
187 mocchiut 1.21 // qu << "SELECT BOOT_NUMBER from ROOT_TABLE where BOOT_NUMBER!=0 AND ABS(LAST_TIME_SYNC_INFO-"<< chlastts <<")<10000 AND ABS(REAL_TIME_INIT-"<< row2->GetField(10) <<")<7200 group by BOOT_NUMBER order by BOOT_NUMBER asc;";
188 mocchiut 1.22 qu << "SELECT BOOT_NUMBER from ROOT_TABLE where BOOT_NUMBER!=0 AND ABS(LAST_TIME_SYNC_INFO-"<< chlastts <<")<40000 AND ABS(REAL_TIME_INIT-"<< row2->GetField(10) <<")<40000 group by BOOT_NUMBER order by BOOT_NUMBER asc;"; // relax conditions... 090112 [8RED: error -29]
189 mocchiut 1.18 if ( debug ) printf(" chewbacca: query is %s \n",qu.str().c_str());
190     result3 = conn->Query(qu.str().c_str());
191     if ( result3 ){
192     row3 = result3->Next();
193 mocchiut 1.19 if ( row3 && result3->GetRowCount() == 1 ){
194 mocchiut 1.18 chboot = (UInt_t)atoll(row3->GetField(0));
195     if ( debug ) printf(" Found boot_number = %u \n",chboot);
196     } else {
197     if ( debug ) printf(" AGH CANNOT DETERMINE THE BOOT NUMBER... \n");
198 mocchiut 1.19 throw -29;
199 mocchiut 1.18 };
200     };
201     };
202     //
203 mocchiut 1.1 chpktinit = (UInt_t)atoll(row2->GetField(6));
204     chpktfinal = (UInt_t)atoll(row2->GetField(7));
205     chobtinit = (UInt_t)atoll(row2->GetField(8));
206     chobtfinal = (UInt_t)atoll(row2->GetField(9));
207     //
208     } else {
209     throw -85;
210     };
211     } else {
212     throw -85;
213     };
214     filerootname = chpath + chfile;// + ".root";
215     };
216     this->SetRootName(filerootname);
217     };
218 mocchiut 1.13 if ( debug ) printf(" Filename is %s \n",filerootname.Data());
219     file = TFile::Open(this->GetRootName().Data());
220     // } else {
221     // this->SetRootName("");
222     // this->SetRootName(filerootname);
223     // };
224 mocchiut 1.1 }
225    
226     //
227     // must be out of the constructor in order to FORCE the validation of the latest runs in case you run the validation together with the latest file
228     //
229     void PamelaDBOperations::CheckValidate(Long64_t olderthan){
230     clean_time = new TDatime();
231     //
232     if(olderthan >= 0){
233     VALIDATE = true;
234     UInt_t timelim = 0;
235     timelim = (UInt_t)clean_time->Convert(true) - olderthan;
236     clean_time->Set(timelim,false);
237     };
238     };
239    
240     /**
241     * Open the DB connection
242     * @param host hostname for the SQL connection.
243     * @param user username for the SQL connection.
244     * @param password password for the SQL connection.
245     */
246     void PamelaDBOperations::SetConnection(TString host, TString user, TString password){
247     if ( IsDebug() ) printf(" Connecting using host = %s user = %s password = %s \n",host.Data(),user.Data(),password.Data());
248     conn = TSQLServer::Connect(host.Data(),user.Data(),password.Data());
249     };
250    
251     /**
252     * Store the ID of the ROOT file.
253     * @param idr ID of the ROOT file
254     */
255     void PamelaDBOperations::SetID_ROOT(UInt_t idr){
256     idroot=idr;
257     };
258    
259     /**
260     * Store the ID of the RAW file.
261     * @param idr ID of the RAW file
262     */
263     void PamelaDBOperations::SetID_RAW(UInt_t idr){
264     id=idr;
265     };
266    
267     /**
268     * Set the debug flag
269     *
270     */
271     void PamelaDBOperations::SetDebugFlag(Bool_t dbg){
272     debug = dbg;
273     };
274    
275     /**
276     * Set the autoboot flag
277     *
278     */
279     void PamelaDBOperations::SetAutoBoot(Bool_t dbg){
280     AUTOBOOT = dbg;
281     };
282    
283     /**
284     * Set the pedantic flag
285     *
286     */
287     void PamelaDBOperations::SetPedantic(Bool_t dbg){
288     PEDANTIC = dbg;
289     };
290    
291     /**
292     * Set the nofrag flag
293     *
294     */
295     void PamelaDBOperations::SetNoFrag(Bool_t nf){
296     NOFRAG = nf;
297     };
298    
299     /**
300     * Store the BOOT number of the RAW file.
301     * @param boot BOOT number of the RAW file
302     */
303     void PamelaDBOperations::SetBOOTnumber(UInt_t boot){
304     this->SetBOOTnumber(boot,false);
305     };
306    
307     /**
308     * Store the BOOT number of the RAW file.
309     * @param boot BOOT number of the RAW file
310     */
311     void PamelaDBOperations::SetBOOTnumber(UInt_t boot, Bool_t gpamela){
312     BOOTNO=boot;
313     if ( gpamela ){
314     stringstream oss;
315     TSQLResult *result = 0;
316     TSQLRow *row = 0;
317     if ( !boot ){
318     //
319     BOOTNO = 1;
320     //
321     // look in the DB for the last timesync and the last run
322     //
323     oss.str("");
324     oss << "SELECT BOOT_NUMBER FROM GL_RUN order by RUNHEADER_TIME desc limit 1;";
325     result = conn->Query(oss.str().c_str());
326     if ( result ){
327     row = result->Next();
328     if ( row ){
329     BOOTNO = (UInt_t)atoll(row->GetField(0)) + 1;
330     };
331     };
332     };
333     };
334     };
335    
336     /**
337     * Store the time sync of the RAW file.
338     * @param boot time sync
339     */
340     void PamelaDBOperations::SetTsync(UInt_t ts){
341     this->SetTsync(ts,false);
342     };
343    
344     /**
345     * Store the time sync of the RAW file.
346     * @param boot time sync
347     */
348     void PamelaDBOperations::SetTsync(UInt_t ts, Bool_t gpamela){
349     //
350     // if not gpamela or given tsync file set ts
351     //
352     tsync=ts;
353     if ( gpamela ){
354     stringstream oss;
355     TSQLResult *result = 0;
356     TSQLRow *row = 0;
357     TSQLResult *result2 = 0;
358     TSQLRow *row2 = 0;
359     if ( !ts ){
360     //
361     tsync = 1;
362     //
363     // look in the DB for the last timesync and the last run
364     //
365     oss.str("");
366     oss << "SELECT TIMESYNC FROM GL_TIMESYNC order by TIMESYNC desc limit 1;";
367     result = conn->Query(oss.str().c_str());
368     if ( result ){
369     row = result->Next();
370     if ( row ){
371     tsync = (UInt_t)atoll(row->GetField(0)) + 1;
372     oss.str("");
373     oss << "SELECT (RUNTRAILER_TIME-RUNHEADER_TIME) FROM GL_RUN order by RUNHEADER_TIME desc limit 1;";
374     result2 = conn->Query(oss.str().c_str());
375     if ( result2 ){
376     row2 = result2->Next();
377     if ( row2 ){
378     tsync += (UInt_t)atoll(row2->GetField(0));
379     };
380     }
381     };
382     };
383     };
384     };
385     };
386    
387     /**
388     * Store the time sync of the RAW file.
389     * @param boot time sync
390     */
391     void PamelaDBOperations::SetObt0(UInt_t ts){
392     obt0=ts;
393     };
394    
395     /**
396     * Store the RAW filename.
397     * @param str the RAW filename.
398     */
399     void PamelaDBOperations::SetRawName(TString str){
400     filerawname=str;
401     };
402    
403     /**
404     * Store the ROOT filename.
405     * @param str the ROOT filename.
406     */
407     void PamelaDBOperations::SetRootName(TString str){
408     filerootname=str;
409     };
410    
411     /**
412     * Store the downlink orbit number from filename.
413     */
414     void PamelaDBOperations::SetOrbitNo(UInt_t dwinput){
415     dworbit = 0;
416     //
417     if ( dwinput ){
418     dworbit = dwinput;
419     if ( IsDebug() && !chewbacca ) printf(" Downlink orbit given by hand: %i \n",dworbit);
420     return;
421     };
422     //
423 mocchiut 1.13 if ( !chewbacca ){
424     TString name = this->GetRootFile();
425     Int_t nlength = name.Length();
426     if ( nlength < 5 ){
427     if ( IsDebug() ) printf(" Agh problems determining the orbit number! name = %s \n",name.Data());
428     return;
429     };
430 pizzolot 1.24 TString dwo = "";
431 mocchiut 1.13 for (Int_t i = 0; i<5; i++){
432 mocchiut 1.1 dwo.Append(name[i],1);
433 mocchiut 1.13 };
434     if ( dwo.IsDigit() ){
435     dworbit = (UInt_t)dwo.Atoi();
436     } else {
437     dwo="";
438     for (Int_t i = 8; i<13; i++){
439     dwo.Append(name[i],1);
440     };
441     if ( dwo.IsDigit() ) dworbit = (UInt_t)dwo.Atoi();
442     };
443     if ( IsDebug() ) printf(" Downlink orbit is %i (dwo = %s) \n",dworbit,dwo.Data());
444 mocchiut 1.1 };
445     return;
446     };
447    
448    
449    
450     /**
451     * Store the NOBOOT flag.
452     * @param noboot true/false.
453     */
454     void PamelaDBOperations::SetNOBOOT(Bool_t noboot){
455     NOBOOT = noboot;
456     };
457    
458     /**
459     * Store path to the TLE file.
460     */
461     void PamelaDBOperations::SetTLEPath(TString str){
462     tlefilename = str;
463     };
464    
465     TString PamelaDBOperations::GetRawPath(){
466     if ( STATIC ){
467     return((TString)gSystem->DirName(filerawname.Data())+'/');
468     } else {
469     return((TString)gSystem->ExpandPathName("$PAM_RAW")+'/');
470     };
471     };
472    
473     TString PamelaDBOperations::GetRootPath(){
474     if ( STATIC ){
475 mocchiut 1.5 return((TString)gSystem->DirName(this->GetRootName().Data())+'/');
476     } else {
477     if ( KEEPENV ){
478     return((TString)gSystem->ExpandPathName(gSystem->DirName(filerootname.Data()))+'/');
479     } else {
480     return((TString)gSystem->ExpandPathName("$PAM_L0")+'/');
481     };
482 mocchiut 1.1 };
483     };
484    
485     /**
486     * Store the olderthan variable
487     * @param olderthan
488     */
489     // void PamelaDBOperations::SetOlderThan(Long64_t oldthan){
490     // olderthan = oldthan;
491     // };
492    
493     /**
494     * Retrieve the ID_RAW, if exists, returns NULL if does not exist.
495     */
496     Bool_t PamelaDBOperations::SetID_RAW(){
497     stringstream oss;
498     TSQLResult *result = 0;
499     TSQLRow *row = 0;
500     oss.str("");
501     if ( STATIC ){
502     oss << "SELECT ID FROM GL_RAW WHERE "
503     << " PATH = '" << this->GetRawPath().Data() << "' AND "
504     << " NAME = '" << this->GetRawFile().Data() << "' ";
505     } else {
506     oss << "SELECT ID FROM GL_RAW WHERE "
507     << " PATH = '$PAM_RAW' AND "
508     << " NAME = '" << this->GetRawFile().Data() << "' ";
509     }
510     result = conn->Query(oss.str().c_str());
511     if ( result == NULL ) throw -4;
512     row = result->Next();
513     if ( !row ) return(false);
514     id = (UInt_t)atoll(row->GetField(0));
515     delete result;
516     return(true);
517     }
518    
519     /**
520     *
521     * Set the variables which have to be stored in the GL_RUN table and that do not depend on the RUN
522     *
523     */
524     void PamelaDBOperations::SetCommonGLRUN(UInt_t absth, UInt_t abstt){
525     glrun->SetBOOTNUMBER(BOOTNO);
526     glrun->SetRUNHEADER_TIME(absth);
527     glrun->SetRUNTRAILER_TIME(abstt);
528     glrun->SetID_ROOT_L2(0);
529     glrun->SetID_ROOT_L0(idroot);
530     glrun->SetVALIDATION(0);
531     };
532    
533     /**
534 mocchiut 1.2 *
535     * Set the variables which belogns to physendrun tree
536     *
537     */
538     void PamelaDBOperations::SetPhysEndRunVariables(){
539     //
540     //
541     //
542     TTree *T = 0;
543     T = (TTree*)file->Get("PhysEndRun");
544     if ( !T || T->IsZombie() ) throw -90;
545     //
546     PhysEndRunEvent *pher= 0;
547     EventHeader *eh = 0;
548     T->SetBranchAddress("PhysEndRun", &pher);
549     T->SetBranchAddress("Header", &eh);
550     //
551     UInt_t phobt = 0;
552     UInt_t phpkt = 0;
553     //
554     glrun->SetPHYSENDRUN_MASK_S3S2S12(0);
555     glrun->SetPHYSENDRUN_MASK_S11CRC(0);
556     //
557     for (Int_t p=0; p<T->GetEntries(); p++){
558     //
559     T->GetEntry(p);
560     //
561     phobt = (UInt_t)eh->GetPscuHeader()->GetOrbitalTime();
562     phpkt = (UInt_t)eh->GetPscuHeader()->GetCounter();
563     //
564     if ( this->PKT(phpkt) >= this->PKT(glrun->GetRUNHEADER_PKT()) && this->PKT(phpkt) <= this->PKT(glrun->GetRUNTRAILER_PKT()) && this->OBT(phobt) >= this->OBT(glrun->GetRUNHEADER_OBT()) && this->OBT(phobt) <= this->OBT(glrun->GetRUNTRAILER_OBT()) ){
565     if ( glrun->GetPHYSENDRUN_MASK_S3S2S12() || glrun->GetPHYSENDRUN_MASK_S11CRC() ){
566     if ( IsDebug() ) printf(" WARNING while looping in physendrun: found two PhysEndRun packet for the same RUN! \n");
567     if ( IsDebug() ) printf(" Actual values: %X %X New values %X %X \n ",glrun->GetPHYSENDRUN_MASK_S3S2S12(),glrun->GetPHYSENDRUN_MASK_S11CRC(),(UInt_t)pher->TB_ENDRUN.TB_PMT_MASK_S3S2S12,(UInt_t)pher->TB_ENDRUN.TB_PMT_MASK_S11CRC);
568     if ( PEDANTIC && IsDebug() ) printf(" ERROR while looping in physendrun: found two PhysEndRun packet for the same RUN!\n ");
569     if ( PEDANTIC ) throw -91;
570     } else {
571     glrun->SetPHYSENDRUN_MASK_S3S2S12((UInt_t)pher->TB_ENDRUN.TB_PMT_MASK_S3S2S12);
572     glrun->SetPHYSENDRUN_MASK_S11CRC((UInt_t)pher->TB_ENDRUN.TB_PMT_MASK_S11CRC);
573     };
574     };
575     };
576     //
577     };
578    
579     /**
580 mocchiut 1.1 * Patch, look for upper limits to avoid processing retransmitted data
581     */
582     Int_t PamelaDBOperations::SetUpperLimits(){
583     UInt_t nevent = 0;
584     UInt_t pktlast = 0;
585     UInt_t obtlast = 0;
586     Long64_t t_pktlast = 0LL;
587     // UInt_t t_obtlast = 0;
588     Long64_t t_obtlast = 0LL;
589     Long64_t upperpkt2 = 0LL;
590     Long64_t upperobt2 = 0LL;
591     UInt_t zomp = 0;
592     UInt_t jump = 50000; // was 5000
593     EventCounter *code=0;
594     //
595     Long64_t deltapkt = 5000LL;
596     Long64_t deltaobt = 50000LL;
597     //
598     pcksList packetsNames;
599     pcksList::iterator Iter;
600     getPacketsNames(packetsNames);
601     //
602     pktfirst = 0;
603     obtfirst = 0;
604     ppktfirst = 0;
605     pobtfirst = 0;
606     //
607     //
608     //
609     TTree *T = 0;
610     T = (TTree*)file->Get("Physics");
611     if ( !T || T->IsZombie() ) throw -16;
612     EventHeader *eh = 0;
613     PscuHeader *ph = 0;
614     T->SetBranchAddress("Header", &eh);
615     nevent = T->GetEntries();
616     //
617     T->GetEntry(0);
618     ph = eh->GetPscuHeader();
619    
620     if ( chewbacca ){
621     if ( IsDebug() ) printf(" FROM CHEWBACCA: upperpkt %u upperobt %u lowerpkt %u lowerobt %u \n",chpktmax,chobtmax,chpktmin,chobtmin);
622     ppktfirst = chpktmin;
623     pobtfirst = chobtts*1000;
624     } else {
625     //
626     pktfirst = ph->GetCounter();
627     obtfirst = ph->GetOrbitalTime();
628     ppktfirst = pktfirst;
629     pobtfirst = obtfirst; // to be changed AFTER time sync determination this is a profiler bug!
630     };
631     //
632     code = eh->GetCounter();
633     UInt_t en = 0;
634     // if ( !chewbacca ){
635     for(Iter = packetsNames.begin(); Iter != packetsNames.end(); Iter++){
636     en = code->Get(GetPacketType(*Iter));
637     if ( !strcmp("CalibCalPed",*Iter) || !strcmp("CalibTrk1",*Iter) || !strcmp("CalibTrk2",*Iter) || !strcmp("CalibS4",*Iter) ){
638     if ( IsDebug() ) printf(" We have a calibration before the first physic packet: packet type is %s, entries: %i \n",*Iter,en);
639     //
640     TTree *TC = 0;
641     TC = (TTree*)file->Get("CalibCalPed");
642     if ( !TC || TC->IsZombie() ) throw -16;
643     EventHeader *ehc = 0;
644     PscuHeader *phc = 0;
645     TC->SetBranchAddress("Header", &ehc);
646     TC->GetEntry(0);
647     phc = ehc->GetPscuHeader();
648     pktfirst = phc->GetCounter();
649     obtfirst = phc->GetOrbitalTime();
650     //
651     };
652     };
653     //
654     T->GetEntry(nevent-1);
655     ph = eh->GetPscuHeader();
656     pktlast = ph->GetCounter();
657     obtlast = ph->GetOrbitalTime();
658     //
659     // paranoid check
660     //
661     if ( chewbacca ) {
662     //
663     // query the ROOT_TABLE to find upper and lower limits of the file and compare them to the given interval
664     //
665     if ( IsDebug() ) printf(" Is good if \n");
666     if ( IsDebug() ) printf("PKT(chpktfinal) >= PKT(chpktmax) && PKT(chpktinit) <= PKT(chpktmin) && OBT(chobtfinal) >= OBT(chobtmax) && OBT(chobtinit) <= OBT(chobtmin) \n");
667     if ( IsDebug() ) printf(" %llu >= %llu && %llu <= %llu && %llu >= %llu && %llu <= %llu \n",PKT(chpktfinal),PKT(chpktmax),PKT(chpktinit),PKT(chpktmin),OBT(chobtfinal),OBT(chobtmax),OBT(chobtinit),OBT(chobtmin));
668     if ( PKT(chpktfinal) >= PKT(chpktmax) && PKT(chpktinit) <= PKT(chpktmin) && OBT(chobtfinal) >= OBT(chobtmax) && OBT(chobtinit) <= OBT(chobtmin) ){
669     if ( IsDebug() ) printf(" OK, the file contains the chewbacca interval\n");
670     } else {
671     if ( IsDebug() ) printf(" Bah, the file seems to be the wrong one, the chewbacca interval is not contained in the file... is the DB correctly filled??\n");
672     if ( PEDANTIC ) throw -89;
673     };
674     };
675     //
676     nrtbef = 0;
677     nrtaf = 0;
678     nrtbef = 0;
679     nrtaf = 0;
680     //
681     if ( chewbacca ){
682     pktfirst = chpktmin;
683     obtfirst = chobtmin;
684     pktlast = chpktmax;
685     obtlast = chobtmax;
686     upperpkt = PKT(chpktmax);
687     upperobt = OBT(chobtmax);
688     pktlast = numeric_limits<UInt_t>::max();
689     Int_t it = 0;
690     UInt_t tjump = 50000;
691     //UInt_t tjump = 100;
692     while ( tjump > 0 ){
693 mocchiut 1.9 // pktlast = numeric_limits<UInt_t>::max();
694     pktlast = chpktmax + 1;
695 mocchiut 1.8 while ( PKT(pktlast) > PKT(chpktmax) && (Int_t)(nevent-1-it) >= 0 ){
696 mocchiut 1.1 if ( (Int_t)(nevent-1-it) >= 0 ){
697     T->GetEntry(nevent-1-it);
698     ph = eh->GetPscuHeader();
699     pktlast = ph->GetCounter();
700     } else {
701     pktlast = chpktmax + 1;
702     };
703 mocchiut 1.8 if ( (!(it%1000) || abs((int)(PKT(pktlast) - PKT(chpktmax)))<1000 ) && debug ) printf(" look for up %i %i %i nevent %u (nevent-1-it) %i \n",it,pktlast,chpktmax,nevent,(Int_t)(nevent-1-it));
704 mocchiut 1.1 it += tjump;
705     };
706     if ( tjump > 1 ) it -= 2*tjump;
707     if ( it < 0 ) it = 0;
708     //
709     if ( debug ) printf(" - look for up %i %i %i nevent %u (nevent-1-it) %i \n",it,pktlast,chpktmax,nevent,(Int_t)(nevent-1-it));
710     if ( debug ) printf(" - up , tjump was %u it was %u \n",tjump,it);
711     if ( tjump == 1 ) tjump = 0;
712     if ( tjump == 10 ) tjump = 1;
713     if ( tjump == 100 ) tjump = 10;
714     if ( tjump == 1000 ) tjump = 100;
715     if ( tjump == 5000 ) tjump = 1000;
716     if ( tjump == 50000 ) tjump = 5000;
717     //
718     };
719     Int_t tupperentry = (Int_t)nevent-1-(Int_t)it+1;//+1+1;
720     if ( tupperentry < 0 ) tupperentry = 0;
721     upperentry = tupperentry;
722     it = 0;
723     pktlast = 0;
724     tjump = 50000;
725     //tjump = 100;
726     while ( tjump > 0 ){
727 mocchiut 1.9 // pktlast = 0;
728     pktlast = chpktmin - 1;
729     if ( debug ) printf("LLlook for down %i %i %llu %llu \n",it,pktlast,PKT(pktlast),PKT(chpktmin));
730 mocchiut 1.8 while ( PKT(pktlast) < PKT(chpktmin) && it < (Int_t)nevent ){
731 mocchiut 1.1 if ( it < (Int_t)nevent ){
732     T->GetEntry(it);
733     ph = eh->GetPscuHeader();
734     pktlast = ph->GetCounter();
735     } else {
736     // pktlast = chpktmax - 1;
737     pktlast = chpktmin - 1;
738     };
739     if ( !(it%1000) && debug ) printf("look for down %i %i %i \n",it,pktlast,chpktmin);
740     it += tjump;
741     };
742     if ( tjump > 1 ) it -= 2*tjump;
743     if ( it < 0 ) it = 0;
744     //
745     if ( debug ) printf(" down , tjump was %u it was %u \n",tjump,it);
746     if ( tjump == 1 ) tjump = 0;
747     if ( tjump == 10 ) tjump = 1;
748     if ( tjump == 100 ) tjump = 10;
749     if ( tjump == 1000 ) tjump = 100;
750     if ( tjump == 5000 ) tjump = 1000;
751     if ( tjump == 50000 ) tjump = 5000;
752     //
753     };
754     Int_t tchminentry = (Int_t)it-1;//-1+1;
755     if ( tchminentry < 0 ) tchminentry = 0;
756     chminentry = tchminentry;
757     //
758     if ( debug ) printf(" Chewbacca: chminentry %i chmaxentry %i delta %i nevent %i \n",chminentry,upperentry,upperentry-chminentry,nevent);
759     //
760     //
761     //
762     TTree *rh=(TTree*)file->Get("RunHeader");
763     if ( !rh || rh->IsZombie() ) throw -17;
764     TTree *rt=(TTree*)file->Get("RunTrailer");
765     if ( !rt || rt->IsZombie() ) throw -18;
766     //
767     rh->SetBranchAddress("RunHeader", &runh);
768     rh->SetBranchAddress("Header", &ehh);
769     //
770     rt->SetBranchAddress("RunTrailer", &runt);
771     rt->SetBranchAddress("Header", &eht);
772     //
773     rhev = rh->GetEntries();
774     rtev = rt->GetEntries();
775     //
776     if ( IsDebug() ){
777     for (Int_t rr=0; rr<rh->GetEntries(); rr++){
778     rh->GetEntry(rr);
779     phh = ehh->GetPscuHeader();
780     printf(" RUNHEADER %i OBT %u PKT %u \n",rr,phh->GetOrbitalTime(),phh->GetCounter());
781     };
782     for (Int_t rr=0; rr<rt->GetEntries(); rr++){
783     rt->GetEntry(rr);
784     pht = eht->GetPscuHeader();
785     printf(" RUNTRAILER %i OBT %u PKT %u \n",rr,pht->GetOrbitalTime(),pht->GetCounter());
786     };
787     };
788     //
789     nrhev = 0;
790     nrhbef = 0;
791     nrhaf = 0;
792     for (Int_t rr=0; rr<rh->GetEntries(); rr++){
793     rh->GetEntry(rr);
794     phh = ehh->GetPscuHeader();
795     if ( debug ) printf(" RRRRRRR %llu %llu %llu %llu %llu %llu \n",PKT(phh->GetCounter()),PKT(pktfirst),upperpkt,OBT(obtfirst),OBT(phh->GetOrbitalTime()),upperobt);
796     if ( PKT(phh->GetCounter()) >= PKT(pktfirst) && PKT(phh->GetCounter()) <= upperpkt && OBT(phh->GetOrbitalTime()) >= OBT(obtfirst) && OBT(phh->GetOrbitalTime()) <= upperobt ){
797     nrhev++;
798     if ( debug ) printf(" ++++ RH %i \n",nrhev);
799     };
800     if ( !nrhev ) nrhbef++;
801     if ( (nrhev && (nrhev+1+nrhbef+1) == rr) || nrhaf ) nrhaf++;
802     };
803     nrtev = 0;
804     nrtbef = 0;
805     nrtaf = 0;
806     for (Int_t rr=0; rr<rt->GetEntries(); rr++){
807     rt->GetEntry(rr);
808     pht = eht->GetPscuHeader();
809     if ( debug ) printf(" TTTTTTT %llu %llu %llu %llu %llu %llu \n",PKT(pht->GetCounter()),PKT(pktfirst),upperpkt,OBT(obtfirst),OBT(pht->GetOrbitalTime()),upperobt);
810     if ( PKT(pht->GetCounter()) >= PKT(pktfirst) && PKT(pht->GetCounter()) <= upperpkt && OBT(pht->GetOrbitalTime()) >= OBT(obtfirst) && OBT(pht->GetOrbitalTime()) <= upperobt ){
811     nrtev++;
812     if ( debug ) printf(" ++++ RT %i \n",nrtev);
813     };
814     if ( !nrtev ) nrtbef++;
815     if ( (nrtev && (nrtev+1+nrtbef+1) == rr) || nrtaf ) nrtaf++;
816     };
817     if ( debug ) printf(" NUMBER OF RH %i RT %i IN THE INTERVAL, NUMBER OF TOTAL RH %i RT %i \n",nrhev,nrtev,rhev,rtev);
818     if ( debug ) printf(" RH before %i RH after %i -- RT before %i RT after %i \n",nrhbef,nrhaf,nrtbef,nrtaf);
819     //
820     T->GetEntry(upperentry);
821     ph = eh->GetPscuHeader();
822     pktlast = ph->GetCounter();
823     nevent = upperentry - chminentry;
824 mocchiut 1.21 if ( ((Int_t)upperentry - (Int_t)chminentry) < 0 ) nevent = 0; // nevent is UInt_t! 090112 [8RED: error -88]
825     if ( IsDebug() ) printf(" Setting nevent to %u - upperentry %i chminentry %i \n",nevent,upperentry,chminentry);
826 mocchiut 1.1 //
827     } else {
828     upperpkt = PKT(pktlast);
829     upperobt = OBT(obtlast);
830     upperentry = nevent-1;
831     };
832     //
833     if ( chewbacca && nevent < 1 ) {
834 mocchiut 1.21 if ( IsDebug() ) printf(" chewbacca and no events in the file \n");
835 mocchiut 1.2 pktfirst = chpktmin;
836     upperpkt = PKT(chpktmax);
837     pktlast = chpktmax;
838     obtfirst = chobtmin;
839     obtlast = chobtmax;
840     upperobt = OBT(chobtmax);
841 mocchiut 1.1 };
842     //
843     if ( IsDebug() ) printf(" First entries are: OBT %u pkt_num %u entry %i\n",obtfirst,pktfirst,chminentry);
844     //
845     if ( IsDebug() ) printf(" Last entries are: OBT %lld pkt_num %lld entry %i\n",upperobt,upperpkt,upperentry);
846     //
847     if ( (PKT(pktlast) < PKT(pktfirst) && OBT(obtlast) > OBT(obtfirst)) || (PKT(pktlast) > PKT(pktfirst) && OBT(obtlast) < OBT(obtfirst)) ){
848 mocchiut 1.2 if ( IsDebug() ) printf(" Inconsistent PKT/OBT sequence: \n (PKT(pktlast) < PKT(pktfirst) && OBT(obtlast) > OBT(obtfirst)) %llu < %llu && %llu > %llu \n OR \n (PKT(pktlast) > PKT(pktfirst) && OBT(obtlast) < OBT(obtfirst)) %llu > %llu && %llu < %llu \n",PKT(pktlast),PKT(pktfirst),OBT(obtlast),OBT(obtfirst),PKT(pktlast),PKT(pktfirst),OBT(obtlast),OBT(obtfirst));
849     if ( PEDANTIC ) throw -88;
850     return(32);
851 mocchiut 1.1 };
852     //
853     if ( !nevent ) return(64);
854     //
855     if ( nevent < 2 ) return(128);
856     if ( nevent < jump ) jump = 1;
857     // if ( nevent < jump ) jump = int(nevent/10);
858     // if ( !jump ) jump = 1;
859     //
860     if ( (PKT(pktlast) < PKT(pktfirst) && OBT(obtlast) < OBT(obtfirst)) || (labs(PKT(pktlast)-PKT(pktfirst))<deltapkt && labs(OBT(obtlast)-OBT(obtfirst))<deltaobt) && nevent > deltapkt ){
861     //
862     if ( IsDebug() ) printf(" starting jump %i \n",jump);
863     // if ( IsDebug() ) printf(" (PKT(pktlast) < PKT(pktfirst) && OBT(obtlast) > OBT(obtfirst)) %llu < %llu && %llu > %llu \n OR \n (PKT(pktlast) > PKT(pktfirst) && OBT(obtlast) < OBT(obtfirst)) %llu > %llu && %llu < %llu \n",PKT(pktlast),PKT(pktfirst),OBT(obtlast),OBT(obtfirst),PKT(pktlast),PKT(pktfirst),OBT(obtlast),OBT(obtfirst));
864     if ( IsDebug() ) printf(" labs(PKT(pktlast)-PKT(pktfirst) %lu < deltapkt %lld && labs(OBT(obtlast)-OBT(obtfirst)) %lu <deltaobt %lld && nevent %u > deltapkt %lld \n",(labs(PKT(pktlast)-PKT(pktfirst))),deltapkt, labs(OBT(obtlast)-OBT(obtfirst)),deltaobt, nevent, deltapkt);
865     if ( PEDANTIC ) throw -66;
866     // go back
867     zomp = nevent - 2;
868     //
869     while ( jump > 0 ){
870     //
871     t_pktlast = PKT(pktlast);
872     t_obtlast = OBT(obtlast);
873     //
874     for (UInt_t i = zomp; i>1; i-=jump){
875     //
876     if ( i >= 0 ) T->GetEntry(i);
877     ph = eh->GetPscuHeader();
878     upperpkt = PKT(ph->GetCounter());
879     upperobt = OBT(ph->GetOrbitalTime());
880     upperentry = i;
881     //
882     if ( (i-1) >= 0 ) T->GetEntry(i-1);
883     ph = eh->GetPscuHeader();
884     upperpkt2 = PKT(ph->GetCounter());
885     upperobt2 = OBT(ph->GetOrbitalTime());
886     //
887     if ( (t_pktlast < upperpkt && t_obtlast > upperobt) || (t_pktlast < upperpkt2 && t_obtlast > upperobt2) ){
888     if ( IsDebug() ) printf(" .-. upperpkt2 %lld upperobt2 %lld \n",upperpkt2,upperobt2);
889     if ( IsDebug() ) printf(" .-. upperpkt %lld t_pktlast %lld upperobt %lld t_obtlast %lld \n",upperpkt,t_pktlast,upperobt,t_obtlast);
890     if ( IsDebug() ) printf(" .-. jump %i zomp %i upperpkt %lld pktlast %u upperobt %lld obtlast %u last entry is %i \n",jump,zomp,upperpkt,pktlast,upperobt,obtlast,i);
891     throw -13;
892     };
893     //
894     if ( t_pktlast < upperpkt && t_obtlast < upperobt && t_pktlast < upperpkt2 && t_obtlast < upperobt2 ){
895     zomp = i + jump + 1;
896     if ( zomp > nevent-2 ) zomp = nevent - 2;
897     if ( IsDebug() ) printf(" .-. jump %i zomp %i upperpkt %lld pktlast %u upperobt %lld obtlast %u last entry is %i \n",jump,zomp,upperpkt,pktlast,upperobt,obtlast,i);
898     break;
899     };
900     //
901     t_pktlast = upperpkt;
902     t_obtlast = upperobt;
903     };
904     //
905     if ( jump == 1 ) jump = 0;
906     if ( jump == 10 ) jump = 1;
907     if ( jump == 100 ) jump = 10;
908     if ( jump == 1000 ) jump = 100;
909     if ( jump == 5000 ) jump = 1000;
910     if ( jump == 50000 ) jump = 5000;
911     //
912     };
913     //
914     };
915     //
916     // check if last runtrailer is within limits, if not extend limits (one should check for all packets but we need only runtrailer)
917     //
918     if ( !chewbacca ){
919     PacketType *pctp=0;
920     TTree *rh=(TTree*)file->Get("RunHeader");
921     if ( !rh || rh->IsZombie() ) throw -17;
922     TTree *rt=(TTree*)file->Get("RunTrailer");
923     if ( !rt || rt->IsZombie() ) throw -18;
924     //
925     rh->SetBranchAddress("RunHeader", &runh);
926     rh->SetBranchAddress("Header", &ehh);
927     //
928     rt->SetBranchAddress("RunTrailer", &runt);
929     rt->SetBranchAddress("Header", &eht);
930     //
931     rhev = rh->GetEntries();
932     rtev = rt->GetEntries();
933     Long64_t sobtt = 0LL;
934     Long64_t sobth = 0LL;
935     Long64_t spktt = 0LL;
936     Long64_t spkth = 0LL;
937     Long64_t pktt = 0LL;
938     Long64_t obtt = 0LL;
939     Long64_t pkth = 0LL;
940     Long64_t obth = 0LL;
941     //
942     if ( rhev || rtev ){
943    
944     T->GetEntry(upperentry);
945     code = eh->GetCounter();
946     Int_t lasttrail = code->Get(pctp->RunTrailer);
947     Int_t lasthead = code->Get(pctp->RunHeader);
948     if ( lasttrail < rtev ){
949     rt->GetEntry(lasttrail);
950     pht = eht->GetPscuHeader();
951     pktt = PKT(pht->GetCounter());
952     obtt = OBT(pht->GetOrbitalTime());
953     };
954     //
955     if ( lasthead < rhev ){
956     rh->GetEntry(lasthead);
957     phh = ehh->GetPscuHeader();
958     pkth = PKT(phh->GetCounter());
959     obth = OBT(phh->GetOrbitalTime());
960     };
961     //
962     if ( IsDebug() ) printf(" rhev before %i ph %lld upperp %lld oh %lld uppero %lld \n",rhev,pkth,upperpkt,obth,upperobt);
963     if ( pkth > upperpkt && obth > upperobt ){
964     if ( IsDebug() ) printf(" Upper limits extended to include last header: ph %lld upperp %lld oh %lld uppero %lld \n",pkth,upperpkt,obth,upperobt);
965     upperpkt = pkth;
966     upperobt = obth;
967     rhev = lasthead+1;
968     } else {
969     rhev = lasthead;
970     };
971     if ( IsDebug() ) printf(" rhev after %i ph %lld upperp %lld oh %lld uppero %lld \n",rhev,pkth,upperpkt,obth,upperobt);
972     //
973     if ( IsDebug() ) printf(" rtev beforev %i pt %lld upperp %lld ot %lld uppero %lld \n",rtev,pktt,upperpkt,obtt,upperobt);
974     if ( pktt > upperpkt && obtt > upperobt ){
975     if ( IsDebug() ) printf(" Upper limits extended to include last trailer: pt %lld upperp %lld ot %lld uppero %lld \n",pktt,upperpkt,obtt,upperobt);
976     upperpkt = pktt;
977     upperobt = obtt;
978     rtev = lasttrail+1;
979     } else {
980     rtev = lasttrail;
981     };
982     if ( IsDebug() ) printf(" rtev after %i pt %lld upperp %lld ot %lld uppero %lld \n",rtev,pktt,upperpkt,obtt,upperobt);
983     // goto kikko;
984     //
985     //
986     // Check if runtrailer/runheader are within lower limits
987     //
988     //
989     pkth = 0LL;
990     obth = 0LL;
991     spkth = 0LL;
992     sobth = 0LL;
993     for (Int_t k=0; k<rhev; k++){
994     if ( k > 0 ){
995     spkth = pkth;
996     sobth = obth;
997     };
998     rh->GetEntry(k);
999     phh = ehh->GetPscuHeader();
1000     pkth = PKT(phh->GetCounter());
1001     obth = OBT(phh->GetOrbitalTime());
1002     //
1003     // if ( IsDebug() ) printf(" k %i rhev before %i ph %u upperp %u oh %u uppero %u \n",k,rhev,pkth,spkth,obth,sobth);
1004     //
1005     if ( pkth < spkth && obth < sobth ){
1006     if ( IsDebug() ) printf(" RH PROBLEMS determining the event repetition at the end of the file lasthead %i \n",rhev);
1007     if ( PEDANTIC ) throw -66;
1008     //
1009     rhev = k-1;
1010     rh->GetEntry(rhev);
1011     pkth = spkth;
1012     obth = sobth;
1013     //
1014     UInt_t evbefh = 0;
1015     code = ehh->GetCounter();
1016     evbefh = code->Get(pctp->Physics);
1017     if ( evbefh >= 0 ){
1018     T->GetEntry(evbefh);
1019     ph = eh->GetPscuHeader();
1020     t_pktlast = PKT(ph->GetCounter());
1021     t_obtlast = OBT(ph->GetOrbitalTime());
1022     if ( t_pktlast <= spkth && t_obtlast <= sobth ){ // jump
1023     upperpkt = pkth;
1024     upperobt = obth;
1025     upperentry = evbefh-1;
1026     } else {
1027     while ( t_pktlast > spkth && t_obtlast > sobth && evbefh < nevent ){
1028     evbefh++;
1029     T->GetEntry(evbefh);
1030     ph = eh->GetPscuHeader();
1031     t_pktlast = PKT(ph->GetCounter());
1032     t_obtlast = OBT(ph->GetOrbitalTime());
1033     };
1034     T->GetEntry(evbefh-1);
1035     ph = eh->GetPscuHeader();
1036     upperpkt = PKT(ph->GetCounter());
1037     upperobt = OBT(ph->GetOrbitalTime());
1038     upperentry = evbefh-1;
1039     };
1040     };
1041     if ( IsDebug() ) printf(" rhev after %i ph %lld upperp %lld oh %lld uppero %lld \n",rhev,pkth,upperpkt,obth,upperobt);
1042     goto kikko0;
1043     };
1044     };
1045     kikko0:
1046     //
1047     //
1048     //
1049     pktt = 0LL;
1050     obtt = 0LL;
1051     spktt = 0LL;
1052     sobtt = 0LL;
1053     for (Int_t k=0; k<rtev; k++){
1054     if ( k > 0 ){
1055     spktt = pktt;
1056     sobtt = obtt;
1057     };
1058     rt->GetEntry(k);
1059     pht = eht->GetPscuHeader();
1060     pktt = PKT(pht->GetCounter());
1061     obtt = OBT(pht->GetOrbitalTime());
1062     //
1063     // if ( IsDebug() ) printf(" k %i rtev beforev %i pt %i upperp %i ot %llu uppero %llu \n",k,rtev,pktt,spktt,obtt,sobtt);
1064     //
1065     if ( pktt < spktt && obtt < sobtt ){
1066     if ( IsDebug() ) printf(" RT PROBLEMS determining the event repetition at the end of the file lasttrail %i \n",rtev);
1067     if ( PEDANTIC ) throw -66;
1068     //
1069     rtev = k-1;
1070     rt->GetEntry(rtev);
1071     pktt = spktt;
1072     obtt = sobtt;
1073     if ( IsDebug() ) printf(" lasttrail %i pt %lld upperp %lld ot %lld uppero %lld \n",rtev,pktt,upperpkt,obtt,upperobt);
1074     //
1075     UInt_t evbeft = 0;
1076     code = eht->GetCounter();
1077     evbeft = code->Get(pctp->Physics);
1078     if ( evbeft >= 0 ){
1079     T->GetEntry(evbeft);
1080     ph = eh->GetPscuHeader();
1081     t_pktlast = PKT(ph->GetCounter());
1082     t_obtlast = OBT(ph->GetOrbitalTime());
1083     if ( t_pktlast <= spktt && t_obtlast <= sobtt ){ // jump
1084     upperpkt = pktt;
1085     upperobt = obtt;
1086     upperentry = evbeft-1;
1087     } else {
1088     while ( t_pktlast > spktt && t_obtlast > sobtt && evbeft < nevent ){
1089     evbeft++;
1090     T->GetEntry(evbeft);
1091     ph = eh->GetPscuHeader();
1092     t_pktlast = PKT(ph->GetCounter());
1093     t_obtlast = OBT(ph->GetOrbitalTime());
1094     };
1095     T->GetEntry(evbeft-1);
1096     ph = eh->GetPscuHeader();
1097     upperpkt = PKT(ph->GetCounter());
1098     upperobt = OBT(ph->GetOrbitalTime());
1099     upperentry = evbeft-1;
1100     };
1101     };
1102     if ( IsDebug() ) printf(" rtev after %i pt %lld upperp %lld ot %lld uppero %lld \n",rtev,pktt,upperpkt,obtt,upperobt);
1103     goto kikko;
1104     // break;
1105     //
1106     };
1107     //
1108     };
1109     //
1110     kikko:
1111     //
1112     T->GetEntry(upperentry);
1113     code = eh->GetCounter();
1114     lasttrail = code->Get(pctp->RunTrailer);
1115     lasthead = code->Get(pctp->RunHeader);
1116     if ( lasttrail < rtev ){
1117     rt->GetEntry(lasttrail);
1118     pht = eht->GetPscuHeader();
1119     pktt = PKT(pht->GetCounter());
1120     obtt = OBT(pht->GetOrbitalTime());
1121     };
1122     //
1123     if ( lasthead < rhev ){
1124     rh->GetEntry(lasthead);
1125     phh = ehh->GetPscuHeader();
1126     pkth = PKT(phh->GetCounter());
1127     obth = OBT(phh->GetOrbitalTime());
1128     };
1129     //
1130     if ( IsDebug() ) printf(" rhev before %i ph %lld upperp %lld oh %lld uppero %lld \n",rhev,pkth,upperpkt,obth,upperobt);
1131     if ( pkth > upperpkt && obth > upperobt ){
1132     if ( IsDebug() ) printf(" Upper limits extended to include last header: ph %lld upperp %lld oh %lld uppero %lld \n",pkth,upperpkt,obth,upperobt);
1133     upperpkt = pkth;
1134     upperobt = obth;
1135     rhev = lasthead+1;
1136 mocchiut 1.2 } else {
1137 mocchiut 1.1 rhev = lasthead;
1138     };
1139     if ( IsDebug() ) printf(" rhev after %i ph %lld upperp %lld oh %lld uppero %lld \n",rhev,pkth,upperpkt,obth,upperobt);
1140     //
1141     if ( IsDebug() ) printf(" rtev beforev %i pt %lld upperp %lld ot %lld uppero %lld \n",rtev,pktt,upperpkt,obtt,upperobt);
1142     if ( pktt > upperpkt && obtt > upperobt ){
1143     if ( IsDebug() ) printf(" Upper limits extended to include last trailer: pt %lld upperp %lld ot %lld uppero %lld \n",pktt,upperpkt,obtt,upperobt);
1144     upperpkt = pktt;
1145     upperobt = obtt;
1146     rtev = lasttrail+1;
1147     } else {
1148     rtev = lasttrail;
1149     };
1150     if ( IsDebug() ) printf(" rtev after %i pt %lld upperp %lld ot %lld uppero %lld \n",rtev,pktt,upperpkt,obtt,upperobt);
1151     //
1152     };
1153     };
1154     //
1155     if ( IsDebug() ) printf(" Upper limits are: OBT %lld pkt_num %lld upper entry %i \n",upperobt,upperpkt,upperentry);
1156     //
1157     return(0);
1158     }
1159    
1160     /**
1161     *
1162     * Trick to have unique RUN ID numbers even when runs are deleted and mysql deamon restarted.
1163     * Entries in the _RUNID_GEN table are never deleted.
1164     *
1165     **/
1166     UInt_t PamelaDBOperations::AssignRunID(){
1167     //
1168     TSQLResult *result = 0;
1169     TSQLRow *row = 0;
1170     UInt_t runid = 0;
1171     //
1172     stringstream oss;
1173     //
1174     oss.str("");
1175 mocchiut 1.5 if ( chewbacca ){// if chewbacca and tag=none then use chewbacca tag (chiby = chewbacca inserted by), if chewbacca and tag!=none then use tag, if not chewbacca use tag.
1176     if ( !strcmp(tag.Data(),"NONE") ){
1177     oss << "INSERT INTO _RUNID_GEN VALUES (NULL,'"<< chiby.Data() <<"');";
1178     } else {
1179     oss << "INSERT INTO _RUNID_GEN VALUES (NULL,'"<< tag.Data() <<"');";
1180     };
1181     } else {
1182     oss << "INSERT INTO _RUNID_GEN VALUES (NULL,'"<< tag.Data() <<"');";
1183     };
1184 mocchiut 1.1 result = conn->Query(oss.str().c_str());
1185     if ( !result ) throw -10;
1186     oss.str("");
1187     oss << "SELECT ID FROM _RUNID_GEN ORDER BY ID DESC LIMIT 1;";
1188     result = conn->Query(oss.str().c_str());
1189     if ( !result ) throw -10;
1190     //
1191     row = result->Next();
1192     //
1193     if ( !row ) throw -28;
1194     //
1195     runid = (UInt_t)atoll(row->GetField(0));
1196     //
1197     return(runid);
1198     };
1199    
1200     //
1201     // GETTERS
1202     //
1203    
1204     /**
1205     *
1206     * Returns the DB absolute time needed to associate calibrations to data
1207     *
1208     */
1209     UInt_t PamelaDBOperations::GetAbsTime(UInt_t obt){
1210     //
1211     return(((UInt_t)(OBT(obt)/1000)+toffset));
1212     //
1213     };
1214    
1215     /**
1216     *
1217     * List of packet types (just to make easily the loops)
1218     *
1219     */
1220     const PacketType* PamelaDBOperations::GetPacketType(const char* type){
1221     if ( !strcmp(type,"Pscu") ) return(PacketType::Pscu);
1222     if ( !strcmp(type,"PhysEndRun") ) return(PacketType::PhysEndRun);
1223     if ( !strcmp(type,"CalibCalPulse1") ) return(PacketType::CalibCalPulse1);
1224     if ( !strcmp(type,"CalibCalPulse2") ) return(PacketType::CalibCalPulse2);
1225     if ( !strcmp(type,"Physics") ) return(PacketType::Physics);
1226     if ( !strcmp(type,"CalibTrkBoth") ) return(PacketType::CalibTrkBoth);
1227     if ( !strcmp(type,"CalibTrk1") ) return(PacketType::CalibTrk1);
1228     if ( !strcmp(type,"CalibTrk2") ) return(PacketType::CalibTrk2);
1229     if ( !strcmp(type,"CalibTof") ) return(PacketType::CalibTof);
1230     if ( !strcmp(type,"CalibS4") ) return(PacketType::CalibS4);
1231     if ( !strcmp(type,"CalibCalPed") ) return(PacketType::CalibCalPed);
1232     if ( !strcmp(type,"Calib1_Ac1") ) return(PacketType::Calib1_Ac1);
1233     if ( !strcmp(type,"Calib2_Ac1") ) return(PacketType::Calib2_Ac1);
1234     if ( !strcmp(type,"Calib1_Ac2") ) return(PacketType::Calib1_Ac2);
1235     if ( !strcmp(type,"Calib2_Ac2") ) return(PacketType::Calib2_Ac2);
1236     if ( !strcmp(type,"CalibCal") ) return(PacketType::CalibCal);
1237     if ( !strcmp(type,"RunHeader") ) return(PacketType::RunHeader);
1238     if ( !strcmp(type,"RunTrailer") ) return(PacketType::RunTrailer);
1239     if ( !strcmp(type,"CalibHeader") ) return(PacketType::CalibHeader);
1240     if ( !strcmp(type,"CalibTrailer") ) return(PacketType::CalibTrailer);
1241     if ( !strcmp(type,"InitHeader") ) return(PacketType::InitHeader);
1242     if ( !strcmp(type,"InitTrailer") ) return(PacketType::InitTrailer);
1243     if ( !strcmp(type,"EventTrk") ) return(PacketType::EventTrk);
1244     if ( !strcmp(type,"Log") ) return(PacketType::Log);
1245     if ( !strcmp(type,"VarDump") ) return(PacketType::VarDump);
1246     if ( !strcmp(type,"ArrDump") ) return(PacketType::ArrDump);
1247     if ( !strcmp(type,"TabDump") ) return(PacketType::TabDump);
1248     if ( !strcmp(type,"Tmtc") ) return(PacketType::Tmtc);
1249     if ( !strcmp(type,"Mcmd") ) return(PacketType::Mcmd);
1250     if ( !strcmp(type,"ForcedFECmd") ) return(PacketType::ForcedFECmd);
1251     if ( !strcmp(type,"Ac1Init") ) return(PacketType::Ac1Init);
1252     if ( !strcmp(type,"CalInit") ) return(PacketType::CalInit);
1253     if ( !strcmp(type,"TrkInit") ) return(PacketType::TrkInit);
1254     if ( !strcmp(type,"TofInit") ) return(PacketType::TofInit);
1255     if ( !strcmp(type,"TrgInit") ) return(PacketType::TrgInit);
1256     if ( !strcmp(type,"NdInit") ) return(PacketType::NdInit);
1257     if ( !strcmp(type,"S4Init") ) return(PacketType::S4Init);
1258     if ( !strcmp(type,"Ac2Init") ) return(PacketType::Ac2Init);
1259     if ( !strcmp(type,"CalAlarm") ) return(PacketType::CalAlarm);
1260     if ( !strcmp(type,"Ac1Alarm") ) return(PacketType::Ac1Alarm);
1261     if ( !strcmp(type,"TrkAlarm") ) return(PacketType::TrkAlarm);
1262     if ( !strcmp(type,"TrgAlarm") ) return(PacketType::TrgAlarm);
1263     if ( !strcmp(type,"TofAlarm") ) return(PacketType::TofAlarm);
1264     if ( !strcmp(type,"S4Alarm") ) return(PacketType::S4Alarm);
1265     if ( !strcmp(type,"Ac2Alarm") ) return(PacketType::Ac2Alarm);
1266     if ( !strcmp(type,"TsbT") ) return(PacketType::TsbT);
1267     if ( !strcmp(type,"TsbB") ) return(PacketType::TsbB);
1268     return(PacketType::Invalid);
1269     };
1270    
1271     //
1272     // PRIVATE FUNCTIONS
1273     //
1274    
1275     // /**
1276     // * Open the ROOT filename for reading
1277     // */
1278     // void PamelaDBOperations::OpenFile(){
1279     // file = TFile::Open(this->GetRootName().Data());
1280     // //
1281    
1282     void PamelaDBOperations::CheckFile(){
1283     if ( !file ) throw -12;
1284     };
1285    
1286    
1287     /**
1288     * Check if LEVEL0 file and DB connection have really be opened
1289     */
1290     void PamelaDBOperations::CheckConnection(){
1291     //
1292     // check connection
1293     //
1294     if( !conn ) throw -1;
1295     bool connect = conn->IsConnected();
1296     if( !connect ) throw -1;
1297     //
1298     if ( IsDebug() ) printf("\n DB INFORMATIONS:\n SQL: %s Version: %s Host %s Port %i \n\n",conn->GetDBMS(),conn->ServerInfo(),conn->GetHost(),conn->GetPort());
1299     //
1300     if ( !dworbit && strcmp(this->GetRootName().Data(),"") ) throw -27;
1301     //
1302     // set DB timezone to UTC
1303     //
1304     stringstream oss;
1305     //
1306     oss.str("");
1307     oss << "SET time_zone='+0:00';";
1308     TSQLResult *result = 0;
1309     result = conn->Query(oss.str().c_str());
1310     if ( !result ) throw -10;
1311     oss.str("");
1312     oss << "SET wait_timeout=173000;";
1313     conn->Query(oss.str().c_str());
1314     //
1315     }
1316    
1317     /**
1318     * Lock tables
1319     */
1320     void PamelaDBOperations::LockTables(){
1321     //
1322     // check connection
1323     //
1324     if( !conn ) throw -1;
1325     bool connect = conn->IsConnected();
1326     if( !connect ) throw -1;
1327     //
1328     stringstream oss;
1329     //
1330     oss.str("");
1331 pam-fi 1.4 oss << "lock table GL_RUN write, GL_ROOT write, GL_RAW write, GL_TIMESYNC write, GL_RESURS_OFFSET write, GL_PARAM write, GL_TLE write, GL_RUN_FRAGMENTS write, GL_RUN_TRASH write, GL_CALO_CALIB write, GL_CALOPULSE_CALIB write, GL_TRK_CALIB write, GL_S4_CALIB write, ROOT_TABLE_MERGING write, ROOT_TABLE_BAD write, ROOT_TABLE write, _RUNID_GEN write;";
1332 mocchiut 1.1 TSQLResult *result = 0;
1333     result = conn->Query(oss.str().c_str());
1334     if ( !result ) throw -10;
1335     //
1336     }
1337    
1338     /**
1339     * Lock tables
1340     */
1341     void PamelaDBOperations::UnLockTables(){
1342     //
1343     // check connection
1344     //
1345     if( !conn ) throw -1;
1346     bool connect = conn->IsConnected();
1347     if( !connect ) throw -1;
1348     //
1349     stringstream oss;
1350     //
1351     oss.str("");
1352     oss << "unlock tables;";
1353     TSQLResult *result = 0;
1354     result = conn->Query(oss.str().c_str());
1355     if ( !result ) throw -10;
1356     //
1357     }
1358    
1359     /**
1360     * Return the correct packet number if we went back to zero
1361     */
1362     Long64_t PamelaDBOperations::PKT(UInt_t pkt_num){
1363     //
1364 mocchiut 1.2 // if ( IsDebug() ) printf(" pkt conversion: pkt_num is %u pktfirst is %u (UInt_t)(16777214/2)) is %u \n",pkt_num,ppktfirst,(UInt_t)(16777214/2));
1365 mocchiut 1.1 //
1366     if ( pkt_num < (ppktfirst/2) && ppktfirst > (16777214/2) ){
1367 mocchiut 1.2 // if ( IsDebug() ) printf(" rise up pktnum %lld \n",(Long64_t)pkt_num+16777215LL);
1368 mocchiut 1.1 return((Long64_t)pkt_num+16777215LL);
1369     };
1370     //
1371     if ( pkt_num > ((Long64_t)ppktfirst*2) && pkt_num > (16777214/2) ){
1372 mocchiut 1.2 // if ( IsDebug() ) printf(" rise down pktnum %lld \n",(Long64_t)pkt_num-16777215LL);
1373 mocchiut 1.1 return((Long64_t)pkt_num-16777215LL);
1374     };
1375     //
1376 mocchiut 1.2 // if ( IsDebug() ) printf(" as it is %lld \n",(Long64_t)pkt_num);
1377 mocchiut 1.1 return((Long64_t)pkt_num);
1378     //
1379     };
1380    
1381     /**
1382     * Return the correct On Board Time if we went back to zero
1383     */
1384     Long64_t PamelaDBOperations::OBT(UInt_t obt){
1385     //
1386 mocchiut 1.2 // if ( IsDebug() ) printf(" obt conversion: obt is %u obtfirst is %u (numeric_limits<UInt_t>::max()/2) is %u \n",obt,pobtfirst,(UInt_t)(numeric_limits<UInt_t>::max()/2));
1387 mocchiut 1.1 //
1388 mocchiut 1.11 if ( obt < ((Long64_t)pobtfirst/2) && pobtfirst > (numeric_limits<UInt_t>::max()/2) ){
1389 mocchiut 1.2 // if ( IsDebug() ) printf(" rise up obt %lld \n",(Long64_t)obt+(Long64_t)numeric_limits<UInt_t>::max());
1390 mocchiut 1.1 return((Long64_t)obt+(Long64_t)numeric_limits<UInt_t>::max());
1391     };
1392     //
1393     if ( obt > ((Long64_t)pobtfirst*2) && obt > (numeric_limits<UInt_t>::max()/2) ){
1394 mocchiut 1.2 // if ( IsDebug() ) printf(" pobtfirst*2 %lld \n",((Long64_t)pobtfirst*2));
1395     // if ( IsDebug() ) printf(" rise down pktnum %lld \n", (Long64_t)obt-(Long64_t)numeric_limits<UInt_t>::max());
1396 mocchiut 1.1 return((Long64_t)obt-(Long64_t)numeric_limits<UInt_t>::max());
1397     };
1398     //
1399 mocchiut 1.2 // if ( IsDebug() ) printf(" as it is %lld \n",(Long64_t)obt);
1400 mocchiut 1.1 return((Long64_t)obt);
1401     };
1402    
1403     /**
1404     *
1405     * Fill the glrun class with infos about the run when we have both runtrailer and runheader
1406     *
1407     */
1408     void PamelaDBOperations::FillClass(){
1409     this->FillClass(false,false,-1,-1);
1410     };
1411    
1412     /**
1413     *
1414     * Fill the glrun class with infos about the run when we have both runtrailer and runheader
1415     *
1416     */
1417     void PamelaDBOperations::FillClass(Bool_t mishead, Bool_t mistrail, Int_t firstev, Int_t lastev){
1418     //
1419     TTree *T = 0;
1420     T = (TTree*)file->Get("Physics");
1421     if ( !T || T->IsZombie() ) throw -16;
1422     //
1423     EventHeader *eh = 0;
1424     PscuHeader *ph = 0;
1425     T->SetBranchAddress("Header", &eh);
1426     PacketType *pctp=0;
1427     EventCounter *codt=0;
1428     EventCounter *codh=0;
1429     UInt_t firstObt = 0;
1430     UInt_t lastObt = 0;
1431     UInt_t firstPkt = 0;
1432     UInt_t lastPkt = 0;
1433     UInt_t rhtime = 0;
1434     UInt_t rttime = 0;
1435 mocchiut 1.3 //
1436     if ( IsDebug() ) printf(" A firstev %i lastev %i nevents %i \n",firstev,lastev,lastev-firstev+1);
1437     //
1438 mocchiut 1.1 if ( !mishead ){
1439     codh = ehh->GetCounter();
1440 mocchiut 1.3 if ( (lastev+1 == firstev && lastev != -1) || (lastev == firstev && lastev != -1) ){
1441     if ( IsDebug() ) printf(" B firstev %i lastev %i nevents %i \n",firstev,lastev,lastev-firstev+1);
1442 mocchiut 1.1 firstev = 1;
1443     lastev = 0;
1444     } else {
1445     firstev = codh->Get(pctp->Physics);
1446     };
1447     rhtime = this->GetAbsTime(phh->GetOrbitalTime());
1448     glrun->Set_GL_RUNH(runh,phh);
1449     firstObt = glrun->GetRUNHEADER_OBT();
1450     firstPkt = glrun->GetRUNHEADER_PKT();
1451     };
1452     if ( !mistrail ){
1453     codt = eht->GetCounter();
1454 mocchiut 1.3 if ( (lastev+1 == firstev && lastev != -1) || (lastev == firstev && lastev != -1)){
1455     if ( IsDebug() ) printf(" C firstev %i lastev %i nevents %i \n",firstev,lastev,lastev-firstev+1);
1456 mocchiut 1.1 lastev = 0;
1457     firstev = lastev+1;
1458     } else {
1459     lastev = codt->Get(pctp->Physics)-1;
1460     };
1461     rttime = this->GetAbsTime(pht->GetOrbitalTime());
1462     glrun->Set_GL_RUNT(runt,pht);
1463     lastObt = glrun->GetRUNTRAILER_OBT();
1464     lastPkt = glrun->GetRUNTRAILER_PKT();
1465     };
1466     //
1467     if ( mishead && mistrail && lastev+1 == firstev ) throw -14; // run with no events, no runtrailer, no runheader... unsupported should never arrive here
1468     //
1469     if ( mishead ) {
1470     glrun->Set_GL_RUNH0();
1471     //
1472 mocchiut 1.3 if ( (lastev+1 == firstev && lastev != -1) || (lastev == firstev && lastev != -1) ){
1473 mocchiut 1.1 firstObt = lastObt;
1474     firstPkt = lastPkt;
1475     rhtime = rttime;
1476     } else {
1477     T->GetEntry(firstev);
1478     ph = eh->GetPscuHeader();
1479     firstObt = ph->GetOrbitalTime();
1480     rhtime = this->GetAbsTime(firstObt);
1481     firstPkt = ph->GetCounter();
1482     };
1483     //
1484     glrun->SetRUNHEADER_PKT(firstPkt);
1485     glrun->SetRUNHEADER_OBT(firstObt);
1486     //
1487     };
1488     if ( mistrail ){
1489     glrun->Set_GL_RUNT0();
1490     //
1491 mocchiut 1.3 if ( (lastev+1 == firstev && lastev != -1) || (lastev == firstev && lastev != -1) ){
1492 mocchiut 1.1 lastObt = firstObt;
1493     lastPkt = firstPkt;
1494     rttime = rhtime;
1495     } else {
1496     T->GetEntry(lastev);
1497     ph = eh->GetPscuHeader();
1498     lastObt = ph->GetOrbitalTime();
1499     rttime = this->GetAbsTime(lastObt);
1500     lastPkt = ph->GetCounter();
1501     };
1502     //
1503     glrun->SetRUNTRAILER_OBT(lastObt);
1504     glrun->SetRUNTRAILER_PKT(lastPkt);
1505     //
1506     };
1507 mocchiut 1.23 //
1508     // ad hoc solution for INF EV_TO [8RED] 090113
1509     //
1510     if ( !firstev && lastev == -1 ){
1511     if ( IsDebug() ) printf(" EE firstev %i lastev %i nevents %i \n",firstev,lastev,lastev-firstev+1);
1512     firstev = 1;
1513     lastev = 0;
1514     };
1515 mocchiut 1.1 glrun->SetEV_FROM((UInt_t)firstev);
1516     glrun->SetEV_TO((UInt_t)lastev);
1517     glrun->SetNEVENTS((UInt_t)lastev-(UInt_t)firstev+1);
1518     //
1519     if ( IsDebug() ) printf(" firstev %i lastev %i nevents %i \n",firstev,lastev,lastev-firstev+1);
1520     //
1521     this->SetCommonGLRUN(rhtime,rttime);
1522 mocchiut 1.2 this->SetPhysEndRunVariables();
1523 mocchiut 1.1 //
1524     };
1525    
1526     //
1527     // PUBLIC FUNCTIONS
1528     //
1529    
1530     /**
1531     * Insert a new row into GL_RAW table.
1532     */
1533     Int_t PamelaDBOperations::insertPamelaRawFile(){
1534 pam-fi 1.4
1535     //
1536     Bool_t idr = this->SetID_RAW();
1537     if ( idr ) return(1);
1538    
1539     GL_RAW glraw = GL_RAW();
1540    
1541     glraw.PATH = GetRawPath();
1542     glraw.NAME = GetRawFile();
1543 mocchiut 1.5 // glraw.BOOT_NUMBER = 0;//???
1544     glraw.BOOT_NUMBER = this->GetBOOTnumber();
1545 pam-fi 1.4
1546     if( insertPamelaRawFile(&glraw) )return(1);
1547     //
1548     idr = this->SetID_RAW();
1549     if ( !idr ) throw -11;
1550    
1551     return(0);
1552     }
1553     /**
1554     * Insert a new row into GL_RAW table.
1555     */
1556     Int_t PamelaDBOperations::insertPamelaRawFile(GL_RAW *glraw){
1557 mocchiut 1.1 //
1558 mocchiut 1.5 if(!glraw)return(1);//?? ok I think
1559 pam-fi 1.4 //
1560     stringstream oss;
1561     //
1562     oss.str("");
1563     if ( STATIC ){
1564     oss << "INSERT INTO GL_RAW (PATH, NAME) VALUES ('"
1565     << glraw->PATH << "', '" << glraw->NAME << "')";
1566     } else {
1567     oss << "INSERT INTO GL_RAW (PATH, NAME) VALUES ('$PAM_RAW', '" << glraw->NAME << "')";
1568     };
1569     if ( debug ) cout <<oss.str().c_str() <<endl;
1570     if ( conn->Query(oss.str().c_str()) == 0 ) throw -4;
1571     //
1572     oss.str("");
1573     oss << "SELECT ID FROM GL_RAW WHERE NAME=\""<<glraw->NAME<<"\";";
1574     if ( debug ) cout << oss.str().c_str()<<endl;
1575     if ( conn->Query(oss.str().c_str()) == 0 ) throw -4;
1576     //
1577     TSQLResult *result = 0;
1578     TSQLRow *row = 0;
1579     result = conn->Query(oss.str().c_str());
1580     if ( result == NULL ) throw -4;
1581     row = result->Next();
1582     if ( !row ) return(1);
1583     glraw->ID = (UInt_t)atoll(row->GetField(0));
1584     if ( debug ) printf(" The ID of the RAW file is %u \n",glraw->ID);
1585     delete result;
1586     delete row;
1587     //
1588     return(0);
1589 mocchiut 1.1 }
1590    
1591    
1592     /**
1593     * Look for one timesync information in the file and
1594     * fill the GL_TIMESYNC table. It will look for: 1) TS-MCMD 2) TS info in the RunHeader 3) TS info in the runtrailer, if none exists exit with error
1595     */
1596     Int_t PamelaDBOperations::insertPamelaGL_TIMESYNC(){
1597     //
1598     Int_t signal = 0;
1599     UInt_t idresof = 0;
1600     stringstream oss;
1601     TSQLResult *result = 0;
1602     TSQLRow *row = 0;
1603     UInt_t OBT = 0;
1604     UInt_t TYPE = 0;
1605     UInt_t TSYNC = 0;
1606     UInt_t t0 = 0;
1607     Bool_t existsts = false;
1608     //
1609     if ( chewbacca ){
1610     //
1611     OBT = chobtts * 1000;
1612     TSYNC = chlastts;
1613     t0 = chresursts;
1614     TYPE = 777;
1615     oss.str("");
1616     oss << "select * from GL_RESURS_OFFSET where OFFSET_DATE=FROM_UNIXTIME("<< t0 <<") limit 1;";
1617     if ( IsDebug() ) printf(" %s \n",oss.str().c_str());
1618     result = conn->Query(oss.str().c_str());
1619     if ( !result ) throw -10;
1620     row = result->Next();
1621 mocchiut 1.14 if ( !row ) throw -92;
1622 mocchiut 1.1 idresof = (UInt_t)atoll(row->GetField(0));
1623     existsts = true;
1624     goto eout;
1625     //
1626     } else {
1627     //
1628     //signal = this->SetUpperLimits();
1629     //
1630     if ( this->GetID_RAW() == 0 ) throw -11;
1631     //
1632     oss.str("");
1633     oss << "SELECT YEAR(OFFSET_DATE),MONTH(OFFSET_DATE),DAY(OFFSET_DATE),HOUR(OFFSET_DATE),MINUTE(OFFSET_DATE),SECOND(OFFSET_DATE),ID FROM GL_RESURS_OFFSET WHERE SPECIAL_FILE='"
1634     << this->GetRawFile().Data() << "';";
1635     if ( IsDebug() ) printf(" %s \n",oss.str().c_str());
1636     result = conn->Query(oss.str().c_str());
1637     if ( !result ) throw -10;
1638     row = result->Next();
1639     //
1640     if ( !row ){
1641     oss.str("");
1642     oss << "SELECT YEAR(OFFSET_DATE),MONTH(OFFSET_DATE),DAY(OFFSET_DATE),HOUR(OFFSET_DATE),MINUTE(OFFSET_DATE),SECOND(OFFSET_DATE),ID FROM GL_RESURS_OFFSET WHERE FROM_ORBIT< "
1643 mocchiut 1.20 << dworbit << " AND SPECIAL_FILE='' order by FROM_ORBIT desc limit 1;";
1644 mocchiut 1.1 if ( IsDebug() ) printf(" %s \n",oss.str().c_str());
1645     result = conn->Query(oss.str().c_str());
1646     if ( !result ) throw -10;
1647     row = result->Next();
1648     if ( !row ) throw -10;
1649     };
1650     //
1651     idresof = (UInt_t)atoll(row->GetField(6));
1652     //
1653     TTimeStamp tu = TTimeStamp((UInt_t)atoi(row->GetField(0)),(UInt_t)atoi(row->GetField(1)),(UInt_t)atoi(row->GetField(2)),(UInt_t)atoi(row->GetField(3)),(UInt_t)atoi(row->GetField(4)),(UInt_t)atoi(row->GetField(5)),0,true,0);
1654     t0 = (UInt_t)tu.GetSec();
1655     if ( IsDebug() ) printf(" t0 is %u ti is %s %s %s %s %s %s %s\n",t0,row->GetField(0),row->GetField(1),row->GetField(2),row->GetField(3),row->GetField(4),row->GetField(5),row->GetField(6));
1656     //
1657     /*
1658     * Verify that the TIMESYNC have been not already processed
1659     */
1660     oss.str("");
1661     oss << " SELECT COUNT(GL_TIMESYNC.ID),GL_TIMESYNC.OBT0,GL_TIMESYNC.TIMESYNC FROM GL_TIMESYNC "
1662     << " LEFT JOIN GL_RAW "
1663     << " ON GL_RAW.ID = GL_TIMESYNC.ID_RAW "
1664     << " WHERE GL_TIMESYNC.ID_RAW = " << this->GetID_RAW()
1665     << " GROUP BY GL_TIMESYNC.OBT0;";
1666     if ( IsDebug() ) printf(" check for old timesync: query is \n %s \n",oss.str().c_str());
1667     result = conn->Query(oss.str().c_str());
1668     if (result == NULL) throw -10;
1669     row = result->Next();
1670     if ((row != NULL) && ((UInt_t)atoll(row->GetField(0)) > 0)){
1671     if ( IsDebug() ) printf(" found a timesync t0 is %u \n",t0);
1672     toffset = (UInt_t)atoll(row->GetField(2)) - (UInt_t)(this->OBT((UInt_t)atoll(row->GetField(1)))/1000) + t0;
1673     //
1674     tsync = (UInt_t)atoll(row->GetField(2));
1675     obt0 = (UInt_t)atoll(row->GetField(1));
1676     //
1677     if ( PEDANTIC ) throw -67;
1678     return(1);
1679     };
1680     //
1681     TTree *T = 0;
1682     //
1683     UInt_t nevent = 0;
1684     UInt_t recEntries = 0;
1685     //
1686     OBT = 0;
1687     TYPE = 0;
1688     TSYNC = 0;
1689     //
1690     Double_t minimum = 0.;
1691     Double_t maximum = 0.;
1692     Double_t minimum2 = 0.;
1693     Double_t maximum2 = 0.;
1694     //
1695     //
1696     pamela::McmdEvent *mc = 0;
1697     pamela::McmdRecord *mcrc = 0;
1698     TArrayC *mcmddata = 0;
1699     //
1700     minimum = numeric_limits<Double_t>::max();
1701     maximum = numeric_limits<Double_t>::min();
1702     minimum2 = numeric_limits<Double_t>::max();
1703     maximum2 = numeric_limits<Double_t>::min();
1704     //
1705     T = (TTree*)file->Get("Mcmd");
1706     if ( !T || T->IsZombie() ) throw -19;
1707     T->SetBranchAddress("Mcmd",&mc);
1708     //
1709     nevent = T->GetEntries();
1710     //
1711     // loop over events
1712     //
1713     existsts = false;
1714     //
1715     for (UInt_t i=0; i<nevent;i++){
1716     //
1717     T->GetEntry(i);
1718     //
1719     recEntries = mc->Records->GetEntries();
1720     //
1721     for (UInt_t j = 0; j < recEntries; j++){
1722     mcrc = (pamela::McmdRecord*)mc->Records->At(j);
1723     mcmddata = mcrc->McmdData;
1724     //
1725     if (mcrc->ID1 == 0xE0){ // mcmd timesync
1726     //
1727     OBT = (Int_t)(mcrc->MCMD_RECORD_OBT);
1728     //
1729     TSYNC = (((UInt_t)mcmddata->At(0)<<24)&0xFF000000) + (((UInt_t)mcmddata->At(1)<<16)&0x00FF0000) + (((UInt_t)mcmddata->At(2)<<8)&0x0000FF00) + (((UInt_t)mcmddata->At(3))&0x000000FF);
1730     //
1731     TYPE = 55;//224;
1732     //
1733     if ( IsDebug() ) printf("mcmd tsync %i tsync %u obt %u \n",i,TSYNC,OBT);
1734     //
1735     if ( TSYNC && OBT ){
1736     existsts = true;
1737     goto eout;
1738     };
1739     //
1740     };
1741     };
1742     };
1743     if ( !existsts ) { // try with runheader and runtrailer
1744     //
1745     if ( IsDebug() ) printf(" No ts mcmd \n");
1746     signal = 2;
1747     //
1748     TTree *rh=(TTree*)file->Get("RunHeader");
1749     if ( !rh || rh->IsZombie() ) throw -17;
1750     TTree *rt=(TTree*)file->Get("RunTrailer");
1751     if ( !rt || rt->IsZombie() ) throw -18;
1752     //
1753     rh->SetBranchAddress("RunHeader", &runh);
1754     //
1755     rt->SetBranchAddress("RunTrailer", &runt);
1756     //
1757     Int_t nnrhev = rh->GetEntries();
1758     Int_t nnrtev = rt->GetEntries();
1759     if ( IsDebug() ) printf(" ou nevent %i rhev %i rtev %i \n",nevent,nnrhev,nnrtev);
1760     //
1761     if ( nnrhev > 0 ){
1762     for (Int_t i=0; i<nnrhev; i++){
1763     //
1764     rh->GetEntry(i);
1765     //
1766     TSYNC = runh->LAST_TIME_SYNC_INFO;
1767     OBT = runh->OBT_TIME_SYNC * 1000;
1768     //
1769     TYPE = 20;
1770     //
1771     if ( IsDebug() ) printf("runheader %i tsync %u obt %u \n",i,TSYNC,OBT);
1772     //
1773     if ( TSYNC && OBT ){
1774     existsts = true;
1775     goto eout;
1776     };
1777     };
1778     //
1779     };
1780     if ( nnrtev > 0 ){
1781     //
1782     if ( IsDebug() ) printf(" No runheader \n");
1783     signal = 6;
1784     //
1785     for (Int_t i=0; i<nnrtev; i++){
1786     //
1787     rt->GetEntry(i);
1788     //
1789     TSYNC = runt->LAST_TYME_SYNC_INFO;
1790     OBT = runt->OBT_TYME_SYNC * 1000;
1791     //
1792     TYPE = 21;
1793     //
1794     if ( IsDebug() ) printf("runtrailer %i tsync %u obt %u \n",i,TSYNC,OBT);
1795     //
1796     if ( TSYNC && OBT ){
1797     existsts = true;
1798     goto eout;
1799     };
1800     };
1801     //
1802     } else {
1803     if ( IsDebug() ) printf(" No runheader \n");
1804     };
1805     };
1806     //
1807     if ( !existsts ){ // try with inclination mcmd
1808     //
1809     if ( IsDebug() ) printf(" No runtrailer \n");
1810     signal = 14;
1811     //
1812     Double_t timesync = 0.;
1813     for (UInt_t i=0; i<nevent;i++){
1814     //
1815     T->GetEntry(i);
1816     //
1817     recEntries = mc->Records->GetEntries();
1818     // //
1819     for (UInt_t j = 0; j < recEntries; j++){
1820     mcrc = (pamela::McmdRecord*)mc->Records->At(j);
1821     mcmddata = mcrc->McmdData;
1822     //
1823     if (mcrc->ID1 == 0xE2){ // mcmd inclination
1824     timesync = 0.;
1825     timesync = (Double_t)(((((UInt_t)mcmddata->At(0) << 24) & 0xFF000000) + (((UInt_t)mcmddata->At(1) << 16) & 0x00FF0000) + (((UInt_t)mcmddata->At(2) << 8) & 0x0000FF00) + ((UInt_t)mcmddata->At(3) & 0x000000FF))/128.0);
1826     //
1827     if ( timesync > maximum2){
1828     maximum2 = timesync;
1829     OBT = (Int_t)(mcrc->MCMD_RECORD_OBT);
1830     };
1831     };
1832     //
1833     };
1834     };
1835     if ( maximum2 > numeric_limits<Double_t>::min() ){
1836     TSYNC = (UInt_t)(maximum2 + 0.5);
1837     TYPE = 666;
1838     if ( TSYNC && OBT ){
1839     existsts = true;
1840     goto eout;
1841     };
1842     };
1843     };
1844     //
1845     };
1846     //
1847     if ( !existsts && obt0 ){ // insert timesync by hand
1848     //
1849     if ( PEDANTIC ) throw -68;
1850     if ( IsDebug() ) printf(" No incl mcmd \n");
1851     signal = 30;
1852     //
1853     OBT = obt0;
1854     TSYNC = tsync;
1855     TYPE = 999;
1856     existsts = true;
1857     goto eout;
1858     };
1859     //
1860     eout:
1861     //
1862     if ( !existsts ) throw -3;
1863     //
1864     oss.str("");
1865     oss << "INSERT INTO GL_TIMESYNC (ID_RAW,TYPE,OBT0,TIMESYNC,ID_RESURS_OFFSET) VALUES ('"
1866     << this->GetID_RAW() << "','"//224'"
1867     << dec << (UInt_t)TYPE << "','"
1868     << dec << (UInt_t)OBT << "','"
1869     << dec << (UInt_t)TSYNC << "','"
1870     << dec << (UInt_t)idresof << "');";
1871     conn->Query(oss.str().c_str());
1872     if ( IsDebug() ) printf(" Query the GL_TIMESYNC table to fill it:\n %s \n",oss.str().c_str());
1873     if ( conn->GetErrorCode() ){
1874     printf(" OK, you got an error because the database structure you are using is not up to date\n Using backward compability code, hence you can continue safetly \n");
1875     oss.str("");
1876     oss << "INSERT INTO GL_TIMESYNC (ID_RAW,TYPE,OBT0,TIMESYNC) VALUES ('"
1877     << this->GetID_RAW() << "','"//224'"
1878     << dec << (UInt_t)TYPE << "','"
1879     << dec << (UInt_t)OBT << "','"
1880     << dec << (UInt_t)TSYNC << "');";
1881     conn->Query(oss.str().c_str());
1882     if ( IsDebug() ) printf(" Query the GL_TIMESYNC table to fill it:\n %s \n",oss.str().c_str());
1883     };
1884     //
1885     if ( IsDebug() ) printf(" found a timesync t0 is %u \n",t0);
1886     //
1887     toffset = (UInt_t)TSYNC - (UInt_t)(this->OBT(OBT)/1000) + t0;
1888     //
1889     tsync = TSYNC;
1890     obt0 = OBT;
1891     //
1892     delete result;
1893     return(signal);
1894     }
1895    
1896     /**
1897     * Insert all the new rows into GL_ROOT.
1898     * The raw file indicates in the parameters should be already been stored in the database.
1899     */
1900     Int_t PamelaDBOperations::insertPamelaRootFile(){
1901 pam-fi 1.4
1902     stringstream oss;
1903     TSQLResult *result = 0;
1904     TSQLRow *row = 0;
1905 mocchiut 1.5 //
1906 pam-fi 1.4 // ----------------------
1907     // determine the timesync
1908     // ----------------------
1909     UInt_t idtimesync = 0;
1910     //
1911     if ( chewbacca ){
1912     oss.str("");
1913     oss << " SELECT ID FROM GL_TIMESYNC where TIMESYNC="<<chlastts<<" AND OBT0="<<chobtts*1000<<" limit 1;";
1914     if ( debug ) printf(" %s \n",oss.str().c_str());
1915     result = conn->Query(oss.str().c_str());
1916     //
1917     if ( !result ) throw -3;
1918     //
1919     row = result->Next();
1920     //
1921     if ( !row ) throw -3;
1922     idtimesync = (UInt_t)atoll(row->GetField(0));
1923     } else {
1924     oss.str("");
1925     if ( STATIC ){
1926     oss << " SELECT COUNT(GL_ROOT.ID_RAW),GL_RAW.ID,GL_ROOT.ID FROM GL_RAW "
1927     << " LEFT JOIN GL_ROOT "
1928     << " ON GL_RAW.ID = GL_ROOT.ID_RAW "
1929     << " WHERE GL_RAW.PATH = '" << this->GetRawPath().Data() << "' AND "
1930     << " GL_RAW.NAME = '" << this->GetRawFile().Data() << "' GROUP BY GL_RAW.ID ";
1931     } else {
1932     oss << " SELECT COUNT(GL_ROOT.ID_RAW),GL_RAW.ID,GL_ROOT.ID FROM GL_RAW "
1933     << " LEFT JOIN GL_ROOT "
1934     << " ON GL_RAW.ID = GL_ROOT.ID_RAW "
1935     << " WHERE GL_RAW.PATH = '$PAM_RAW' AND "
1936     << " GL_RAW.NAME = '" << this->GetRawFile().Data() << "' GROUP BY GL_RAW.ID ";
1937     };
1938     result = conn->Query(oss.str().c_str());
1939     //
1940     if ( !result ) throw -12;
1941     //
1942     row = result->Next();
1943     //
1944     if ( !row ) throw -10;
1945     if ( row != NULL && (UInt_t)atoll(row->GetField(0))>0 ){
1946     idroot = (UInt_t)atoll(row->GetField(2));
1947     delete row;
1948     delete result;
1949     return(1);
1950     };
1951     //
1952     // determine which timesync has to be used
1953     //
1954     oss.str("");
1955     oss << "SELECT GL_TIMESYNC.ID FROM GL_TIMESYNC LEFT JOIN GL_RAW ON GL_RAW.ID = GL_TIMESYNC.ID_RAW ORDER BY GL_TIMESYNC.ID DESC LIMIT 1;";
1956     result = conn->Query(oss.str().c_str());
1957     //
1958     if ( !result ) throw -3;
1959     //
1960     row = result->Next();
1961     //
1962     if ( !row ) throw -3;
1963     idtimesync = (UInt_t)atoll(row->GetField(0));
1964     };
1965    
1966     delete row;
1967     delete result;
1968    
1969     // ----------------------
1970     // insert root file
1971     // ----------------------
1972    
1973     GL_ROOT glroot = GL_ROOT();
1974    
1975     glroot.ID_RAW = GetID_RAW();
1976     glroot.ID_TIMESYNC = idtimesync;
1977 mocchiut 1.5 if ( STATIC ){
1978     glroot.PATH = GetRootPath();
1979     } else {
1980     if ( KEEPENV ){
1981     glroot.PATH = gSystem->DirName(filerootname.Data());
1982     } else {
1983     glroot.PATH = "$PAM_L0";
1984     };
1985     };
1986 mocchiut 1.6 glroot.NAME = GetRootFile();
1987 pam-fi 1.4
1988     if ( insertPamelaRootFile(&glroot) )return 1;
1989    
1990     SetID_ROOT(glroot.ID);
1991    
1992    
1993     return (0);
1994     }
1995     /**
1996     * Insert all the new rows into GL_ROOT.
1997     * The raw file indicates in the parameters should be already been stored in the database.
1998     */
1999     Int_t PamelaDBOperations::insertPamelaRootFile(GL_ROOT *glroot){
2000 mocchiut 1.1 stringstream oss;
2001     TSQLResult *result = 0;
2002     TSQLRow *row = 0;
2003     //
2004     //
2005     oss.str("");
2006 mocchiut 1.5 oss << "INSERT INTO GL_ROOT (ID_RAW, ID_TIMESYNC,PATH, NAME) VALUES ('"
2007     << glroot->ID_RAW << "', '" << glroot->ID_TIMESYNC << "', '" << glroot->PATH << "', '" << glroot->NAME << "')";
2008 mocchiut 1.1 //
2009 pam-fi 1.4 if ( debug ) printf("%s \n",oss.str().c_str());
2010 mocchiut 1.1 if (conn->Query(oss.str().c_str()) == 0) throw -4;
2011     //
2012     delete result;
2013     //
2014     oss.str("");
2015     // oss << "SELECT ID FROM GL_ROOT WHERE ID_RAW=" << this->GetID_RAW() << ";";
2016 mocchiut 1.5 oss << "SELECT ID FROM GL_ROOT WHERE PATH='" << glroot->PATH << "' and NAME='"<< glroot->NAME <<"';";
2017 mocchiut 1.1 //
2018 pam-fi 1.4 if ( debug ) printf("%s \n",oss.str().c_str());
2019 mocchiut 1.1 result = conn->Query(oss.str().c_str());
2020     if ( !result ) throw -12;
2021     row = result->Next();
2022     if ( !row ) throw -3;
2023 pam-fi 1.4
2024     glroot->ID = (UInt_t)atoll(row->GetField(0));
2025    
2026     if ( debug ) printf(" The ID of the ROOT file is %u \n",glroot->ID);
2027 mocchiut 1.1 //
2028     delete result;
2029     //
2030     return(0);
2031     }
2032    
2033     /**
2034     * Assign the BOOT_NUMBER to the raw file.
2035     */
2036     Int_t PamelaDBOperations::assignBOOT_NUMBER(){
2037     Bool_t found = false;
2038     UInt_t idRaw = 0;
2039     UInt_t bn = 0;
2040     stringstream oss;
2041     TSQLResult *result = 0;
2042     TSQLRow *row = 0;
2043     if ( chewbacca ){
2044     if ( chboot == 1 ){
2045     // not found!
2046     found = false;
2047     } else {
2048     found = true;
2049     this->SetBOOTnumber(chboot);
2050     };
2051     } else {
2052     oss.str("");
2053     if ( STATIC ){
2054     oss << "SELECT ID, BOOT_NUMBER FROM GL_RAW WHERE "
2055     << " PATH = '" << this->GetRawPath().Data() << "' AND "
2056     << " NAME = '" << this->GetRawFile().Data() << "' ";
2057     } else {
2058     oss << "SELECT ID, BOOT_NUMBER FROM GL_RAW WHERE "
2059     << " PATH = '$PAM_RAW' AND "
2060     << " NAME = '" << this->GetRawFile().Data() << "' ";
2061     };
2062     result = conn->Query(oss.str().c_str());
2063     //
2064     if ( !result ) throw -4;;
2065     row = result->Next();
2066     if ( !row ) return(16);
2067     if ( row->GetField(1) ){
2068     this->SetBOOTnumber((UInt_t)atoll(row->GetField(1)));
2069     return(1);
2070     };
2071     if ( !row->GetField(0) ) throw -26;
2072     //
2073     idRaw = (UInt_t)atoll(row->GetField(0));
2074     //
2075     //
2076     //
2077     TTree *trDumpEv = 0;
2078     trDumpEv = (TTree*)file->Get("VarDump");
2079     if ( !trDumpEv || trDumpEv->IsZombie() ) throw -20;
2080     //
2081     VarDumpEvent *vde = 0;
2082     VarDumpRecord *vdr = 0;
2083     //
2084     trDumpEv->SetBranchAddress("VarDump", &vde);
2085     if ( trDumpEv->GetEntries() > 0 ){
2086     found = false;
2087     for ( Int_t i = 0; i < trDumpEv->GetEntries(); i++){
2088     trDumpEv->GetEntry(i);
2089     // vde->Records->GetEntries();
2090     if ( vde->Records->GetEntries()>5 ){
2091     found = true;
2092     goto fill;
2093     };
2094     };
2095     fill:
2096     if ( found ){
2097     //
2098     vdr = (VarDumpRecord*)vde->Records->At(6);
2099     //
2100     this->SetBOOTnumber((Int_t)vdr->VAR_VALUE);
2101     //
2102     } else {
2103     if ( !this->GetBOOTnumber() && !this->AutoBoot()) return(4);
2104     };
2105     } else {
2106     if ( !this->GetBOOTnumber() && !this->AutoBoot()) return(2);
2107     };
2108     //
2109     };
2110     //
2111     Bool_t afound = false;
2112     if ( !found && this->AutoBoot()){
2113     afound = true;
2114     //
2115     // Search for other files with similar timesync
2116     //
2117     if ( IsDebug() ) printf(" tsync %u obt0 %u \n",tsync,obt0);
2118     UInt_t upperts = tsync-(obt0/1000)+5;
2119     UInt_t lowerts = tsync-(obt0/1000)-5;
2120     if ( chewbacca ){
2121     oss.str("");
2122     oss << "select BOOT_NUMBER from ROOT_TABLE where LAST_TIME_SYNC_INFO-(OBT_TIME_SYNC)<"
2123     << upperts
2124     << " AND LAST_TIME_SYNC_INFO-(OBT_TIME_SYNC)>"
2125     << lowerts
2126     << " AND BOOT_NUMBER>1;";
2127     } else {
2128     oss.str("");
2129     oss << "select GL_RAW.BOOT_NUMBER from GL_TIMESYNC LEFT JOIN GL_RAW ON GL_RAW.ID = GL_TIMESYNC.ID_RAW where TIMESYNC-(OBT0/1000)<"
2130     << upperts
2131     << " AND TIMESYNC-(OBT0/1000)>"
2132     << lowerts
2133     << " AND GL_RAW.BOOT_NUMBER>0 GROUP BY GL_TIMESYNC.OBT0;";
2134     };
2135     result = conn->Query(oss.str().c_str());
2136     if ( IsDebug() && !chewbacca ) printf(" Query the GL_TIMESYNC table to find boot number:\n %s \n",oss.str().c_str());
2137     if ( IsDebug() && chewbacca ) printf(" Query the ROOT_TABLE table to find boot number:\n %s \n",oss.str().c_str());
2138     //
2139     if ( !result ) throw -4;;
2140     found = true;
2141     if ( result->GetRowCount()<3 ){
2142     if ( IsDebug() ) printf(" AGH! no results!\n");
2143     found = false;
2144     } else {
2145     row = result->Next();
2146     bn = (UInt_t)atoll(row->GetField(0));
2147     for ( Int_t r=1; r<result->GetRowCount() ;r++){
2148     if ( !row ) throw -4;
2149     if ( IsDebug() ) printf(" BOOT number is %s \n",row->GetField(0));
2150     if ( bn != (UInt_t)atoll(row->GetField(0)) ){
2151     if ( IsDebug() ) printf(" AGH! bn = %u here instead %u \n",bn,(UInt_t)atoll(row->GetField(0)));
2152     found = false;
2153     };
2154     row = result->Next();
2155     };
2156     };
2157     };
2158     //
2159     Int_t sgn = 0;
2160     //
2161     if ( !found && !BOOTNO ){
2162     throw -29;
2163     } else {
2164     if ( afound ){
2165     this->SetBOOTnumber(bn);
2166     sgn = 8;
2167     };
2168     };
2169     //
2170     if ( !chewbacca ){
2171     oss.str("");
2172     oss << " UPDATE GL_RAW "
2173     << " SET GL_RAW.BOOT_NUMBER = '" << dec << this->GetBOOTnumber() << "'"
2174     << " WHERE GL_RAW.ID = '" << idRaw << "'";
2175     conn->Query(oss.str().c_str());
2176     };
2177     //
2178     delete result;
2179     return(sgn);
2180     };
2181    
2182     /**
2183     * Scan runtrailer packet, fill the GL_RUN table and
2184     * check for missing and truncated runs
2185     */
2186     Int_t PamelaDBOperations::insertPamelaRUN(){
2187     Int_t signal = 0;
2188     //
2189     stringstream oss;
2190     oss.str("");
2191     //
2192     // signal = this->SetUpperLimits();
2193    
2194     //
2195     // loop on runheader and runtrailer events
2196     //
2197     TTree *rh=(TTree*)file->Get("RunHeader");
2198     if ( !rh || rh->IsZombie() ) throw -17;
2199     TTree *rt=(TTree*)file->Get("RunTrailer");
2200     if ( !rt || rt->IsZombie() ) throw -18;
2201     //
2202     PacketType *pctp=0;
2203     EventCounter *cod=0;
2204     //
2205     rh->SetBranchAddress("RunHeader", &runh);
2206     rh->SetBranchAddress("Header", &ehh);
2207     //
2208     rt->SetBranchAddress("RunTrailer", &runt);
2209     rt->SetBranchAddress("Header", &eht);
2210     //
2211     TTree *T = (TTree*)file->Get("Physics");
2212     if ( !T || T->IsZombie() ) throw -16;
2213     EventHeader *eh = 0;
2214     T->SetBranchAddress("Header", &eh);
2215     //
2216     if ( !(rh->GetEntries()) && !(rt->GetEntries()) && !(T->GetEntries()) ) return(16);
2217     //
2218     UInt_t obtt = 0;
2219     UInt_t obth = 0;
2220     UInt_t pktt = 0;
2221     UInt_t pkth = 0;
2222     Int_t pth = -1;
2223     Int_t ptht = -1;
2224     Int_t evbeft = 0;
2225     Int_t evbefh = 0;
2226     UInt_t tcod;
2227     //
2228     // no runtrailers in the file!
2229     //
2230     if ( !rtev ){
2231     if ( !rhev ){
2232     if ( IsDebug() ) printf(" No runheaders nor runtrailers!! \n");
2233     if ( !(upperentry-chminentry) ){
2234     if ( IsDebug() ) printf(" No physics events nor runs in the file \n"); // di nuovo potrebbe esserci un runtrailer senza eventi (riempimento MM)
2235     // throw -8;
2236     return 0; // one could check if there is any calibration no need to exit with error
2237     } else {
2238     this->HandleRunFragments(true,true,chminentry,upperentry); // no runtrailers ma potrebbe esserci un runheader ora...
2239     };
2240     } else {
2241     //
2242     // we have runheaders but not runtrailers!
2243     //
2244     if ( debug ) printf(" We have runheaders (%i) but not runtrailers (%i) ! \n",rhev,rtev);
2245     for ( pth=0; pth < rhev; pth++ ){
2246     rh->GetEntry(pth);
2247     phh = ehh->GetPscuHeader();
2248     pkth = phh->GetCounter();
2249     obth = phh->GetOrbitalTime();
2250     if ( PKT(pkth) >= PKT(pktfirst) && PKT(pkth) <= upperpkt ){
2251     cod = ehh->GetCounter();
2252     tcod = (UInt_t)cod->Get(pctp->Physics);
2253     evbefh = TMath::Max(chminentry,tcod);
2254 mocchiut 1.2 // if ( (UInt_t)evbefh == upperentry ) evbefh = upperentry + 1; // this does not work due to the Counter bug in chewbacca
2255 mocchiut 1.1 if ( (UInt_t)evbefh == upperentry || !upperentry ) evbefh = upperentry + 1;
2256 mocchiut 1.2 //
2257     if ( debug ) printf(" evbefh %i upperentry %u \n",evbefh,upperentry);
2258 mocchiut 1.1 //
2259     this->HandleRunFragments(false,true,evbefh,upperentry);
2260     //
2261     };
2262     };
2263     //
2264     };
2265     //
2266     } else {
2267     //
2268     Int_t conptt = -1;
2269     for (Int_t ptt=0; ptt<rtev; ptt++){
2270     //
2271     rt->GetEntry(ptt);
2272     pht = eht->GetPscuHeader();
2273     pktt = pht->GetCounter();
2274     obtt = pht->GetOrbitalTime();
2275     //
2276     if ( PKT(pktt) >= PKT(pktfirst) && PKT(pktt) <= upperpkt ){
2277     //
2278     conptt++;
2279     //
2280     cod = eht->GetCounter();
2281     ptht = cod->Get(pctp->RunHeader) - 1;
2282     // evbeft = cod->Get(pctp->Physics);
2283     tcod = (UInt_t)cod->Get(pctp->Physics);
2284 mocchiut 1.17 if ( !tcod ) tcod = 1; // IS A BUG SINCE RUNS WITH ZERO EVENTS WILL LOOK LIKE RUNS WITH ONE EVENT
2285 mocchiut 1.1 evbeft = TMath::Min(upperentry,(tcod-1));
2286     if ( debug ) printf(" Loop in runtrailers, evbeft is %u upperentry %u cod->getetc %u \n",evbeft,upperentry,cod->Get(pctp->Physics));
2287     //
2288     // if ( !conptt && !(ptht+1) ){ // here we assume ptht+1 = 0 at the beginning of the interval that could not be true if the interval start from middle file... it must be equal to the number of RH before the interval that is not counted anywhere
2289     if ( !conptt && (ptht+1) == nrhbef ){
2290     //
2291     if ( IsDebug() ) printf(" Piece of run at the beginning of the file %i %i %u \n",ptht,pth,ptt);
2292     //
2293     this->HandleRunFragments(true,false,chminentry,(evbeft));
2294     //
2295     pth = ptht; // ??
2296     //
2297     } else if ( pth == ptht ){
2298     //
2299     if ( IsDebug() ) printf(" Missing header %i %i %u\n",ptht,pth,ptt);
2300     //
2301     if ( (ptt-1) < 0 ) throw -15; // should never arrive here!
2302     rt->GetEntry(ptt-1);
2303     cod = eht->GetCounter();
2304     tcod = (UInt_t)cod->Get(pctp->Physics);
2305     evbefh = TMath::Max(chminentry,tcod);
2306     //evbefh = cod->Get(pctp->Physics);
2307     rt->GetEntry(ptt);
2308     pht = eht->GetPscuHeader();
2309     //
2310     if ( IsDebug() ) printf(" Try to find the beginning of a run which has only the runtrailer %i %i %u \n",ptht,pth,ptt);
2311     if ( IsDebug() ) printf(" ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''' %u %u %u \n",pkth,obth,obtt);
2312     //
2313     this->HandleMissingHoT(true,false,evbefh,(evbeft));
2314     //
2315     } else {
2316     //
2317     rh->GetEntry(ptht);
2318     phh = ehh->GetPscuHeader();
2319     pkth = phh->GetCounter();
2320     obth = phh->GetOrbitalTime();
2321     cod = ehh->GetCounter();
2322     tcod = (UInt_t)cod->Get(pctp->Physics);
2323 mocchiut 1.17 if ( !tcod ) tcod = 1; // IS A BUG SINCE RUNS WITH ZERO EVENTS WILL LOOK LIKE RUNS WITH ONE EVENT
2324 mocchiut 1.1 evbefh = TMath::Max(chminentry,(tcod-1));
2325     //
2326     if ( PKT(pkth) >= PKT(pktfirst) && PKT(pkth) <= upperpkt ){
2327     if ( IsDebug() ) printf(" Could be a good run, we have a runheader followed by a runtrailer %i %i %u\n",ptht,pth,ptt);
2328     //
2329     // evbefh = cod->Get(pctp->Physics);
2330     if ( IsDebug() ) printf(" ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''' %u %u %u \n",pkth,obth,obtt);
2331     //
2332     // handle this run
2333     //
2334     this->HandleRun();
2335     //
2336     //
2337     if ( debug ) printf(" Standard case, evbefh is %u chminentry %u cod->getetc %u \n",evbefh,chminentry,cod->Get(pctp->Physics));
2338     //
2339     } else {
2340     // missing header in the considered interval!
2341     if ( debug ) printf(" Missing header in the considered interval \n");
2342     this->HandleRunFragments(true,false,evbefh,evbeft);
2343     };
2344     //
2345     if ( PKT(pkth)>PKT(pktfirst) && OBT(obth)>OBT(obtfirst) && PKT(pkth)<=(upperpkt) && !conptt ){
2346     //
2347     if ( IsDebug() ) printf(" Piece of run at the beginning of the file WITH NO RUNTRAILER evbefh = %u \n",evbefh);
2348     //
2349     if ( evbefh == 0 ) {
2350     //
2351     if ( !chewbacca ){
2352     signal = 8;
2353     if ( IsDebug() ) printf(" Not supported yet: run with no events, no runtrailer, no runheader \n");
2354     } else {
2355     if ( debug ) printf(" The file does not start with a physics packet, no problem continue \n");
2356     };
2357     //
2358     } else {
2359     //
2360     this->HandleRunFragments(true,true,chminentry,(evbefh));
2361     //
2362 mocchiut 1.10 // what about pth=ptht-1
2363 mocchiut 1.1 };
2364     };
2365     //
2366     //
2367     if ( (ptht - pth) > 1 ){
2368     //
2369     if ( IsDebug() ) printf(" Missing runtrailers! \n");
2370     if ( IsDebug() ) printf(" Attention there is a jump in the runheader counter %i %i %u \n",ptht,pth,ptt);
2371     // is not the consecutive header
2372     while ( pth != ptht ){
2373     //
2374     // treat the header(s) in the middle and then go to the next header, repeat until you reach the correct header.
2375     //
2376     pth++;
2377     //
2378     rh->GetEntry(pth+1);
2379     phh = ehh->GetPscuHeader();
2380     pktt = phh->GetCounter();
2381     obtt = phh->GetOrbitalTime();
2382     cod = ehh->GetCounter();
2383     // evbeft = cod->Get(pctp->Physics);
2384     tcod = (UInt_t)cod->Get(pctp->Physics);
2385 mocchiut 1.17 if ( !tcod ) tcod = 1; // IS A BUG SINCE RUNS WITH ZERO EVENTS WILL LOOK LIKE RUNS WITH ONE EVENT
2386 mocchiut 1.1 evbeft = TMath::Min(upperentry,(tcod-1));
2387     rh->GetEntry(pth);
2388     phh = ehh->GetPscuHeader();
2389     cod = ehh->GetCounter();
2390     pkth = phh->GetCounter();
2391     obth = phh->GetOrbitalTime();
2392     //evbefh = cod->Get(pctp->Physics);
2393     tcod = (UInt_t)cod->Get(pctp->Physics);
2394     evbefh = TMath::Max(chminentry,tcod);
2395     //
2396     if ( PKT(pkth) >= PKT(pktfirst) && PKT(pkth) <= upperpkt && pth != ptht ){
2397     //
2398     if ( IsDebug() ) printf(" Try to find the end of a run which has only the runheader %i %i %u \n",ptht,pth,ptt);
2399     if ( IsDebug() ) printf(" ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''' %u %u %u \n",pkth,obth,obtt);
2400     //
2401     this->HandleMissingHoT(false,true,evbefh,evbeft);
2402     //
2403     };
2404     };
2405     //
2406     } else if ( !(ptht - pth) ){
2407     //
2408     if ( IsDebug() ) printf(" Missing runheader! \n");
2409     if ( IsDebug() ) printf(" Attention! the runheader counter did not changed %i %i %u \n",ptht,pth,ptt);
2410     if ( IsDebug() ) printf(" The run should have already been handled by HandleRun() \n");
2411     if ( PEDANTIC ) throw -87;
2412     //
2413     } else {
2414     //
2415     // go on with next header
2416     //
2417     pth = ptht;
2418     };
2419     //
2420     };
2421     //
2422     // if ( ptt+1 == rtev){
2423     if ( conptt+1 == nrtev ){
2424     // if ( conptt+1 == (nrtev+nrtbef )){
2425 mocchiut 1.10 if ( IsDebug() ) printf(" >>>>>>>>>>> %i %u %i %u \n",ptht,rhev,nrtev,conptt);
2426 mocchiut 1.1 ptht++;
2427 mocchiut 1.15 if ( ptht < rhev ){
2428 mocchiut 1.1 rh->GetEntry(ptht);
2429 mocchiut 1.10 //pth++;
2430     //if ( pth < rhev ){
2431     //rh->GetEntry(pth);
2432 mocchiut 1.1 phh = ehh->GetPscuHeader();
2433     pkth = phh->GetCounter();
2434     obth = phh->GetOrbitalTime();
2435     cod = ehh->GetCounter();
2436     tcod = (UInt_t)cod->Get(pctp->Physics);
2437     evbefh = TMath::Max(chminentry,tcod);
2438     if ( PKT(pkth) >= PKT(pktfirst) && PKT(pkth) <= upperpkt ){
2439     // evbefh = cod->Get(pctp->Physics);
2440     if ( IsDebug() ) printf(" Piece of run at the end of file %u %u %u \n",pkth,obth,obtt);
2441     if ( IsDebug() ) printf(" ''''''''''''''''''''''''''''''' %i %i %u \n",ptht,pth,ptt);
2442     if ( IsDebug() ) printf(" ''''''''''''''''''''''''''''''' %u \n",rhev);
2443     if ( IsDebug() ) printf(" evbefh %u upperentry %u \n",(UInt_t)evbefh,upperentry);
2444     //
2445     this->HandleRunFragments(false,true,evbefh,upperentry);
2446     //
2447     };
2448     } else {
2449     //
2450     // check if we have a fragment with no header
2451     //
2452     if ( (UInt_t)evbeft < upperentry-1 && upperentry>0 ){
2453     if ( IsDebug() ) printf(" Piece of run at the end of the file with NO RUNHEADER! evbeft %u upperentry-1 %u \n",(UInt_t)evbeft,upperentry-1);
2454     //
2455 mocchiut 1.15 // if ( (ptt-1) < 0 ) throw -15; // should never arrive here!
2456     if ( (rtev-1) < 0 || ptt < 0 ) throw -15; // should never arrive here!
2457 mocchiut 1.10 // rt->GetEntry(ptt-1);
2458     rt->GetEntry(rtev-1);
2459 mocchiut 1.1 cod = eht->GetCounter();
2460 mocchiut 1.10 tcod = (UInt_t)cod->Get(pctp->Physics)+1;
2461 mocchiut 1.1 evbefh = TMath::Max(chminentry,tcod);
2462     // evbefh = cod->Get(pctp->Physics);
2463     rt->GetEntry(ptt);
2464     pht = eht->GetPscuHeader();
2465     this->HandleRunFragments(true,true,evbefh,upperentry);
2466     };
2467     };
2468     };
2469     //
2470     };
2471     };
2472     };
2473     //
2474     return(signal);
2475     };
2476    
2477     /**
2478     *
2479     * Check if the run has already been inserted
2480     *
2481     */
2482     Bool_t PamelaDBOperations::IsRunAlreadyInserted(){
2483     //
2484     TSQLResult *result = 0;
2485     TSQLRow *row = 0;
2486     //
2487     stringstream oss;
2488     oss.str("");
2489     //
2490     // the where clause is of the type: boot_number = _our_boot && (
2491     // ( runhead_time >= (_our_runhead_time-10) && runtrail_time <= (_our_runtrail_time+10) &&
2492     // ( runhead_obt >= _our_runheadobt || runhead_pkt >= _our_runheadpkt ) &&
2493     // ( runtrail_obt >= _our_runtrailobt || runtrail_pkt >= _our_runtrailpkt ) )
2494     // ||
2495     // ( runhead_time <= _our_runhead_time && runtrail_time >= _our_runtrail_time &&
2496     // ( runhead_obt <= _our_runheadobt || runhead_pkt <= _our_runheadpkt ) &&
2497     // ( runtrail_obt <= _our_runtrailobt || runtrail_pkt <= _our_runtrailpkt ) )
2498     // ||
2499     // ( runhead_time = _our_runhead_time && runtrail_time = _our_runtrail_time && nevents > 100 )
2500     // )
2501     // ||
2502     // ( runhead_time = _our_runhead_time && runtrail_time > _our_runtrail_time && nevents > 100 )
2503     // )
2504     // ||
2505     // ( runhead_time < _our_runhead_time && runtrail_time = _our_runtrail_time && nevents > 100 )
2506     // )
2507     //
2508     oss << " SELECT ID,NEVENTS,TRK_CALIB_USED,PKT_COUNTER FROM GL_RUN WHERE "
2509     << " BOOT_NUMBER=" << this->GetBOOTnumber() << " AND ("
2510     << " (RUNHEADER_TIME>=" << (UInt_t)(glrun->GetRUNHEADER_TIME()-10) << " AND "
2511     << " RUNTRAILER_TIME<=" << (UInt_t)(glrun->GetRUNTRAILER_TIME()+10) << " AND ("
2512     << " RUNHEADER_OBT>=" << glrun->GetRUNHEADER_OBT() << " OR "
2513     << " RUNHEADER_PKT>=" << glrun->GetRUNHEADER_PKT() << ") AND ("
2514     << " RUNTRAILER_OBT<=" << glrun->GetRUNTRAILER_OBT() << " OR "
2515     << " RUNTRAILER_PKT<=" << glrun->GetRUNTRAILER_PKT() << ") ) OR "
2516     << " (RUNHEADER_TIME<=" << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND "
2517     << " RUNTRAILER_TIME>=" << (UInt_t)glrun->GetRUNTRAILER_TIME() <<" AND ("
2518     << " RUNHEADER_OBT<=" << glrun->GetRUNHEADER_OBT() << " OR "
2519     << " RUNHEADER_PKT<=" << glrun->GetRUNHEADER_PKT() << ") AND ("
2520     << " RUNTRAILER_OBT>=" << glrun->GetRUNTRAILER_OBT() << " OR ";
2521     if ( glrun->GetNEVENTS() < 100 ){
2522     oss<<" RUNTRAILER_PKT>=" << glrun->GetRUNTRAILER_PKT() << "))); ";
2523     } else {
2524     oss << " RUNTRAILER_PKT>=" << glrun->GetRUNTRAILER_PKT() << ")) OR "
2525     << " (RUNHEADER_TIME=" << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND " // these two lines in a certain way disable the patch below...
2526     << " RUNTRAILER_TIME=" << (UInt_t)glrun->GetRUNTRAILER_TIME() <<" AND NEVENTS>100) OR" //
2527     << " (RUNHEADER_TIME=" << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND " //
2528     << " RUNTRAILER_TIME>" << (UInt_t)glrun->GetRUNTRAILER_TIME() <<" AND NEVENTS>100) OR" //
2529     << " (RUNHEADER_TIME<" << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND " //
2530     << " RUNTRAILER_TIME=" << (UInt_t)glrun->GetRUNTRAILER_TIME() <<" AND NEVENTS>100)" //
2531     << " );";
2532     };
2533     //
2534     if ( IsDebug() ) printf(" THIS RUN: RUNHEADER_OBT %u RUNTRAILER_OBT %u RUNHEADER_PKT %u RUNTRAILER_PKT %u NEVENTS %u\n", glrun->GetRUNHEADER_OBT(),glrun->GetRUNTRAILER_OBT(),glrun->GetRUNHEADER_PKT(),glrun->GetRUNTRAILER_PKT(),glrun->GetNEVENTS());
2535     if ( IsDebug() ) printf(" check if run has been inserted: query is \n %s \n",oss.str().c_str());
2536     result = conn->Query(oss.str().c_str());
2537     //
2538     if ( !result ) throw -4;
2539     //
2540     row = result->Next();
2541     //
2542     if ( !row ){
2543     if ( IsDebug() ) printf(" The run is new \n");
2544     if ( IsDebug() ) printf(" -> fill the DB \n");
2545     return(false); // the file has not been inserted in the DB, go on.
2546     };
2547     //
2548     Bool_t signal = true;
2549     //
2550     while ( row != NULL ){
2551     if ( IsDebug() ) printf(" A run exists with runheader and runtrailer time and packets compatible with this one \n");
2552     //
2553     // the run has already been inserted
2554     //
2555     if ( signal && IsDebug() ) printf(" The run has already been inserted\n");
2556     if ( PEDANTIC ) throw -86;
2557     return(true); //<<<<<<<<<<<<<<<<<<<<<<<< patch follows, uncomment here
2558     //
2559     // PATCH!
2560     // we keep the processing run if (in order of growing importance) 1) we have the runtrailer while the old run doesn't have it 2) we have the runheader
2561     // while the old run doesn't have it 3) we have more events than the old run
2562     //
2563     if ( glrun->GetNEVENTS() > (UInt_t)atoll(row->GetField(1)) ){
2564     //
2565     if ( IsDebug() ) printf(" The new run has more events than the old one \n");
2566     glrun->DeleteRun(conn,(UInt_t)atoll(row->GetField(0)),"GL_RUN");
2567 mocchiut 1.2 // oss.str("");
2568     // oss << "DELETE FROM GL_RUN WHERE ID=" << row->GetField(0) <<";";
2569     // if ( IsDebug() ) printf(" delete the run entry: query is \n %s \n",oss.str().c_str());
2570     // conn->Query(oss.str().c_str());
2571 mocchiut 1.1 if ( signal ) signal = false;
2572     goto gonext;
2573     //
2574     } else if ( glrun->GetNEVENTS() < (UInt_t)atoll(row->GetField(1)) ){
2575     if ( IsDebug() ) printf(" The new run has less events than the old one \n");
2576     if ( IsDebug() ) printf(" The run is already inserted \n");
2577     goto gonext;
2578     };
2579     //
2580     if ( glrun->GetTRK_CALIB() && !(UInt_t)atoll(row->GetField(2)) ){
2581     //
2582     if ( IsDebug() ) printf(" The new run has the same number of events and the runheader the old one miss the runheader \n");
2583     //
2584     glrun->DeleteRun(conn,(UInt_t)atoll(row->GetField(0)),"GL_RUN");
2585 mocchiut 1.2 // oss.str("");
2586     // oss << "DELETE FROM GL_RUN WHERE ID=" << row->GetField(0) <<";";
2587     // if ( IsDebug() ) printf(" delete the run entry: query is \n %s \n",oss.str().c_str());
2588     // conn->Query(oss.str().c_str());
2589 mocchiut 1.1 //
2590     if ( signal ) signal = false;
2591     goto gonext;
2592     } else if ( !glrun->GetTRK_CALIB() && (UInt_t)atoll(row->GetField(2)) ){
2593     if ( IsDebug() ) printf(" The new run has the same number of events but miss the runheader the old has the runheader \n");
2594     if ( IsDebug() ) printf(" The run is already inserted \n");
2595     goto gonext;
2596     };
2597     //
2598     if ( glrun->GetPKT_COUNTER() && !(UInt_t)atoll(row->GetField(3)) ){
2599     //
2600     if ( IsDebug() ) printf(" The new run has the same number of events, the runheader and the runtrailer the old one miss the runtrailer \n");
2601     //
2602     glrun->DeleteRun(conn,(UInt_t)atoll(row->GetField(0)),"GL_RUN");
2603 mocchiut 1.2 // oss.str("");
2604     // oss << "DELETE FROM GL_RUN WHERE ID=" << row->GetField(0) <<";";
2605     // if ( IsDebug() ) printf(" delete the run entry: query is \n %s \n",oss.str().c_str());
2606     // conn->Query(oss.str().c_str());
2607 mocchiut 1.1 if ( signal ) signal = false;
2608     //
2609     };
2610     //
2611     gonext:
2612     // END PATCH!
2613     //
2614     row = result->Next();
2615     //
2616     };
2617     //
2618     delete result;
2619     //
2620     if ( signal && IsDebug() ) printf(" The run has already been inserted \n");
2621     if ( !signal && IsDebug() ) printf(" The run existed and has been overridden, fill the DB \n");
2622     if ( PEDANTIC ) throw -86;
2623     return(signal);
2624     };
2625    
2626     /**
2627     * Handle runs which seems to be good ones.
2628     **/
2629     void PamelaDBOperations::HandleRun(){
2630     ULong64_t chkpkt = 0;
2631     ULong64_t pktt = (ULong64_t)PKT(pht->GetCounter());
2632     ULong64_t pkth = (ULong64_t)PKT(phh->GetCounter());
2633     //
2634     chkpkt = pkth + (ULong64_t)runt->PKT_COUNTER + 1ULL + 1ULL;
2635     //
2636     if ( labs(chkpkt-pktt)<2 ){
2637     //
2638     if ( IsDebug() ) printf(" check %llu pktt %llu \n",chkpkt,pktt);
2639     //
2640     // it must be a good run, fill the db
2641     //
2642     this->FillClass();
2643     //
2644     if ( !IsRunAlreadyInserted() ){
2645     glrun->SetID(this->AssignRunID());
2646     glrun->SetID_RUN_FRAG(0);
2647     glrun->Fill_GL_RUN(conn);
2648     };
2649     } else {
2650     //
2651     if ( IsDebug() ) printf(" oh no! the distance between runheader and runtrailer seems wrong: check %llu pktt %llu \n",chkpkt,pktt);
2652     if ( IsDebug() ) printf(" try to recover run(s) without runheader and runtrailer between runheader and runtrailer\n");
2653     //
2654     this->HandleSuspiciousRun();
2655     //
2656     };
2657     //
2658     //
2659     return;
2660     };
2661    
2662    
2663     /**
2664     * Handle run fragments at the beginning or at the end of the file
2665     **/
2666     void PamelaDBOperations::HandleRunFragments(Bool_t mishead, Bool_t mistrail, UInt_t firstev, UInt_t lastev){
2667     //
2668     UInt_t rhfirstev = firstev;
2669     UInt_t rtlastev = lastev;
2670     Bool_t found = false;
2671     Bool_t foundinrun = false;
2672     //
2673     TSQLResult *result = 0;
2674     TSQLRow *row = 0;
2675     //
2676     stringstream oss;
2677     oss.str("");
2678     //
2679     // is the piece of run good (no other packets inside)?
2680     //
2681     if ( !this->IsRunConsistent(mishead,mistrail,firstev,lastev)){
2682     //
2683     // if not, handle other pieces and continue with the first one
2684     //
2685     if ( IsDebug() ) printf("The run is not consistent, it contains non-physics packets! The run has been handled \n");
2686     //
2687     } else {
2688     //
2689 mocchiut 1.2 // we have now the good first piece of a run, fill the glrun object
2690     //
2691 mocchiut 1.16 if ( firstev != (lastev+1) ){ // could be a problem sometimes (?)
2692     if ( rhfirstev != firstev && !mishead ) mishead = true;
2693     if ( rtlastev != lastev && !mistrail ) mistrail = true;
2694     };
2695 mocchiut 1.1 //
2696 mocchiut 1.16 if ( IsDebug() ) printf(" bhere firstev is %i lastev is %i \n",firstev,lastev);
2697 mocchiut 1.2 this->FillClass(mishead,mistrail,firstev,lastev);
2698 mocchiut 1.16 if ( IsDebug() ) printf(" chere firstev is %i lastev is %i \n",firstev,lastev);
2699 mocchiut 1.1 //
2700 mocchiut 1.2 if ( IsDebug() ) printf("The run is good, is it the other piece in the GL_RUN_FRAGMENTS table?\n");
2701     if ( IsDebug() ) printf(" C THIS RUN: RUNHEADER_OBT %u RUNTRAILER_OBT %u RUNHEADER_PKT %u RUNTRAILER_PKT %u \n", glrun->GetRUNHEADER_OBT(),glrun->GetRUNTRAILER_OBT(),glrun->GetRUNHEADER_PKT(),glrun->GetRUNTRAILER_PKT());
2702 mocchiut 1.1 //
2703 mocchiut 1.2 // First of all insert the run in the fragment table...
2704 mocchiut 1.1 //
2705     oss.str("");
2706 mocchiut 1.2 oss << " SELECT ID FROM GL_RUN_FRAGMENTS WHERE "
2707     << " BOOT_NUMBER=" << this->GetBOOTnumber() << " AND ("
2708     << " (RUNHEADER_TIME>=" << (UInt_t)(glrun->GetRUNHEADER_TIME()-10) << " AND "
2709     << " RUNTRAILER_TIME<=" << (UInt_t)(glrun->GetRUNTRAILER_TIME()+10) << " AND ("
2710     << " RUNHEADER_OBT>=" << glrun->GetRUNHEADER_OBT() << " OR "
2711     << " RUNHEADER_PKT>=" << glrun->GetRUNHEADER_PKT() << ") AND ("
2712     << " RUNTRAILER_OBT<=" << glrun->GetRUNTRAILER_OBT() << " OR "
2713     << " RUNTRAILER_PKT<=" << glrun->GetRUNTRAILER_PKT() << ") ) OR "
2714     << " (RUNHEADER_TIME<=" << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND "
2715     << " RUNTRAILER_TIME>=" << (UInt_t)glrun->GetRUNTRAILER_TIME() <<" AND ("
2716     << " RUNHEADER_OBT<=" << glrun->GetRUNHEADER_OBT() << " OR "
2717     << " RUNHEADER_PKT<=" << glrun->GetRUNHEADER_PKT() << ") AND ("
2718     << " RUNTRAILER_OBT>=" << glrun->GetRUNTRAILER_OBT() << " OR "
2719     << " RUNTRAILER_PKT>=" << glrun->GetRUNTRAILER_PKT() << ") ));";
2720 mocchiut 1.1 //
2721 mocchiut 1.2 if ( IsDebug() ) printf(" check if run has been inserted: query is \n %s \n",oss.str().c_str());
2722 mocchiut 1.1 result = conn->Query(oss.str().c_str());
2723     //
2724     if ( !result ) throw -4;
2725     //
2726     row = result->Next();
2727     //
2728 mocchiut 1.2 if ( !row ){
2729     //
2730     // no, insert this run in the GL_RUN_FRAGMENTS table (check if exist before!)
2731     //
2732     if ( IsDebug() ) printf(" The run is new \n");
2733     if ( IsDebug() ) printf(" -> fill the GL_RUNFRAGMENTS table \n");
2734     //
2735     glrun->SetID(this->AssignRunID());
2736     glrun->SetID_RUN_FRAG(0);
2737     glrun->Fill_GL_RUN_FRAGMENTS(conn);
2738     //
2739     } else {
2740 mocchiut 1.21 if ( IsDebug() ) printf(" The run is already present in the fragment table, relaxed %u \n",RELAXED);
2741     if ( !RELAXED ){
2742     if ( PEDANTIC ) throw -69;
2743     return;
2744     } else {
2745     glrun->SetID((UInt_t)atoll(row->GetField(0)));
2746     glrun->SetID_RUN_FRAG(0);
2747     };
2748 mocchiut 1.2 };
2749     //
2750     if ( chewbacca && mishead && mistrail ) goto justcheck;
2751     //
2752     // can we find the other piece of the run in the GL_RUN_FRAGMENTS table?
2753     //
2754     if ( mishead && ( rhfirstev == firstev || chewbacca ) ) { // look for runheader (only when at the beginning of the file, if at the end and the runh is
2755     // missing it no way we can found a piece in the frag table
2756 mocchiut 1.1 //
2757     oss.str("");
2758 mocchiut 1.2 oss << " SELECT ID,TRK_CALIB_USED,RUNTRAILER_TIME,RUNTRAILER_OBT,RUNHEADER_PKT,RUNTRAILER_PKT FROM GL_RUN_FRAGMENTS WHERE "
2759 mocchiut 1.1 << " BOOT_NUMBER=" << this->GetBOOTnumber() << " AND "
2760     << " RUNHEADER_TIME <= " << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND "
2761     << " ID != " << glrun->ID
2762 mocchiut 1.2 << " ORDER BY RUNHEADER_TIME DESC LIMIT 1;"; // DESC NOT ASC!!
2763 mocchiut 1.1 //
2764 mocchiut 1.2 if ( IsDebug() ) printf(" look for runheader in the fragments table: query is \n %s \n",oss.str().c_str());
2765 mocchiut 1.1 result = conn->Query(oss.str().c_str());
2766     //
2767     if ( !result ) throw -4;
2768     //
2769     row = result->Next();
2770     //
2771 mocchiut 1.2 if ( !row && NoFrag() ){
2772     //
2773     oss.str("");
2774     oss << " SELECT ID,TRK_CALIB_USED,RUNTRAILER_TIME,RUNTRAILER_OBT,RUNHEADER_PKT,RUNTRAILER_PKT FROM GL_RUN WHERE "
2775     << " BOOT_NUMBER=" << this->GetBOOTnumber() << " AND "
2776     << " RUNHEADER_TIME <= " << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND "
2777     << " ID != " << glrun->ID
2778     << " AND ID=ID_RUN_FRAG ORDER BY RUNHEADER_TIME DESC LIMIT 1;"; // DESC NOT ASC!!
2779     //
2780     if ( IsDebug() ) printf(" look for runheader in the GL_RUN table: query is \n %s \n",oss.str().c_str());
2781     result = conn->Query(oss.str().c_str());
2782     //
2783     if ( !result ) throw -4;
2784     //
2785     foundinrun = true;
2786     //
2787     row = result->Next();
2788     //
2789     };
2790 mocchiut 1.1 //
2791 mocchiut 1.2 if ( !row ){
2792     if ( IsDebug() ) printf(" the corresponding piece has NOT been found \n");
2793     found = false;
2794     } else {
2795     //
2796     found = false; // default value
2797     //
2798 mocchiut 1.16 if ( IsDebug() ) printf(" A Found a possible candidate, checking if it is the good one... \n");
2799 mocchiut 1.1 //
2800 mocchiut 1.2 // if we have both runheader and runtrailer we can check with pkt_counter:
2801 mocchiut 1.1 //
2802 mocchiut 1.2 if ( !mistrail && (UInt_t)atoll(row->GetField(1)) != 0 ){
2803     ULong64_t chkpkt = 0;
2804     ULong64_t pktt = (ULong64_t)PKT(glrun->GetRUNTRAILER_PKT());
2805     ULong64_t pkth = (ULong64_t)PKT((UInt_t)atoll(row->GetField(4)));
2806     //
2807     chkpkt = pkth + (ULong64_t)glrun->GetPKT_COUNTER() + 1ULL + 1ULL;
2808 mocchiut 1.1 //
2809 mocchiut 1.2 if ( labs(chkpkt-pktt)<2 ){
2810     //
2811     if ( IsDebug() ) printf(" FOUND!!! check %llu pktt %llu \n",chkpkt,pktt);
2812     //
2813     found = true;
2814 mocchiut 1.16 if ( IsDebug() ) printf(" where firstev is %i lastev is %i \n",firstev,lastev);
2815 mocchiut 1.2 //
2816     } else {
2817     //
2818     if ( IsDebug() ) printf(" The check with pkt counter failed: check %llu pktt %llu \n",chkpkt,pktt);
2819     //
2820     found = false;
2821     //
2822     };
2823     };
2824     if ( !found && chewbacca ) goto justcheck;
2825     if ( !found ){
2826 mocchiut 1.1 //
2827 mocchiut 1.2 // if we arrive here we were not able to decide if the two pieces matches using only the pkt counter information, we must check times and obts
2828 mocchiut 1.1 //
2829 mocchiut 1.2 ULong64_t chkpkt1 = 0;
2830     ULong64_t orunh1 = (ULong64_t)PKT(glrun->GetRUNHEADER_PKT());
2831     ULong64_t dbrunt1 = (ULong64_t)PKT((UInt_t)atoll(row->GetField(5)));
2832     chkpkt1 = labs(orunh1-dbrunt1);
2833 mocchiut 1.1 //
2834 mocchiut 1.2 ULong64_t chkpkt2 = 0;
2835     ULong64_t orunh2 = (ULong64_t)OBT(glrun->GetRUNHEADER_OBT());
2836     ULong64_t dbrunt2 = (ULong64_t)OBT((UInt_t)atoll(row->GetField(3)));
2837     chkpkt2 = labs(orunh2-dbrunt2);
2838 mocchiut 1.1 //
2839 mocchiut 1.2 ULong64_t chkpkt3 = 0;
2840     ULong64_t orunh3 = (ULong64_t)(glrun->GetRUNHEADER_TIME());
2841     ULong64_t dbrunt3 = (ULong64_t)((UInt_t)atoll(row->GetField(2)));
2842     chkpkt3 = labs(orunh3-dbrunt3);
2843 mocchiut 1.1 //
2844 mocchiut 1.2 if ( (chkpkt1 < 200 || chkpkt2 < 20000) && chkpkt3 < 20 ){
2845     // if ( chkpkt1 < 100 && chkpkt2 < 30000 && chkpkt3 < 30 ){
2846     //
2847     if ( IsDebug() ) printf(" FOUND!!! check1 %llu<200 cechk2 %llu<20000 check3 %llu<20 \n",chkpkt1,chkpkt2,chkpkt3);
2848     //
2849     found = true;
2850     //
2851     } else {
2852     //
2853     if ( IsDebug() ) printf(" Check failed: check1 %llu<200? cechk2 %llu<20000? check3 %llu<20? \n",chkpkt1,chkpkt2,chkpkt3);
2854     //
2855     found = false;
2856     //
2857     };
2858 mocchiut 1.1 };
2859     };
2860 mocchiut 1.2 //
2861     if ( found ){
2862     //
2863     // we have found the missing piece, glue the two together, merge the informations, fill the gl_run table (check first runs do not exists), delete entry in frag table
2864     //
2865     if ( IsDebug() ) printf(" now you can handle the piece of the run \n ");
2866     //
2867     if ( foundinrun ){
2868     glrun->RestoreRun(conn,(UInt_t)atoll(row->GetField(0)),"GL_RUN_FRAGMENTS");
2869     glrun->DeleteRun(conn,(UInt_t)atoll(row->GetField(0)),"GL_RUN");
2870     };
2871 mocchiut 1.1 //
2872 mocchiut 1.2 GL_RUN *glrun1 = new GL_RUN();
2873 mocchiut 1.1 //
2874 mocchiut 1.2 // UInt_t idfrag = (UInt_t)atoll(row->GetField(0));
2875     //
2876     oss.str("");
2877     oss << " ID="<<row->GetField(0)<<";";
2878     //
2879     glrun1->Query_GL_RUN_FRAGMENTS(oss.str().c_str(),conn); // here we have runheader infos
2880 mocchiut 1.16 if ( IsDebug() ) printf(" there firstev is %i lastev is %i \n",firstev,lastev);
2881 mocchiut 1.2 //
2882     // merge infos
2883     //
2884     UInt_t apkt = PKT(glrun1->GetRUNTRAILER_PKT());
2885     ULong64_t aobt = OBT(glrun1->GetRUNTRAILER_OBT());
2886     UInt_t bpkt = PKT(glrun->GetRUNHEADER_PKT());
2887     ULong64_t bobt = OBT(glrun->GetRUNHEADER_OBT());
2888     if ( IsDebug() ) printf(" Check overlapping events: %u %u %llu %llu firstev is %i\n",apkt,bpkt,aobt,bobt,firstev);
2889     TTree *T= 0;
2890     T = (TTree*)file->Get("Physics");
2891     if ( !T || T->IsZombie() ) throw -16;
2892     EventHeader *eh = 0;
2893     PscuHeader *ph = 0;
2894     T->SetBranchAddress("Header", &eh);
2895     while ( apkt > bpkt && aobt > bobt && firstev < lastev ){
2896     T->GetEntry(firstev);
2897     ph = eh->GetPscuHeader();
2898     bpkt = PKT(ph->GetCounter());
2899     bobt = OBT(ph->GetOrbitalTime());
2900     firstev++;
2901     if ( PEDANTIC ) throw -71;
2902     };
2903     if ( IsDebug() ) printf(" Check overlapping events done: %u %u %llu %llu firstev is %i\n",apkt,bpkt,aobt,bobt,firstev);
2904 mocchiut 1.1 //
2905 mocchiut 1.2 glrun1->SetPKT_COUNTER(glrun->GetPKT_COUNTER());
2906     glrun1->SetPKT_READY_COUNTER(glrun->GetPKT_READY_COUNTER());
2907     glrun1->SetRUNTRAILER_TIME(glrun->GetRUNTRAILER_TIME());
2908     glrun1->SetRUNTRAILER_OBT(glrun->GetRUNTRAILER_OBT());
2909     glrun1->SetRUNTRAILER_PKT(glrun->GetRUNTRAILER_PKT());
2910     //
2911 mocchiut 1.16 if ( IsDebug() ) printf(" here firstev is %i lastev is %i \n",firstev,lastev);
2912     //
2913 mocchiut 1.2 glrun->SetEV_FROM(firstev);
2914     glrun->SetNEVENTS(lastev-firstev+1);
2915     //
2916     glrun->SetRUNHEADER_TIME(glrun1->GetRUNHEADER_TIME());
2917     glrun->SetRUNHEADER_OBT(glrun1->GetRUNHEADER_OBT());
2918     glrun->SetRUNHEADER_PKT(glrun1->GetRUNHEADER_PKT());
2919     glrun->SetCOMPILATIONTIMESTAMP(glrun1->GetCOMPILATIONTIMESTAMP());
2920     glrun->SetFAV_WRK_SCHEDULE(glrun1->GetFAV_WRK_SCHEDULE());
2921     glrun->SetEFF_WRK_SCHEDULE(glrun1->GetEFF_WRK_SCHEDULE());
2922     glrun->SetPRH_VAR_TRG_MODE_A(glrun1->GetPRH_VAR_TRG_MODE_A());
2923     glrun->SetPRH_VAR_TRG_MODE_B(glrun1->GetPRH_VAR_TRG_MODE_B());
2924     glrun->SetACQ_BUILD_INFO(glrun1->GetACQ_BUILD_INFO());
2925     glrun->SetACQ_VAR_INFO(glrun1->GetACQ_VAR_INFO());
2926     glrun->SetRM_ACQ_AFTER_CALIB(glrun1->GetRM_ACQ_AFTER_CALIB());
2927     glrun->SetRM_ACQ_SETTING_MODE(glrun1->GetRM_ACQ_SETTING_MODE());
2928     glrun->SetTRK_CALIB_USED(glrun1->GetTRK_CALIB_USED());
2929     glrun->SetCAL_DSP_MASK(glrun1->GetCAL_DSP_MASK());
2930     glrun->SetLAST_TIMESYNC(glrun1->GetLAST_TIMESYNC());
2931     glrun->SetOBT_TIMESYNC(glrun1->GetOBT_TIMESYNC());
2932     //
2933     if ( glrun1->GetPHYSENDRUN_MASK_S3S2S12() ) glrun->SetPHYSENDRUN_MASK_S3S2S12(glrun1->GetPHYSENDRUN_MASK_S3S2S12());
2934     if ( glrun1->GetPHYSENDRUN_MASK_S11CRC() ) glrun->SetPHYSENDRUN_MASK_S11CRC(glrun1->GetPHYSENDRUN_MASK_S11CRC());
2935     //
2936     if ( !IsRunAlreadyInserted() ){
2937     //
2938     // glrun->SetID(this->AssignRunID());
2939     glrun->SetID_RUN_FRAG(glrun1->GetID());
2940     glrun->Fill_GL_RUN(conn);
2941 mocchiut 1.1 //
2942 mocchiut 1.2 // set id number
2943 mocchiut 1.1 //
2944 mocchiut 1.2 glrun1->SetID_RUN_FRAG(glrun->GetID());
2945     glrun1->Fill_GL_RUN(conn);
2946 mocchiut 1.1 //
2947     };
2948 mocchiut 1.2 // delete old entry in fragment table
2949     //
2950     glrun->DeleteRun(conn,0,"GL_RUN_FRAGMENTS");
2951     glrun1->DeleteRun(conn,0,"GL_RUN_FRAGMENTS");
2952 mocchiut 1.1 //
2953 mocchiut 1.2 delete glrun1;
2954 mocchiut 1.1 //
2955     //
2956 mocchiut 1.2 return;
2957 mocchiut 1.1 //
2958     };
2959     //
2960     };
2961     //
2962 mocchiut 1.2 if ( mistrail && ( rtlastev == lastev || chewbacca )) { // look for runtrailer (only when at the end of the file, if at the beginning and the runh is
2963     // missing it no way we can found a piece in the frag table
2964 mocchiut 1.1 //
2965     oss.str("");
2966 mocchiut 1.2 oss << " SELECT ID,PKT_COUNTER,RUNHEADER_TIME,RUNHEADER_OBT,RUNTRAILER_PKT,RUNHEADER_PKT FROM GL_RUN_FRAGMENTS WHERE "
2967 mocchiut 1.1 << " BOOT_NUMBER=" << this->GetBOOTnumber() << " AND "
2968     << " RUNTRAILER_TIME >= " << (UInt_t)glrun->GetRUNTRAILER_TIME() << " AND "
2969     << " ID != " << glrun->ID
2970 mocchiut 1.2 << " ORDER BY RUNTRAILER_TIME ASC LIMIT 1;";
2971 mocchiut 1.1 //
2972 mocchiut 1.2 if ( IsDebug() ) printf(" look for runtrailer in the fragments table: query is \n %s \n",oss.str().c_str());
2973 mocchiut 1.1 result = conn->Query(oss.str().c_str());
2974     //
2975     if ( !result ) throw -4;
2976     //
2977     row = result->Next();
2978     //
2979 mocchiut 1.2 if ( !row && NoFrag() ){
2980     //
2981     oss.str("");
2982     oss << " SELECT ID,PKT_COUNTER,RUNHEADER_TIME,RUNHEADER_OBT,RUNTRAILER_PKT,RUNHEADER_PKT FROM GL_RUN WHERE "
2983     << " BOOT_NUMBER=" << this->GetBOOTnumber() << " AND "
2984     << " RUNTRAILER_TIME >= " << (UInt_t)glrun->GetRUNTRAILER_TIME() << " AND "
2985     << " ID != " << glrun->ID
2986     << " AND ID=ID_RUN_FRAG ORDER BY RUNTRAILER_TIME ASC LIMIT 1;";
2987     //
2988     if ( IsDebug() ) printf(" look for runheader in the GL_RUN table: query is \n %s \n",oss.str().c_str());
2989     result = conn->Query(oss.str().c_str());
2990     //
2991     if ( !result ) throw -4;
2992     //
2993     foundinrun = true;
2994     row = result->Next();
2995     //
2996     };
2997 mocchiut 1.1 //
2998 mocchiut 1.2 if ( !row ){
2999     if ( IsDebug() ) printf(" the corresponding piece has NOT been found \n");
3000     found = false;
3001     } else {
3002     //
3003     found = false; // default value
3004     //
3005 mocchiut 1.16 if ( IsDebug() ) printf(" B Found a possible candidate, checking if it is the good one... \n");
3006 mocchiut 1.1 //
3007 mocchiut 1.2 // if we have both runheader and runtrailer we can check with pkt_counter:
3008 mocchiut 1.1 //
3009 mocchiut 1.2 if ( !mishead && (UInt_t)atoll(row->GetField(1)) != 0 ){
3010     ULong64_t chkpkt = 0;
3011     ULong64_t pktt = (ULong64_t)PKT((UInt_t)atoll(row->GetField(4)));
3012     ULong64_t pkth = (ULong64_t)PKT(glrun->GetRUNHEADER_PKT());
3013 mocchiut 1.1 //
3014 mocchiut 1.2 chkpkt = pkth + (ULong64_t)((UInt_t)atoll(row->GetField(1))) + 1ULL + 1ULL;
3015 mocchiut 1.1 //
3016 mocchiut 1.2 if ( labs(chkpkt-pktt)<2 ){
3017     //
3018     if ( IsDebug() ) printf(" FOUND!!! check %llu pktt %llu \n",chkpkt,pktt);
3019     //
3020     found = true;
3021     //
3022     } else {
3023     //
3024     if ( IsDebug() ) printf(" The check with pkt counter failed: check %llu pktt %llu \n",chkpkt,pktt);
3025     //
3026     found = false;
3027     //
3028     };
3029     };
3030     if ( !found && chewbacca ) goto justcheck;
3031     if ( !found ){
3032     //
3033     // if we arrive here we were not able to decide if the two pieces matches using only the pkt counter information, we must check times and obts
3034 mocchiut 1.1 //
3035 mocchiut 1.2 ULong64_t chkpkt1 = 0;
3036     ULong64_t orunh1 = (ULong64_t)PKT(glrun->GetRUNTRAILER_PKT());
3037     ULong64_t dbrunt1 = (ULong64_t)PKT((UInt_t)atoll(row->GetField(5)));
3038     chkpkt1 = labs(orunh1-dbrunt1);
3039 mocchiut 1.1 //
3040 mocchiut 1.2 ULong64_t chkpkt2 = 0;
3041     ULong64_t orunh2 = (ULong64_t)OBT(glrun->GetRUNTRAILER_OBT());
3042     ULong64_t dbrunt2 = (ULong64_t)OBT((UInt_t)atoll(row->GetField(3)));
3043     chkpkt2 = labs(orunh2-dbrunt2);
3044 mocchiut 1.1 //
3045 mocchiut 1.2 ULong64_t chkpkt3 = 0;
3046     ULong64_t orunh3 = (ULong64_t)(glrun->GetRUNTRAILER_TIME());
3047     ULong64_t dbrunt3 = (ULong64_t)((UInt_t)atoll(row->GetField(2)));
3048     chkpkt3 = labs(orunh3-dbrunt3);
3049 mocchiut 1.1 //
3050 mocchiut 1.2 if ( (chkpkt1 < 200 || chkpkt2 < 20000) && chkpkt3 < 20 ){
3051     //
3052     if ( IsDebug() ) printf(" FOUND!!! check1 %llu<200 cechk2 %llu<20000 check3 %llu<20 \n",chkpkt1,chkpkt2,chkpkt3);
3053     //
3054     found = true;
3055     //
3056     } else {
3057     //
3058     if ( IsDebug() ) printf(" Check failed: check1 %llu<200? cechk2 %llu<20000? check3 %llu<20? \n",chkpkt1,chkpkt2,chkpkt3);
3059     //
3060     found = false;
3061     //
3062     };
3063 mocchiut 1.1 };
3064     };
3065 mocchiut 1.2 //
3066     if ( found ){
3067     //
3068     // we have found the missing piece, glue the two together, merge the informations, fill the gl_run table (check first runs do not exists), delete entry in frag table
3069     //
3070     if ( IsDebug() ) printf(" now you can handle the piece of the run \n ");
3071     //
3072     if ( foundinrun ){
3073     glrun->RestoreRun(conn,(UInt_t)atoll(row->GetField(0)),"GL_RUN_FRAGMENTS");
3074     glrun->DeleteRun(conn,(UInt_t)atoll(row->GetField(0)),"GL_RUN");
3075     };
3076 mocchiut 1.1 //
3077 mocchiut 1.2 GL_RUN *glrun1 = new GL_RUN();
3078 mocchiut 1.1 //
3079 mocchiut 1.2 // UInt_t idfrag = (UInt_t)atoll(row->GetField(0));
3080 mocchiut 1.1 //
3081 mocchiut 1.2 oss.str("");
3082     oss << " ID="<<row->GetField(0)<<";";
3083     //
3084     glrun1->Query_GL_RUN_FRAGMENTS(oss.str().c_str(),conn); // here we have runtrailer infos
3085 mocchiut 1.1 //
3086 mocchiut 1.2 // merge infos
3087 mocchiut 1.1 //
3088 mocchiut 1.2 UInt_t apkt = PKT(glrun->GetRUNTRAILER_PKT());
3089     ULong64_t aobt = OBT(glrun->GetRUNTRAILER_OBT());
3090     UInt_t bpkt = PKT(glrun1->GetRUNHEADER_PKT());
3091     ULong64_t bobt = OBT(glrun1->GetRUNHEADER_OBT());
3092     if ( IsDebug() ) printf(" Check overlapping events: %u %u %llu %llu lastev is %i\n",apkt,bpkt,aobt,bobt,lastev);
3093     TTree *T= 0;
3094     T = (TTree*)file->Get("Physics");
3095     if ( !T || T->IsZombie() ) throw -16;
3096     EventHeader *eh = 0;
3097     PscuHeader *ph = 0;
3098     T->SetBranchAddress("Header", &eh);
3099     while ( apkt > bpkt && aobt > bobt && lastev > 0 ){
3100     T->GetEntry(lastev);
3101     ph = eh->GetPscuHeader();
3102     apkt = PKT(ph->GetCounter());
3103     aobt = OBT(ph->GetOrbitalTime());
3104     lastev--;
3105 mocchiut 1.21 if ( PEDANTIC && !RELAXED) throw -72;
3106 mocchiut 1.2 };
3107     if ( IsDebug() ) printf(" Check overlapping events done: %u %u %llu %llu lastev is %i\n",apkt,bpkt,aobt,bobt,lastev);
3108     //
3109     glrun->SetEV_TO(lastev);
3110     glrun->SetNEVENTS(lastev-firstev+1);
3111     glrun->SetPKT_COUNTER(glrun1->GetPKT_COUNTER());
3112     glrun->SetPKT_READY_COUNTER(glrun1->GetPKT_READY_COUNTER());
3113     glrun->SetRUNTRAILER_TIME(glrun1->GetRUNTRAILER_TIME());
3114     glrun->SetRUNTRAILER_OBT(glrun1->GetRUNTRAILER_OBT());
3115     glrun->SetRUNTRAILER_PKT(glrun1->GetRUNTRAILER_PKT());
3116     //
3117     glrun1->SetRUNHEADER_TIME(glrun->GetRUNHEADER_TIME());
3118     glrun1->SetRUNHEADER_OBT(glrun->GetRUNHEADER_OBT());
3119     glrun1->SetRUNHEADER_PKT(glrun->GetRUNHEADER_PKT());
3120     glrun1->SetCOMPILATIONTIMESTAMP(glrun->GetCOMPILATIONTIMESTAMP());
3121     glrun1->SetFAV_WRK_SCHEDULE(glrun->GetFAV_WRK_SCHEDULE());
3122     glrun1->SetEFF_WRK_SCHEDULE(glrun->GetEFF_WRK_SCHEDULE());
3123     glrun1->SetPRH_VAR_TRG_MODE_A(glrun->GetPRH_VAR_TRG_MODE_A());
3124     glrun1->SetPRH_VAR_TRG_MODE_B(glrun->GetPRH_VAR_TRG_MODE_B());
3125     glrun1->SetACQ_BUILD_INFO(glrun->GetACQ_BUILD_INFO());
3126     glrun1->SetACQ_VAR_INFO(glrun->GetACQ_VAR_INFO());
3127     glrun1->SetRM_ACQ_AFTER_CALIB(glrun->GetRM_ACQ_AFTER_CALIB());
3128     glrun1->SetRM_ACQ_SETTING_MODE(glrun->GetRM_ACQ_SETTING_MODE());
3129     glrun1->SetTRK_CALIB_USED(glrun->GetTRK_CALIB_USED());
3130     glrun1->SetCAL_DSP_MASK(glrun->GetCAL_DSP_MASK());
3131     glrun1->SetLAST_TIMESYNC(glrun->GetLAST_TIMESYNC());
3132     glrun1->SetOBT_TIMESYNC(glrun->GetOBT_TIMESYNC());
3133     //
3134     if ( glrun->GetPHYSENDRUN_MASK_S3S2S12() ) glrun1->SetPHYSENDRUN_MASK_S3S2S12(glrun->GetPHYSENDRUN_MASK_S3S2S12());
3135     if ( glrun->GetPHYSENDRUN_MASK_S11CRC() ) glrun1->SetPHYSENDRUN_MASK_S11CRC(glrun->GetPHYSENDRUN_MASK_S11CRC());
3136     //
3137     if ( !IsRunAlreadyInserted() ){
3138     //
3139     // glrun->SetID(this->AssignRunID());
3140 mocchiut 1.1 //
3141 mocchiut 1.2 glrun->SetID_RUN_FRAG(glrun1->GetID());
3142     glrun->Fill_GL_RUN(conn);
3143 mocchiut 1.1 //
3144 mocchiut 1.2 // set id number
3145 mocchiut 1.1 //
3146 mocchiut 1.2 glrun1->SetID_RUN_FRAG(glrun->GetID());
3147     glrun1->Fill_GL_RUN(conn);
3148 mocchiut 1.1 //
3149     };
3150 mocchiut 1.2 //
3151     // delete old entries in fragment table
3152     //
3153     glrun->DeleteRun(conn,0,"GL_RUN_FRAGMENTS");
3154     glrun1->DeleteRun(conn,0,"GL_RUN_FRAGMENTS");
3155     //
3156     delete glrun1;
3157     //
3158     return;
3159     //
3160 mocchiut 1.1 };
3161 mocchiut 1.2 //
3162 mocchiut 1.1 };
3163     //
3164 mocchiut 1.2 justcheck:
3165     //
3166     if ( !found ){
3167 mocchiut 1.1 //
3168 mocchiut 1.2 if ( IsDebug() ) printf(" not found, check if we have already processed the file \n ");
3169 mocchiut 1.1 //
3170 mocchiut 1.2 // not found, has this run already inserted in the GL_RUN or in the GL_RUN_FRAGMENTS table?
3171 mocchiut 1.1 //
3172     oss.str("");
3173 mocchiut 1.21 oss << " SELECT ID,ID_ROOT_L0 FROM GL_RUN WHERE "
3174 mocchiut 1.2 << " BOOT_NUMBER=" << this->GetBOOTnumber() << " AND ("
3175     << " (RUNHEADER_TIME>=" << (UInt_t)(glrun->GetRUNHEADER_TIME()-10) << " AND "
3176     << " RUNTRAILER_TIME<=" << (UInt_t)(glrun->GetRUNTRAILER_TIME()+10) << " AND ("
3177     << " RUNHEADER_OBT>=" << glrun->GetRUNHEADER_OBT() << " OR "
3178     << " RUNHEADER_PKT>=" << glrun->GetRUNHEADER_PKT() << ") AND ("
3179     << " RUNTRAILER_OBT<=" << glrun->GetRUNTRAILER_OBT() << " OR "
3180     << " RUNTRAILER_PKT<=" << glrun->GetRUNTRAILER_PKT() << ") ) OR "
3181     << " (RUNHEADER_TIME<=" << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND "
3182     << " RUNTRAILER_TIME>=" << (UInt_t)glrun->GetRUNTRAILER_TIME() <<" AND ("
3183     << " RUNHEADER_OBT<=" << glrun->GetRUNHEADER_OBT() << " OR "
3184     << " RUNHEADER_PKT<=" << glrun->GetRUNHEADER_PKT() << ") AND ("
3185     << " RUNTRAILER_OBT>=" << glrun->GetRUNTRAILER_OBT() << " OR "
3186     << " RUNTRAILER_PKT>=" << glrun->GetRUNTRAILER_PKT() << ") ));";
3187 mocchiut 1.1 //
3188 mocchiut 1.2 if ( IsDebug() ) printf(" check if run has been inserted: query is \n %s \n",oss.str().c_str());
3189     result = conn->Query(oss.str().c_str());
3190 mocchiut 1.1 //
3191 mocchiut 1.2 if ( !result ) throw -4;
3192 mocchiut 1.1 //
3193 mocchiut 1.2 row = result->Next();
3194 mocchiut 1.1 //
3195 mocchiut 1.2 if ( row ){
3196 mocchiut 1.21 //
3197     // we end up here if chewbacca and we have RH---| small gap |---RT, in this case the two pieces are attached and moved to GL_RUN. We are now processing the
3198     // "small gap" piece... we recognize this since: we have two entries from this query, the pkt number is consistent with our pkt number.
3199     //
3200     // 090112 [8RED (-70): RUN ALREADY INSERTED]
3201     //
3202     Bool_t OK = false;
3203     UInt_t IDRL2A = 0;
3204     UInt_t IDRL2B = 0;
3205     if ( chewbacca ){
3206     if ( result->GetRowCount() == 2 ){
3207     IDRL2A = (UInt_t)atoll(row->GetField(0));
3208     UInt_t IDRL0A = (UInt_t)atoll(row->GetField(1));
3209     row = result->Next();
3210     IDRL2B = (UInt_t)atoll(row->GetField(0));
3211     UInt_t IDRL0B = (UInt_t)atoll(row->GetField(1));
3212     if ( IsDebug() ) printf(" IDRL0A %u B %u IDRL2A %u B %u \n",IDRL0A,IDRL0B,IDRL2A,IDRL2B);
3213     if ( IDRL0A == IDRL0B ){
3214     TSQLResult *result2 = 0;
3215     TSQLRow *row2 = 0;
3216     oss.str("");
3217     oss << "select PKT_NUMBER_FINAL from ROOT_TABLE_MERGING where REAL_TIME_INIT<" << chrtinit << " order by REAL_TIME_INIT desc limit 1;";
3218     if ( IsDebug() ) printf(" Check if we are in the case RH---| small gap |---RT: query is \n %s \n",oss.str().c_str());
3219     result2 = conn->Query(oss.str().c_str());
3220     //
3221     if ( !result2 ) throw -4;
3222     //
3223     row2 = result2->Next();
3224     //
3225     if ( row2 ){
3226     UInt_t PKA = (UInt_t)atoll(row2->GetField(0));
3227     delete result2;
3228     oss.str("");
3229     oss << "select PKT_NUMBER_INIT from ROOT_TABLE_MERGING where REAL_TIME_INIT>" << chrtinit << " order by REAL_TIME_INIT asc limit 1;";
3230     if ( IsDebug() ) printf(" Check if we are in the case RH---| small gap |---RT: query is \n %s \n",oss.str().c_str());
3231     result2 = conn->Query(oss.str().c_str());
3232     //
3233     if ( !result2 ) throw -4;
3234     //
3235     row2 = result2->Next();
3236     //
3237     if ( row2 ){
3238     UInt_t PKB = (UInt_t)atoll(row2->GetField(0));
3239     //
3240     if ( IsDebug() ) printf(" PKT(PKA) + 1 %llu == runheaderpkt %llu && PKB = runtrailer %llu + 1 %llu \n",PKT(PKA)+1LL, PKT(glrun->GetRUNHEADER_PKT()),PKT(PKB), PKT(glrun->GetRUNTRAILER_PKT())+1LL);
3241     if ( PKT(PKA)+1LL == PKT(glrun->GetRUNHEADER_PKT()) && PKT(PKB) == PKT(glrun->GetRUNTRAILER_PKT())+1LL ){
3242     if ( IsDebug() ) printf(" Ok, we are in the case: RH---| small gap |---RT \n");
3243     OK = true;
3244     };
3245     };
3246     };
3247     };
3248     };
3249     };
3250     if ( OK ){
3251     //
3252     // this is the case in which we must insert a piece of run between two fragments in the GL_RUN table
3253     //
3254     // we have to update with runheader/trailer infos our run and we have to change the ROOT_ID_FRAG of the header piece ( 1/2 2/1 must become 1/3 3/2 2/1 )
3255     //
3256     GL_RUN *glA = new GL_RUN();
3257     glA->Query_GL_RUN(IDRL2A,conn);
3258     //
3259     if ( glA->GetACQ_BUILD_INFO() != 0 ){
3260     //
3261     // the first piece contains a good runheader we can update all the other runs with correct infos!
3262     //
3263     oss.str("");
3264     oss << "UPDATE GL_RUN_FRAGMENTS SET "
3265     << " RUNHEADER_TIME=" << glA->GetRUNHEADER_TIME()<< " , "
3266     << " RUNHEADER_OBT=" << glA->GetRUNHEADER_OBT()<< " , "
3267     << " RUNHEADER_PKT=" << glA->GetRUNHEADER_PKT()<< " , "
3268     << " COMPILATIONTIMESTAMP=" << glA->GetCOMPILATIONTIMESTAMP()<< " , "
3269     << " FAV_WRK_SCHEDULE=" << glA->GetFAV_WRK_SCHEDULE()<< " , "
3270     << " EFF_WRK_SCHEDULE=" << glA->GetEFF_WRK_SCHEDULE()<< " , "
3271     << " PRH_VAR_TRG_MODE_A=" << glA->GetPRH_VAR_TRG_MODE_A()<< " , "
3272     << " PRH_VAR_TRG_MODE_B=" << glA->GetPRH_VAR_TRG_MODE_B()<< " , "
3273     << " ACQ_BUILD_INFO=" << glA->GetACQ_BUILD_INFO()<< " , "
3274     << " ACQ_VAR_INFO=" << glA->GetACQ_VAR_INFO()<< " , "
3275     << " RM_ACQ_AFTER_CALIB=" << glA->GetRM_ACQ_AFTER_CALIB()<< " , "
3276     << " RM_ACQ_SETTING_MODE=" << glA->GetRM_ACQ_SETTING_MODE()<< " , "
3277     << " TRK_CALIB_USED=" << glA->GetTRK_CALIB_USED()<< " , "
3278     << " CAL_DSP_MASK=" << glA->GetCAL_DSP_MASK()<< " , "
3279     << " LAST_TIMESYNC=" << glA->GetLAST_TIMESYNC()<< " , ";
3280     //
3281     if ( glA->GetPHYSENDRUN_MASK_S3S2S12() )
3282     oss << " PHYSENDRUN_MASK_S3S2S12=" << glA->GetPHYSENDRUN_MASK_S3S2S12() << " , ";
3283     if ( glA->GetPHYSENDRUN_MASK_S11CRC() )
3284     oss << " PHYSENDRUN_MASK_S11CRC=" << glA->GetPHYSENDRUN_MASK_S11CRC() << " , ";
3285     //
3286     oss << " OBT_TIMESYNC=" << glA->GetOBT_TIMESYNC();
3287     oss << " WHERE ID=" << glrun->GetID() << ";";
3288     if ( IsDebug() ) printf(" update with correct infos: %s\n",oss.str().c_str());
3289     conn->Query(oss.str().c_str());
3290     //
3291     } else {
3292     //
3293     // sig no runheader, let set anyway what is possible...
3294     //
3295     oss.str("");
3296     oss << "UPDATE GL_RUN_FRAGMENTS SET "
3297     << " RUNHEADER_TIME=" << glA->GetRUNHEADER_TIME()<< " , ";
3298     //
3299     if ( glA->GetPHYSENDRUN_MASK_S3S2S12() )
3300     oss << " PHYSENDRUN_MASK_S3S2S12=" << glA->GetPHYSENDRUN_MASK_S3S2S12()<< " , ";
3301     if ( glA->GetPHYSENDRUN_MASK_S11CRC() )
3302     oss << " PHYSENDRUN_MASK_S11CRC=" << glA->GetPHYSENDRUN_MASK_S11CRC()<< " , ";
3303     //
3304     oss << " RUNHEADER_OBT=" << glA->GetRUNHEADER_OBT()<< " , "
3305     << " RUNHEADER_PKT=" << glA->GetRUNHEADER_PKT();
3306     oss << " WHERE ID=" << glrun->GetID() << ";";
3307     if ( IsDebug() ) printf(" update with correct infos2: %s\n",oss.str().c_str());
3308     conn->Query(oss.str().c_str());
3309     };
3310     //
3311     // update runheader ROOT_ID_FRAG
3312     //
3313     oss.str("");
3314     oss << "UPDATE GL_RUN SET ID_RUN_FRAG = " << glrun->GetID() << " where ID = " << IDRL2A << ";";
3315     if ( IsDebug() ) printf(" update gl_run to have cross indexing: %s\n",oss.str().c_str());
3316     conn->Query(oss.str().c_str());
3317     //
3318     // now let's look for runtrailer if any in the last run
3319     //
3320     glA->Query_GL_RUN(IDRL2B,conn);
3321     //
3322     if ( glA->GetPKT_READY_COUNTER() != 0 ){
3323     //
3324     // the first piece contains a good runtrailer we can update all the other runs with correct infos!
3325     //
3326     oss.str("");
3327     oss << "UPDATE GL_RUN_FRAGMENTS SET "
3328     << " RUNTRAILER_TIME=" << glA->GetRUNTRAILER_TIME()<< " , "
3329     << " RUNTRAILER_OBT=" << glA->GetRUNTRAILER_OBT()<< " , "
3330     << " RUNTRAILER_PKT=" << glA->GetRUNTRAILER_PKT()<< " , "
3331     << " PKT_COUNTER=" << glA->GetPKT_COUNTER()<< " , ";
3332     //
3333     if ( glA->GetPHYSENDRUN_MASK_S3S2S12() ){
3334     oss << " PHYSENDRUN_MASK_S3S2S12=" << glA->GetPHYSENDRUN_MASK_S3S2S12()<< " , "; };
3335     if ( glA->GetPHYSENDRUN_MASK_S11CRC() ) {
3336     oss << " PHYSENDRUN_MASK_S11CRC=" << glA->GetPHYSENDRUN_MASK_S11CRC()<< " , "; };
3337     //
3338     oss << " PKT_READY_COUNTER=" << glA->GetPKT_READY_COUNTER()
3339     << " WHERE ID=" << glrun->GetID() << ";";
3340     if ( IsDebug() ) printf(" update with correct trailer infos: %s\n",oss.str().c_str());
3341     conn->Query(oss.str().c_str());
3342     //
3343     } else {
3344     //
3345     // sig no runtrailer, let set anyway what is possible...
3346     //
3347     oss.str("");
3348     oss << "UPDATE GL_RUN_FRAGMENTS SET "
3349     << " RUNTRAILER_TIME=" << glA->GetRUNTRAILER_TIME()<< " , "
3350     << " RUNTRAILER_OBT=" << glA->GetRUNTRAILER_OBT()<< " , ";
3351     //
3352     if ( glA->GetPHYSENDRUN_MASK_S3S2S12() ){
3353     oss << " PHYSENDRUN_MASK_S3S2S12=" << glA->GetPHYSENDRUN_MASK_S3S2S12()<< " , "; };
3354     if ( glA->GetPHYSENDRUN_MASK_S11CRC() ){
3355     oss << " PHYSENDRUN_MASK_S11CRC=" << glA->GetPHYSENDRUN_MASK_S11CRC()<< " , "; };
3356     //
3357     oss << " RUNTRAILER_PKT=" << glrun->GetRUNTRAILER_PKT()
3358     << " WHERE ID=" << glrun->GetID() << ";";
3359     if ( IsDebug() ) printf(" update with correct trailer infos2: %s\n",oss.str().c_str());
3360     conn->Query(oss.str().c_str());
3361     };
3362     //
3363     UInt_t myi = glrun->GetID();
3364     oss.str("");
3365     oss << " ID= "<< myi;
3366     //
3367     glrun->Query_GL_RUN_FRAGMENTS(oss.str().c_str(),conn);
3368     //
3369     // fill the new run in GL_RUN
3370     //
3371     glrun->SetID_RUN_FRAG(IDRL2B);
3372     glrun->Fill_GL_RUN(conn);
3373     glrun->DeleteRun(conn,0,"GL_RUN_FRAGMENTS");
3374 mocchiut 1.23 delete glA;
3375 mocchiut 1.21 //
3376     } else {
3377     //
3378     // is just a repetition
3379     //
3380     if ( IsDebug() ) printf(" The run is already present in the GL_RUN table \n");
3381     if ( PEDANTIC ) throw -70;
3382     };
3383     //
3384 mocchiut 1.2 } else {
3385     if ( NoFrag() ){
3386     glrun->SetID_RUN_FRAG(glrun->GetID());
3387     glrun->Fill_GL_RUN(conn);
3388     glrun->DeleteRun(conn,0,"GL_RUN_FRAGMENTS");
3389     };
3390 mocchiut 1.1 };
3391     };
3392     }; // EEE
3393     //
3394     return;
3395     };
3396    
3397    
3398     /**
3399     * Handle run without header or trailer
3400     **/
3401     void PamelaDBOperations::HandleMissingHoT(Bool_t mishead, Bool_t mistrail, UInt_t firstev, UInt_t lastev){
3402     //
3403     //
3404     // is the piece of run good (no other packets inside)?
3405     //
3406     if ( !this->IsRunConsistent(mishead,mistrail,firstev,lastev)){
3407     //
3408     // if not, handle other pieces and continue with the first one
3409     //
3410     if ( IsDebug() ) printf("The run is not consistent, it contains non-physics packets! The run has been handled \n");
3411     //
3412     } else {
3413     //
3414     this->FillClass(mishead,mistrail,firstev,lastev);
3415     //
3416     if ( !IsRunAlreadyInserted() ){
3417     glrun->SetID(this->AssignRunID());
3418     glrun->SetID_RUN_FRAG(0);
3419     glrun->Fill_GL_RUN(conn); // it'ok we arrive here only inside a file hence in the middle of the runs...
3420 mocchiut 1.16 };
3421 mocchiut 1.1 //
3422     };
3423     //
3424     return;
3425     };
3426    
3427     /**
3428     *
3429     * check if we have non-physics packets inside the run
3430     *
3431     */
3432     Bool_t PamelaDBOperations::IsRunConsistent(Bool_t mishead, Bool_t mistrail, UInt_t &firstev, UInt_t &lastev){
3433     //
3434     EventCounter *code=0;
3435     //
3436     UInt_t nevent = 0;
3437     UInt_t checkfirst = 0;
3438     UInt_t checklast = 0;
3439     UInt_t firstentry = 0;
3440     UInt_t lastentry = 0;
3441     UInt_t firstTime = 0;
3442     UInt_t lastTime = 0;
3443     UInt_t firstPkt = 0;
3444     UInt_t lastPkt = 0;
3445     UInt_t firstObt = 0;
3446     UInt_t lastObt = 0;
3447     //
3448     pcksList packetsNames;
3449     pcksList::iterator Iter;
3450     getPacketsNames(packetsNames);
3451     //
3452     TTree *T= 0;
3453     T =(TTree*)file->Get("Physics");
3454     if ( !T || T->IsZombie() ) throw -16;
3455     EventHeader *eh = 0;
3456     PscuHeader *ph = 0;
3457     T->SetBranchAddress("Header", &eh);
3458     nevent = T->GetEntries();
3459     //
3460     //
3461     if ( firstev == lastev+1 || lastev == firstev ) { // no events inside the run!
3462     //if ( firstev <= lastev+1 ) { // no events inside the run!
3463     if ( IsDebug() ) printf(" Checking but no events in the run! \n");
3464 mocchiut 1.16 firstev = lastev+1; // this is necessary for files with no Physics entries, should have no influence on other files
3465 mocchiut 1.1 // return true is correct
3466     return(true);
3467     //
3468     } else {
3469     //
3470     T->GetEntry(firstev);
3471     code = eh->GetCounter();
3472     checkfirst = 0;
3473     for(Iter = packetsNames.begin(); Iter != packetsNames.end(); Iter++){
3474 mocchiut 1.2 if ( strcmp(*Iter,"Physics") ) checkfirst += code->Get(GetPacketType(*Iter));
3475     };
3476 mocchiut 1.1 if ( IsDebug() ) printf(" Check first is %i firstev is %i\n",checkfirst,firstev);
3477     //
3478     T->GetEntry(lastev);
3479     code = eh->GetCounter();
3480     checklast = 0;
3481     for(Iter = packetsNames.begin(); Iter != packetsNames.end(); Iter++){
3482 mocchiut 1.2 if ( strcmp(*Iter,"Physics") ) checklast += code->Get(GetPacketType(*Iter));
3483     };
3484 mocchiut 1.1 if ( IsDebug() ) printf(" Check last is %i lastev is %i\n",checklast,lastev);
3485     //
3486     if ( checkfirst == checklast ){
3487     //
3488     if ( IsDebug() ) printf(" No packets but physics inside the run, I will consider it as good\n");
3489     //
3490     return(true);
3491     //
3492     } else {
3493     //
3494 mocchiut 1.10 if ( IsDebug() ) printf(" There are no-physics packets inside the run!\n");
3495 mocchiut 1.1 //
3496     // HERE WE MUST HANDLE THAT RUNS AND GO BACK
3497     //
3498 mocchiut 1.2 // if ( IsDebug() ) printf(" Never seen this case, try to handle it anyway, it was throw -95\n");
3499 mocchiut 1.1 //
3500     Bool_t emptyruns = false;
3501     UInt_t check = 0;
3502     UInt_t lastevtemp = lastev;
3503     UInt_t firstevno = firstev;
3504 mocchiut 1.10 UInt_t rhchko=0;
3505     UInt_t rhchk=0;
3506 mocchiut 1.1 //
3507     for (UInt_t i=firstev; i<=lastev; i++){
3508     //
3509     T->GetEntry(i);
3510     code = eh->GetCounter();
3511     //
3512     check = 0;
3513     //
3514 mocchiut 1.10
3515     // if we have a runheader set lastev then exit
3516     //
3517 mocchiut 1.1 for(Iter = packetsNames.begin(); Iter != packetsNames.end(); Iter++){
3518     if ( strcmp(*Iter,"Physics") ) check += code->Get(GetPacketType(*Iter));
3519     };
3520 mocchiut 1.10 // check here if we have a runheader
3521     rhchko = rhchk;
3522     rhchk = code->Get(GetPacketType("RunHeader"));
3523 mocchiut 1.1 //
3524     if ( checkfirst < check || i == lastev ){
3525     //
3526     firstentry = firstevno;
3527     //
3528     if ( checkfirst < check ){
3529     lastentry = i-1;
3530     } else {
3531     lastentry = i;
3532     };
3533     //
3534     if ( IsDebug() ) printf(" Run between %i and %i entries\n",firstentry,lastentry);
3535     //
3536     glrun->SetEV_FROM(firstentry);
3537     glrun->SetEV_TO(lastentry);
3538     if ( lastentry == (firstentry-1) ){ // no physics packets inside physics run with no runheader no runtrailer
3539     if ( IsDebug() ) printf(" no physics packets inside physics run with no runheader no runtrailer\n");
3540     lastentry--;
3541     };
3542     glrun->SetNEVENTS(lastentry-firstentry+1);
3543     //
3544     glrun->Set_GL_RUNH0();
3545     glrun->Set_GL_RUNT0();
3546     //
3547     glrun->SetLAST_TIMESYNC(0);
3548     glrun->SetOBT_TIMESYNC(0);
3549     //
3550     T->GetEntry(firstentry);
3551     ph = eh->GetPscuHeader();
3552     firstObt = ph->GetOrbitalTime();
3553     firstTime = this->GetAbsTime(firstObt);
3554     firstPkt = ph->GetCounter();
3555     //
3556     T->GetEntry(lastentry);
3557     ph = eh->GetPscuHeader();
3558     lastObt = ph->GetOrbitalTime();
3559     lastTime = this->GetAbsTime(lastObt);
3560     lastPkt = ph->GetCounter();
3561     //
3562     glrun->SetRUNHEADER_PKT(firstPkt);
3563 mocchiut 1.2 glrun->SetRUNTRAILER_PKT(lastPkt);
3564     //
3565     glrun->SetRUNHEADER_OBT(firstObt);
3566     glrun->SetRUNTRAILER_OBT(lastObt);
3567     //
3568     if ( IsDebug() ) printf(" A THIS RUN: RUNHEADER_OBT %u RUNTRAILER_OBT %u RUNHEADER_PKT %u RUNTRAILER_PKT %u \n", glrun->GetRUNHEADER_OBT(),glrun->GetRUNTRAILER_OBT(),glrun->GetRUNHEADER_PKT(),glrun->GetRUNTRAILER_PKT());
3569     if ( firstev == firstentry && !emptyruns && !mishead ){
3570     glrun->Set_GL_RUNH(runh,phh);
3571     firstTime = this->GetAbsTime(phh->GetOrbitalTime());
3572     if ( IsDebug() ) printf(" We have the runheader \n");
3573     };
3574     if ( lastev == i && !mistrail ){
3575     glrun->Set_GL_RUNT(runt,pht);
3576     lastTime = this->GetAbsTime(pht->GetOrbitalTime());
3577     if ( IsDebug() ) printf(" We have the runtrailer \n");
3578     };
3579     //
3580     if ( IsDebug() ) printf(" B THIS RUN: RUNHEADER_OBT %u RUNTRAILER_OBT %u RUNHEADER_PKT %u RUNTRAILER_PKT %u \n", glrun->GetRUNHEADER_OBT(),glrun->GetRUNTRAILER_OBT(),glrun->GetRUNHEADER_PKT(),glrun->GetRUNTRAILER_PKT());
3581     if ( lastentry == (firstentry-2) ){ // no events in the run
3582     emptyruns = true;
3583     if ( IsDebug() ) printf(" No events in the run \n");
3584     lastTime = firstTime;
3585     if ( (UInt_t)firstTime == this->GetAbsTime(phh->GetOrbitalTime()) ){
3586     lastObt = glrun->RUNHEADER_OBT;
3587     lastPkt = glrun->RUNHEADER_PKT;
3588     } else {
3589     lastObt = firstObt;
3590     lastPkt = firstPkt;
3591     };
3592     glrun->SetRUNTRAILER_PKT(lastPkt);
3593     glrun->SetRUNTRAILER_OBT(lastObt);
3594     lastentry++;
3595     };
3596     //
3597     this->SetCommonGLRUN(firstTime,lastTime);
3598     this->SetPhysEndRunVariables();
3599     //
3600     if ( chminentry == firstentry ){ // EEE
3601     if ( IsDebug() ) printf(" Inside isrunconsistent found a fragment of run at the beginning of the file, put it in the fragment table \n");
3602     //
3603     // this->HandleRunFragments(true,mistrail,firstentry,lastentry); // cannot call it here since it enters a loop which will destroy the already stored variables if we arrive here from HandleRunFragments
3604     //
3605    
3606     mishead = true;
3607    
3608    
3609     UInt_t rhfirstev = firstentry;
3610     // UInt_t rtlastev = lastentry;
3611     Bool_t found = false;
3612     Bool_t foundinrun = false;
3613     //
3614     TSQLResult *result = 0;
3615     TSQLRow *row = 0;
3616     //
3617     stringstream oss;
3618     oss.str("");
3619     //
3620     // we have now the good first piece of a run, fill the glrun object
3621     //
3622     // if ( rhfirstev != firstev && !mishead ) mishead = true;
3623     // if ( rtlastev != lastev && !mistrail ) mistrail = true;
3624     //
3625     // this->FillClass(mishead,mistrail,firstev,lastev);
3626     //
3627     if ( IsDebug() ) printf("zz The run is good, is it the other piece in the GL_RUN_FRAGMENTS table?\n");
3628     if ( IsDebug() ) printf("zz C THIS RUN: RUNHEADER_OBT %u RUNTRAILER_OBT %u RUNHEADER_PKT %u RUNTRAILER_PKT %u \n", glrun->GetRUNHEADER_OBT(),glrun->GetRUNTRAILER_OBT(),glrun->GetRUNHEADER_PKT(),glrun->GetRUNTRAILER_PKT());
3629     //
3630     // First of all insert the run in the fragment table...
3631     //
3632     oss.str("");
3633     oss << " SELECT ID FROM GL_RUN_FRAGMENTS WHERE "
3634     << " BOOT_NUMBER=" << this->GetBOOTnumber() << " AND ("
3635     << " (RUNHEADER_TIME>=" << (UInt_t)(glrun->GetRUNHEADER_TIME()-10) << " AND "
3636     << " RUNTRAILER_TIME<=" << (UInt_t)(glrun->GetRUNTRAILER_TIME()+10) << " AND ("
3637     << " RUNHEADER_OBT>=" << glrun->GetRUNHEADER_OBT() << " OR "
3638     << " RUNHEADER_PKT>=" << glrun->GetRUNHEADER_PKT() << ") AND ("
3639     << " RUNTRAILER_OBT<=" << glrun->GetRUNTRAILER_OBT() << " OR "
3640     << " RUNTRAILER_PKT<=" << glrun->GetRUNTRAILER_PKT() << ") ) OR "
3641     << " (RUNHEADER_TIME<=" << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND "
3642     << " RUNTRAILER_TIME>=" << (UInt_t)glrun->GetRUNTRAILER_TIME() <<" AND ("
3643     << " RUNHEADER_OBT<=" << glrun->GetRUNHEADER_OBT() << " OR "
3644     << " RUNHEADER_PKT<=" << glrun->GetRUNHEADER_PKT() << ") AND ("
3645     << " RUNTRAILER_OBT>=" << glrun->GetRUNTRAILER_OBT() << " OR "
3646     << " RUNTRAILER_PKT>=" << glrun->GetRUNTRAILER_PKT() << ") ));";
3647     //
3648     if ( IsDebug() ) printf(" check if run has been inserted: query is \n %s \n",oss.str().c_str());
3649     result = conn->Query(oss.str().c_str());
3650     //
3651     if ( !result ) throw -4;
3652     //
3653     row = result->Next();
3654     //
3655     if ( !row ){
3656     //
3657     // no, insert this run in the GL_RUN_FRAGMENTS table (check if exist before!)
3658     //
3659     if ( IsDebug() ) printf(" The run is new \n");
3660     if ( IsDebug() ) printf(" -> fill the GL_RUNFRAGMENTS table \n");
3661     //
3662     glrun->SetID(this->AssignRunID());
3663     glrun->SetID_RUN_FRAG(0);
3664     glrun->Fill_GL_RUN_FRAGMENTS(conn);
3665     //
3666     } else {
3667     if ( IsDebug() ) printf(" The run is already present in the fragment table \n");
3668     if ( PEDANTIC ) throw -69;
3669     // return;
3670     };
3671     //
3672     if ( chewbacca && mishead && mistrail ) goto zjustcheck;
3673     //
3674     // can we find the other piece of the run in the GL_RUN_FRAGMENTS table?
3675     //
3676     if ( mishead && ( rhfirstev == firstev || chewbacca ) ) { // look for runheader (only when at the beginning of the file, if at the end and the runh is
3677     // missing it no way we can found a piece in the frag table
3678     //
3679     oss.str("");
3680     oss << " SELECT ID,TRK_CALIB_USED,RUNTRAILER_TIME,RUNTRAILER_OBT,RUNHEADER_PKT,RUNTRAILER_PKT FROM GL_RUN_FRAGMENTS WHERE "
3681     << " BOOT_NUMBER=" << this->GetBOOTnumber() << " AND "
3682     << " RUNHEADER_TIME <= " << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND "
3683     << " ID != " << glrun->ID
3684     << " ORDER BY RUNHEADER_TIME DESC LIMIT 1;"; // DESC NOT ASC!!
3685     //
3686     if ( IsDebug() ) printf(" look for runheader in the fragments table: query is \n %s \n",oss.str().c_str());
3687     result = conn->Query(oss.str().c_str());
3688     //
3689     if ( !result ) throw -4;
3690     //
3691     row = result->Next();
3692     //
3693     if ( !row && NoFrag() ){
3694     //
3695     oss.str("");
3696     oss << " SELECT ID,TRK_CALIB_USED,RUNTRAILER_TIME,RUNTRAILER_OBT,RUNHEADER_PKT,RUNTRAILER_PKT FROM GL_RUN WHERE "
3697     << " BOOT_NUMBER=" << this->GetBOOTnumber() << " AND "
3698     << " RUNHEADER_TIME <= " << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND "
3699     << " ID != " << glrun->ID
3700     << " AND ID=ID_RUN_FRAG ORDER BY RUNHEADER_TIME DESC LIMIT 1;"; // DESC NOT ASC!!
3701     //
3702     if ( IsDebug() ) printf(" look for runheader in the GL_RUN table: query is \n %s \n",oss.str().c_str());
3703     result = conn->Query(oss.str().c_str());
3704     //
3705     if ( !result ) throw -4;
3706     //
3707     foundinrun = true;
3708     //
3709     row = result->Next();
3710     //
3711     };
3712     //
3713     if ( !row ){
3714     if ( IsDebug() ) printf(" the corresponding piece has NOT been found \n");
3715     found = false;
3716     } else {
3717     //
3718     found = false; // default value
3719     //
3720 mocchiut 1.16 if ( IsDebug() ) printf(" C Found a possible candidate, checking if it is the good one... \n");
3721 mocchiut 1.2 //
3722     // if we have both runheader and runtrailer we can check with pkt_counter:
3723     //
3724     if ( !mistrail && (UInt_t)atoll(row->GetField(1)) != 0 ){
3725     ULong64_t chkpkt = 0;
3726     ULong64_t pktt = (ULong64_t)PKT(glrun->GetRUNTRAILER_PKT());
3727     ULong64_t pkth = (ULong64_t)PKT((UInt_t)atoll(row->GetField(4)));
3728     //
3729     chkpkt = pkth + (ULong64_t)glrun->GetPKT_COUNTER() + 1ULL + 1ULL;
3730     //
3731     if ( labs(chkpkt-pktt)<2 ){
3732     //
3733     if ( IsDebug() ) printf(" FOUND!!! check %llu pktt %llu \n",chkpkt,pktt);
3734     //
3735     found = true;
3736     //
3737     } else {
3738     //
3739     if ( IsDebug() ) printf(" The check with pkt counter failed: check %llu pktt %llu \n",chkpkt,pktt);
3740     //
3741     found = false;
3742     //
3743     };
3744     };
3745     if ( !found && chewbacca ) goto zjustcheck;
3746     if ( !found ){
3747     //
3748     // if we arrive here we were not able to decide if the two pieces matches using only the pkt counter information, we must check times and obts
3749     //
3750     ULong64_t chkpkt1 = 0;
3751     ULong64_t orunh1 = (ULong64_t)PKT(glrun->GetRUNHEADER_PKT());
3752     ULong64_t dbrunt1 = (ULong64_t)PKT((UInt_t)atoll(row->GetField(5)));
3753     chkpkt1 = labs(orunh1-dbrunt1);
3754     //
3755     ULong64_t chkpkt2 = 0;
3756     ULong64_t orunh2 = (ULong64_t)OBT(glrun->GetRUNHEADER_OBT());
3757     ULong64_t dbrunt2 = (ULong64_t)OBT((UInt_t)atoll(row->GetField(3)));
3758     chkpkt2 = labs(orunh2-dbrunt2);
3759     //
3760     ULong64_t chkpkt3 = 0;
3761     ULong64_t orunh3 = (ULong64_t)(glrun->GetRUNHEADER_TIME());
3762     ULong64_t dbrunt3 = (ULong64_t)((UInt_t)atoll(row->GetField(2)));
3763     chkpkt3 = labs(orunh3-dbrunt3);
3764     //
3765     if ( (chkpkt1 < 200 || chkpkt2 < 20000) && chkpkt3 < 20 ){
3766     // if ( chkpkt1 < 100 && chkpkt2 < 30000 && chkpkt3 < 30 ){
3767     //
3768     if ( IsDebug() ) printf(" FOUND!!! check1 %llu<200 cechk2 %llu<20000 check3 %llu<20 \n",chkpkt1,chkpkt2,chkpkt3);
3769     //
3770     found = true;
3771     //
3772     } else {
3773     //
3774     if ( IsDebug() ) printf(" Check failed: check1 %llu<200? cechk2 %llu<20000? check3 %llu<20? \n",chkpkt1,chkpkt2,chkpkt3);
3775     //
3776     found = false;
3777     //
3778     };
3779     };
3780     };
3781     //
3782     if ( found ){
3783     //
3784     // we have found the missing piece, glue the two together, merge the informations, fill the gl_run table (check first runs do not exists), delete entry in frag table
3785     //
3786     if ( IsDebug() ) printf(" now you can handle the piece of the run \n ");
3787     //
3788     if ( foundinrun ){
3789     glrun->RestoreRun(conn,(UInt_t)atoll(row->GetField(0)),"GL_RUN_FRAGMENTS");
3790     glrun->DeleteRun(conn,(UInt_t)atoll(row->GetField(0)),"GL_RUN");
3791     };
3792     //
3793     GL_RUN *glrun1 = new GL_RUN();
3794     //
3795     // UInt_t idfrag = (UInt_t)atoll(row->GetField(0));
3796     //
3797     oss.str("");
3798     oss << " ID="<<row->GetField(0)<<";";
3799     //
3800     glrun1->Query_GL_RUN_FRAGMENTS(oss.str().c_str(),conn); // here we have runheader infos
3801     //
3802     // merge infos
3803     //
3804     UInt_t apkt = PKT(glrun1->GetRUNTRAILER_PKT());
3805     ULong64_t aobt = OBT(glrun1->GetRUNTRAILER_OBT());
3806     UInt_t bpkt = PKT(glrun->GetRUNHEADER_PKT());
3807     ULong64_t bobt = OBT(glrun->GetRUNHEADER_OBT());
3808     if ( IsDebug() ) printf(" Check overlapping events: %u %u %llu %llu firstev is %i\n",apkt,bpkt,aobt,bobt,firstev);
3809     TTree *T= 0;
3810     T = (TTree*)file->Get("Physics");
3811     if ( !T || T->IsZombie() ) throw -16;
3812     EventHeader *eh = 0;
3813     PscuHeader *ph = 0;
3814     T->SetBranchAddress("Header", &eh);
3815     while ( apkt > bpkt && aobt > bobt && firstev < lastev ){
3816     T->GetEntry(firstev);
3817     ph = eh->GetPscuHeader();
3818     bpkt = PKT(ph->GetCounter());
3819     bobt = OBT(ph->GetOrbitalTime());
3820     firstev++;
3821     if ( PEDANTIC ) throw -71;
3822     };
3823     if ( IsDebug() ) printf(" Check overlapping events done: %u %u %llu %llu firstev is %i\n",apkt,bpkt,aobt,bobt,firstev);
3824     //
3825     glrun1->SetPKT_COUNTER(glrun->GetPKT_COUNTER());
3826     glrun1->SetPKT_READY_COUNTER(glrun->GetPKT_READY_COUNTER());
3827     glrun1->SetRUNTRAILER_TIME(glrun->GetRUNTRAILER_TIME());
3828     glrun1->SetRUNTRAILER_OBT(glrun->GetRUNTRAILER_OBT());
3829     glrun1->SetRUNTRAILER_PKT(glrun->GetRUNTRAILER_PKT());
3830     //
3831     glrun->SetEV_FROM(firstev);
3832     glrun->SetNEVENTS(lastev-firstev+1);
3833     //
3834     glrun->SetRUNHEADER_TIME(glrun1->GetRUNHEADER_TIME());
3835     glrun->SetRUNHEADER_OBT(glrun1->GetRUNHEADER_OBT());
3836     glrun->SetRUNHEADER_PKT(glrun1->GetRUNHEADER_PKT());
3837     glrun->SetCOMPILATIONTIMESTAMP(glrun1->GetCOMPILATIONTIMESTAMP());
3838     glrun->SetFAV_WRK_SCHEDULE(glrun1->GetFAV_WRK_SCHEDULE());
3839     glrun->SetEFF_WRK_SCHEDULE(glrun1->GetEFF_WRK_SCHEDULE());
3840     glrun->SetPRH_VAR_TRG_MODE_A(glrun1->GetPRH_VAR_TRG_MODE_A());
3841     glrun->SetPRH_VAR_TRG_MODE_B(glrun1->GetPRH_VAR_TRG_MODE_B());
3842     glrun->SetACQ_BUILD_INFO(glrun1->GetACQ_BUILD_INFO());
3843     glrun->SetACQ_VAR_INFO(glrun1->GetACQ_VAR_INFO());
3844     glrun->SetRM_ACQ_AFTER_CALIB(glrun1->GetRM_ACQ_AFTER_CALIB());
3845     glrun->SetRM_ACQ_SETTING_MODE(glrun1->GetRM_ACQ_SETTING_MODE());
3846     glrun->SetTRK_CALIB_USED(glrun1->GetTRK_CALIB_USED());
3847     glrun->SetCAL_DSP_MASK(glrun1->GetCAL_DSP_MASK());
3848     glrun->SetLAST_TIMESYNC(glrun1->GetLAST_TIMESYNC());
3849     glrun->SetOBT_TIMESYNC(glrun1->GetOBT_TIMESYNC());
3850     //
3851     if ( glrun1->GetPHYSENDRUN_MASK_S3S2S12() ) glrun->SetPHYSENDRUN_MASK_S3S2S12(glrun1->GetPHYSENDRUN_MASK_S3S2S12());
3852     if ( glrun1->GetPHYSENDRUN_MASK_S11CRC() ) glrun->SetPHYSENDRUN_MASK_S11CRC(glrun1->GetPHYSENDRUN_MASK_S11CRC());
3853     //
3854     if ( !IsRunAlreadyInserted() ){
3855     //
3856     // glrun->SetID(this->AssignRunID());
3857     glrun->SetID_RUN_FRAG(glrun1->GetID());
3858     glrun->Fill_GL_RUN(conn);
3859     //
3860     // set id number
3861     //
3862     glrun1->SetID_RUN_FRAG(glrun->GetID());
3863     glrun1->Fill_GL_RUN(conn);
3864     //
3865     };
3866     // delete old entry in fragment table
3867     //
3868     glrun->DeleteRun(conn,0,"GL_RUN_FRAGMENTS");
3869     glrun1->DeleteRun(conn,0,"GL_RUN_FRAGMENTS");
3870     //
3871     delete glrun1;
3872     //
3873     //
3874     // return;
3875     //
3876     };
3877     //
3878 mocchiut 1.1 };
3879 mocchiut 1.2 //
3880     //
3881     zjustcheck:
3882     //
3883     if ( !found ){
3884     //
3885     if ( IsDebug() ) printf(" not found, check if we have already processed the file \n ");
3886     //
3887     // not found, has this run already inserted in the GL_RUN or in the GL_RUN_FRAGMENTS table?
3888     //
3889     oss.str("");
3890     oss << " SELECT ID FROM GL_RUN WHERE "
3891     << " BOOT_NUMBER=" << this->GetBOOTnumber() << " AND ("
3892     << " (RUNHEADER_TIME>=" << (UInt_t)(glrun->GetRUNHEADER_TIME()-10) << " AND "
3893     << " RUNTRAILER_TIME<=" << (UInt_t)(glrun->GetRUNTRAILER_TIME()+10) << " AND ("
3894     << " RUNHEADER_OBT>=" << glrun->GetRUNHEADER_OBT() << " OR "
3895     << " RUNHEADER_PKT>=" << glrun->GetRUNHEADER_PKT() << ") AND ("
3896     << " RUNTRAILER_OBT<=" << glrun->GetRUNTRAILER_OBT() << " OR "
3897     << " RUNTRAILER_PKT<=" << glrun->GetRUNTRAILER_PKT() << ") ) OR "
3898     << " (RUNHEADER_TIME<=" << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND "
3899     << " RUNTRAILER_TIME>=" << (UInt_t)glrun->GetRUNTRAILER_TIME() <<" AND ("
3900     << " RUNHEADER_OBT<=" << glrun->GetRUNHEADER_OBT() << " OR "
3901     << " RUNHEADER_PKT<=" << glrun->GetRUNHEADER_PKT() << ") AND ("
3902     << " RUNTRAILER_OBT>=" << glrun->GetRUNTRAILER_OBT() << " OR "
3903     << " RUNTRAILER_PKT>=" << glrun->GetRUNTRAILER_PKT() << ") ));";
3904     //
3905     if ( IsDebug() ) printf(" check if run has been inserted: query is \n %s \n",oss.str().c_str());
3906     result = conn->Query(oss.str().c_str());
3907     //
3908     if ( !result ) throw -4;
3909     //
3910     row = result->Next();
3911     //
3912     if ( row ){
3913     if ( IsDebug() ) printf(" The run is already present in the GL_RUN table \n");
3914     if ( PEDANTIC ) throw -70;
3915     } else {
3916     if ( NoFrag() ){
3917     glrun->SetID_RUN_FRAG(glrun->GetID());
3918     glrun->Fill_GL_RUN(conn);
3919     glrun->DeleteRun(conn,0,"GL_RUN_FRAGMENTS");
3920     };
3921     };
3922     }; // EEE
3923 mocchiut 1.1
3924    
3925     } else {
3926 mocchiut 1.2 if ( !IsRunAlreadyInserted() ){
3927     glrun->SetID(this->AssignRunID());
3928     glrun->SetID_RUN_FRAG(0);
3929     glrun->Fill_GL_RUN(conn);
3930     };
3931 mocchiut 1.1 }; // EEE
3932     //
3933     firstevno = lastentry + 1;
3934     //
3935     checkfirst = check;
3936     //
3937     };
3938     //
3939 mocchiut 1.10 if ( i > firstev ){
3940     if ( rhchko != rhchk ){
3941     if ( IsDebug() ) printf("oh oh... we have a runheader! stop here and handle later the remaining piece\n");
3942     lastev = i;
3943     return(false);
3944     };
3945     };
3946     //
3947 mocchiut 1.1 if ( check == checklast && i != lastev ){
3948     lastevtemp = i - 1;
3949     i = lastev - 1;
3950     };
3951     //
3952     };
3953     //
3954     lastev = lastevtemp;
3955     //
3956     return(false);
3957     //
3958     };
3959     };
3960     //
3961     return(false); // should never arrive here
3962     };
3963    
3964     /**
3965     *
3966     * we end up here when we have a runheader and a runtrailer but they seems not belonging to the same run since the number of events does not coincide with the
3967     * number of event written in the runtrailer. We try to split into different runs scanning the physics events from the runheader to the runtrailer and
3968     * looking for non-physics packets inside.
3969     *
3970     */
3971     void PamelaDBOperations::HandleSuspiciousRun(){
3972     //
3973     PacketType *pctp=0;
3974     EventCounter *codt=0;
3975     EventCounter *codh=0;
3976     EventCounter *code=0;
3977     UInt_t firstev = 0;
3978     UInt_t lastev = 0;
3979     UInt_t nevent = 0;
3980     UInt_t checkfirst = 0;
3981     UInt_t checklast = 0;
3982     UInt_t firstentry = 0;
3983     UInt_t lastentry = 0;
3984     UInt_t firstTime = 0;
3985     UInt_t lastTime = 0;
3986     UInt_t firstPkt = 0;
3987     UInt_t lastPkt = 0;
3988     UInt_t firstObt = 0;
3989     UInt_t lastObt = 0;
3990     //
3991     pcksList packetsNames;
3992     pcksList::iterator Iter;
3993     getPacketsNames(packetsNames);
3994     //
3995     TTree *rh=0;
3996     rh = (TTree*)file->Get("RunHeader");
3997     if ( !rh || rh->IsZombie() ) throw -17;
3998     TTree *T=0;
3999     T =(TTree*)file->Get("Physics");
4000     if ( !T || T->IsZombie() ) throw -16;
4001     EventHeader *eh = 0;
4002     PscuHeader *ph = 0;
4003     T->SetBranchAddress("Header", &eh);
4004     nevent = T->GetEntries();
4005     //
4006     codt = eht->GetCounter();
4007     codh = ehh->GetCounter();
4008     firstev = codh->Get(pctp->Physics);
4009     lastev = codt->Get(pctp->Physics)-1;
4010     if ( IsDebug() ) printf(" From the current runheader firstev is %u from the runtrailer lastev is %u \n",firstev,lastev);
4011     //
4012     if ( firstev == lastev+1 ) { // no events inside the run!
4013     if ( IsDebug() ) printf(" Checking but no events in the run! \n");
4014     //
4015     this->FillClass();
4016     if ( !IsRunAlreadyInserted() ){
4017     glrun->SetID(this->AssignRunID());
4018     glrun->SetID_RUN_FRAG(0);
4019     glrun->Fill_GL_RUN(conn);
4020     };
4021     //
4022     } else {
4023     //
4024     UInt_t nrunh = 0 + codh->Get(pctp->RunHeader);
4025     UInt_t nrunh1 = 0 + codh->Get(pctp->RunHeader);
4026     T->GetEntry(firstev);
4027     code = eh->GetCounter();
4028     checkfirst = 0;
4029     for(Iter = packetsNames.begin(); Iter != packetsNames.end(); Iter++){
4030 mocchiut 1.2 if ( strcmp(*Iter,"Physics") ) checkfirst += code->Get(GetPacketType(*Iter));
4031     if ( !strcmp(*Iter,"RunHeader") ) nrunh1++;
4032     };
4033 mocchiut 1.1 if ( IsDebug() ) printf(" Check first is %i \n",checkfirst);
4034     //
4035     T->GetEntry(lastev);
4036     code = eh->GetCounter();
4037     checklast = 0;
4038     for(Iter = packetsNames.begin(); Iter != packetsNames.end(); Iter++){
4039 mocchiut 1.2 if ( strcmp(*Iter,"Physics") ) checklast += code->Get(GetPacketType(*Iter));
4040     };
4041 mocchiut 1.1 if ( IsDebug() ) printf(" Check last is %i \n",checklast);
4042     //
4043     if ( checkfirst == checklast ){
4044     //
4045     if ( IsDebug() ) printf(" No packets but physics inside the run, I will consider it as good\n");
4046     //
4047     this->FillClass();
4048     if ( !IsRunAlreadyInserted() ){
4049     glrun->SetID(this->AssignRunID());
4050     glrun->SetID_RUN_FRAG(0);
4051     glrun->Fill_GL_RUN(conn);
4052     };
4053     //
4054     } else {
4055     //
4056     if ( IsDebug() ) printf(" There are no-physics packets inside the run, try to separate runs \n");
4057     //
4058     Bool_t emptyruns = false;
4059     UInt_t check = 0;
4060     UInt_t firstevno = firstev;
4061     //
4062     for (UInt_t i=firstev; i<=lastev; i++){
4063     //
4064     T->GetEntry(i);
4065     code = eh->GetCounter();
4066     //
4067     check = 0;
4068     //
4069     for(Iter = packetsNames.begin(); Iter != packetsNames.end(); Iter++){
4070     if ( strcmp(*Iter,"Physics") ) check += code->Get(GetPacketType(*Iter));
4071     if ( !strcmp(*Iter,"RunHeader") ) nrunh++;
4072     };
4073     //
4074     if ( checkfirst < check || i == lastev ){
4075     //
4076     firstentry = firstevno;
4077     //
4078     if ( checkfirst < check ){
4079     lastentry = i-1;
4080     } else {
4081     lastentry = i;
4082     };
4083     //
4084     if ( IsDebug() ) printf(" Run between %i and %i entries\n",firstentry,lastentry);
4085     //
4086     glrun->SetEV_FROM(firstentry);
4087     glrun->SetEV_TO(lastentry);
4088     if ( lastentry == (firstentry-1) ){ // no physics packets inside physics run with no runheader no runtrailer
4089     if ( IsDebug() ) printf(" no physics packets inside physics run with no runheader no runtrailer\n");
4090     lastentry--;
4091     };
4092     glrun->SetNEVENTS(lastentry-firstentry+1);
4093     //
4094     glrun->Set_GL_RUNH0();
4095     glrun->Set_GL_RUNT0();
4096     //
4097     glrun->SetLAST_TIMESYNC(0);
4098     glrun->SetOBT_TIMESYNC(0);
4099     //
4100     T->GetEntry(firstentry);
4101     ph = eh->GetPscuHeader();
4102     firstObt = ph->GetOrbitalTime();
4103     firstTime = this->GetAbsTime(firstObt);
4104     firstPkt = ph->GetCounter();
4105     //
4106     T->GetEntry(lastentry);
4107     ph = eh->GetPscuHeader();
4108     lastObt = ph->GetOrbitalTime();
4109     lastTime = this->GetAbsTime(lastObt);
4110     lastPkt = ph->GetCounter();
4111     //
4112     glrun->SetRUNHEADER_PKT(firstPkt);
4113     glrun->SetRUNTRAILER_PKT(lastPkt);
4114     //
4115     glrun->SetRUNHEADER_OBT(firstObt);
4116     glrun->SetRUNTRAILER_OBT(lastObt);
4117     //
4118     if ( IsDebug() ) printf(" AA THIS RUN: RUNHEADER_OBT %u RUNTRAILER_OBT %u RUNHEADER_PKT %u RUNTRAILER_PKT %u \n", glrun->GetRUNHEADER_OBT(),glrun->GetRUNTRAILER_OBT(),glrun->GetRUNHEADER_PKT(),glrun->GetRUNTRAILER_PKT());
4119     //
4120     if ( (firstev == firstentry && !emptyruns) || nrunh == (nrunh1 + 1) ){
4121     rh->GetEntry(nrunh1-1);
4122     phh = ehh->GetPscuHeader();
4123     nrunh1++;
4124     glrun->Set_GL_RUNH(runh,phh);
4125     firstTime = this->GetAbsTime(phh->GetOrbitalTime());
4126     if ( IsDebug() ) printf(" We have the runheader \n");
4127     };
4128     if ( lastev == i && checkfirst == check ){
4129     glrun->Set_GL_RUNT(runt,pht);
4130     lastTime = this->GetAbsTime(pht->GetOrbitalTime());
4131     if ( IsDebug() ) printf(" We have the runtrailer \n");
4132     };
4133     if ( IsDebug() ) printf(" BB THIS RUN: RUNHEADER_OBT %u RUNTRAILER_OBT %u RUNHEADER_PKT %u RUNTRAILER_PKT %u \n", glrun->GetRUNHEADER_OBT(),glrun->GetRUNTRAILER_OBT(),glrun->GetRUNHEADER_PKT(),glrun->GetRUNTRAILER_PKT());
4134     //
4135     if ( lastentry == (firstentry-2) ){ // no events in the run
4136     emptyruns = true;
4137     if ( IsDebug() ) printf(" No events in the run \n");
4138     lastTime = firstTime;
4139     if ( (UInt_t)firstTime == this->GetAbsTime(phh->GetOrbitalTime()) ){
4140     lastObt = glrun->RUNHEADER_OBT;
4141     lastPkt = glrun->RUNHEADER_PKT;
4142     } else {
4143     lastObt = firstObt;
4144     lastPkt = firstPkt;
4145     };
4146     glrun->SetRUNTRAILER_PKT(lastPkt);
4147     glrun->SetRUNTRAILER_OBT(lastObt);
4148     lastentry++;
4149     };
4150     //
4151     this->SetCommonGLRUN(firstTime,lastTime);
4152 mocchiut 1.2 this->SetPhysEndRunVariables();
4153 mocchiut 1.1 //
4154     if ( !IsRunAlreadyInserted() ){
4155     glrun->SetID(this->AssignRunID());
4156     glrun->SetID_RUN_FRAG(0);
4157     glrun->Fill_GL_RUN(conn);
4158     };
4159     //
4160     if ( i == lastev && checkfirst < check ){ // if the last event gives a wrong check...
4161     //
4162     firstentry = i;
4163     //
4164     lastentry = i;
4165     //
4166     if ( IsDebug() ) printf(" Run between %i and %i entries\n",firstentry,lastentry);
4167     //
4168     glrun->SetEV_FROM(firstentry);
4169     glrun->SetEV_TO(lastentry);
4170     glrun->SetNEVENTS(lastentry-firstentry+1);
4171     //
4172     glrun->Set_GL_RUNH0();
4173     //
4174     glrun->SetLAST_TIMESYNC(0);
4175     glrun->SetOBT_TIMESYNC(0);
4176     //
4177     T->GetEntry(firstentry);
4178     ph = eh->GetPscuHeader();
4179     firstObt = ph->GetOrbitalTime();
4180     firstTime = this->GetAbsTime(firstObt);
4181     firstPkt = ph->GetCounter();
4182     //
4183     glrun->SetRUNHEADER_PKT(firstPkt);
4184     //
4185     glrun->SetRUNHEADER_OBT(firstObt);
4186     //
4187     glrun->Set_GL_RUNT(runt,pht);
4188     lastTime = this->GetAbsTime(pht->GetOrbitalTime());
4189     if ( IsDebug() ) printf(" We have the runtrailer \n");
4190     //
4191     this->SetCommonGLRUN(firstTime,lastTime);
4192 mocchiut 1.2 this->SetPhysEndRunVariables();
4193 mocchiut 1.1 //
4194     if ( !IsRunAlreadyInserted() ){
4195     glrun->SetID(this->AssignRunID());
4196     glrun->SetID_RUN_FRAG(0);
4197     glrun->Fill_GL_RUN(conn);
4198     };
4199     };
4200     //
4201     firstevno = lastentry + 1;
4202     //
4203     checkfirst = check;
4204     //
4205     };
4206     //
4207     if ( check == checklast && i != lastev ) i = lastev - 1; // >>>>>>>>>>>>>>>>>>>>>>
4208     //
4209     };
4210     };
4211     };
4212     //
4213     return;
4214     };
4215    
4216    
4217     /**
4218     * Scan calorimeter calibrations packets, fill the GL_CALO_CALIB table
4219     */
4220     Int_t PamelaDBOperations::insertCALO_CALIB(){
4221     //
4222     TSQLResult *result = 0;
4223     TSQLRow *row = 0;
4224     //
4225     stringstream oss;
4226     oss.str("");
4227     //
4228     CalibCalPedEvent *calibCalPed = 0;
4229     TTree *tr = 0;
4230     EventHeader *eh = 0;
4231     PscuHeader *ph = 0;
4232     //
4233     UInt_t nevents = 0;
4234     UInt_t fromtime = 0;
4235     UInt_t totime = 0;
4236     UInt_t obt = 0;
4237     UInt_t pkt = 0;
4238     //
4239     tr = (TTree*)file->Get("CalibCalPed");
4240     if ( !tr || tr->IsZombie() ) throw -21;
4241     //
4242     tr->SetBranchAddress("CalibCalPed", &calibCalPed);
4243     tr->SetBranchAddress("Header", &eh);
4244     nevents = tr->GetEntries();
4245     //
4246     if ( !nevents ) return(1);
4247     //
4248     for (UInt_t i=0; i < nevents; i++){
4249     tr->GetEntry(i);
4250     for (UInt_t section = 0; section < 4; section++){
4251     //
4252     if ( calibCalPed->cstwerr[section] ){
4253     valid = 1;
4254     if ( calibCalPed->cperror[section] ) valid = 0;
4255     ph = eh->GetPscuHeader();
4256     obt = ph->GetOrbitalTime();
4257     pkt = ph->GetCounter();
4258     fromtime = this->GetAbsTime(ph->GetOrbitalTime());
4259     if ( this->PKT(pkt) >= this->PKT(pktfirst) && this->PKT(pkt) <= upperpkt && this->OBT(obt) >= this->OBT(obtfirst) && this->OBT(obt) <= upperobt ){
4260     //
4261     if ( IsDebug() ) printf(" Calo calibration for section %i at time %u obt %u pkt %u \n",section,fromtime,obt,pkt);
4262     //
4263     // check if the calibration has already been inserted
4264     //
4265     oss.str("");
4266     oss << " SELECT ID FROM GL_CALO_CALIB WHERE "
4267     << " SECTION = "<< section << " AND "
4268     << " BOOT_NUMBER = "<< this->GetBOOTnumber() << " AND "
4269     << " OBT = "<< obt << " AND "
4270     << " PKT = "<< pkt << ";";
4271     //
4272     if ( IsDebug() ) printf(" Check if the calo calibration has already been inserted: query is \n %s \n",oss.str().c_str());
4273     result = conn->Query(oss.str().c_str());
4274     //
4275     if ( !result ) throw -4;
4276     //
4277     row = result->Next();
4278     //
4279     if ( row ){
4280     //
4281     if ( IsDebug() ) printf(" Calo calibration already inserted in the DB\n");
4282     if ( PEDANTIC ) throw -73;
4283     //
4284     } else {
4285     //
4286     // we have to insert a new calibration, check where to place it
4287     //
4288     oss.str("");
4289     oss << " SELECT ID,TO_TIME FROM GL_CALO_CALIB WHERE "
4290     << " SECTION = "<< section << " AND "
4291     << " FROM_TIME < "<< fromtime << " AND "
4292     << " TO_TIME > "<< fromtime << ";";
4293     //
4294     if ( IsDebug() ) printf(" Check where to place the calo calibration: query is \n %s \n",oss.str().c_str());
4295     result = conn->Query(oss.str().c_str());
4296     //
4297     if ( !result ) throw -4;
4298     //
4299     row = result->Next();
4300     //
4301     if ( !row ){
4302     //
4303     // no calibrations in the db contain our calibration
4304     //
4305     if ( IsDebug() ) printf(" Calibration with fromtime lower than others to be inserted in the DB for section %i \n",section);
4306     if ( fromtime < 1150871000 ){ //1150866904
4307     if ( IsDebug() ) printf(" First PAMELA flight calibration at time %u \n",fromtime);
4308     fromtime = 0;// the first flight calibration was taken at about 1156429100 s, this line allow to analyze first runs in raw mode
4309     };
4310     //
4311     oss.str("");
4312     oss << " SELECT FROM_TIME FROM GL_CALO_CALIB WHERE "
4313     << " SECTION = "<< section << " AND "
4314     << " FROM_TIME > "<< fromtime << " ORDER BY FROM_TIME ASC LIMIT 1;";
4315     //
4316     if ( IsDebug() ) printf(" Check the upper limit for calibration: query is \n %s \n",oss.str().c_str());
4317     result = conn->Query(oss.str().c_str());
4318     //
4319     if ( !result ) throw -4;
4320     //
4321     row = result->Next();
4322     if ( !row ){
4323     totime = numeric_limits<UInt_t>::max();
4324     } else {
4325     totime = (UInt_t)atoll(row->GetField(0));
4326     };
4327     //
4328     } else {
4329     //
4330     // determine upper and lower limits and make space for the new calibration
4331     //
4332     totime = (UInt_t)atoll(row->GetField(1));
4333     //
4334     oss.str("");
4335     oss << " UPDATE GL_CALO_CALIB SET "
4336     << " TO_TIME = "<< fromtime << " WHERE " // NOTICE: to_time is equal to from_time of the calibration before, so the interval is: [from_time,to_time[
4337     << " ID = "<< row->GetField(0) << ";";
4338     //
4339     if ( IsDebug() ) printf(" Make space for the new calibration: query is \n %s \n",oss.str().c_str());
4340     result = conn->Query(oss.str().c_str());
4341     //
4342     if ( !result ) throw -4;
4343     //
4344     };
4345     //
4346     oss.str("");
4347     oss << " INSERT INTO GL_CALO_CALIB (ID,ID_ROOT_L0,EV_ROOT,FROM_TIME,TO_TIME,SECTION,OBT,PKT,BOOT_NUMBER,VALIDATION) "
4348     << " VALUES (NULL,' "
4349     << idroot << "','"
4350     << i << "','"
4351     << fromtime << "','"
4352     << totime << "','"
4353     << section << "','"
4354     << obt << "','"
4355     << pkt << "','"
4356     << this->GetBOOTnumber() << "','"
4357     << valid << "');";
4358     //
4359     if ( IsDebug() ) printf(" Insert the new calibration: query is \n %s \n",oss.str().c_str());
4360     //
4361     result = conn->Query(oss.str().c_str());
4362     //
4363     if ( !result ) throw -4;
4364     //
4365     };
4366     //
4367     } else {
4368     //
4369     if ( IsDebug() ) printf(" Calo calibration for section %i at time %u obt %u pkt %u OUTSIDE the considered interval \n",section,fromtime,obt,pkt);
4370     // if ( PEDANTIC ) throw -74;
4371     //
4372     };
4373     //
4374     };
4375     };
4376     };
4377     //
4378     return(0);
4379     };
4380    
4381    
4382     /**
4383     * Scan calorimeter calibrations packets, fill the GL_CALO_CALIB table
4384     */
4385     Int_t PamelaDBOperations::insertCALOPULSE_CALIB(){
4386     //
4387     TSQLResult *result = 0;
4388     TSQLRow *row = 0;
4389     //
4390     stringstream oss;
4391     oss.str("");
4392     //
4393     oss << " DESCRIBE GL_CALOPULSE_CALIB;";
4394     if ( IsDebug() ) printf(" Check if the GL_CALOPULSE_CALIB table exists: query is \n %s \n",oss.str().c_str());
4395     result = conn->Query(oss.str().c_str());
4396     //
4397     if ( conn->GetErrorCode() ){
4398     if ( IsDebug() ) printf(" The GL_CALOPULSE_CALIB table does not exists! \n");
4399     throw -30;
4400     };
4401     //
4402     // CaloPulse1
4403     //
4404     CalibCalPulse1Event *cp1 = 0;
4405     TTree *tr = 0;
4406     EventHeader *eh = 0;
4407     PscuHeader *ph = 0;
4408     //
4409     UInt_t nevents = 0;
4410     UInt_t fromtime = 0;
4411     UInt_t totime = 0;
4412     UInt_t obt = 0;
4413     UInt_t pkt = 0;
4414     //
4415     tr = (TTree*)file->Get("CalibCalPulse1");
4416     if ( !tr || tr->IsZombie() ) throw -31;
4417     //
4418     tr->SetBranchAddress("CalibCalPulse1", &cp1);
4419     tr->SetBranchAddress("Header", &eh);
4420     nevents = tr->GetEntries();
4421     //
4422     if ( nevents > 0 ){
4423     //
4424     for (UInt_t i=0; i < nevents; i++){
4425     tr->GetEntry(i);
4426     for (UInt_t section = 0; section < 4; section++){
4427     //
4428     if ( cp1->pstwerr[section] && cp1->unpackError == 0 ){
4429     valid = 1;
4430     if ( cp1->pperror[section] ) valid = 0;
4431     ph = eh->GetPscuHeader();
4432     obt = ph->GetOrbitalTime();
4433     pkt = ph->GetCounter();
4434     fromtime = this->GetAbsTime(ph->GetOrbitalTime());
4435     if ( this->PKT(pkt) >= this->PKT(pktfirst) && this->PKT(pkt) <= upperpkt && this->OBT(obt) >= this->OBT(obtfirst) && this->OBT(obt) <= upperobt ){
4436     // if ( this->PKT(pkt) >= this->PKT(pktfirst) && this->OBT(obt) >= this->OBT(obtfirst) ){
4437     //
4438     if ( IsDebug() ) printf(" Calo pulse1 calibration for section %i at time %u obt %u pkt %u \n",section,fromtime,obt,pkt);
4439     //
4440     // check if the calibration has already been inserted
4441     //
4442     oss.str("");
4443     oss << " SELECT ID FROM GL_CALOPULSE_CALIB WHERE "
4444     << " SECTION = "<< section << " AND "
4445     << " PULSE_AMPLITUDE = 0 AND "
4446     << " BOOT_NUMBER = "<< this->GetBOOTnumber() << " AND "
4447     << " OBT = "<< obt << " AND "
4448     << " PKT = "<< pkt << ";";
4449     //
4450     if ( IsDebug() ) printf(" Check if the calo pulse1 calibration has already been inserted: query is \n %s \n",oss.str().c_str());
4451     result = conn->Query(oss.str().c_str());
4452     //
4453     if ( !result ) throw -4;
4454     //
4455     row = result->Next();
4456     //
4457     if ( row ){
4458     //
4459     if ( IsDebug() ) printf(" Calo pulse1 calibration already inserted in the DB\n");
4460     if ( PEDANTIC ) throw -75;
4461     //
4462     } else {
4463     //
4464     // we have to insert a new calibration, check where to place it
4465     //
4466     oss.str("");
4467     oss << " SELECT ID,TO_TIME FROM GL_CALOPULSE_CALIB WHERE "
4468     << " SECTION = "<< section << " AND "
4469     << " PULSE_AMPLITUDE = 0 AND "
4470     << " SECTION = "<< section << " AND "
4471     << " FROM_TIME < "<< fromtime << " AND "
4472     << " TO_TIME > "<< fromtime << ";";
4473     //
4474     if ( IsDebug() ) printf(" Check where to place the pulse1 calo calibration: query is \n %s \n",oss.str().c_str());
4475     result = conn->Query(oss.str().c_str());
4476     //
4477     if ( !result ) throw -4;
4478     //
4479     row = result->Next();
4480     //
4481     if ( !row ){
4482     //
4483     // no calibrations in the db contain our calibration
4484     //
4485     if ( IsDebug() ) printf(" Pulse1 calibration with fromtime lower than others to be inserted in the DB for section %i \n",section);
4486     if ( fromtime < 1150871000 ){ //1150866904
4487     if ( IsDebug() ) printf(" First PAMELA flight calibration at time %u \n",fromtime);
4488     fromtime = 0;// the first flight calibration was taken at about 1156429100 s, this line allow to analyze first runs in raw mode
4489     };
4490     //
4491     oss.str("");
4492     oss << " SELECT FROM_TIME FROM GL_CALOPULSE_CALIB WHERE "
4493     << " PULSE_AMPLITUDE = 0 AND "
4494     << " SECTION = "<< section << " AND "
4495     << " FROM_TIME > "<< fromtime << " ORDER BY FROM_TIME ASC LIMIT 1;";
4496     //
4497     if ( IsDebug() ) printf(" Check the upper limit for pulse1 calibration: query is \n %s \n",oss.str().c_str());
4498     result = conn->Query(oss.str().c_str());
4499     //
4500     if ( !result ) throw -4;
4501     //
4502     row = result->Next();
4503     if ( !row ){
4504     totime = numeric_limits<UInt_t>::max();
4505     } else {
4506     totime = (UInt_t)atoll(row->GetField(0));
4507     };
4508     //
4509     } else {
4510     //
4511     // determine upper and lower limits and make space for the new calibration
4512     //
4513     totime = (UInt_t)atoll(row->GetField(1));
4514     //
4515     oss.str("");
4516     oss << " UPDATE GL_CALOPULSE_CALIB SET "
4517     << " TO_TIME = "<< fromtime << " WHERE " // NOTICE: to_time is equal to from_time of the calibration before, so the interval is: [from_time,to_time[
4518     << " ID = "<< row->GetField(0) << ";";
4519     //
4520     if ( IsDebug() ) printf(" Make space for the new pulse1 calibration: query is \n %s \n",oss.str().c_str());
4521     result = conn->Query(oss.str().c_str());
4522     //
4523     if ( !result ) throw -4;
4524     //
4525     };
4526     //
4527     oss.str("");
4528     oss << " INSERT INTO GL_CALOPULSE_CALIB (ID,ID_ROOT_L0,EV_ROOT,FROM_TIME,TO_TIME,SECTION,PULSED_STRIP,PULSE_AMPLITUDE,OBT,PKT,BOOT_NUMBER,VALIDATION) "
4529     << " VALUES (NULL,' "
4530     << idroot << "','"
4531     << i << "','"
4532     << fromtime << "','"
4533     << totime << "','"
4534     << section << "',NULL,'0','"
4535     << obt << "','"
4536     << pkt << "','"
4537     << this->GetBOOTnumber() << "','"
4538     << valid << "');";
4539     //
4540     if ( IsDebug() ) printf(" Insert the new pulse1 calibration: query is \n %s \n",oss.str().c_str());
4541     //
4542     result = conn->Query(oss.str().c_str());
4543     //
4544     if ( !result ) throw -4;
4545     //
4546     };
4547     //
4548     } else {
4549     //
4550     if ( IsDebug() ) printf(" Pulse1 calo calibration for section %i at time %u obt %u pkt %u OUTSIDE the considered time interval \n",section,fromtime,obt,pkt);
4551     // if ( PEDANTIC ) throw -76;
4552     //
4553     };
4554     //
4555     };
4556     };
4557     };
4558     };
4559     //
4560     // CaloPulse2
4561     //
4562     tr->Reset();
4563     CalibCalPulse2Event *cp2 = 0;
4564     tr = 0;
4565     //
4566     nevents = 0;
4567     fromtime = 0;
4568     totime = 0;
4569     obt = 0;
4570     pkt = 0;
4571     //
4572     tr = (TTree*)file->Get("CalibCalPulse2");
4573     if ( !tr || tr->IsZombie() ) throw -32;
4574     //
4575     tr->SetBranchAddress("CalibCalPulse2", &cp2);
4576     tr->SetBranchAddress("Header", &eh);
4577     nevents = tr->GetEntries();
4578     //
4579     if ( nevents > 0 ){
4580     //
4581     for (UInt_t i=0; i < nevents; i++){
4582     tr->GetEntry(i);
4583     for (UInt_t section = 0; section < 4; section++){
4584     //
4585     if ( cp2->pstwerr[section] && cp2->unpackError == 0 ){
4586     valid = 1;
4587     if ( cp2->pperror[section] ) valid = 0;
4588     ph = eh->GetPscuHeader();
4589     obt = ph->GetOrbitalTime();
4590     pkt = ph->GetCounter();
4591     fromtime = this->GetAbsTime(ph->GetOrbitalTime());
4592     if ( this->PKT(pkt) >= this->PKT(pktfirst) && this->PKT(pkt) <= upperpkt && this->OBT(obt) >= this->OBT(obtfirst) && this->OBT(obt) <= upperobt ){
4593     // if ( this->PKT(pkt) >= this->PKT(pktfirst) && this->OBT(obt) >= this->OBT(obtfirst) ){
4594     //
4595     if ( IsDebug() ) printf(" Calo pulse2 calibration for section %i at time %u obt %u pkt %u \n",section,fromtime,obt,pkt);
4596     //
4597     // check if the calibration has already been inserted
4598     //
4599     oss.str("");
4600     oss << " SELECT ID FROM GL_CALOPULSE_CALIB WHERE "
4601     << " SECTION = "<< section << " AND "
4602     << " PULSE_AMPLITUDE != 0 AND "
4603     << " BOOT_NUMBER = "<< this->GetBOOTnumber() << " AND "
4604     << " OBT = "<< obt << " AND "
4605     << " PKT = "<< pkt << ";";
4606     //
4607     if ( IsDebug() ) printf(" Check if the calo pulse2 calibration has already been inserted: query is \n %s \n",oss.str().c_str());
4608     result = conn->Query(oss.str().c_str());
4609     //
4610     if ( !result ) throw -4;
4611     //
4612     row = result->Next();
4613     //
4614     if ( row ){
4615     //
4616     if ( IsDebug() ) printf(" Calo pulse2 calibration already inserted in the DB\n");
4617     if ( PEDANTIC ) throw -77;
4618     //
4619     } else {
4620     //
4621     // we have to insert a new calibration
4622     //
4623     //
4624     // Determine the amplitude of the pulse
4625     //
4626     UInt_t pampli = 1;
4627     UInt_t pstrip = 0;
4628     UInt_t se = 0;
4629     if ( section == 1 ) se = 2;
4630     if ( section == 2 ) se = 3;
4631     if ( section == 3 ) se = 1;
4632     for (Int_t ii=0;ii<16;ii++){
4633     if ( cp2->calpuls[se][0][ii] > 10000. ){
4634     pampli = 2;
4635     pstrip = ii;
4636     };
4637     };
4638     if ( pampli == 1 ){
4639     Bool_t found = false;
4640     Float_t delta=0.;
4641     UInt_t cstr = 0;
4642     while ( !found && cstr < 16 ){
4643     for (Int_t ii=0;ii<16;ii++){
4644     delta = cp2->calpuls[se][0][ii] - cp2->calpuls[se][0][cstr];
4645     if ( IsDebug() ) printf(" cstr is %u ii is %i delta is %f \n",cstr,ii,delta);
4646     if ( delta > 500. ){
4647     pampli = 1;
4648     pstrip = ii;
4649     found = true;
4650     if ( IsDebug() ) printf(" FOUND cstr is %u ii is %i delta is %f \n",cstr,ii,delta);
4651     };
4652     };
4653     cstr++;
4654     };
4655     if ( !found ) pstrip = 100;
4656     };
4657     if ( IsDebug() ) printf(" The amplitude of the pulser is %u (where 1 = low pulse, 2 = high pulse), pulsed strip is %u \n",pampli,pstrip);
4658     //
4659     // we have to insert a new calibration, check where to place it
4660     //
4661     oss.str("");
4662     oss << " SELECT ID,TO_TIME FROM GL_CALOPULSE_CALIB WHERE "
4663     << " SECTION = "<< section << " AND "
4664     << " PULSE_AMPLITUDE = " << pampli << " AND "
4665     << " SECTION = "<< section << " AND "
4666     << " FROM_TIME < "<< fromtime << " AND "
4667     << " TO_TIME > "<< fromtime << ";";
4668     //
4669     if ( IsDebug() ) printf(" Check where to place the pulse2 calo calibration: query is \n %s \n",oss.str().c_str());
4670     result = conn->Query(oss.str().c_str());
4671     //
4672     if ( !result ) throw -4;
4673     //
4674     row = result->Next();
4675     //
4676     if ( !row ){
4677     //
4678     // no calibrations in the db contain our calibration
4679     //
4680     if ( IsDebug() ) printf(" Pulse2 calibration with fromtime lower than others to be inserted in the DB for section %i \n",section);
4681     if ( fromtime < 1150871000 ){ //1150866904
4682     if ( IsDebug() ) printf(" First PAMELA flight calibration at time %u \n",fromtime);
4683     fromtime = 0;// the first flight calibration was taken at about 1156429100 s, this line allow to analyze first runs in raw mode
4684     };
4685     //
4686     oss.str("");
4687     oss << " SELECT FROM_TIME FROM GL_CALOPULSE_CALIB WHERE "
4688     << " PULSE_AMPLITUDE = " << pampli << " AND "
4689     << " SECTION = "<< section << " AND "
4690     << " FROM_TIME > "<< fromtime << " ORDER BY FROM_TIME ASC LIMIT 1;";
4691     //
4692     if ( IsDebug() ) printf(" Check the upper limit for pulse2 calibration: query is \n %s \n",oss.str().c_str());
4693     result = conn->Query(oss.str().c_str());
4694     //
4695     if ( !result ) throw -4;
4696     //
4697     row = result->Next();
4698     if ( !row ){
4699     totime = numeric_limits<UInt_t>::max();
4700     } else {
4701     totime = (UInt_t)atoll(row->GetField(0));
4702     };
4703     //
4704     } else {
4705     //
4706     // determine upper and lower limits and make space for the new calibration
4707     //
4708     totime = (UInt_t)atoll(row->GetField(1));
4709     //
4710     oss.str("");
4711     oss << " UPDATE GL_CALOPULSE_CALIB SET "
4712     << " TO_TIME = "<< fromtime << " WHERE " // NOTICE: to_time is equal to from_time of the calibration before, so the interval is: [from_time,to_time[
4713     << " ID = "<< row->GetField(0) << ";";
4714     //
4715     if ( IsDebug() ) printf(" Make space for the new pulse2 calibration: query is \n %s \n",oss.str().c_str());
4716     result = conn->Query(oss.str().c_str());
4717     //
4718     if ( !result ) throw -4;
4719     //
4720     };
4721     //
4722     // Fill the DB
4723     //
4724     oss.str("");
4725     // oss << " INSERT INTO GL_CALOPULSE_CALIB (ID,ID_ROOT_L0,EV_ROOT,FROM_TIME,TO_TIME,SECTION,OBT,PKT,BOOT_NUMBER,VALIDATION) "
4726     oss << " INSERT INTO GL_CALOPULSE_CALIB (ID,ID_ROOT_L0,EV_ROOT,FROM_TIME,TO_TIME,SECTION,PULSED_STRIP,PULSE_AMPLITUDE,OBT,PKT,BOOT_NUMBER,VALIDATION) "
4727     << " VALUES (NULL,' "
4728     << idroot << "','"
4729     << i << "','"
4730     << fromtime << "','"
4731     << totime << "','"
4732     << section << "','"
4733     << pstrip << "','"
4734     << pampli << "','"
4735     << obt << "','"
4736     << pkt << "','"
4737     << this->GetBOOTnumber() << "','"
4738     << valid << "');";
4739     //
4740     if ( IsDebug() ) printf(" Insert the new pulse2 calibration: query is \n %s \n",oss.str().c_str());
4741     //
4742     result = conn->Query(oss.str().c_str());
4743     //
4744     if ( !result ) throw -4;
4745     //
4746     };
4747     //
4748     } else {
4749     //
4750     if ( IsDebug() ) printf(" Pulse2 calo calibration for section %i at time %u obt %u pkt %u OUTSIDE the considered time interval \n",section,fromtime,obt,pkt);
4751     // if ( PEDANTIC ) throw -78;
4752     //
4753     };
4754     //
4755     };
4756     };
4757     };
4758     };
4759     //
4760     return(0);
4761     };
4762    
4763     /**
4764     * Fill the GL_TRK_CALIB table
4765     */
4766     void PamelaDBOperations::HandleTRK_CALIB(Bool_t pk1, Bool_t pk2){
4767 pam-fi 1.4
4768     GL_TRK_CALIB *glcal = new GL_TRK_CALIB();
4769     //
4770     glcal->ID = 0;
4771     glcal->ID_ROOT_L0 = GetID_ROOT();
4772     glcal->EV_ROOT_CALIBTRK1 = t1;
4773     glcal->EV_ROOT_CALIBTRK2 = t2;
4774     glcal->FROM_TIME = fromtime;
4775     glcal->TO_TIME = 0;
4776     glcal->OBT1 = obt1;
4777     glcal->OBT2 = obt2;
4778     glcal->PKT1 = pkt1;
4779     glcal->PKT2 = pkt2;
4780     glcal->BOOT_NUMBER = GetBOOTnumber();
4781     glcal->VALIDATION = valid;
4782     //
4783     HandleTRK_CALIB(glcal);
4784     //
4785     delete glcal;
4786     }
4787     /**
4788     * Fill the GL_TRK_CALIB table
4789     */
4790     void PamelaDBOperations::HandleTRK_CALIB(GL_TRK_CALIB *glcal){
4791    
4792     Bool_t pk1 = (glcal->OBT1>0&&glcal->PKT1>0);
4793     Bool_t pk2 = (glcal->OBT2>0&&glcal->PKT2>0);
4794     UInt_t boot_number = glcal->BOOT_NUMBER;
4795     UInt_t obt1 = glcal->OBT1;
4796     UInt_t obt2 = glcal->OBT2;
4797     UInt_t pkt1 = glcal->PKT1;
4798     UInt_t pkt2 = glcal->PKT2;
4799     UInt_t fromtime = glcal->FROM_TIME;
4800     UInt_t totime = 0;
4801     UInt_t idroot = glcal->ID_ROOT_L0;
4802     UInt_t t1 = glcal->EV_ROOT_CALIBTRK1;
4803     UInt_t t2 = glcal->EV_ROOT_CALIBTRK2;
4804     UInt_t valid = glcal->VALIDATION;
4805     //
4806     TSQLResult *result = 0;
4807     TSQLRow *row = 0;
4808     //
4809     stringstream oss;
4810     oss.str("");
4811 mocchiut 1.1 //
4812     //
4813 pam-fi 1.4 if ( !pk1 && !pk2 ){
4814     if ( IsDebug() ) printf(" Cannot handle trk calibration with both packet missing!\n");
4815     return;
4816     };
4817 mocchiut 1.1 //
4818 pam-fi 1.4 // check if the calibration has already been inserted
4819 mocchiut 1.1 //
4820     oss.str("");
4821 pam-fi 1.4 oss << " SELECT ID FROM GL_TRK_CALIB WHERE "
4822     << " BOOT_NUMBER = "<< boot_number; //
4823     oss << " AND FROM_TIME="<<fromtime; /// NEWNEWNEW -- VA BENE ?!?!?!?!
4824     oss << " AND ( ( ";
4825     if ( pk1 ){
4826     oss << " OBT1 = "<< obt1 << " AND "
4827     << " PKT1 = "<< pkt1
4828     << " ) OR ( ";
4829     } else {
4830     oss << " PKT1 = "<< pkt2-1
4831     << " ) OR ( ";
4832     };
4833     if ( pk2 ){
4834     oss << " OBT2 = "<< obt2 << " AND "
4835     << " PKT2 = "<< pkt2;
4836     } else {
4837     oss << " PKT2 = "<< pkt1+1;
4838     };
4839     oss << " ) );";
4840 mocchiut 1.1 //
4841 pam-fi 1.4 if ( IsDebug() ) printf(" Check if the trk calibration has already been inserted: query is \n %s \n",oss.str().c_str());
4842 mocchiut 1.1 result = conn->Query(oss.str().c_str());
4843     //
4844     if ( !result ) throw -4;
4845     //
4846     row = result->Next();
4847     //
4848 pam-fi 1.4 if ( row ){
4849     //
4850     if ( IsDebug() ) printf(" Trk calibration already inserted in the DB\n");
4851     if ( PEDANTIC ) throw -80;
4852     //
4853 mocchiut 1.1 } else {
4854 pam-fi 1.4 //
4855     // we have to insert a new calibration, check where to place it
4856     //
4857     oss.str("");
4858     oss << " SELECT ID,TO_TIME FROM GL_TRK_CALIB WHERE "
4859     << " FROM_TIME < "<< fromtime << " AND "
4860     << " TO_TIME > "<< fromtime << ";";
4861     //
4862     if ( IsDebug() ) printf(" Check where to place the trk calibration: query is \n %s \n",oss.str().c_str());
4863     result = conn->Query(oss.str().c_str());
4864     //
4865     if ( !result ) throw -4;
4866     //
4867     row = result->Next();
4868     //
4869     if ( !row ){
4870     //
4871     // no calibrations in the db contain our calibration
4872     //
4873     if ( IsDebug() ) printf(" Calibration with fromtime lower than others to be inserted in the DB\n");
4874     if ( fromtime < 1150871000 ) fromtime = 0; // the first flight calibration was taken at about 1150863300 s, this line allows to analyze first runs in raw mode
4875     //
4876     oss.str("");
4877     oss << " SELECT FROM_TIME FROM GL_TRK_CALIB WHERE "
4878     << " FROM_TIME > "<< fromtime << " ORDER BY FROM_TIME ASC LIMIT 1;";
4879     //
4880     if ( IsDebug() ) printf(" Check the upper limit for calibration: query is \n %s \n",oss.str().c_str());
4881     result = conn->Query(oss.str().c_str());
4882     //
4883     if ( !result ) throw -4;
4884     //
4885     row = result->Next();
4886     if ( !row ){
4887     totime = numeric_limits<UInt_t>::max();
4888     } else {
4889     totime = (UInt_t)atoll(row->GetField(0));
4890     };
4891     //
4892     } else {
4893     //
4894     // determine upper and lower limits and make space for the new calibration
4895     //
4896     totime = (UInt_t)atoll(row->GetField(1));
4897     //
4898     oss.str("");
4899     oss << " UPDATE GL_TRK_CALIB SET "
4900     << " TO_TIME = "<< fromtime << " WHERE " // NOTICE: to_time is equal to from_time of the calibration before, so the interval is: [from_time,to_time[
4901     << " ID = "<< row->GetField(0) << ";";
4902     //
4903     if ( IsDebug() ) printf(" Make space for the new trk calibration: query is \n %s \n",oss.str().c_str());
4904     result = conn->Query(oss.str().c_str());
4905     //
4906     if ( !result ) throw -4;
4907     //
4908     };
4909     //
4910     oss.str("");
4911     oss << " INSERT INTO GL_TRK_CALIB (ID,ID_ROOT_L0,EV_ROOT_CALIBTRK1,EV_ROOT_CALIBTRK2,FROM_TIME,TO_TIME,OBT1,PKT1,OBT2,PKT2,BOOT_NUMBER,VALIDATION) "
4912     << " VALUES (NULL,' "
4913     << idroot << "',";
4914     //
4915     if ( !pk1 ){
4916     oss << "NULL,";
4917     } else {
4918     oss << "'"
4919     << t1 << "',";
4920     };
4921     //
4922     if ( !pk2 ){
4923     oss << "NULL,'";
4924     } else {
4925     oss << "'"
4926     << t2 << "','";
4927     };
4928     //
4929     oss << fromtime << "','"
4930     << totime << "','"
4931     << obt1 << "','"
4932     << pkt1 << "','"
4933     << obt2 << "','"
4934     << pkt2 << "','"
4935     << boot_number << "','"
4936     << valid << "');";
4937     //
4938     if ( IsDebug() ) printf(" Insert the new trk calibration: query is \n %s \n",oss.str().c_str());
4939     //
4940     result = conn->Query(oss.str().c_str());
4941     //
4942     if ( !result ) throw -4;
4943     //
4944 mocchiut 1.1 };
4945 pam-fi 1.4
4946 mocchiut 1.1 oss.str("");
4947 pam-fi 1.4 oss << " SELECT ID FROM GL_TRK_CALIB ORDER BY ID DESC LIMIT 1 ;";
4948     if ( IsDebug() ) cout << oss.str().c_str() << endl;
4949 mocchiut 1.1 result = conn->Query(oss.str().c_str());
4950 pam-fi 1.4 if ( !result ) throw -4;;
4951     row = result->Next();
4952     if(row)glcal->ID = (UInt_t)atoll(row->GetField(0));
4953 mocchiut 1.21 //
4954     delete result; // mmm... "Error in <TMySQLResult::Next>: result set closed" solved? 090112 [8RED error messages]
4955 mocchiut 1.1 //
4956     };
4957    
4958     /**
4959     * Scan tracker calibrations packets, fill the GL_TRK_CALIB table
4960     */
4961     Int_t PamelaDBOperations::insertTRK_CALIB(){
4962     //
4963 pam-fi 1.4 CalibTrk1Event *caltrk1 = 0;
4964     CalibTrk2Event *caltrk2 = 0;
4965     TTree *tr1 = 0;
4966     TTree *tr2 = 0;
4967     EventHeader *eh1 = 0;
4968     PscuHeader *ph1 = 0;
4969     EventHeader *eh2 = 0;
4970     PscuHeader *ph2 = 0;
4971     //
4972     PacketType *pctp=0;
4973     EventCounter *codt2=0;
4974     //
4975     Int_t nevents1 = 0;
4976     Int_t nevents2 = 0;
4977 mocchiut 1.1 //
4978 pam-fi 1.4 fromtime = 0;
4979 mocchiut 1.1 //
4980 pam-fi 1.4 obt1 = 0;
4981     pkt1 = 0;
4982     obt2 = 0;
4983     pkt2 = 0;
4984 mocchiut 1.1 //
4985 pam-fi 1.4 tr1 = (TTree*)file->Get("CalibTrk1");
4986     if ( !tr1 || tr1->IsZombie() ) throw -22;
4987     tr2 = (TTree*)file->Get("CalibTrk2");
4988     if ( !tr2 || tr2->IsZombie() ) throw -23;
4989     //
4990     tr1->SetBranchAddress("CalibTrk1", &caltrk1);
4991     tr1->SetBranchAddress("Header", &eh1);
4992     nevents1 = tr1->GetEntries();
4993     tr2->SetBranchAddress("CalibTrk2", &caltrk2);
4994     tr2->SetBranchAddress("Header", &eh2);
4995     nevents2 = tr2->GetEntries();
4996     //
4997     if ( !nevents1 && !nevents2 ) return(1);
4998     //
4999     t2 = -1;
5000     Int_t pret2 = 0;
5001     Int_t t2t1cal = 0;
5002     //
5003     bool MISSING_pkt1 = true;
5004     bool MISSING_pkt2 = true;
5005     int ncalib = 0;
5006     bool try_to_recover = false;
5007 mocchiut 1.1 //
5008 pam-fi 1.4 for (t1=0; t1 < nevents1; t1++){//loop over packet1
5009     //
5010     pret2 = t2;
5011     tr1->GetEntry(t1);
5012 mocchiut 1.1 //
5013 pam-fi 1.4 ph1 = eh1->GetPscuHeader();
5014     obt1 = ph1->GetOrbitalTime();
5015     pkt1 = ph1->GetCounter();
5016     fromtime = GetAbsTime(ph1->GetOrbitalTime());
5017 mocchiut 1.1 //
5018 pam-fi 1.4 // chek if the packet number and obt are consistent with the other packets ???
5019 mocchiut 1.1 //
5020 pam-fi 1.4 if ( PKT(pkt1) >= PKT(pktfirst) && PKT(pkt1) <= upperpkt && OBT(obt1) >= OBT(obtfirst) && OBT(obt1) <= upperobt ){
5021     // if ( this->PKT(pkt1) >= this->PKT(pktfirst) && this->OBT(obt1) >= this->OBT(obtfirst) ){
5022     //
5023     if ( IsDebug() ) printf("\n Trk calibration1 %u at time %u obt %u pkt %u \n",t1,fromtime,obt1,pkt1);
5024     //
5025     valid = ValidateTrkCalib( caltrk1, eh1 );
5026     if ( IsDebug() ) cout << " pkt1 validation --> "<<valid<<endl;
5027     //
5028     // Do we have the second calibration packet?
5029     //
5030     if ( IsDebug() ) cout << " Loop over calibration2 to search associated calibration: "<<endl;
5031     while ( t2t1cal < t1+1 ){ // get the calibration packet2 that follows the packet1
5032     //
5033     t2++;
5034     //
5035     pret2 = t2 - 1; // EMILIANO
5036     //
5037     if ( t2 < nevents2 ){
5038     tr2->GetEntry(t2);
5039     codt2 = eh2->GetCounter();
5040     t2t1cal = codt2->Get(pctp->CalibTrk1);
5041     //
5042     ph2 = eh2->GetPscuHeader();
5043     obt2 = ph2->GetOrbitalTime();
5044     pkt2 = ph2->GetCounter();
5045     //
5046     if ( IsDebug() ) printf(" >> trk calibration2 at obt %u pkt %u t2 is %u , t2t1cal is %u \n",obt2,pkt2,t2,t2t1cal);
5047     // if ( caltrk2->unpackError != 0 || caltrk2->good0 == 0 ) valid = 0; // CONDITIONS ON THE GOODNESS OF THE CALIBRATION PKT2
5048     //
5049     } else {
5050     //
5051     // running out of vector without finding the corresponding calibration, sig
5052     //
5053     if ( IsDebug() ) printf(" t2 >= nevents2 \n");
5054     pret2 = t2;
5055     obt2 = 0;
5056     // pkt2 = pkt1+2;
5057     pkt2 = 0;
5058     t2t1cal = t1+1;
5059     };
5060     // if ( (this->PKT(pkt2) < this->PKT(pktfirst) || this->PKT(pkt2) > upperpkt) && (this->OBT(obt2) < this->OBT(obtfirst) || this->OBT(obt2) > upperobt) ){
5061    
5062     // EMILIANO
5063     // if ( (this->PKT(pkt2) < this->PKT(pktfirst) || this->PKT(pkt2) > upperpkt) || (this->OBT(obt2) < this->OBT(obtfirst) || this->OBT(obt2) > upperobt) ){
5064     // // if ( this->PKT(pkt2) < this->PKT(pktfirst) && this->OBT(obt2) < this->OBT(obtfirst) ){
5065     // if ( IsDebug() ) printf(" running out of vector without finding the corresponding calibration, sig \n");
5066     // //
5067     // // running out of vector without finding the corresponding calibration, sig
5068     // //
5069     // pret2 = t2;
5070     // obt2 = 0;
5071     // // pkt2 = pkt1+2;
5072     // pkt2 = 0;
5073     // t2t1cal = t1+1;
5074     // };
5075    
5076    
5077     //
5078     };
5079     //
5080     if ( IsDebug() ) printf(" Check if trk calibration2 is the right one \n");
5081     //
5082     // EMILIANO
5083     if ( ( PKT(pkt2) < PKT(pktfirst) || PKT(pkt2) > upperpkt) || (OBT(obt2) < OBT(obtfirst) || OBT(obt2) > upperobt) ){
5084     // if ( this->PKT(pkt2) < this->PKT(pktfirst) && this->OBT(obt2) < this->OBT(obtfirst) ){
5085     if ( IsDebug() ) printf(" *WARNING* The calibration found is outside the interval, sig \n");
5086     //
5087     // running out of vector without finding the corresponding calibration, sig
5088     //
5089     pret2 = t2;
5090     obt2 = 0;
5091     pkt2 = 0;
5092     };
5093     if ( PKT(pkt2) == PKT(pkt1)+1 ){
5094     if ( IsDebug() ) cout << " ...OK"<<endl;
5095     // =======================
5096     // The calibration is good
5097     // =======================
5098     //
5099     // if ( IsDebug() ) printf(" Found trk calibration2 at obt %u pkt %u t2 is %u \n",obt2,pkt2,t2);
5100     // if ( IsDebug() ) printf(" Trk calibration2 at obt %u pkt %u t2 is %u is good \n",obt2,pkt2,t2);
5101     // if ( IsDebug() ) printf("\n Trk calibration2 at time %u obt %u pkt %u \n",fromtime,obt2,pkt2);
5102     if ( IsDebug() ) printf(" Trk calibration2 %u at time %u obt %u pkt %u \n",t2,fromtime,obt2,pkt2);
5103     //
5104     UInt_t valid2 = ValidateTrkCalib( caltrk2, eh2 );
5105     if ( IsDebug() ) cout << " pkt2 validation --> "<<valid2<<endl;
5106     // valid = valid & valid2;
5107     valid = valid & valid2; //QUESTO VA CAMBIATO
5108     //
5109     // Handle good calib
5110     //
5111     MISSING_pkt1 = false;
5112     MISSING_pkt2 = false;
5113     // this->HandleTRK_CALIB(!MISSING_pkt1,!MISSING_pkt2);
5114     //
5115     // Check for missing calibtrk1
5116     //
5117     if ( t2 != pret2+1 ){
5118     //
5119     if ( IsDebug() ) printf(" Missing the trk calibration1! Next one at obt %u pkt %u t2 is %u pret2 is %u \n",obt2,pkt2,t2,pret2);
5120     //
5121     while ( t2 > pret2+1 ){
5122     //
5123     // handle missing calib1
5124     //
5125     pret2++;
5126     //
5127     obt1 = 0;
5128     pkt1 = 0;
5129     //
5130     tr2->GetEntry(pret2);
5131     ph2 = eh2->GetPscuHeader();
5132     obt2 = ph2->GetOrbitalTime();
5133     pkt2 = ph2->GetCounter();
5134     //
5135     fromtime = this->GetAbsTime(ph2->GetOrbitalTime());
5136     //
5137     valid = 0;
5138     MISSING_pkt1 = true;
5139     MISSING_pkt2 = false;
5140     // this->HandleTRK_CALIB(!MISSING_pkt1,!MISSING_pkt2);
5141     //
5142     };
5143     //
5144     };
5145     //
5146     } else if ( this->PKT(pkt2) > this->PKT(pkt1)+1 ){
5147     //
5148     // Check for missing calibtrk2
5149     //
5150     if ( IsDebug() ) printf(" Missing the trk calibration2! Next one at obt %u pkt %u t2 is %u\n",obt2,pkt2,t2);
5151     t2 = pret2;
5152     //
5153     // handle missing calib2
5154     //
5155     obt2 = 0;
5156     pkt2 = 0;
5157     valid = 0;
5158     MISSING_pkt1 = false;
5159     MISSING_pkt2 = true;
5160     // this->HandleTRK_CALIB(!MISSING_pkt1,!MISSING_pkt2);
5161     //
5162     };
5163     //
5164 mocchiut 1.7
5165     if( !(MISSING_pkt1&MISSING_pkt2) ){
5166     this->HandleTRK_CALIB(!MISSING_pkt1,!MISSING_pkt2);
5167     ncalib++;
5168     if( MISSING_pkt1||MISSING_pkt2||!valid )try_to_recover=true;
5169     }
5170    
5171    
5172 mocchiut 1.1 } else {
5173 mocchiut 1.7 //
5174 pam-fi 1.4 if ( IsDebug() ) printf(" Trk calibration1 at time %u obt %u pkt %u OUTSIDE the considered time interval \n",fromtime,obt1,pkt1);
5175     // if ( PEDANTIC ) throw -79;
5176     //
5177 mocchiut 1.1 };
5178 pam-fi 1.4 //
5179    
5180     }; //end loop on pkt1
5181 mocchiut 1.1
5182    
5183    
5184 pam-fi 1.4 //
5185     // we have one more calib pkt2 !
5186     //
5187     t2++;
5188     while ( t2 < nevents2 ){
5189 mocchiut 1.1 //
5190 pam-fi 1.4 // handle missing calib1
5191 mocchiut 1.1 //
5192 pam-fi 1.4 if ( IsDebug() ) printf(" t2 is %u nevents2 is %u \n",t2,nevents2);
5193     obt1 = 0;
5194     pkt1 = 0;
5195 mocchiut 1.1 //
5196 pam-fi 1.4 tr2->GetEntry(t2);
5197     ph2 = eh2->GetPscuHeader();
5198     obt2 = ph2->GetOrbitalTime();
5199     pkt2 = ph2->GetCounter();
5200 mocchiut 1.1 //
5201 pam-fi 1.4 fromtime = this->GetAbsTime(ph2->GetOrbitalTime());
5202     valid = 0;
5203     // if ( this->PKT(pkt1) >= this->PKT(pktfirst) && this->PKT(pkt1) <= upperpkt && this->OBT(obt1) >= this->OBT(obtfirst) && this->OBT(obt1) <= upperobt ){
5204     // EMILIANO
5205     if ( this->PKT(pkt2) >= this->PKT(pktfirst) && this->PKT(pkt2 <= upperpkt) && this->OBT(obt2) >= this->OBT(obtfirst) && this->OBT(obt2) <= upperobt ){
5206     // if ( this->PKT(pkt2) > this->PKT(pktfirst) || this->OBT(obt2) > this->OBT(obtfirst) ){
5207 mocchiut 1.1 //
5208 pam-fi 1.4 if ( IsDebug() ) printf(" Missing the trk calibration1! Next one at obt %u pkt %u t2 is %u\n",obt2,pkt2,t2);
5209 mocchiut 1.1 //
5210 pam-fi 1.4 MISSING_pkt1 = true;
5211     MISSING_pkt2 = false;
5212     this->HandleTRK_CALIB(!MISSING_pkt1,!MISSING_pkt2);
5213     ncalib++;
5214     if( MISSING_pkt1||MISSING_pkt2||!valid )try_to_recover=true;
5215 mocchiut 1.1 //
5216     };
5217     //
5218 pam-fi 1.4 t2++;
5219 mocchiut 1.1 //
5220 pam-fi 1.4 };
5221    
5222     // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
5223     // -----------------------------------------------------------------
5224     // in case of corruption, check if the calibration can be recovered
5225     // from another chewbacca file
5226     // -----------------------------------------------------------------
5227     // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
5228    
5229     // cout <<" TRY TO RECOVER ?? "<<try_to_recover<<endl;
5230    
5231     if(chewbacca&&try_to_recover){
5232    
5233    
5234     if ( IsDebug() ) cout << endl << ">>>> TRY TO RECOVER TRACKER CALIBRATIONS <<<<"<<endl;
5235    
5236     TSQLResult *result = 0;
5237     TSQLRow *row = 0;
5238 mocchiut 1.1 //
5239 pam-fi 1.4 stringstream oss;
5240     oss.str("");
5241 mocchiut 1.1 //
5242 pam-fi 1.4
5243     ////////////////////////////////////////////////////////////////////////
5244     // retrieve the name of the current file:
5245     ////////////////////////////////////////////////////////////////////////
5246     oss.str("");
5247     oss << "SELECT NAME FROM GL_ROOT where ID=" << GetID_ROOT() <<";";
5248     if ( IsDebug() ) cout << oss.str().c_str() << endl;
5249    
5250     result = conn->Query(oss.str().c_str());
5251     if ( !result ) throw -4;;
5252     row = result->Next();
5253     TString thisfilename = (TString)row->GetField(0);
5254     if ( IsDebug() ) cout << "Current file ==> "<<thisfilename<<endl;
5255    
5256     ////////////////////////////////////////////////////////////////////////
5257     // read all the calibrations inserted
5258     ////////////////////////////////////////////////////////////////////////
5259     oss.str("");
5260     oss << " SELECT ";
5261     oss << " ID,FROM_TIME,OBT1,PKT1,OBT2,PKT2,BOOT_NUMBER,VALIDATION,EV_ROOT_CALIBTRK1,EV_ROOT_CALIBTRK2,TO_TIME";
5262     oss << " FROM GL_TRK_CALIB ";
5263     oss << " ORDER BY ID DESC LIMIT "<<ncalib<<"; ";
5264     if ( IsDebug() ) cout << oss.str().c_str() << endl;
5265    
5266     result = conn->Query(oss.str().c_str());
5267     if ( !result ) throw -4;;
5268     if ( IsDebug() ) cout <<"Rows: "<<result->GetRowCount()<<endl;
5269    
5270     // -----------------------------------
5271     // loop over calibrations ...
5272     // -----------------------------------
5273     UInt_t nn=0;
5274     do {
5275     row = result->Next();
5276     if(!row)break;
5277    
5278     UInt_t id = (UInt_t)atoll(row->GetField(0));
5279     UInt_t fromtime = (UInt_t)atoll(row->GetField(1));
5280     UInt_t obt1 = (UInt_t)atoll(row->GetField(2));
5281     UInt_t pkt1 = (UInt_t)atoll(row->GetField(3));
5282     UInt_t obt2 = (UInt_t)atoll(row->GetField(4));
5283     UInt_t pkt2 = (UInt_t)atoll(row->GetField(5));
5284     UInt_t boot = (UInt_t)atoll(row->GetField(6));
5285     UInt_t valid = (UInt_t)atoll(row->GetField(7));
5286     bool MISSING_pkt1 = (row->GetFieldLength(8)==0);
5287     bool MISSING_pkt2 = (row->GetFieldLength(9)==0);
5288     UInt_t totime = (UInt_t)atoll(row->GetField(10));
5289    
5290     // -------------------------------------
5291     // ...check if the entry is corrupted...
5292     // -------------------------------------
5293     cout <<"*** "<< MISSING_pkt1 << MISSING_pkt2 << valid <<endl;
5294     bool CORRUPTED = (MISSING_pkt1||MISSING_pkt2||!valid);
5295    
5296     if ( IsDebug() ) cout << "("<<nn<<") ID = "<<id<<" from GL_TRK_CALIB ==> corrupted ? "<<CORRUPTED<<endl;
5297    
5298     // if( !CORRUPTED )continue; // nothing to do
5299    
5300     /////////////////////////////////////////////////////////
5301     // if it is corrupted, ...look for ather chewbacca files
5302     // containing the same calibrations ...
5303     /////////////////////////////////////////////////////////
5304    
5305     bool this_MISSING_pkt1 = false;
5306     bool this_MISSING_pkt2 = false;
5307     int this_t1=0;
5308     int this_t2=0;;
5309     UInt_t this_valid = 0;
5310    
5311     TString path = "";
5312     TString name = "";
5313     TString raw = "";
5314     UInt_t obt0 = 0;
5315     UInt_t timesync = 0;
5316     UInt_t boot_number = 0;
5317     bool FOUND = false;
5318    
5319     if ( IsDebug() ) cout << "------------------------------------------------------------" <<endl;
5320    
5321     // for(int itable=0; itable<2; itable++){
5322     for(int itable=0; itable<1; itable++){
5323    
5324     // ------------------------------------------------------
5325     // loop over both ROOT_TABLE and ROOT_TABLE_BAD
5326     // ------------------------------------------------------
5327    
5328     TString table = "ROOT_TABLE";
5329     if(itable==1)table = "ROOT_TABLE_BAD";
5330    
5331     oss.str("");
5332     oss << " SELECT ";
5333     oss << " FOLDER_NAME,FILE_NAME,OBT_TIME_SYNC,LAST_TIME_SYNC_INFO,BOOT_NUMBER,INPUT_NAME ";
5334     oss << " FROM "<<table;
5335     oss << " WHERE 1 " << endl;
5336     oss << " AND FILE_NAME != \""<< thisfilename<<"\"";
5337     if( !MISSING_pkt1 ){
5338     oss << " AND ";
5339     oss << " PKT_NUMBER_INIT < "<<pkt1;
5340     oss << " AND ";
5341     oss << " PKT_NUMBER_FINAL > "<<pkt1;
5342     oss << " AND ";
5343     oss << " PKT_OBT_INIT < "<<obt1;
5344     oss << " AND ";
5345     oss << " PKT_OBT_FINAL > "<<obt1;
5346     }else{
5347     if(pkt2>1) pkt1 = pkt2-1;//serve dopo
5348     }
5349     if( !MISSING_pkt2 ){
5350     oss << " AND ";
5351     oss << " PKT_NUMBER_INIT < "<<pkt2;
5352     oss << " AND ";
5353     oss << " PKT_NUMBER_FINAL > "<<pkt2;
5354     oss << " AND ";
5355     oss << " PKT_OBT_INIT < "<<obt2;
5356     oss << " AND ";
5357     oss << " PKT_OBT_FINAL > "<<obt2;
5358     }else{
5359     if(pkt1>0) pkt2 = pkt1+1;//serve dopo
5360     }
5361     if( boot> 0 ){
5362     oss << " AND ";
5363     oss << " BOOT_NUMBER = "<<boot;
5364     }else{
5365     }
5366     oss << " ORDER BY BAD_PKT_CALREAD ASC; ";
5367    
5368     TSQLResult *result2 = 0;
5369     TSQLRow *row2 = 0;
5370    
5371     if ( IsDebug() ) cout << oss.str().c_str() << endl;
5372     result2 = conn->Query(oss.str().c_str());
5373     if ( !result2 ) throw -4;;
5374     if ( IsDebug() ) cout <<"Rows: "<<result2->GetRowCount()<<endl;
5375    
5376     // ------------------------------------------------------
5377     // loop over files containing repetition (if any)
5378     // ------------------------------------------------------
5379     do {
5380     row2 = result2->Next();
5381     if(!row2)break;
5382    
5383     // ------------------------------------------------------
5384     // ... a repetition is found ...
5385     // ------------------------------------------------------
5386     path = (TString)row2->GetField(0);
5387     name = (TString)row2->GetField(1);
5388     raw = (TString)row2->GetField(5);
5389     obt0 = (UInt_t)atoll(row2->GetField(2));
5390     timesync = (UInt_t)atoll(row2->GetField(3));
5391     boot_number = (UInt_t)atoll(row2->GetField(4));
5392    
5393     if ( IsDebug() ) cout << "- - - - - - - - - - -" <<endl;
5394     // cout << path <<endl;
5395 mocchiut 1.5 // cout << "File : " <<name <<endl;
5396 pam-fi 1.4 // cout << obt0 <<endl;
5397     // cout << timesync <<endl;
5398 mocchiut 1.5 // cout << "boot n. : "<<boot_number <<endl;
5399 pam-fi 1.4 // cout << raw <<endl;
5400    
5401     // ------------------------------------------------------
5402     // ... retrieve the calibration packets.
5403     // ------------------------------------------------------
5404 mocchiut 1.7 if ( IsDebug() ) printf(" file is %s/%s \n",((TString)gSystem->ExpandPathName(path.Data())).Data(),name.Data());
5405     TFile *file = new TFile(((TString)gSystem->ExpandPathName(path.Data()))+"/"+name); // EM, path could be symbolic and we must expand it
5406 pam-fi 1.4 if(!file)throw -100;
5407     if(file->IsZombie())throw -100;
5408     //
5409     tr1 = (TTree*)file->Get("CalibTrk1");
5410     if ( !tr1 || tr1->IsZombie() ) throw -22;
5411     tr2 = (TTree*)file->Get("CalibTrk2");
5412     if ( !tr2 || tr2->IsZombie() ) throw -23;
5413     //
5414     tr1->SetBranchAddress("CalibTrk1", &caltrk1);
5415     tr1->SetBranchAddress("Header", &eh1);
5416     nevents1 = tr1->GetEntries();
5417     tr2->SetBranchAddress("CalibTrk2", &caltrk2);
5418     tr2->SetBranchAddress("Header", &eh2);
5419     nevents2 = tr2->GetEntries();
5420     for(this_t1=0; this_t1<nevents1; this_t1++){
5421     tr1->GetEntry(this_t1);
5422     if(
5423     (UInt_t)eh1->GetPscuHeader()->GetCounter() == pkt1 &&
5424     true) break;
5425     this_MISSING_pkt1 = true;
5426     }
5427     for(this_t2=0; this_t2<nevents2; this_t2++){
5428     tr2->GetEntry(this_t2);
5429     if(
5430     (UInt_t)eh2->GetPscuHeader()->GetCounter() == pkt2 &&
5431     true) break;
5432     this_MISSING_pkt2 = true;
5433     }
5434     this_valid =
5435     ValidateTrkCalib( caltrk1, eh1, file )
5436     *
5437     ValidateTrkCalib( caltrk2, eh2, file );
5438    
5439     // ---------------------------------------------------------------------
5440     // accept the calibration if it is better than the previous:
5441     //
5442     // - if the new calibration is perfect (both valid packets)
5443     // - if the new calibration has both the packets and the previous does not
5444     // ---------------------------------------------------------------------
5445     if(
5446     ( !this_MISSING_pkt1&&!this_MISSING_pkt2&&this_valid )||
5447     ( (MISSING_pkt1||MISSING_pkt2) && (!this_MISSING_pkt1&&!this_MISSING_pkt2) )||
5448     false)FOUND=true;
5449    
5450     if(file)file->Close();
5451    
5452     if(FOUND)break;
5453    
5454     }while(1);//endl loop over root table entries
5455    
5456     if(FOUND)break;
5457    
5458     }//end loop over tables
5459    
5460     if(FOUND){
5461    
5462 mocchiut 1.21 if ( IsDebug() ) cout << " >>> REPETITION FOUND :-) <<<" <<endl;
5463 pam-fi 1.4
5464 mocchiut 1.21 ////////////////////////////////////////////
5465     // insert a new entry in GL_TRK_CALIB and
5466     // modify the time-tag of the previous one
5467     ////////////////////////////////////////////
5468    
5469     // ---------------------------------------------------------------------
5470     // step 1: insert a new raw file in GL_RAW
5471     // ---------------------------------------------------------------------
5472     //
5473     // check if the raw file already exist
5474     //
5475     UInt_t id_raw = 0; // EM GL_RAW is there only for backward compatibility so we do not need to fill it when in "chewbacca" mode
5476     // oss.str("");
5477     // oss << "SELECT ID FROM GL_RAW where NAME=\"" << gSystem->BaseName(raw.Data()) <<"\";";
5478     // if ( IsDebug() ) cout << oss.str().c_str() << endl;
5479 pam-fi 1.4
5480 mocchiut 1.21 // result = conn->Query(oss.str().c_str());
5481     // if ( !result ) throw -4;;
5482     // if ( IsDebug() ) cout <<"Rows: "<<result->GetRowCount()<<endl;
5483     // if( result->GetRowCount() == 0){
5484     // if ( IsDebug() ) cout << " << Insert new RAW file >> "<<endl;
5485     // // - - - - - - - - - - -
5486     // // insert new raw file
5487     // // - - - - - - - - - - -
5488     // GL_RAW glraw = GL_RAW();
5489     // glraw.PATH = gSystem->DirName(raw.Data());
5490     // glraw.NAME = gSystem->BaseName(raw.Data());
5491     // glraw.BOOT_NUMBER = boot_number;
5492     // //
5493     // insertPamelaRawFile( &glraw );
5494     // //
5495     // id_raw = glraw.ID;
5496     // }else{
5497     // row = result->Next();
5498     // id_raw = (UInt_t)atoll(row->GetField(0));
5499     // }
5500     // if ( IsDebug() ) cout << "ID_RAW = "<<id_raw<<endl;
5501    
5502     // ---------------------------------------------------------------------
5503     // step 1(bis): retrieve the timesync id associated to the file
5504     // (NB, uso lo stesso associato al file iniziale)
5505     // ---------------------------------------------------------------------
5506     UInt_t idtimesync = 0;
5507     oss.str("");
5508     oss << " SELECT ID FROM GL_TIMESYNC where TIMESYNC="<<chlastts<<" AND OBT0="<<chobtts*1000<<" limit 1;";
5509     if ( debug ) printf(" %s \n",oss.str().c_str());
5510     result = conn->Query(oss.str().c_str());
5511     if ( !result ) throw -3;
5512 pam-fi 1.4 row = result->Next();
5513     if ( !row ) throw -3;
5514     idtimesync = (UInt_t)atoll(row->GetField(0));
5515     if ( IsDebug() ) cout << "ID_TIMESYNC = "<<idtimesync<<endl;
5516    
5517 mocchiut 1.21 delete result;// mmm... "Error in <TMySQLResult::Next>: result set closed" solved? 090112 [8RED error messages]
5518 pam-fi 1.4 // ---------------------------------------------------------------------
5519     // step 2: insert a new root file in GL_ROOT
5520     // ---------------------------------------------------------------------
5521     //
5522 mocchiut 1.5 // check if the root file already exist
5523 pam-fi 1.4 //
5524     UInt_t id_root = 0;
5525     oss.str("");
5526     oss << "SELECT ID FROM GL_ROOT where NAME=\"" << gSystem->BaseName(name.Data()) <<"\";";
5527     if ( IsDebug() ) cout << oss.str().c_str() << endl;
5528    
5529     result = conn->Query(oss.str().c_str());
5530     if ( !result ) throw -4;;
5531     if ( IsDebug() ) cout <<"Rows: "<<result->GetRowCount()<<endl;
5532     if( result->GetRowCount() == 0){
5533     if ( IsDebug() ) cout << " << Insert new ROOT file >> "<<endl;
5534     // - - - - - - - - - - -
5535     // insert new root file
5536     // - - - - - - - - - - -
5537     GL_ROOT glroot = GL_ROOT();
5538     glroot.ID_RAW = id_raw;
5539     glroot.ID_TIMESYNC = idtimesync;
5540 mocchiut 1.5 //
5541     // EM STATIC = the full expanded path must be put in the DB, KEEPENV = the path given as input (or found in ROOT_TABLE) must be used,
5542     // NOT STATIC NOT KEEPENV = $PAM_L0 must be used in the DB
5543     //
5544     if ( STATIC ){
5545     glroot.PATH = (TString)gSystem->ExpandPathName(path);
5546     } else {
5547     if ( KEEPENV ){
5548     glroot.PATH = path;
5549     } else {
5550     glroot.PATH = "$PAM_L0";
5551     };
5552     };
5553     // glroot.PATH = path;
5554 pam-fi 1.4 glroot.NAME = name;
5555     //
5556     insertPamelaRootFile( &glroot );
5557     //
5558     id_root = glroot.ID;
5559     }else{
5560     row = result->Next();
5561     if(row)id_root = (UInt_t)atoll(row->GetField(0));
5562     }
5563     if ( IsDebug() ) cout << "ID_ROOT = "<<id_root<<endl;
5564    
5565 mocchiut 1.21 delete result;// mmm... "Error in <TMySQLResult::Next>: result set closed" solved? 090112 [8RED error messages]
5566 pam-fi 1.4 // ---------------------------------------------------------------------
5567     // step 3: modify time-tag of corrupted GL_TRK_CALIB entry
5568     // ---------------------------------------------------------------------
5569     if ( IsDebug() ) cout << " << Modify time-tag of calibration ID="<<id<<" >> "<<endl;
5570     oss.str("");
5571     oss << " UPDATE GL_TRK_CALIB SET "
5572     << " TO_TIME=0 , FROM_TIME=0 WHERE "
5573     << " ID = "<< id << ";";
5574     if ( IsDebug() ) cout << oss.str().c_str() << endl;
5575     result = conn->Query(oss.str().c_str());
5576     if ( !result ) throw -4;;
5577    
5578 mocchiut 1.21 delete result; // mmm... "Error in <TMySQLResult::Next>: result set closed" solved? 090112 [8RED error messages]
5579    
5580 pam-fi 1.4 // ---------------------------------------------------------------------
5581     // step 4: insert the new calibration:
5582     // ---------------------------------------------------------------------
5583     if ( IsDebug() ) cout << " << Insert new TRK calibration >> "<<endl;
5584     //
5585     GL_TRK_CALIB glcal = GL_TRK_CALIB();
5586     //
5587     glcal.ID_ROOT_L0 = id_root;
5588     glcal.EV_ROOT_CALIBTRK1 = this_t1;
5589     glcal.EV_ROOT_CALIBTRK2 = this_t2;
5590     glcal.FROM_TIME = fromtime;
5591     glcal.TO_TIME = totime;
5592     glcal.OBT1 = obt1;
5593     glcal.OBT2 = obt2;
5594     glcal.PKT1 = pkt1;
5595     glcal.PKT2 = pkt1;
5596     glcal.BOOT_NUMBER = GetBOOTnumber();
5597     glcal.VALIDATION = this_valid;
5598     //
5599     HandleTRK_CALIB(&glcal);
5600     if ( IsDebug() ) cout << "ID = "<<glcal.ID<<endl;
5601     //
5602    
5603     }
5604     if ( IsDebug() ) cout << "------------------------------------------------------------" <<endl;
5605    
5606     }while(1);//end loop over calibrations
5607    
5608    
5609     if( result )delete result;
5610     if( row )delete row;
5611    
5612    
5613    
5614    
5615    
5616    
5617     }
5618    
5619    
5620     // // ------------------------------
5621     // // try to recover the calibration
5622     // // ------------------------------
5623     // cout << "TRY TO RECOVER TRACKER CALIBRATION"<<endl;
5624     // //
5625     // ULong64_t time = 0; //absolute time
5626     // string path[100]; //mettere un limite massimo
5627     // int nrows = 0;
5628     // UInt_t pkt = 0;
5629     // UInt_t obt = 0;
5630     // char *type = "";
5631     // EventHeader *eh = new EventHeader();
5632     // CalibTrk1Event *c = new CalibTrk1Event();
5633    
5634     // //
5635     // if(which_is_not_valid==1 || which_is_not_valid==3){
5636     // //
5637     // cout << "PKT1 --> missing or corrupted "<<endl;
5638     // type = "CalibTrk1";
5639     // pkt = pkt1;
5640     // obt = obt1;
5641     // time = this->GetAbsTime(obt1);
5642     // if( pkt1 == 0 ){//missing
5643     // time = this->GetAbsTime(obt2);
5644     // pkt = pkt2-1;
5645     // }
5646     // //
5647     // }else if (which_is_not_valid==2 || which_is_not_valid==3){
5648     // //
5649     // cout << "PKT2--> missing or corrupted "<<endl;
5650     // type = "CalibTrk2 ";
5651     // pkt = pkt2;
5652     // obt = obt2;
5653     // time = this->GetAbsTime(obt2);
5654     // if( pkt2 == 0 ){//missing
5655     // time = this->GetAbsTime(obt1);
5656     // pkt = pkt1+1;
5657     // }
5658     // //
5659     // }else{
5660     // cout << "this should not happen!!! "<<endl;
5661     // trow -666;
5662     // }
5663    
5664     // nrows = Query_ROOT_TABLE(time,conn,path);// get the list of file which might contain the packet
5665    
5666    
5667     // for(int r=0; r<nrows; r++){ //loop over rows
5668     // if(path)cout << r << " >>>> "<<(path+r)->c_str() << endl;
5669     // /// verifica che il file non sia quello gia` aperto
5670     // }
5671    
5672     // ////////////////////////////////////////////////////////////////////////
5673    
5674     // TSQLResult *result = 0;
5675     // TSQLRow *row = 0;
5676     // //
5677     // stringstream oss;
5678     // oss.str("");
5679     // // ----------------------------------------
5680     // // read the id of last calibration inserted
5681     // // ----------------------------------------
5682     // oss.str("");
5683     // oss << " SELECT ";
5684     // oss << " (ID,ID_ROOT_L0,EV_ROOT_CALIBTRK1,EV_ROOT_CALIBTRK2,FROM_TIME,TO_TIME,OBT1,PKT1,OBT2,PKT2,BOOT_NUMBER,VALIDATION) ";
5685     // oss << " ORDER BY ID DESC LIMIT 1; ";
5686    
5687     // result = conn->Query(oss.str().c_str());
5688     // row = result->Next();
5689     // if( !row )throw -666;
5690    
5691     // if( result )delete result;
5692     // if( row )delete row;
5693    
5694     // UInt_t id = (UInt_t)atoll(row->GetField(0));
5695    
5696     // // -------------------------------------
5697     // // ...and modify it with new parameters
5698     // // -------------------------------------
5699    
5700    
5701     // }
5702 mocchiut 1.1 //
5703     return(0);
5704     };
5705    
5706    
5707     /**
5708     * Scan S4 calibrations packets, fill the GL_S4_CALIB table
5709     */
5710     Int_t PamelaDBOperations::insertS4_CALIB(){
5711     //
5712     TSQLResult *result = 0;
5713     TSQLRow *row = 0;
5714     //
5715     stringstream oss;
5716     oss.str("");
5717     //
5718     TTree *tr = 0;
5719     EventHeader *eh = 0;
5720     PscuHeader *ph = 0;
5721     //
5722     UInt_t nevents = 0;
5723     UInt_t fromtime = 0;
5724     UInt_t totime = 0;
5725     UInt_t obt = 0;
5726     UInt_t pkt = 0;
5727     //
5728     tr = (TTree*)file->Get("CalibS4");
5729     if ( !tr || tr->IsZombie() ) throw -24;
5730     //
5731     tr->SetBranchAddress("Header", &eh);
5732     //
5733     nevents = tr->GetEntries();
5734     //
5735     if ( !nevents ) return(1);
5736     //
5737     for (UInt_t i = 0; i < nevents; i++){
5738     //
5739     tr->GetEntry(i);
5740     //
5741     ph = eh->GetPscuHeader();
5742     obt = ph->GetOrbitalTime();
5743     pkt = ph->GetCounter();
5744     fromtime = this->GetAbsTime(ph->GetOrbitalTime());
5745     if ( this->PKT(pkt) >= this->PKT(pktfirst) && this->PKT(pkt) <= upperpkt && this->OBT(obt) >= this->OBT(obtfirst) && this->OBT(obt) <= upperobt ){
5746     // if ( this->PKT(pkt) >= this->PKT(pktfirst) && this->OBT(obt) >= this->OBT(obtfirst) ){
5747     //
5748     if ( IsDebug() ) printf(" S4 calibration at time %u obt %u pkt %u \n",fromtime,obt,pkt);
5749     //
5750     // check if the calibration has already been inserted
5751     //
5752     oss.str("");
5753     oss << " SELECT ID FROM GL_S4_CALIB WHERE "
5754     << " BOOT_NUMBER = "<< this->GetBOOTnumber() << " AND "
5755     << " OBT = "<< obt << " AND "
5756     << " PKT = "<< pkt << ";";
5757     //
5758     if ( IsDebug() ) printf(" Check if the S4 calibration has already been inserted: query is \n %s \n",oss.str().c_str());
5759     result = conn->Query(oss.str().c_str());
5760     //
5761     if ( !result ) throw -4;
5762     //
5763     row = result->Next();
5764     //
5765     if ( row ){
5766     //
5767     if ( IsDebug() ) printf(" S4 calibration already inserted in the DB\n");
5768     if ( PEDANTIC ) throw -81;
5769     //
5770     } else {
5771     //
5772     // we have to insert a new calibration, check where to place it
5773     //
5774     oss.str("");
5775     oss << " SELECT ID,TO_TIME FROM GL_S4_CALIB WHERE "
5776     << " FROM_TIME < "<< fromtime << " AND "
5777     << " TO_TIME > "<< fromtime << ";";
5778     //
5779     if ( IsDebug() ) printf(" Check where to place the S4 calibration: query is \n %s \n",oss.str().c_str());
5780     result = conn->Query(oss.str().c_str());
5781     //
5782     if ( !result ) throw -4;
5783     //
5784     row = result->Next();
5785     //
5786     if ( !row ){
5787     //
5788     // no calibrations in the db contain our calibration
5789     //
5790     if ( IsDebug() ) printf(" Calibration with fromtime lower than others to be inserted in the DB \n");
5791     if ( fromtime < 1150871000 ){
5792     if ( IsDebug() ) printf(" First PAMELA flight calibration at time %u \n",fromtime);
5793     fromtime = 0;// the first flight calibration was taken at about 1156429100 s, this line allow to analyze first runs in raw mode
5794     };
5795     //
5796     oss.str("");
5797     oss << " SELECT FROM_TIME FROM GL_S4_CALIB WHERE "
5798     << " FROM_TIME > "<< fromtime << " ORDER BY FROM_TIME ASC LIMIT 1;";
5799     //
5800     if ( IsDebug() ) printf(" Check the upper limit for calibration: query is \n %s \n",oss.str().c_str());
5801     result = conn->Query(oss.str().c_str());
5802     //
5803     if ( !result ) throw -4;
5804     //
5805     row = result->Next();
5806     if ( !row ){
5807     totime = numeric_limits<UInt_t>::max();
5808     } else {
5809     totime = (UInt_t)atoll(row->GetField(0));
5810     };
5811     //
5812     } else {
5813     //
5814     // determine upper and lower limits and make space for the new calibration
5815     //
5816     totime = (UInt_t)atoll(row->GetField(1));
5817     //
5818     oss.str("");
5819     oss << " UPDATE GL_S4_CALIB SET "
5820     << " TO_TIME = "<< fromtime << " WHERE " // NOTICE: to_time is equal to from_time of the calibration before, so the interval is: [from_time,to_time[
5821     << " ID = "<< row->GetField(0) << ";";
5822     //
5823     if ( IsDebug() ) printf(" Make space for the new calibration: query is \n %s \n",oss.str().c_str());
5824     result = conn->Query(oss.str().c_str());
5825     //
5826     if ( !result ) throw -4;
5827     //
5828     };
5829     //
5830     oss.str("");
5831     oss << " INSERT INTO GL_S4_CALIB (ID,ID_ROOT_L0,EV_ROOT,FROM_TIME,TO_TIME,OBT,PKT,BOOT_NUMBER) "
5832     << " VALUES (NULL,' "
5833     << idroot << "','"
5834     << i << "','"
5835     << fromtime << "','"
5836     << totime << "','"
5837     << obt << "','"
5838     << pkt << "','"
5839     << this->GetBOOTnumber() << "');";
5840     //
5841     if ( IsDebug() ) printf(" Insert the new calibration: query is \n %s \n",oss.str().c_str());
5842     //
5843     result = conn->Query(oss.str().c_str());
5844     //
5845     if ( !result ) throw -4;
5846     //
5847     };
5848     //
5849     } else {
5850     //
5851     if ( IsDebug() ) printf(" S4 calibration at time %u obt %u pkt %u OUTSIDE the considered time interval\n",fromtime,obt,pkt);
5852     // if ( PEDANTIC ) throw -82;
5853     //
5854     };
5855     //
5856     };
5857     //
5858     return(0);
5859     };
5860    
5861     /**
5862     * Scan the fragment table and move old fragments to the GL_RUN table
5863     */
5864     Int_t PamelaDBOperations::CleanGL_RUN_FRAGMENTS(){
5865     return(this->CleanGL_RUN_FRAGMENTS(""));
5866     };
5867    
5868     /**
5869     * Scan the fragment table and move old fragments to the GL_RUN table
5870     */
5871     Int_t PamelaDBOperations::CleanGL_RUN_FRAGMENTS(Bool_t runpieces){
5872     return(this->CleanGL_RUN_FRAGMENTS("",runpieces));
5873     };
5874    
5875     /**
5876     * Scan the fragment table and move old fragments to the GL_RUN table
5877     */
5878     Int_t PamelaDBOperations::CleanGL_RUN_FRAGMENTS(TString fcleanfile){
5879     return(this->CleanGL_RUN_FRAGMENTS("",false));
5880     };
5881    
5882     /**
5883     * Scan the fragment table and move old fragments to the GL_RUN table
5884     */
5885     Int_t PamelaDBOperations::CleanGL_RUN_FRAGMENTS(TString fcleanfile, Bool_t runpieces){
5886     //
5887     TSQLResult *nresult = 0;
5888     TSQLRow *nrow = 0;
5889     TSQLResult *nresult1 = 0;
5890     TSQLRow *nrow1 = 0;
5891     TSQLResult *result = 0;
5892     TSQLRow *row = 0;
5893     TSQLResult *result2 = 0;
5894     TSQLRow *row2 = 0;
5895     //
5896     UInt_t moved = 0;
5897     //
5898     stringstream oss;
5899     oss.str("");
5900     //
5901     // Before moving blindly the runs from GL_RUN_FRAGMENTS to GL_RUN try to find out if we have runs divided in more than two pieces (chewbacca or explicit flag only)
5902     //
5903     if ( runpieces ){
5904     //
5905     UInt_t nid = 0;
5906     UInt_t myid[500];
5907     memset(myid,0,500*sizeof(UInt_t));
5908     //
5909     oss.str("");
5910     oss << "SELECT ID,RUNTRAILER_TIME,RUNTRAILER_PKT,BOOT_NUMBER FROM GL_RUN_FRAGMENTS WHERE INSERT_TIME <= '" << clean_time->AsSQLString() << "'order BY RUNHEADER_TIME asc;";
5911     if ( IsDebug() ) printf(" Select from GL_RUN_FRAGMENTS runs older than %s : query is \n %s \n",clean_time->AsSQLString(),oss.str().c_str());
5912     nresult = conn->Query(oss.str().c_str());
5913     //
5914     if ( nresult ){
5915     //
5916     nrow = nresult->Next();
5917     //
5918     while ( nrow ){
5919     //
5920     UInt_t mbo = (UInt_t)atoll(nrow->GetField(3));
5921     UInt_t mrhp = (UInt_t)atoll(nrow->GetField(2));
5922     UInt_t mrht = (UInt_t)atoll(nrow->GetField(1));
5923     Bool_t anr = true;
5924     Bool_t runisthere = true;
5925     //
5926     for (UInt_t u=0; u<=nid; u++){
5927     if ( (UInt_t)atoll(nrow->GetField(0)) == myid[u] && (UInt_t)atoll(nrow->GetField(0)) != 0 ) runisthere = false;
5928     };
5929     //
5930     // check if the run is still in the fragment table or if we have just move it in the gl_run table!
5931     //
5932     if ( runisthere ){
5933     //
5934     memset(myid,0,500*sizeof(UInt_t));
5935     nid = 0;
5936     myid[nid] = (UInt_t)atoll(nrow->GetField(0));
5937     //
5938     while ( anr ){
5939     //
5940     oss.str("");
5941     oss << "SELECT ID,RUNTRAILER_TIME,RUNTRAILER_PKT,BOOT_NUMBER FROM GL_RUN_FRAGMENTS WHERE BOOT_NUMBER=" << mbo << " AND RUNHEADER_PKT=" << mrhp << "+1 AND ABS(RUNHEADER_TIME-"<< mrht <<")<=1 AND INSERT_TIME <= '" << clean_time->AsSQLString() << "' order BY RUNHEADER_TIME asc;";
5942     if ( IsDebug() ) printf(" In the loop searching for fragmented runs : query is \n %s \n",oss.str().c_str());
5943     //
5944     nresult1 = conn->Query(oss.str().c_str());
5945     //
5946     if ( nresult1 ){
5947     //
5948     if ( nresult1->GetRowCount() == 1 ){
5949     //
5950     // one piece is found
5951     //
5952     nrow1 = nresult1->Next();
5953     //
5954     if ( nrow1 ){
5955     //
5956     nid++;
5957     myid[nid] = (UInt_t)atoll(nrow1->GetField(0));
5958     mbo = (UInt_t)atoll(nrow1->GetField(3));
5959     mrhp = (UInt_t)atoll(nrow1->GetField(2));
5960     mrht = (UInt_t)atoll(nrow1->GetField(1));
5961     if ( debug ) printf(" FOUND A PIECE OF RUN! nid %u myid[nid] %u mbo %u mrhp %u mrht %u \n",nid,myid[nid],mbo,mrhp,mrht);
5962     //
5963     nrow1->Close();
5964     } else {
5965     throw -88;
5966     };
5967     } else {
5968     anr = false;
5969     };
5970     nresult1->Close();
5971     } else {
5972     throw -88;
5973     };
5974     };
5975     //
5976     // handle these runs which are ordered and "good". Does the first contain a valid runheader?
5977     //
5978     oss.str("");
5979     oss << " ID= "<< myid[0];
5980     //
5981     glrun->Query_GL_RUN_FRAGMENTS(oss.str().c_str(),conn);
5982     //
5983     if ( glrun->GetACQ_BUILD_INFO() != 0 ){
5984     //
5985     // the first piece contains a good runheader we can update all the other runs with correct infos!
5986     //
5987     for (UInt_t u=1; u <= nid ; u++){
5988     oss.str("");
5989     oss << "UPDATE GL_RUN_FRAGMENTS SET "
5990     << " RUNHEADER_TIME=" << glrun->GetRUNHEADER_TIME()<< " , "
5991     << " RUNHEADER_OBT=" << glrun->GetRUNHEADER_OBT()<< " , "
5992     << " RUNHEADER_PKT=" << glrun->GetRUNHEADER_PKT()<< " , "
5993     << " COMPILATIONTIMESTAMP=" << glrun->GetCOMPILATIONTIMESTAMP()<< " , "
5994     << " FAV_WRK_SCHEDULE=" << glrun->GetFAV_WRK_SCHEDULE()<< " , "
5995     << " EFF_WRK_SCHEDULE=" << glrun->GetEFF_WRK_SCHEDULE()<< " , "
5996     << " PRH_VAR_TRG_MODE_A=" << glrun->GetPRH_VAR_TRG_MODE_A()<< " , "
5997     << " PRH_VAR_TRG_MODE_B=" << glrun->GetPRH_VAR_TRG_MODE_B()<< " , "
5998     << " ACQ_BUILD_INFO=" << glrun->GetACQ_BUILD_INFO()<< " , "
5999     << " ACQ_VAR_INFO=" << glrun->GetACQ_VAR_INFO()<< " , "
6000     << " RM_ACQ_AFTER_CALIB=" << glrun->GetRM_ACQ_AFTER_CALIB()<< " , "
6001     << " RM_ACQ_SETTING_MODE=" << glrun->GetRM_ACQ_SETTING_MODE()<< " , "
6002     << " TRK_CALIB_USED=" << glrun->GetTRK_CALIB_USED()<< " , "
6003     << " CAL_DSP_MASK=" << glrun->GetCAL_DSP_MASK()<< " , "
6004 mocchiut 1.2 << " LAST_TIMESYNC=" << glrun->GetLAST_TIMESYNC()<< " , ";
6005     //
6006     if ( glrun->GetPHYSENDRUN_MASK_S3S2S12() )
6007     oss << " PHYSENDRUN_MASK_S3S2S12=" << glrun->GetPHYSENDRUN_MASK_S3S2S12() << " , ";
6008     if ( glrun->GetPHYSENDRUN_MASK_S11CRC() )
6009     oss << " PHYSENDRUN_MASK_S11CRC=" << glrun->GetPHYSENDRUN_MASK_S11CRC() << " , ";
6010     //
6011     oss << " OBT_TIMESYNC=" << glrun->GetOBT_TIMESYNC();
6012     oss << " WHERE ID=" << myid[u] << ";";
6013 mocchiut 1.1 conn->Query(oss.str().c_str());
6014     };
6015     //
6016     } else {
6017     //
6018     // sig no runheader, let set anyway what is possible...
6019     //
6020     for (UInt_t u=1; u <= nid ; u++){
6021     oss.str("");
6022     oss << "UPDATE GL_RUN_FRAGMENTS SET "
6023 mocchiut 1.2 << " RUNHEADER_TIME=" << glrun->GetRUNHEADER_TIME()<< " , ";
6024     //
6025     if ( glrun->GetPHYSENDRUN_MASK_S3S2S12() )
6026     oss << " PHYSENDRUN_MASK_S3S2S12=" << glrun->GetPHYSENDRUN_MASK_S3S2S12()<< " , ";
6027     if ( glrun->GetPHYSENDRUN_MASK_S11CRC() )
6028     oss << " PHYSENDRUN_MASK_S11CRC=" << glrun->GetPHYSENDRUN_MASK_S11CRC()<< " , ";
6029     //
6030     oss << " RUNHEADER_OBT=" << glrun->GetRUNHEADER_OBT()<< " , "
6031 mocchiut 1.21 << " RUNHEADER_PKT=" << glrun->GetRUNHEADER_PKT();
6032     oss << " WHERE ID=" << myid[u] << ";"; // BUG!!! 090112
6033 mocchiut 1.1 conn->Query(oss.str().c_str());
6034     };
6035     };
6036     //
6037     // now let's look for runtrailer if any in the last run
6038     //
6039     oss.str("");
6040     oss << " ID= "<< myid[nid];
6041     //
6042     glrun->Query_GL_RUN_FRAGMENTS(oss.str().c_str(),conn);
6043     //
6044     if ( glrun->GetPKT_READY_COUNTER() != 0 ){
6045     //
6046     // the first piece contains a good runtrailer we can update all the other runs with correct infos!
6047     //
6048     for (UInt_t u=0; u < nid ; u++){
6049     oss.str("");
6050     oss << "UPDATE GL_RUN_FRAGMENTS SET "
6051     << " RUNTRAILER_TIME=" << glrun->GetRUNTRAILER_TIME()<< " , "
6052     << " RUNTRAILER_OBT=" << glrun->GetRUNTRAILER_OBT()<< " , "
6053     << " RUNTRAILER_PKT=" << glrun->GetRUNTRAILER_PKT()<< " , "
6054 mocchiut 1.2 << " PKT_COUNTER=" << glrun->GetPKT_COUNTER()<< " , ";
6055     //
6056     if ( glrun->GetPHYSENDRUN_MASK_S3S2S12() ){
6057     oss << " PHYSENDRUN_MASK_S3S2S12=" << glrun->GetPHYSENDRUN_MASK_S3S2S12()<< " , "; };
6058     if ( glrun->GetPHYSENDRUN_MASK_S11CRC() ) {
6059     oss << " PHYSENDRUN_MASK_S11CRC=" << glrun->GetPHYSENDRUN_MASK_S11CRC()<< " , "; };
6060     //
6061     oss << " PKT_READY_COUNTER=" << glrun->GetPKT_READY_COUNTER()
6062 mocchiut 1.1 << " WHERE ID=" << myid[u] << ";";
6063     conn->Query(oss.str().c_str());
6064     };
6065     //
6066     } else {
6067     //
6068     // sig no runtrailer, let set anyway what is possible...
6069     //
6070     for (UInt_t u=0; u < nid ; u++){
6071     oss.str("");
6072     oss << "UPDATE GL_RUN_FRAGMENTS SET "
6073     << " RUNTRAILER_TIME=" << glrun->GetRUNTRAILER_TIME()<< " , "
6074 mocchiut 1.2 << " RUNTRAILER_OBT=" << glrun->GetRUNTRAILER_OBT()<< " , ";
6075     //
6076     if ( glrun->GetPHYSENDRUN_MASK_S3S2S12() ){
6077     oss << " PHYSENDRUN_MASK_S3S2S12=" << glrun->GetPHYSENDRUN_MASK_S3S2S12()<< " , "; };
6078     if ( glrun->GetPHYSENDRUN_MASK_S11CRC() ){
6079     oss << " PHYSENDRUN_MASK_S11CRC=" << glrun->GetPHYSENDRUN_MASK_S11CRC()<< " , "; };
6080     //
6081 mocchiut 1.21 oss << " RUNTRAILER_PKT=" << glrun->GetRUNTRAILER_PKT();
6082     oss << " WHERE ID=" << myid[u] << ";"; // BUG!!! 090112
6083 mocchiut 1.1 conn->Query(oss.str().c_str());
6084     };
6085     };
6086     //
6087     // Now we want to cross indexize the runs
6088     //
6089     for (UInt_t u=0; u < nid ; u++){
6090     oss.str("");
6091     oss << "UPDATE GL_RUN_FRAGMENTS SET "
6092     << " ID_RUN_FRAG=" << myid[u+1] << " where ID=" << myid[u] <<";";
6093     conn->Query(oss.str().c_str());
6094     };
6095     oss.str("");
6096     oss << "UPDATE GL_RUN_FRAGMENTS SET "
6097     << " ID_RUN_FRAG=" << myid[0] << " where ID=" << myid[nid] <<";";
6098     conn->Query(oss.str().c_str());
6099     //
6100     // and now we can move the runs in the GL_RUN table
6101     //
6102     for (UInt_t u=0; u <= nid; u++){
6103     oss.str("");
6104     oss << " ID= "<< myid[u];
6105     //
6106     glrun->Query_GL_RUN_FRAGMENTS(oss.str().c_str(),conn);
6107     //
6108     if ( u == 0 ){
6109     oss.str("");
6110     oss << " SELECT ID,NEVENTS,TRK_CALIB_USED,PKT_COUNTER FROM GL_RUN WHERE "
6111     << " BOOT_NUMBER=" << glrun->GetBOOT_NUMBER() << " AND ("
6112     << " (RUNHEADER_TIME>=" << (UInt_t)(glrun->GetRUNHEADER_TIME()-10) << " AND "
6113     << " RUNTRAILER_TIME<=" << (UInt_t)(glrun->GetRUNTRAILER_TIME()+10) << " AND ("
6114     << " RUNHEADER_OBT>=" << glrun->GetRUNHEADER_OBT() << " OR "
6115     << " RUNHEADER_PKT>=" << glrun->GetRUNHEADER_PKT() << ") AND ("
6116     << " RUNTRAILER_OBT<=" << glrun->GetRUNTRAILER_OBT() << " OR "
6117     << " RUNTRAILER_PKT<=" << glrun->GetRUNTRAILER_PKT() << ") ) OR "
6118     << " (RUNHEADER_TIME<=" << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND "
6119     << " RUNTRAILER_TIME>=" << (UInt_t)glrun->GetRUNTRAILER_TIME() <<" AND ("
6120     << " RUNHEADER_OBT<=" << glrun->GetRUNHEADER_OBT() << " OR "
6121     << " RUNHEADER_PKT<=" << glrun->GetRUNHEADER_PKT() << ") AND ("
6122     << " RUNTRAILER_OBT>=" << glrun->GetRUNTRAILER_OBT() << " OR "
6123     << " RUNTRAILER_PKT>=" << glrun->GetRUNTRAILER_PKT() << ") ));";
6124     //
6125     if ( IsDebug() ) printf(" check if run has been inserted: query is \n %s \n",oss.str().c_str());
6126     result2 = conn->Query(oss.str().c_str());
6127     //
6128     if ( !result2 ) throw -4;
6129     //
6130     row2 = result2->Next();
6131     //
6132     if ( row2 ){
6133 mocchiut 1.23 if ( IsDebug() ) printf(" The run already exists in the GL_RUN table! \n");
6134 mocchiut 1.1 if ( PEDANTIC ) throw -83;
6135     row2->Close();
6136     };
6137     result2->Close();
6138     };
6139     //
6140     if ( IsDebug() ) printf(" The run is new \n");
6141     if ( IsDebug() ) printf(" -> fill the DB \n");
6142     //
6143     glrun->Fill_GL_RUN(conn);
6144     //
6145     if ( IsDebug() ) printf(" Delete run %u from the GL_RUN_FRAGMENTS table \n",myid[u]);
6146     //
6147     glrun->DeleteRun(conn,myid[u],"GL_RUN_FRAGMENTS");
6148     //
6149     moved++;
6150     //
6151     };
6152     //
6153     };
6154     //
6155     nrow = nresult->Next();
6156     };
6157     };
6158    
6159    
6160    
6161     };
6162     //
6163     if ( !strcmp(fcleanfile.Data(),"") ){
6164     //
6165     // check if there are entries older than "olderthan" seconds from now
6166     //
6167     oss.str("");
6168     oss << " SELECT ID FROM GL_RUN_FRAGMENTS WHERE"
6169     << " INSERT_TIME <= '" << clean_time->AsSQLString() << "';";
6170     //
6171     if ( IsDebug() ) printf(" Select from GL_RUN_FRAGMENTS runs older than %s : query is \n %s \n",clean_time->AsSQLString(),oss.str().c_str());
6172     result = conn->Query(oss.str().c_str());
6173     //
6174     } else {
6175     oss.str("");
6176     oss << " SELECT ID FROM GL_ROOT WHERE NAME='" << fcleanfile.Data() << "';";
6177     if ( IsDebug() ) printf(" Getting ID_ROOT_L0 query %s \n",oss.str().c_str());
6178     result = conn->Query(oss.str().c_str());
6179     //
6180     if ( result ){
6181     //
6182     row = result->Next();
6183     //
6184     if ( row ){
6185     oss.str("");
6186     oss << " SELECT ID FROM GL_RUN_FRAGMENTS WHERE"
6187     << " ID_ROOT_L0=" << row->GetField(0) << ";";
6188     //
6189     if ( IsDebug() ) printf(" Select from GL_RUN_FRAGMENTS for ROOT file query is \n %s \n",oss.str().c_str());
6190     result = conn->Query(oss.str().c_str());
6191     //
6192     };
6193     } else {
6194     return(2);
6195     };
6196     };
6197     //
6198     if ( result ){
6199     //
6200     row = result->Next();
6201     //
6202     while ( row ){
6203     //
6204     oss.str("");
6205     oss << " ID= "<< row->GetField(0);
6206     //
6207     glrun->Query_GL_RUN_FRAGMENTS(oss.str().c_str(),conn);
6208     //
6209     oss.str("");
6210 mocchiut 1.23 oss << " SELECT ID,NEVENTS,TRK_CALIB_USED,PKT_COUNTER,ID_ROOT_L0 FROM GL_RUN WHERE "
6211 mocchiut 1.1 << " BOOT_NUMBER=" << glrun->GetBOOT_NUMBER() << " AND ("
6212     << " (RUNHEADER_TIME>=" << (UInt_t)(glrun->GetRUNHEADER_TIME()-10) << " AND "
6213     << " RUNTRAILER_TIME<=" << (UInt_t)(glrun->GetRUNTRAILER_TIME()+10) << " AND ("
6214     << " RUNHEADER_OBT>=" << glrun->GetRUNHEADER_OBT() << " OR "
6215     << " RUNHEADER_PKT>=" << glrun->GetRUNHEADER_PKT() << ") AND ("
6216     << " RUNTRAILER_OBT<=" << glrun->GetRUNTRAILER_OBT() << " OR "
6217     << " RUNTRAILER_PKT<=" << glrun->GetRUNTRAILER_PKT() << ") ) OR "
6218     << " (RUNHEADER_TIME<=" << (UInt_t)glrun->GetRUNHEADER_TIME() << " AND "
6219     << " RUNTRAILER_TIME>=" << (UInt_t)glrun->GetRUNTRAILER_TIME() <<" AND ("
6220     << " RUNHEADER_OBT<=" << glrun->GetRUNHEADER_OBT() << " OR "
6221     << " RUNHEADER_PKT<=" << glrun->GetRUNHEADER_PKT() << ") AND ("
6222     << " RUNTRAILER_OBT>=" << glrun->GetRUNTRAILER_OBT() << " OR "
6223     << " RUNTRAILER_PKT>=" << glrun->GetRUNTRAILER_PKT() << ") ));";
6224     //
6225     if ( IsDebug() ) printf(" check if run has been inserted: query is \n %s \n",oss.str().c_str());
6226     result2 = conn->Query(oss.str().c_str());
6227     //
6228     if ( !result2 ) throw -4;
6229     //
6230     row2 = result2->Next();
6231     //
6232     if ( !row2 ){
6233     //
6234     if ( IsDebug() ) printf(" The run is new \n");
6235     if ( IsDebug() ) printf(" -> fill the DB \n");
6236     //
6237     // glrun->SetID(this->AssignRunID()); we use the old run number!
6238     glrun->SetID_RUN_FRAG(glrun->GetID());
6239     glrun->Fill_GL_RUN(conn);
6240     //
6241 mocchiut 1.2 // oss.str("");
6242     // oss << " SELECT ID FROM GL_RUN WHERE "
6243     // << " BOOT_NUMBER=" << glrun->GetBOOT_NUMBER() << " AND "
6244     // << " RUNHEADER_PKT=" << (UInt_t)glrun->GetRUNHEADER_PKT() << " AND "
6245     // << " RUNTRAILER_PKT=" << (UInt_t)glrun->GetRUNTRAILER_PKT() << " AND "
6246     // << " RUNHEADER_OBT=" << (UInt_t)glrun->GetRUNHEADER_OBT() << " AND "
6247     // << " RUNTRAILER_OBT=" << (UInt_t)glrun->GetRUNTRAILER_OBT() << "; ";
6248     // //
6249     // if ( IsDebug() ) printf(" Look for the ID of the inserted run: query is \n %s \n",oss.str().c_str());
6250     // result2 = conn->Query(oss.str().c_str());
6251     // //
6252     // if ( !result2 ) throw -4;
6253     // //
6254     // row2 = result2->Next();
6255     // //
6256     // if ( !row2 ) throw -25;
6257     // //
6258     // oss.str("");
6259     // oss << " UPDATE GL_RUN SET ID_RUN_FRAG = " << row2->GetField(0) << " WHERE ID = " << row2->GetField(0);
6260     // if ( IsDebug() ) printf(" Update the ID_RUN_FRAG of the inserted run: query is \n %s \n",oss.str().c_str());
6261     // result2 = conn->Query(oss.str().c_str());
6262     // //
6263     // if ( !result2 ) throw -4;
6264 mocchiut 1.1 //
6265     moved++;
6266     //
6267     } else {
6268 mocchiut 1.23
6269     // questa parte mah mah mah... da controllare
6270    
6271     //
6272     // we end up here if chewbacca and we have RH---| small gap |---RT, in this case the two pieces are attached and moved to GL_RUN. We are now processing the
6273     // "small gap" piece... we recognize this since: we have two entries from this query, the pkt number is consistent with our pkt number.
6274     //
6275     // 090112 [8RED (-70): RUN ALREADY INSERTED]
6276     //
6277     Bool_t OK = false;
6278     UInt_t IDRL2A = 0;
6279     UInt_t IDRL2B = 0;
6280     if ( result2->GetRowCount() == 2 ){
6281     IDRL2A = (UInt_t)atoll(row2->GetField(0));
6282     UInt_t IDRL0A = (UInt_t)atoll(row2->GetField(4));
6283     row2 = result2->Next();
6284     IDRL2B = (UInt_t)atoll(row2->GetField(0));
6285     UInt_t IDRL0B = (UInt_t)atoll(row2->GetField(4));
6286     if ( IsDebug() ) printf(" IDRL0A %u B %u IDRL2A %u B %u \n",IDRL0A,IDRL0B,IDRL2A,IDRL2B);
6287     // if ( IDRL0A == IDRL0B ){
6288     // TSQLResult *result2a = 0;
6289     // TSQLRow *row2a = 0;
6290     // oss.str("");
6291     // oss << "select PKT_NUMBER_FINAL from ROOT_TABLE_MERGING where REAL_TIME_INIT<" << chrtinit << " order by REAL_TIME_INIT desc limit 1;";
6292     // if ( IsDebug() ) printf(" Check if we are in the case RH---| small gap |---RT: query is \n %s \n",oss.str().c_str());
6293     // result2a = conn->Query(oss.str().c_str());
6294     // //
6295     // if ( !result2a ) throw -4;
6296     // //
6297     // row2a = result2a->Next();
6298     // //
6299     // if ( row2a ){
6300     // UInt_t PKA = (UInt_t)atoll(row2a->GetField(0));
6301     // delete result2a;
6302     // oss.str("");
6303     // oss << "select PKT_NUMBER_INIT from ROOT_TABLE_MERGING where REAL_TIME_INIT>" << chrtinit << " order by REAL_TIME_INIT asc limit 1;";
6304     // if ( IsDebug() ) printf(" Check if we are in the case RH---| small gap |---RT: query is \n %s \n",oss.str().c_str());
6305     // result2a = conn->Query(oss.str().c_str());
6306     // //
6307     // if ( !result2a ) throw -4;
6308     // //
6309     // row2a = result2a->Next();
6310     // //
6311     // if ( row2a ){
6312     // UInt_t PKB = (UInt_t)atoll(row2a->GetField(0));
6313     // //
6314     // if ( IsDebug() ) printf(" PKT(PKA) + 1 %llu == runheaderpkt %llu && PKB = runtrailer %llu + 1 %llu \n",PKT(PKA)+1LL, PKT(glrun->GetRUNHEADER_PKT()),PKT(PKB), PKT(glrun->GetRUNTRAILER_PKT())+1LL);
6315     // if ( PKT(PKA)+1LL == PKT(glrun->GetRUNHEADER_PKT()) && PKT(PKB) == PKT(glrun->GetRUNTRAILER_PKT())+1LL ){
6316     // if ( IsDebug() ) printf(" Ok, we are in the case: RH---| small gap |---RT \n");
6317     OK = true;
6318     // };
6319     // };
6320     // };
6321     // };
6322     };
6323     if ( OK ){
6324     //
6325     // this is the case in which we must insert a piece of run between two fragments in the GL_RUN table
6326     //
6327     // we have to update with runheader/trailer infos our run and we have to change the ROOT_ID_FRAG of the header piece ( 1/2 2/1 must become 1/3 3/2 2/1 )
6328     //
6329     GL_RUN *glA = new GL_RUN();
6330     glA->Query_GL_RUN(IDRL2A,conn);
6331     //
6332     if ( glA->GetACQ_BUILD_INFO() != 0 ){
6333     //
6334     // the first piece contains a good runheader we can update all the other runs with correct infos!
6335     //
6336     oss.str("");
6337     oss << "UPDATE GL_RUN_FRAGMENTS SET "
6338     << " RUNHEADER_TIME=" << glA->GetRUNHEADER_TIME()<< " , "
6339     << " RUNHEADER_OBT=" << glA->GetRUNHEADER_OBT()<< " , "
6340     << " RUNHEADER_PKT=" << glA->GetRUNHEADER_PKT()<< " , "
6341     << " COMPILATIONTIMESTAMP=" << glA->GetCOMPILATIONTIMESTAMP()<< " , "
6342     << " FAV_WRK_SCHEDULE=" << glA->GetFAV_WRK_SCHEDULE()<< " , "
6343     << " EFF_WRK_SCHEDULE=" << glA->GetEFF_WRK_SCHEDULE()<< " , "
6344     << " PRH_VAR_TRG_MODE_A=" << glA->GetPRH_VAR_TRG_MODE_A()<< " , "
6345     << " PRH_VAR_TRG_MODE_B=" << glA->GetPRH_VAR_TRG_MODE_B()<< " , "
6346     << " ACQ_BUILD_INFO=" << glA->GetACQ_BUILD_INFO()<< " , "
6347     << " ACQ_VAR_INFO=" << glA->GetACQ_VAR_INFO()<< " , "
6348     << " RM_ACQ_AFTER_CALIB=" << glA->GetRM_ACQ_AFTER_CALIB()<< " , "
6349     << " RM_ACQ_SETTING_MODE=" << glA->GetRM_ACQ_SETTING_MODE()<< " , "
6350     << " TRK_CALIB_USED=" << glA->GetTRK_CALIB_USED()<< " , "
6351     << " CAL_DSP_MASK=" << glA->GetCAL_DSP_MASK()<< " , "
6352     << " LAST_TIMESYNC=" << glA->GetLAST_TIMESYNC()<< " , ";
6353     //
6354     if ( glA->GetPHYSENDRUN_MASK_S3S2S12() )
6355     oss << " PHYSENDRUN_MASK_S3S2S12=" << glA->GetPHYSENDRUN_MASK_S3S2S12() << " , ";
6356     if ( glA->GetPHYSENDRUN_MASK_S11CRC() )
6357     oss << " PHYSENDRUN_MASK_S11CRC=" << glA->GetPHYSENDRUN_MASK_S11CRC() << " , ";
6358     //
6359     oss << " OBT_TIMESYNC=" << glA->GetOBT_TIMESYNC();
6360     oss << " WHERE ID=" << glrun->GetID() << ";";
6361     if ( IsDebug() ) printf(" update with correct infos: %s\n",oss.str().c_str());
6362     conn->Query(oss.str().c_str());
6363     //
6364     } else {
6365     //
6366     // sig no runheader, let set anyway what is possible...
6367     //
6368     oss.str("");
6369     oss << "UPDATE GL_RUN_FRAGMENTS SET "
6370     << " RUNHEADER_TIME=" << glA->GetRUNHEADER_TIME()<< " , ";
6371     //
6372     if ( glA->GetPHYSENDRUN_MASK_S3S2S12() )
6373     oss << " PHYSENDRUN_MASK_S3S2S12=" << glA->GetPHYSENDRUN_MASK_S3S2S12()<< " , ";
6374     if ( glA->GetPHYSENDRUN_MASK_S11CRC() )
6375     oss << " PHYSENDRUN_MASK_S11CRC=" << glA->GetPHYSENDRUN_MASK_S11CRC()<< " , ";
6376     //
6377     oss << " RUNHEADER_OBT=" << glA->GetRUNHEADER_OBT()<< " , "
6378     << " RUNHEADER_PKT=" << glA->GetRUNHEADER_PKT();
6379     oss << " WHERE ID=" << glrun->GetID() << ";";
6380     if ( IsDebug() ) printf(" update with correct infos2: %s\n",oss.str().c_str());
6381     conn->Query(oss.str().c_str());
6382     };
6383     //
6384     // update runheader ROOT_ID_FRAG
6385     //
6386     oss.str("");
6387     oss << "UPDATE GL_RUN SET ID_RUN_FRAG = " << glrun->GetID() << " where ID = " << IDRL2A << ";";
6388     if ( IsDebug() ) printf(" update gl_run to have cross indexing: %s\n",oss.str().c_str());
6389     conn->Query(oss.str().c_str());
6390     //
6391     // now let's look for runtrailer if any in the last run
6392     //
6393     glA->Query_GL_RUN(IDRL2B,conn);
6394     //
6395     if ( glA->GetPKT_READY_COUNTER() != 0 ){
6396     //
6397     // the first piece contains a good runtrailer we can update all the other runs with correct infos!
6398     //
6399     oss.str("");
6400     oss << "UPDATE GL_RUN_FRAGMENTS SET "
6401     << " RUNTRAILER_TIME=" << glA->GetRUNTRAILER_TIME()<< " , "
6402     << " RUNTRAILER_OBT=" << glA->GetRUNTRAILER_OBT()<< " , "
6403     << " RUNTRAILER_PKT=" << glA->GetRUNTRAILER_PKT()<< " , "
6404     << " PKT_COUNTER=" << glA->GetPKT_COUNTER()<< " , ";
6405     //
6406     if ( glA->GetPHYSENDRUN_MASK_S3S2S12() ){
6407     oss << " PHYSENDRUN_MASK_S3S2S12=" << glA->GetPHYSENDRUN_MASK_S3S2S12()<< " , "; };
6408     if ( glA->GetPHYSENDRUN_MASK_S11CRC() ) {
6409     oss << " PHYSENDRUN_MASK_S11CRC=" << glA->GetPHYSENDRUN_MASK_S11CRC()<< " , "; };
6410     //
6411     oss << " PKT_READY_COUNTER=" << glA->GetPKT_READY_COUNTER()
6412     << " WHERE ID=" << glrun->GetID() << ";";
6413     if ( IsDebug() ) printf(" update with correct trailer infos: %s\n",oss.str().c_str());
6414     conn->Query(oss.str().c_str());
6415     //
6416     } else {
6417     //
6418     // sig no runtrailer, let set anyway what is possible...
6419     //
6420     oss.str("");
6421     oss << "UPDATE GL_RUN_FRAGMENTS SET "
6422     << " RUNTRAILER_TIME=" << glA->GetRUNTRAILER_TIME()<< " , "
6423     << " RUNTRAILER_OBT=" << glA->GetRUNTRAILER_OBT()<< " , ";
6424     //
6425     if ( glA->GetPHYSENDRUN_MASK_S3S2S12() ){
6426     oss << " PHYSENDRUN_MASK_S3S2S12=" << glA->GetPHYSENDRUN_MASK_S3S2S12()<< " , "; };
6427     if ( glA->GetPHYSENDRUN_MASK_S11CRC() ){
6428     oss << " PHYSENDRUN_MASK_S11CRC=" << glA->GetPHYSENDRUN_MASK_S11CRC()<< " , "; };
6429     //
6430     oss << " RUNTRAILER_PKT=" << glrun->GetRUNTRAILER_PKT()
6431     << " WHERE ID=" << glrun->GetID() << ";";
6432     if ( IsDebug() ) printf(" update with correct trailer infos2: %s\n",oss.str().c_str());
6433     conn->Query(oss.str().c_str());
6434     };
6435     //
6436     UInt_t myi = glrun->GetID();
6437     oss.str("");
6438     oss << " ID= "<< myi;
6439     //
6440     glrun->Query_GL_RUN_FRAGMENTS(oss.str().c_str(),conn);
6441     //
6442     // fill the new run in GL_RUN
6443     //
6444     glrun->SetID_RUN_FRAG(IDRL2B);
6445     glrun->Fill_GL_RUN(conn);
6446     glrun->DeleteRun(conn,0,"GL_RUN_FRAGMENTS");
6447     delete glA;
6448     moved++;
6449     //
6450     } else {
6451     //
6452     // is just a repetition
6453     //
6454     if ( IsDebug() ) printf(" The run %u is already present in the GL_RUN table...\n",glrun->GetID());
6455     // printf(" CCCCCCCCICCCCCCCCCCCCIOOOOOOOOOO si muove Ciccio! %u \n",glrun->GetID());
6456     // if ( PEDANTIC && glrun->GetID() != 61563 ) throw -83;
6457     if ( PEDANTIC ) throw -83;
6458     };
6459     // if ( IsDebug() ) printf(" The run already exists in the GL_RUN table! ...\n");
6460     // if ( PEDANTIC ) throw -83;
6461 mocchiut 1.1 };
6462     if ( IsDebug() ) printf(" Delete run %s from the GL_RUN_FRAGMENTS table \n",row->GetField(0));
6463     //
6464     //
6465     glrun->DeleteRun(conn,(UInt_t)atoll(row->GetField(0)),"GL_RUN_FRAGMENTS");
6466 mocchiut 1.2 // oss.str("");
6467     // oss << " DELETE from GL_RUN_FRAGMENTS where ID = " << row->GetField(0);
6468     // if ( IsDebug() ) printf(" Clean the GL_RUN_FRAGMENTS table: query is \n %s \n",oss.str().c_str());
6469     // result2 = conn->Query(oss.str().c_str());
6470     // //
6471     // if ( !result2 ) throw -4;
6472     // //
6473 mocchiut 1.1 row = result->Next();
6474     };
6475     };
6476     if ( IsDebug() ) printf(" Moved %u runs\n",moved);
6477     return(0);
6478     };
6479    
6480     /**
6481     * Check if runs are good, i.e. if the tracker calibration is correctly associated..
6482     */
6483     Int_t PamelaDBOperations::ValidateRuns(){
6484     return(this->ValidateRuns(""));
6485     };
6486    
6487     /**
6488     * Check if runs are good, i.e. if the tracker calibration is correctly associated..
6489     */
6490     Int_t PamelaDBOperations::ValidateRuns(TString valfile){
6491     //
6492     TSQLResult *result = 0;
6493     TSQLRow *row = 0;
6494     //
6495     UInt_t calibtime = 50;
6496     //
6497     stringstream oss;
6498     oss.str("");
6499     //
6500     // =======================================================
6501     // validate runs by checking missing calibrations
6502     // =======================================================
6503     UInt_t t_stop = 0;
6504     UInt_t t_start = 0;
6505     if ( !strcmp(valfile.Data(),"") ) {
6506     // --------------------------------------------------------------
6507     // 1) get the OBT of the last run inserted after clean-time limit
6508     // --------------------------------------------------------------
6509     oss.str("");
6510     oss << " SELECT * FROM GL_RUN WHERE INSERT_TIME <= '" << clean_time->AsSQLString()
6511     << "' ORDER BY RUNHEADER_TIME DESC LIMIT 1;";
6512     if ( IsDebug() ) printf(" Get start validation-time: query is \n %s \n",oss.str().c_str());
6513     result = conn->Query(oss.str().c_str());
6514     if ( !result ) throw -4;
6515     if ( !result->GetRowCount() ) {
6516     printf(" No runs to validate \n");
6517     return(1);
6518     }else{
6519     row = result->Next();
6520     t_start = (UInt_t)atoll(row->GetField(4));
6521     };
6522     // --------------------------------------------------------------
6523     // 2) get the OBT of the last validated run
6524     // --------------------------------------------------------------
6525     oss.str("");
6526 mocchiut 1.12 // oss << " SELECT * FROM GL_RUN WHERE VALIDATION=1 AND RUNHEADER_TIME<="<< t_start
6527     oss << " SELECT * FROM GL_RUN WHERE VALIDATION>0 AND RUNHEADER_TIME<="<< t_start
6528 mocchiut 1.1 <<" ORDER BY RUNHEADER_TIME DESC LIMIT 1;";
6529     if ( IsDebug() ) printf(" Get stop validation-time: query is \n %s \n",oss.str().c_str());
6530     result = conn->Query(oss.str().c_str());
6531     if ( !result ) throw -4;
6532     if ( result->GetRowCount() ){
6533     row = result->Next();
6534     t_stop = (UInt_t)atoll(row->GetField(4));
6535     };
6536     if ( IsDebug() ) printf("Validation interval: from time %u - to time %u \n\n",t_stop,t_start);
6537     // --------------------------------------------------------------
6538     // now retrieves runs to be validated
6539     // --------------------------------------------------------------
6540     oss.str("");
6541     oss << " SELECT * FROM GL_RUN WHERE RUNHEADER_TIME <=" << t_start;
6542     oss << " AND RUNHEADER_TIME >="<< t_stop;
6543     oss << " ORDER BY RUNHEADER_TIME DESC;";
6544     if ( IsDebug() )printf(" Check runs for validation: query is \n %s \n",oss.str().c_str());
6545     result = conn->Query(oss.str().c_str());
6546     } else {
6547     //
6548     stringstream myquery;
6549     UInt_t myid = 0;
6550     myquery.str("");
6551     myquery << " SELECT ID FROM GL_ROOT where NAME='"<<valfile.Data() <<"';";
6552     //
6553     result = conn->Query(myquery.str().c_str());
6554     //
6555     row = result->Next();
6556     if( !row ){
6557     if ( strcmp(valfile.Data(),GetRootName().Data()) ){
6558     if ( IsDebug() ) printf(" No file to be validated even if option \"-validate file\" was used!!\n");
6559     return(2);
6560     };
6561     if ( IsDebug() ) printf(" No file to be validated (force mode)! \n");
6562     return(0);
6563     };
6564     myid=(UInt_t)atoll(row->GetField(0));
6565     //
6566     myquery.str("");
6567     myquery << " SELECT MAX(RUNTRAILER_TIME),MIN(RUNHEADER_TIME) FROM GL_RUN WHERE ID_ROOT_L0="<< myid <<";";
6568     //
6569     result = conn->Query(myquery.str().c_str());
6570     //
6571     row = result->Next();
6572     if( !row->GetField(0) || !row->GetField(1)){
6573     //
6574     if ( IsDebug() ) printf(" NO RUN ASSOCIATED TO THIS FILE! \n");
6575     //
6576     return(0);
6577     //
6578     } else {
6579     //
6580     UInt_t runhtime = (UInt_t)atoll(row->GetField(0));
6581     UInt_t runttime = (UInt_t)atoll(row->GetField(1));
6582     UInt_t caltime = 0;
6583     //
6584     myquery.str("");
6585     myquery << " SELECT FROM_TIME FROM GL_TRK_CALIB where FROM_TIME>" <<runhtime;
6586     myquery << " order by FROM_TIME asc limit 1;";
6587     //
6588     if ( IsDebug() ) printf(" query is \n %s \n",myquery.str().c_str());
6589     //
6590     //
6591     result = conn->Query(myquery.str().c_str());
6592     //
6593     row = result->Next();
6594     if( !row ){
6595     caltime = runhtime;
6596     } else {
6597     caltime = (UInt_t)atoll(row->GetField(0));
6598     };
6599     //
6600     myquery.str("");
6601     myquery << " SELECT * from GL_RUN where RUNHEADER_TIME>="<< runttime <<" AND RUNHEADER_TIME<=" ;
6602     myquery << caltime << " order by RUNHEADER_TIME DESC";
6603     //
6604     if ( IsDebug() ) printf(" query is \n %s \n",myquery.str().c_str());
6605     //
6606     result = conn->Query(myquery.str().c_str());
6607     //
6608     };
6609     };
6610     //
6611     if ( !result ) throw -4;
6612     if ( !result->GetRowCount() && IsDebug() ) printf(" No runs to validate \n");
6613     //
6614     Int_t nrow = 0;
6615     GL_RUN* this_run = new GL_RUN();
6616     GL_RUN* next_run = new GL_RUN();
6617     Int_t nseq_max = 1000;
6618 mocchiut 1.2 // UInt_t* sequence = new UInt_t[100];
6619 mocchiut 1.1 vector<UInt_t> sequence(nseq_max);
6620     Int_t nseq = 0;
6621     Bool_t CHECK = false;
6622     Bool_t this_ONLINE = false;
6623     Bool_t next_ONLINE = false;
6624     UInt_t t1=0,t2=0;
6625     // ---------------------------------------------------------------------------------
6626     // - loop over runs, back in time,
6627     // - select sequences of runs close in time (less than calibtime s apart),
6628     // which could be preceeded by a calibration
6629     // - check if there might be a missing calibration
6630     // ---------------------------------------------------------------------------------
6631     while(1){
6632    
6633 mocchiut 1.2 row = result->Next();
6634     if( row == NULL ) break;
6635 mocchiut 1.1
6636 mocchiut 1.2 //------------
6637     //get run info
6638     //------------
6639     this_run->Set_GL_RUN(row);
6640 mocchiut 1.1
6641 mocchiut 1.2 Bool_t this_BAD = false;
6642     if(this_run->GetTRK_CALIB_USED() == 1 || this_run->GetTRK_CALIB_USED() == 2) this_ONLINE = true;
6643     else if (this_run->GetTRK_CALIB_USED() == 104) this_ONLINE = false;
6644     else{
6645     // printf("Missing or corrupted header!! \n");
6646     this_ONLINE = false;
6647     this_BAD = true;
6648     };
6649 mocchiut 1.1
6650 mocchiut 1.2 //-----------------------------------
6651     //compare with previous(next in time)
6652     //-----------------------------------
6653     CHECK = false;
6654     UInt_t interval=0;
6655 mocchiut 1.1
6656 mocchiut 1.2 if( nrow != 0){
6657 mocchiut 1.1
6658    
6659 mocchiut 1.2 t1 = this_run->GetRUNTRAILER_TIME();
6660     t2 = next_run->GetRUNHEADER_TIME();
6661     interval = (t2-t1);
6662 mocchiut 1.1
6663 mocchiut 1.2 if(this_ONLINE && next_ONLINE){ // this: ON-LINE + next: ON-LINE
6664 mocchiut 1.1
6665 mocchiut 1.2 if( this_run->ID == next_run->ID_RUN_FRAG ) interval = 0; //=> run fragments
6666 mocchiut 1.1
6667 mocchiut 1.2 if( interval >= calibtime )CHECK = true; //more than calibtime s => there might be a calibration
6668 mocchiut 1.1
6669 mocchiut 1.2 if( !CHECK && this_run->VALIDATION ){
6670 mocchiut 1.12 // for (Int_t irun = 0; irun < nseq; irun++)assignVALIDATION(sequence[irun],true);
6671     for (Int_t irun = 0; irun < nseq; irun++)assignVALIDATION(sequence[irun],this_run->VALIDATION);
6672 mocchiut 1.2 nseq=0;
6673     }
6674 mocchiut 1.1
6675 mocchiut 1.2 }else if( !this_ONLINE && next_ONLINE) { // this: DEFAULT + next:ON-LINE
6676 mocchiut 1.1
6677 mocchiut 1.2 CHECK = true;
6678 mocchiut 1.1
6679 mocchiut 1.2 }else if( !next_ONLINE ){ // this:ANY + next:DEFAULT
6680 mocchiut 1.1
6681 mocchiut 1.2 assignVALIDATION(next_run->ID,true);
6682     nseq=0;
6683     }
6684     }
6685 mocchiut 1.1
6686 mocchiut 1.2 //----------------------------
6687     //check run sequence for calib
6688     //----------------------------
6689     if( CHECK ){
6690     // check if calibration exists
6691     if ( IsDebug() )printf("DT %i ===> CHECK Missing calibration\n",interval);
6692 mocchiut 1.12 // Bool_t MISSING = MissingTRK_CALIB(t1,t2);
6693     UInt_t MISSING = MissingTRK_CALIB(t1,t2);
6694     UInt_t val = 0;
6695     if ( MISSING == 1 ) val = 0;
6696     if ( MISSING == 0 ) val = 1;
6697     if ( MISSING == 2 ) val = 2;
6698     for (Int_t irun = 0; irun < nseq; irun++)assignVALIDATION(sequence[irun],val);
6699 mocchiut 1.2 nseq=0;
6700     };
6701     //--------------
6702     //store run info
6703     //--------------
6704     *next_run = *this_run;
6705     next_ONLINE = this_ONLINE;
6706     if( !this_BAD ){
6707     if(nseq < nseq_max){
6708     sequence[nseq] = this_run->ID;
6709     nseq++;
6710     }else printf("ValidateRuns ***WARNING*** : run sequence exceed assumed size (%i) \n",nseq_max);
6711     };
6712 mocchiut 1.1
6713 mocchiut 1.2 if ( IsDebug() ) printf("%i Run %u \n",nrow,this_run->ID);
6714     nrow++;
6715 mocchiut 1.1
6716     };
6717     delete this_run;
6718     delete next_run;
6719     //
6720     return(0);
6721     };
6722     /**
6723     * Check if there might be a missing tracker calibration in a given time interval
6724     * @param t1 From absolute time
6725     * @param t2 To absolute time
6726     * @return true if there might be a missing calibration
6727     */
6728 mocchiut 1.12 //Bool_t PamelaDBOperations::MissingTRK_CALIB(UInt_t t1,UInt_t t2){
6729     UInt_t PamelaDBOperations::MissingTRK_CALIB(UInt_t t1,UInt_t t2){
6730 mocchiut 1.1
6731 mocchiut 1.2 GL_TRK_CALIB* trkcalib = new GL_TRK_CALIB();
6732 mocchiut 1.1
6733 pam-fi 1.4 // get the closest calibration before the run start (t2)
6734 mocchiut 1.12 // if ( trkcalib->Query_GL_TRK_CALIB(t2, conn) )return(true); //>>> missing
6735     if ( trkcalib->Query_GL_TRK_CALIB(t2, conn) )return(1); //>>> missing
6736 mocchiut 1.1
6737 mocchiut 1.12 // if ( trkcalib->TO_TIME < t2 ) return(true); //>>> missing
6738     if ( trkcalib->TO_TIME < t2 ) return(1); //>>> missing
6739 mocchiut 1.1
6740 mocchiut 1.2 //==============================================================
6741     // Check is done first on the basis of time between calibration,
6742     // which should be equal to the time between ascending-nodes.
6743     //==============================================================
6744     if ( t2 - trkcalib->FROM_TIME > 5700) {
6745     if ( IsDebug() )printf("Long time between calib and run start %u :-( ==> there might be a missing calib \n",t2 - trkcalib->FROM_TIME);
6746     //==============================================================
6747     // there might be a missing calibration, due to:
6748     // - MM full
6749     // - corrupted packets
6750     // - loss of data
6751     // There is an exception in case a download was done during ascending node
6752     //==============================================================
6753     Bool_t DOWNLOAD = false;
6754     // check if the calib was skipped becouse of download .... DA FARE!!
6755 mocchiut 1.12 // if(DOWNLOAD)return(false);
6756     if(DOWNLOAD)return(0);
6757 mocchiut 1.1
6758 mocchiut 1.12 // return(true); //>>> missing
6759     return(1); //>>> missing
6760 mocchiut 1.1
6761 mocchiut 1.2 };
6762 mocchiut 1.1
6763 mocchiut 1.2 //==============================================================
6764     // If the last calibration is close to the run less than this time,
6765     // it is enough to say that there are no missing calibrations
6766     //==============================================================
6767     // the long time interval bewteen runs might be due to download
6768     if ( IsDebug() )printf("Short time between calib and run start %u :-) ==> OK! \n",t2 - trkcalib->FROM_TIME);
6769 mocchiut 1.12 if ( trkcalib->VALIDATION ) return(0);
6770     if ( IsDebug() )printf("Calibration is not validated... :-/ ==> OK but with VALIDATION=2! \n");
6771     return(2);
6772 mocchiut 1.1
6773     };
6774     /**
6775     * Assign VALIDATION value to a GL_RUN entry
6776     * @param idrun Run ID
6777     * @param validation true/false
6778     */
6779     Int_t PamelaDBOperations::assignVALIDATION(UInt_t idrun, Bool_t validation){
6780 mocchiut 1.12 return(this->assignVALIDATION(idrun,(UInt_t)validation));
6781     }
6782    
6783     Int_t PamelaDBOperations::assignVALIDATION(UInt_t idrun, UInt_t validation){
6784 mocchiut 1.2 TSQLResult *result = 0;
6785     stringstream oss;
6786     oss.str("");
6787     oss << " UPDATE GL_RUN SET VALIDATION="<< (UInt_t)validation <<" WHERE ID= " << idrun << ";";
6788     //
6789     // if ( IsDebug() )
6790     // printf(" Set VALIDATION = %i for run %i \n",validation,idrun);
6791     if ( IsDebug() )printf(" Query: %s \n",oss.str().c_str());
6792     result = conn->Query(oss.str().c_str());
6793     if ( !result ) throw -4;
6794     return(0);
6795 mocchiut 1.1 }
6796    
6797    
6798    
6799     // Insert TLEs from file tlefilename in the table GL_TLE in the db
6800     // opened by conn, sorting them by date from older to newer, if each
6801     // TLE has not been alread inserted.
6802     Int_t PamelaDBOperations::populateTLE()//(TSQLServer *conn, char *tleFile)
6803     {
6804     fstream tlefile(tlefilename, ios::in);
6805    
6806     if ( !tlefile ) throw -7;
6807    
6808     vector<cTle*> ctles;
6809     vector<cTle*>::iterator iter;
6810     int present = 0;
6811    
6812     // Get three lines from tlefile, create a cTle object and put it
6813     // into ctles
6814     while(1) {
6815     cTle *tlef;
6816     string str1, str2, str3;
6817    
6818     getline(tlefile, str1);
6819     if(tlefile.eof()) break;
6820    
6821     getline(tlefile, str2);
6822     if(tlefile.eof()) break;
6823    
6824     getline(tlefile, str3);
6825     if(tlefile.eof()) break;
6826    
6827     // We now have three good lines for a cTle.
6828     tlef = new cTle(str1, str2, str3);
6829     ctles.push_back(tlef);
6830     }
6831    
6832     tlefile.close();
6833    
6834     // Sort by date
6835     sort(ctles.begin(), ctles.end(), compTLE);
6836    
6837     // Now we insert each TLE into the db
6838     for(iter = ctles.begin(); iter != ctles.end(); iter++) {
6839     cTle *tle = *iter;
6840    
6841     // Do nothing if it's already present in the db. Just increase
6842     // the counter present.
6843     if (! isTlePresent(tle))
6844     {
6845     int status = insertTle(tle);
6846    
6847     // Insert query failed. Return 1.
6848     if(status == EXIT_FAILURE) {
6849    
6850     if( IsDebug() ) {
6851     cerr << "Error: inserting TLE:" << endl
6852     << tle->getName() << endl
6853     << tle->getLine1() << endl
6854     << tle->getLine2() << endl;
6855     }
6856    
6857     throw -4;
6858     return 1;
6859     }
6860    
6861     }
6862     else
6863     present++;
6864    
6865     }
6866    
6867     int inserted = ctles.size() - present; // Number of inserted TLE.
6868     if ( IsDebug() )
6869     cout << "\nProcessed TLEs ranging from " << getTleDatetime(ctles[0]) << " to " << getTleDatetime(ctles[ctles.size()-1]) << "." << endl
6870     << inserted << " newly inserted TLEs out of " << ctles.size() << " processed." << endl;
6871    
6872     ctles.clear();
6873    
6874    
6875     // Return 2 if no new TLE has been inserted. 0 otherwise.
6876     if(! inserted ) return 2;
6877     return 0;
6878     }
6879    
6880    
6881     // Insert tle in the table GL_TLE using the connection conn.
6882     Int_t PamelaDBOperations::insertTle(cTle *tle)
6883     {
6884     stringstream oss;
6885     TSQLResult *result = 0;
6886    
6887     oss.str("");
6888     oss << " INSERT INTO GL_TLE (TLE1, TLE2, TLE3, FROM_TIME)"
6889     << " VALUES ( '"
6890     << tle->getName() << "', '"
6891     << tle->getLine1() << "', '"
6892     << tle->getLine2() << "', '"
6893     << getTleDatetime(tle) << "')";
6894    
6895     // cout << oss.str().c_str() << endl;
6896     result = conn->Query(oss.str().c_str());
6897     if (result == NULL)
6898     return EXIT_FAILURE;
6899    
6900     return EXIT_SUCCESS;
6901     }
6902    
6903    
6904     // Return whether tle is already in the db connected by conn.
6905     bool PamelaDBOperations::isTlePresent(cTle *tle)
6906     {
6907     stringstream oss;
6908     TSQLResult *result = 0;
6909    
6910     oss.str("");
6911     oss << "SELECT * FROM GL_TLE WHERE FROM_TIME = '"
6912     << getTleDatetime(tle) << "'";
6913    
6914     result = conn->Query(oss.str().c_str());
6915     if (result == NULL) throw -4;
6916    
6917     if (result->GetRowCount())
6918     return true;
6919     else
6920     return false;
6921     }
6922    
6923    
6924     // Return whether the first TLE is dated early than the second
6925     bool compTLE (cTle *tle1, cTle *tle2)
6926     {
6927     return getTleJulian(tle1) < getTleJulian(tle2);
6928     }
6929    
6930    
6931     // Return the date of the tle using the format (year-2000)*1e3 +
6932     // julian day. e.g. 6365 is the 31th Dec 2006.
6933     // It does *not* return a cJulian date.
6934     float getTleJulian(cTle *tle) {
6935     return tle->getField(cTle::FLD_EPOCHYEAR)*1e3 + tle->getField(cTle::FLD_EPOCHDAY);
6936     }
6937    
6938    
6939     // Return a string like YYYY-MM-DD hh:mm:ss, usable for mysql datetime
6940     // format.
6941     string getTleDatetime(cTle *tle)
6942     {
6943     int year, mon, day, hh, mm, ss;
6944     double dom; // day of month (is double!)
6945     stringstream date; // date in datetime format
6946    
6947     // create a cJulian from the date in tle
6948     cJulian jdate = cJulian( 2000 + (int) tle->getField(cTle::FLD_EPOCHYEAR), tle->getField(cTle::FLD_EPOCHDAY));
6949    
6950     // get year, month, day of month
6951     jdate.getComponent(&year, &mon, &dom);
6952    
6953     // build a datetime YYYY-MM-DD hh:mm:ss
6954     date.str("");
6955     day = (int) floor(dom);
6956     hh = (int) floor( (dom - day) * 24);
6957     mm = (int) floor( ((dom - day) * 24 - hh) * 60);
6958     ss = (int) floor( ((((dom - day) * 24 - hh) * 60 - mm) * 60));
6959     // ms = (int) floor( (((((dom - day) * 24 - hh) * 60 - mm) * 60) - ss) * 1000);
6960    
6961     date << year << "-" << mon << "-" << day << " " << hh << ":" << mm << ":" << ss;
6962    
6963     return date.str();
6964     }
6965    
6966     /**
6967     * Remove a file from the DB, delete on cascade all entries related to that file
6968     * rearrange GL_RUN and GL_XXX_CALIB tables, turn off validation till the following
6969     * calibration
6970     **/
6971     Int_t PamelaDBOperations::removeFile(TString remfile){
6972     //
6973     // Determine ID_ROOT_L0 and ID_RAW
6974     //
6975     TSQLResult *pResult;
6976     TSQLRow *Row;
6977     stringstream myquery;
6978     //
6979     myquery.str("");
6980 mocchiut 1.10 myquery << " SELECT ID,ID_RAW,ID_TIMESYNC FROM GL_ROOT where NAME='"<<remfile.Data() <<"';";
6981 mocchiut 1.1 //
6982     pResult = conn->Query(myquery.str().c_str());
6983     //
6984     Row = pResult->Next();
6985     if( !Row ){
6986     if ( strcmp(remfile.Data(),GetRootName().Data()) ){
6987     if ( IsDebug() ) printf(" No file to be removed even if option \"-remove file\" was used!!\n");
6988     return(1);
6989     };
6990     if ( IsDebug() ) printf(" No file to be removed (force mode)! \n");
6991     return(0);
6992     };
6993     //
6994     this->SetID_ROOT((UInt_t)atoll(Row->GetField(0)));
6995     this->SetID_RAW((UInt_t)atoll(Row->GetField(1)));
6996 mocchiut 1.10 UInt_t idtsy=(UInt_t)atoll(Row->GetField(2));
6997 mocchiut 1.1 //
6998     this->ValidationOFF();
6999     //
7000     this->RemoveCALIBS();
7001     //
7002     this->RemoveRUNS();
7003     //
7004 mocchiut 1.10 this->RemoveFILES(idtsy);
7005 mocchiut 1.1 //
7006     this->SetID_ROOT(0);
7007     this->SetID_RAW(0);
7008     //
7009     return(0);
7010     };
7011    
7012     /**
7013     *
7014     * Set validation bit to zero for runs following the removing file till
7015     * 1) a run with TRK_CALIB_USED=140
7016     * 2) a run with VALIDATION = 0
7017     * 3) the next calibration
7018     *
7019     **/
7020     void PamelaDBOperations::ValidationOFF(){
7021     TSQLResult *pResult;
7022     TSQLRow *Row;
7023     stringstream myquery;
7024     Int_t unv = 0;
7025     //select ID from GL_RUN where RUNHEADER_TIME>=1152671382 AND (VALIDATION=0 OR TRK_CALIB_USED=104) order by RUNHEADER_TIME asc limit 1;
7026     myquery.str("");
7027     myquery << " SELECT MAX(RUNTRAILER_TIME) FROM GL_RUN WHERE ID_ROOT_L0="<< this->GetID_ROOT() <<";";
7028     //
7029     pResult = conn->Query(myquery.str().c_str());
7030     //
7031     Row = pResult->Next();
7032     if( !Row->GetField(0) ){
7033     //
7034     if ( IsDebug() ) printf(" NO RUN ASSOCIATED TO THIS FILE! \n");
7035     //
7036     } else {
7037     //
7038     UInt_t runhtime = (UInt_t)atoll(Row->GetField(0));
7039     UInt_t caltime = 0;
7040     //
7041     myquery.str("");
7042     myquery << " SELECT FROM_TIME FROM GL_TRK_CALIB where FROM_TIME>" <<runhtime;
7043     myquery << " order by FROM_TIME asc limit 1;";
7044     //
7045     if ( IsDebug() ) printf(" query is \n %s \n",myquery.str().c_str());
7046     //
7047     //
7048     delete pResult;
7049     pResult = conn->Query(myquery.str().c_str());
7050     //
7051     Row = pResult->Next();
7052     if( !Row ){
7053     caltime = runhtime;
7054     } else {
7055     caltime = (UInt_t)atoll(Row->GetField(0));
7056     };
7057     //
7058     myquery.str("");
7059     myquery << " SELECT ID,RUNHEADER_TIME from GL_RUN where RUNHEADER_TIME>="<< runhtime <<" AND (VALIDATION=0 OR TRK_CALIB_USED=104 OR RUNHEADER_TIME>" ;
7060     myquery << caltime << ") order by RUNHEADER_TIME asc LIMIT 1";
7061     //
7062     if ( IsDebug() ) printf(" query is \n %s \n",myquery.str().c_str());
7063     //
7064     pResult = conn->Query(myquery.str().c_str());
7065     //
7066     Row = pResult->Next();
7067     if( !Row ){
7068     //
7069     if ( IsDebug() ) printf(" NO RUN NEED TO BE UNVALIDATED \n");
7070     //
7071     } else {
7072     myquery.str("");
7073     myquery << " SELECT ID from GL_RUN where RUNHEADER_TIME<"<< Row->GetField(1) <<" AND ";
7074     myquery << " RUNHEADER_TIME>=" <<runhtime;
7075     myquery << " order by RUNHEADER_TIME asc;";
7076     //
7077     if ( IsDebug() ) printf(" query is \n %s \n",myquery.str().c_str());
7078     //
7079     pResult = conn->Query(myquery.str().c_str());
7080     //
7081     Row = pResult->Next();
7082     while ( Row ){
7083     //
7084     unv++;
7085     this->assignVALIDATION((UInt_t)atoll(Row->GetField(0)), false);
7086     Row = pResult->Next();
7087     //
7088     };
7089     };
7090     };
7091     if ( IsDebug() ) printf(" %u runs have been unvalidated \n",unv);
7092     };
7093    
7094     /**
7095     *
7096     * Rearrange GL_RUN table and remove runs
7097     *
7098     **/
7099     void PamelaDBOperations::RemoveRUNS(){
7100     TSQLResult *pResult;
7101     TSQLRow *Row;
7102     stringstream myquery;
7103     UInt_t drun = 0;
7104     GL_RUN *delrun = new GL_RUN();
7105     //
7106     myquery.str("");
7107     myquery << " SELECT ID FROM GL_RUN where ID_RUN_FRAG=0 and ID_ROOT_L0=" <<this->GetID_ROOT() <<";";
7108     //
7109     if ( IsDebug() ) printf(" query is \n %s \n",myquery.str().c_str());
7110     //
7111     pResult = conn->Query(myquery.str().c_str());
7112     //
7113     Row = pResult->Next();
7114     //
7115     //
7116     if ( !Row ){
7117     if ( IsDebug() ) printf(" No run with ID_RUN_FRAG=0 belonged to this file \n");
7118     } else {
7119     if ( IsDebug() ) printf(" Deleting run from GL_RUN table \n");
7120     while ( Row ){
7121     delrun->DeleteRun(conn,(UInt_t)atoll(Row->GetField(0)),"GL_RUN");
7122     if ( IsDebug() ) printf(" del run %u \n",(UInt_t)atoll(Row->GetField(0)));
7123     drun++;
7124     Row = pResult->Next();
7125     };
7126     };
7127     //
7128     //
7129     myquery.str("");
7130     myquery << " SELECT ID,ID_RUN_FRAG FROM GL_RUN where ID_RUN_FRAG!=0 and ID_ROOT_L0=" <<this->GetID_ROOT() <<";";
7131     //
7132     if ( IsDebug() ) printf(" query is \n %s \n",myquery.str().c_str());
7133     //
7134     pResult = conn->Query(myquery.str().c_str());
7135     //
7136     Row = pResult->Next();
7137     //
7138     if ( !Row ){
7139     if ( IsDebug() ) printf(" No run with ID_RUN_FRAG!=0 belonged to this file \n");
7140     } else {
7141     if ( IsDebug() ) printf(" Deleting run fragments from GL_RUN table \n");
7142     while ( Row ){
7143     if ( IsDebug() ) printf(" restore run %u \n",(UInt_t)atoll(Row->GetField(1)));
7144     delrun->RestoreRun(conn,(UInt_t)atoll(Row->GetField(1)),"GL_RUN_FRAGMENTS");
7145     if ( IsDebug() ) printf(" del run %u \n",(UInt_t)atoll(Row->GetField(1)));
7146     delrun->DeleteRun(conn,(UInt_t)atoll(Row->GetField(1)),"GL_RUN");
7147     if ( (UInt_t)atoll(Row->GetField(1)) != (UInt_t)atoll(Row->GetField(0)) ){
7148     if ( IsDebug() ) printf(" del run %u \n",(UInt_t)atoll(Row->GetField(0)));
7149     delrun->DeleteRun(conn,(UInt_t)atoll(Row->GetField(0)),"GL_RUN");
7150     };
7151     drun++;
7152     Row = pResult->Next();
7153     };
7154     };
7155     //
7156     if ( IsDebug() ) printf(" Deleted %i run(s) from GL_RUN table \n",drun);
7157     //
7158     //
7159     //
7160     drun = 0;
7161     //
7162     myquery.str("");
7163     myquery << " SELECT ID_TRASH FROM GL_RUN_TRASH where BELONGED_TO='GL_RUN_FRAGMENTS' AND ID_ROOT_L0=" <<this->GetID_ROOT() <<";";
7164     //
7165     pResult = conn->Query(myquery.str().c_str());
7166     //
7167     Row = pResult->Next();
7168     //
7169     if ( !Row ){
7170     if ( IsDebug() ) printf(" No run from GL_RUN_FRAGMENTS table in the trash table for this file \n");
7171     } else {
7172     if ( IsDebug() ) printf(" Deleting run fragments from GL_RUN_TRASH table \n");
7173     while ( Row ){
7174     if ( IsDebug() ) printf(" del run idtrash %u \n",(UInt_t)atoll(Row->GetField(0)));
7175     myquery.str("");
7176     myquery << " DELETE FROM GL_RUN_TRASH where ID_TRASH=" << Row->GetField(0) <<";";
7177     conn->Query(myquery.str().c_str());
7178     drun++;
7179     Row = pResult->Next();
7180     };
7181     };
7182     //
7183     if ( IsDebug() ) printf(" Deleted %u run(s) from GL_RUN_TRASH table \n",drun);
7184     //
7185     //
7186     //
7187     drun = 0;
7188     //
7189     myquery.str("");
7190     myquery << " SELECT ID FROM GL_RUN_FRAGMENTS where ID_ROOT_L0=" <<this->GetID_ROOT() <<";";
7191     //
7192     pResult = conn->Query(myquery.str().c_str());
7193     //
7194     Row = pResult->Next();
7195     //
7196     if ( !Row ){
7197     if ( IsDebug() ) printf(" No run in the GL_RUN_FRAGMENTS table for this file \n");
7198     } else {
7199     if ( IsDebug() ) printf(" Deleting run fragments from GL_RUN_FRAGMENTS table \n");
7200     while ( Row ){
7201     if ( IsDebug() ) printf(" del run %u \n",(UInt_t)atoll(Row->GetField(0)));
7202     myquery.str("");
7203     myquery << " DELETE FROM GL_RUN_FRAGMENTS where ID=" << Row->GetField(0) <<";";
7204     conn->Query(myquery.str().c_str());
7205     drun++;
7206     Row = pResult->Next();
7207     };
7208     };
7209     //
7210     if ( IsDebug() ) printf(" Deleted %u run(s) from GL_RUN_FRAGMENTS table \n",drun);
7211     //
7212     //
7213     //
7214     delete delrun;
7215     //
7216     };
7217    
7218    
7219     /**
7220     *
7221     * Rearrange calibration tables
7222     *
7223     **/
7224 mocchiut 1.10 void PamelaDBOperations::RemoveFILES(UInt_t idtsy){
7225 mocchiut 1.1 stringstream myquery;
7226     //
7227     myquery.str("");
7228     myquery << " DELETE FROM GL_RAW WHERE ID=" <<this->GetID_RAW() <<";";
7229     //
7230     if ( IsDebug() ) printf(" query is \n %s \n",myquery.str().c_str());
7231     //
7232     conn->Query(myquery.str().c_str());
7233     //
7234 mocchiut 1.10 myquery.str("");
7235     myquery << " DELETE FROM GL_ROOT WHERE ID=" <<this->GetID_ROOT() <<";";
7236     //
7237     if ( IsDebug() ) printf(" query is \n %s \n",myquery.str().c_str());
7238     //
7239     conn->Query(myquery.str().c_str()); //
7240     //
7241     if ( !chewbacca ){
7242     myquery.str("");
7243     myquery << " DELETE FROM GL_TIMESYNC WHERE ID=" << idtsy <<";";
7244     //
7245     if ( IsDebug() ) printf(" query is \n %s \n",myquery.str().c_str());
7246     //
7247     conn->Query(myquery.str().c_str());
7248     };
7249     //
7250 mocchiut 1.1 };
7251    
7252     /**
7253     *
7254     * Rearrange calibration tables
7255     *
7256     **/
7257     void PamelaDBOperations::RemoveCALIBS(){
7258     TSQLResult *pResult;
7259     TSQLRow *Row;
7260     stringstream myquery;
7261     //
7262     //
7263     // Calorimeter
7264     //
7265     for (Int_t section = 0; section < 4; section++){
7266     myquery.str("");
7267     myquery << " SELECT MIN(FROM_TIME),MAX(TO_TIME) FROM GL_CALO_CALIB WHERE ID_ROOT_L0="<< this->GetID_ROOT() <<" AND ";
7268     myquery << " SECTION=" << section << ";";
7269     //
7270     pResult = conn->Query(myquery.str().c_str());
7271     //
7272     Row = pResult->Next();
7273     if( !Row->GetField(0) || !Row->GetField(1) ){
7274     //
7275     if ( IsDebug() ) printf(" NO CALO CALIBRATION SECTION %i ASSOCIATED TO THIS FILE! \n",section);
7276     //
7277     } else {
7278     //
7279     myquery.str("");
7280     myquery << " UPDATE GL_CALO_CALIB SET TO_TIME=" << Row->GetField(1);
7281     myquery << " WHERE TO_TIME="<< Row->GetField(0) << " AND ";
7282     myquery << " SECTION=" << section << ";";
7283     //
7284     pResult = conn->Query(myquery.str().c_str());
7285     //
7286     if( !pResult ){
7287     //
7288     if ( IsDebug() ) printf(" ERROR DELETING CALO CALIBRATIONS \n");
7289     //
7290     throw -4;
7291     //
7292     };
7293     //
7294     };
7295     };
7296     Bool_t OLDDB = false;
7297     for (Int_t section = 0; section < 4; section++){
7298     myquery.str("");
7299     myquery << " SELECT MIN(FROM_TIME),MAX(TO_TIME) FROM GL_CALOPULSE_CALIB WHERE ID_ROOT_L0="<< this->GetID_ROOT() <<" AND ";
7300     myquery << " SECTION=" << section << ";";
7301     //
7302     pResult = conn->Query(myquery.str().c_str());
7303     //
7304     if ( conn->GetErrorCode() ){
7305     printf(" Section %i : warning, old databse structure no GL_CALOPULSE_CALIB table!\n",section);
7306     OLDDB=true;
7307     } else {
7308     Row = pResult->Next();
7309     if( !Row->GetField(0) || !Row->GetField(1) ){
7310     //
7311     if ( IsDebug() ) printf(" NO PULSE CALO CALIBRATION SECTION %i ASSOCIATED TO THIS FILE! \n",section);
7312     //
7313     } else {
7314     //
7315     myquery.str("");
7316     myquery << " UPDATE GL_CALOPULSE_CALIB SET TO_TIME=" << Row->GetField(1);
7317     myquery << " WHERE TO_TIME="<< Row->GetField(0) << " AND ";
7318     myquery << " SECTION=" << section << ";";
7319     //
7320     pResult = conn->Query(myquery.str().c_str());
7321     //
7322     if( !pResult ){
7323     //
7324     if ( IsDebug() ) printf(" ERROR DELETING CALO PULSE CALIBRATIONS \n");
7325     //
7326     throw -4;
7327     //
7328     };
7329     //
7330     };
7331     };
7332     };
7333     myquery.str("");
7334     myquery << " DELETE FROM GL_CALO_CALIB WHERE ID_ROOT_L0=" << this->GetID_ROOT() << ";";
7335     //
7336     pResult = conn->Query(myquery.str().c_str());
7337     //
7338     if( !pResult ){
7339     //
7340     if ( IsDebug() ) printf(" ERROR DELETING CALO CALIBRATIONS \n");
7341     //
7342     throw -4;
7343     //
7344     };
7345     //
7346     myquery.str("");
7347     myquery << " DELETE FROM GL_CALOPULSE_CALIB WHERE ID_ROOT_L0=" << this->GetID_ROOT() << ";";
7348     //
7349     pResult = conn->Query(myquery.str().c_str());
7350     if ( IsDebug() ) printf(" Delete from GL_CALOPULSE_CALIB query is %s \n",myquery.str().c_str());
7351     if ( !OLDDB ){
7352     //
7353     if( !pResult ){
7354     //
7355     if ( IsDebug() ) printf(" ERROR DELETING PULSE CALO CALIBRATIONS \n");
7356     //
7357     throw -4;
7358     //
7359     };
7360     };
7361     //
7362     // Tracker
7363     //
7364     myquery.str("");
7365     myquery << " SELECT MIN(FROM_TIME),MAX(TO_TIME) FROM GL_TRK_CALIB WHERE ID_ROOT_L0="<< this->GetID_ROOT() <<";";
7366     //
7367     pResult = conn->Query(myquery.str().c_str());
7368     //
7369     Row = pResult->Next();
7370     if( !Row->GetField(0) || !Row->GetField(1) ){
7371     //
7372     if ( IsDebug() ) printf(" NO TRK CALIBRATION ASSOCIATED TO THIS FILE! \n");
7373     //
7374     } else {
7375     //
7376     myquery.str("");
7377     myquery << " UPDATE GL_TRK_CALIB SET TO_TIME=" << Row->GetField(1);
7378     myquery << " WHERE TO_TIME="<< Row->GetField(0) << ";";
7379     //
7380     pResult = conn->Query(myquery.str().c_str());
7381     //
7382     if( !pResult ){
7383     //
7384     if ( IsDebug() ) printf(" ERROR DELETING TRK CALIBRATIONS \n");
7385     //
7386     throw -4;
7387     //
7388     };
7389     //
7390     myquery.str("");
7391     myquery << " DELETE FROM GL_TRK_CALIB WHERE ID_ROOT_L0=" << this->GetID_ROOT() << ";";
7392     //
7393     pResult = conn->Query(myquery.str().c_str());
7394     //
7395     if( !pResult ){
7396     //
7397     if ( IsDebug() ) printf(" ERROR DELETING TRK CALIBRATIONS \n");
7398     //
7399     throw -4;
7400     //
7401     };
7402     };
7403     //
7404     //
7405     // S4
7406     //
7407     myquery.str("");
7408     myquery << " SELECT MIN(FROM_TIME),MAX(TO_TIME) FROM GL_S4_CALIB WHERE ID_ROOT_L0="<< this->GetID_ROOT() <<";";
7409     //
7410     pResult = conn->Query(myquery.str().c_str());
7411     //
7412     Row = pResult->Next();
7413     if( !Row->GetField(0) || !Row->GetField(1) ){
7414     //
7415     if ( IsDebug() ) printf(" NO S4 CALIBRATION ASSOCIATED TO THIS FILE! \n");
7416     //
7417     } else {
7418     //
7419     myquery.str("");
7420     myquery << " UPDATE GL_S4_CALIB SET TO_TIME=" << Row->GetField(1);
7421     myquery << " WHERE TO_TIME="<< Row->GetField(0) << ";";
7422     //
7423     pResult = conn->Query(myquery.str().c_str());
7424     //
7425     if( !pResult ){
7426     //
7427     if ( IsDebug() ) printf(" ERROR DELETING S4 CALIBRATIONS \n");
7428     //
7429     throw -4;
7430     //
7431     };
7432     //
7433     myquery.str("");
7434     myquery << " DELETE FROM GL_S4_CALIB WHERE ID_ROOT_L0=" << this->GetID_ROOT() << ";";
7435     //
7436     pResult = conn->Query(myquery.str().c_str());
7437     //
7438     if( !pResult ){
7439     //
7440     if ( IsDebug() ) printf(" ERROR DELETING S4 CALIBRATIONS \n");
7441     //
7442     throw -4;
7443     //
7444     };
7445     //
7446     };
7447     };
7448    
7449     /**
7450     *
7451     * Rearrange calibration tables
7452     *
7453     **/
7454 pam-fi 1.4 UInt_t PamelaDBOperations::ValidateTrkCalib( CalibTrk1Event* caltrk, EventHeader *eh , TFile *file){
7455    
7456     if(!caltrk) return 0;
7457    
7458     if ( IsDebug() ) cout << "ValidateTrkCalib:"<<endl;
7459    
7460     UInt_t validate = 1;
7461     Int_t vorder[]={5,5,3,3,4,4,2,2,1,1,0,0};
7462     UInt_t timeaftercalib=120000; //2000;
7463     TString classname = caltrk->GetName();
7464    
7465     // ----------------------------------
7466     // Check CRCs and failed calibrations
7467     // ----------------------------------
7468     for(Int_t ipkt=0; ipkt<6; ipkt++){
7469     if(caltrk->DSPnumber[ipkt]>0 && caltrk->DSPnumber[ipkt]<=12){
7470     if( caltrk->crc_hcal[ipkt] ){
7471     // if(IsDebug())cout<<"(CRC Header)";
7472     validate = 0;
7473     if(IsDebug())cout <<endl<<" *** CRC *** (header DSPn "<<caltrk->DSPnumber[ipkt]<<")";
7474    
7475     }
7476     for(Int_t ilad=0; ilad<3; ilad++)if( caltrk->crc_cal[ipkt][ilad] ){
7477     // if(IsDebug())cout<<"(CRC Pkt-"<<ilad<<")";
7478     if(IsDebug())cout <<endl<<" *** CRC *** (data DSPn "<<caltrk->DSPnumber[ipkt]<<" ladder "<<ilad<<")";
7479     validate = 0;
7480     }
7481     if( !(caltrk->ncalib_event[ipkt]==0 && caltrk->cal_flag[ipkt]==0) ){
7482     if(IsDebug())cout <<endl<<" *** FAILURE *** (data DSPn "<<caltrk->DSPnumber[ipkt]<<")";
7483     validate = 0;
7484     }
7485     }else{
7486     // validate=0;
7487     if(IsDebug())cout <<endl<<" *** DSPn *** ("<< caltrk->DSPnumber[ipkt] <<" @pkt "<<ipkt<<")";
7488     }
7489     }
7490    
7491     // -----------------------
7492     // Check missing packets:
7493     // -----------------------
7494     // Readout order:
7495     // ------------------
7496     // DSP packet board
7497     // ------------------
7498     // 12 0 1
7499     // 10 1 1
7500     // 8 2 1
7501     // 4 3 1
7502     // 6 4 1
7503     // 2 5 1
7504     // ------------------
7505     // 11 0 2
7506     // 9 1 2
7507     // 7 2 2
7508     // 3 3 2
7509     // 5 4 2
7510     // 1 5 2
7511     // ------------------
7512     // -------------------------------------------------
7513     // Check if it is first or second calibration packet
7514     // -------------------------------------------------
7515     UInt_t build=0;
7516     UInt_t base=0;
7517     UInt_t mask=0;
7518     if(classname.Contains("CalibTrk1Event")){
7519     base=12;
7520     mask=0x03F000;
7521     }
7522     if(classname.Contains("CalibTrk2Event")){
7523     base=18;
7524     mask=0xFC0000;
7525     }
7526     // ----------------------------------------------------
7527     // Count number of valid packets and set build variable
7528     // ----------------------------------------------------
7529     if(IsDebug())cout <<endl<< " DSP: ";
7530     Int_t npkts=0;
7531     for(Int_t ipkt=0; ipkt<6; ipkt++){
7532     if(caltrk->DSPnumber[ipkt]>0 && caltrk->DSPnumber[ipkt]<=12){
7533     if(IsDebug())cout <<" "<<caltrk->DSPnumber[ipkt];
7534     npkts++;
7535     build = build | ( 1<<(base+vorder[caltrk->DSPnumber[ipkt]-1]) );
7536     // cout << caltrk->DSPnumber[ipkt]
7537     };
7538     }
7539     if(IsDebug())cout << " ==> "<< hex << build << dec;
7540     // ----------------------------------------------------
7541     // If the number of valid packets is 6, ok exit...
7542     // ----------------------------------------------------
7543     if( npkts==6 ){
7544     return validate; // exit
7545     }
7546     ////////////////////////////////////////////////////////
7547     // ...otherwise there might be some missing packets
7548     //
7549     // In this case check the acq configuration
7550     // (some DSPs might be excluded from acquisition)
7551     ////////////////////////////////////////////////////////
7552    
7553     if(!eh || !file || (file&&file->IsZombie()) ){
7554     if ( IsDebug() )cout << " *** MISSING VIEW *** eh="<<eh<<" file="<<file<<" cannot validate"<<endl;
7555     return (0);
7556     }
7557    
7558     // -----------------------------------------------
7559     // retrieve the first run header after calib
7560     // -----------------------------------------------
7561    
7562     PacketType *pctp;
7563     EventCounter *cod;
7564     cod = eh->GetCounter();
7565     Int_t irun = cod->Get(pctp->RunHeader);
7566     TTree *rh=(TTree*)file->Get("RunHeader");
7567     if ( !rh || rh->IsZombie() ) throw -17;
7568     if( rh->GetEntries() <= irun ){
7569     if ( IsDebug() ) cout << " *** MISSING-PKT *** no runs after calib (1) -- cannot validate :-( "<<endl;
7570     return 0; // :-(
7571     }
7572     RunHeaderEvent *run = 0;
7573     EventHeader *hrun = 0;
7574     rh->SetBranchAddress("RunHeader", &run);
7575     rh->SetBranchAddress("Header", &hrun);
7576     rh->GetEntry(irun);
7577     if( OBT(hrun->GetPscuHeader()->GetOrbitalTime()) < OBT(eh->GetPscuHeader()->GetOrbitalTime())){
7578     if ( IsDebug() ) cout << " *** MISSING-PKT *** no runs after calib (2) -- cannot validate :-( "<<endl;
7579     return 0; // :-(
7580     }
7581    
7582     UInt_t dtime = OBT(hrun->GetPscuHeader()->GetOrbitalTime()) - OBT(eh->GetPscuHeader()->GetOrbitalTime());
7583     if( dtime > timeaftercalib ){
7584     if ( IsDebug() ) cout << " *** MISSING-PKT *** run after calib too far ( "<<dtime<<"ms ) -- cannot validate :-( "<<endl;
7585     return 0; // :-(
7586     }
7587    
7588     if ( IsDebug() ) cout <<endl<< " ACQ_BUILD_INFO ==> "<<hex<<(run->ACQ_BUILD_INFO & mask)<<dec;
7589    
7590     if( (run->ACQ_BUILD_INFO & mask) != build ){
7591     validate=0; // :-(
7592     cout <<endl<< " *** MISSING-PKT *** packet mismatch: ACQ_BUILD_INFO="<<hex<<(run->ACQ_BUILD_INFO&mask)<<" != "<<build<<dec;
7593     };
7594    
7595     return validate;
7596 mocchiut 1.1
7597 mocchiut 1.2
7598 pam-fi 1.4 }
7599 mocchiut 1.1
7600     /**
7601     *
7602     * Check the DB (only for overlapping runs at the moment)
7603     *
7604     **/
7605     UInt_t PamelaDBOperations::Check(){
7606 mocchiut 1.2 return(this->Check(0,0));
7607 mocchiut 1.1 }
7608    
7609     UInt_t PamelaDBOperations::Check(UInt_t from, UInt_t to){
7610     //
7611 mocchiut 1.2 if ( IsDebug() ) printf(" from %u to %u \n",from,to);
7612 mocchiut 1.1 //
7613     UInt_t test = 0;
7614     //
7615     UInt_t thisrht = 0;
7616     UInt_t thisrtt = 0;
7617     UInt_t thisid = 0;
7618     UInt_t prevrht = 0;
7619     UInt_t prevrtt = 0;
7620     UInt_t previd = 0;
7621     //
7622     UInt_t prevl0id = 0;
7623     UInt_t thisl0id = 0;
7624     //
7625     stringstream oss;
7626     TSQLResult *result = 0;
7627     TSQLRow *row = 0;
7628     TSQLResult *result2 = 0;
7629     TSQLRow *row2 = 0;
7630     TSQLResult *result3 = 0;
7631     TSQLRow *row3 = 0;
7632     oss.str("");
7633     oss << "SELECT ID,ID_ROOT_L0,RUNHEADER_TIME,RUNTRAILER_TIME,NEVENTS FROM GL_RUN order by RUNHEADER_TIME asc;";
7634     // oss << "SELECT ID,RUNHEADER_TIME,RUNTRAILER_TIME FROM GL_RUN where ID>10170 and ID<10190 order by RUNHEADER_TIME asc;";
7635     result = conn->Query(oss.str().c_str());
7636     //
7637     if ( !result ) throw -4;;
7638     //
7639     row = result->Next();
7640     UInt_t nid = 0;
7641     //
7642     while ( row ){
7643     nid++;
7644     if ( !(nid%1000) && nid ) printf(" %iK run scanned \n",nid/1000);
7645     thisid = (UInt_t)atoll(row->GetField(0));
7646     thisl0id = (UInt_t)atoll(row->GetField(1));
7647     thisrht = (UInt_t)atoll(row->GetField(2));
7648     thisrtt = (UInt_t)atoll(row->GetField(3));
7649     //
7650     if ( from > 0 && nid <= from ) goto ss;
7651     if ( to > 0 && nid >= to ) goto ss;
7652 mocchiut 1.2 //
7653 mocchiut 1.1 if ( (UInt_t)atoll(row->GetField(4)) > 1 ){
7654     //
7655     //
7656     //
7657     oss.str("");
7658     oss << "SELECT ID,ID_ROOT_L0,RUNHEADER_TIME,RUNTRAILER_TIME FROM GL_RUN WHERE ID!="
7659     << thisid << " AND ( RUNHEADER_TIME="
7660     << thisrht << " OR RUNTRAILER_TIME="
7661     << thisrtt << " ) AND NEVENTS!=0 AND NEVENTS!=1 order by RUNHEADER_TIME asc;";
7662     result3 = conn->Query(oss.str().c_str());
7663     if ( IsDebug() ) printf(" query is %s \n",oss.str().c_str());
7664     if ( result3 ){
7665     //
7666     oss.str("");
7667     oss << "SELECT ID,ID_ROOT_L0,RUNHEADER_TIME,RUNTRAILER_TIME FROM GL_RUN WHERE ID!="
7668     << thisid << " AND RUNHEADER_TIME="
7669     << thisrht << " AND RUNTRAILER_TIME!="
7670     << thisrtt << " AND NEVENTS!=0 AND NEVENTS!=1 order by RUNHEADER_TIME asc;";
7671     result3 = conn->Query(oss.str().c_str());
7672     if ( IsDebug() ) printf(" query is %s \n",oss.str().c_str());
7673     if ( result3 ){
7674     row3 = result3->Next();
7675     //
7676     while ( row3 ){
7677     //
7678     // 2 runs with same runheader
7679     //
7680     printf(" CHECK n.4 RUNs %u and %u HAVE SAME RUNHEADER \n",thisid,(UInt_t)atoll(row3->GetField(0)));
7681     row3 = result3->Next();
7682     };
7683 mocchiut 1.2 // delete result3;
7684 mocchiut 1.1
7685     };
7686     //
7687     oss.str("");
7688     oss << "SELECT ID,ID_ROOT_L0,RUNHEADER_TIME,RUNTRAILER_TIME FROM GL_RUN WHERE ID!="
7689     << thisid << " AND RUNHEADER_TIME!="
7690     << thisrht << " AND RUNTRAILER_TIME="
7691     << thisrtt << " AND NEVENTS!=0 AND NEVENTS!=1 order by RUNHEADER_TIME asc;";
7692     result3 = conn->Query(oss.str().c_str());
7693     if ( IsDebug() ) printf(" query is %s \n",oss.str().c_str());
7694     if ( result3 ){
7695     row3 = result3->Next();
7696     //
7697     while ( row3 ){
7698     //
7699     // 2 runs with same runtrailer
7700     //
7701     printf(" CHECK n.5 RUNs %u and %u HAVE SAME RUNTRAILER \n",thisid,(UInt_t)atoll(row3->GetField(0)));
7702     row3 = result3->Next();
7703     };
7704 mocchiut 1.2 // delete result3;
7705 mocchiut 1.1 };
7706     //
7707     oss.str("");
7708     oss << "SELECT ID,ID_ROOT_L0,RUNHEADER_TIME,RUNTRAILER_TIME FROM GL_RUN WHERE ID!="
7709     << thisid << " AND RUNHEADER_TIME="
7710     << thisrht << " AND RUNTRAILER_TIME="
7711     << thisrtt << " AND ID_RUN_FRAG!="
7712     << thisid << " order by RUNHEADER_TIME asc;";
7713     result3 = conn->Query(oss.str().c_str());
7714     if ( result3 ){
7715     row3 = result3->Next();
7716     //
7717     while ( row3 ){
7718     //
7719     // duplicated run
7720     //
7721     printf(" CHECK n.7 RUNs %u and %u HAVE SAME RUNTRAILER AND RUNHEADER (ARE THE SAME?) \n",thisid,(UInt_t)atoll(row3->GetField(0)));
7722     row3 = result3->Next();
7723     };
7724 mocchiut 1.2 // delete result3;
7725 mocchiut 1.1
7726     };
7727     };
7728     //
7729     oss.str("");
7730     oss << "SELECT ID,ID_ROOT_L0,RUNHEADER_TIME,RUNTRAILER_TIME FROM GL_RUN WHERE ID!="
7731     << thisid << " AND RUNHEADER_TIME>"
7732     << thisrht << " AND RUNTRAILER_TIME<"
7733     << thisrtt << " order by RUNHEADER_TIME asc;";
7734     result3 = conn->Query(oss.str().c_str());
7735     if ( result3 ){
7736     row3 = result3->Next();
7737     //
7738     while ( row3 ){
7739     //
7740     // run contained in the checked one
7741     //
7742     printf(" CHECK n.6 RUN %u CONTAINS RUN %u \n",thisid,(UInt_t)atoll(row3->GetField(0)));
7743     row3 = result3->Next();
7744     };
7745 mocchiut 1.2 // delete result3;
7746 mocchiut 1.1 };
7747     //
7748     };
7749     //
7750     // if ( thisrht < prevrtt || thisrtt < prevrht || thisrht > thisrtt && !(!prevrht && !prevrtt &&!previd) ){
7751     // if ( (thisrht < prevrtt || thisrtt < prevrht || thisrht > thisrtt) && (thisrht != prevrht) ){
7752     if ( (thisrht < prevrtt) && (thisrht != prevrht) ){
7753     if ( IsDebug() ) printf(" IDprev %u ID %u prevrht %u prevrtt %u thisrht %u thisrtt %u \n",previd,thisid,prevrht,prevrtt,thisrht,thisrtt);
7754     printf(" CHECK n.1 TIME SCREW of %i s AROUND RUNs %u and %u \n",(thisrht-prevrtt),previd,thisid);
7755     TString prevf = "";
7756     TString thisf = "";
7757     oss.str("");
7758     oss << "SELECT NAME FROM GL_ROOT where ID=" << (UInt_t)prevl0id <<";";
7759     result2 = conn->Query(oss.str().c_str());
7760     if ( !result2 ) throw -4;;
7761     row2 = result2->Next();
7762     prevf = (TString)row2->GetField(0);
7763     oss.str("");
7764     oss << "SELECT NAME FROM GL_ROOT where ID=" << (UInt_t)thisl0id <<";";
7765     result2 = conn->Query(oss.str().c_str());
7766     if ( !result2 ) throw -4;;
7767     row2 = result2->Next();
7768     thisf = (TString)row2->GetField(0);
7769     if ( IsDebug() ) printf(" ==> files %s and %s \n",prevf.Data(),thisf.Data());
7770     test = 1;
7771 mocchiut 1.2 // delete result2;
7772 mocchiut 1.1 };
7773     //
7774     if ( (thisrtt < prevrht) && (thisrht != prevrht) ){
7775     if ( IsDebug() ) printf(" IDprev %u ID %u prevrht %u prevrtt %u thisrht %u thisrtt %u \n",previd,thisid,prevrht,prevrtt,thisrht,thisrtt);
7776     printf(" CHECK n.2 TIME SCREW of %i s AROUND RUNs %u and %u \n",(thisrtt-prevrht),previd,thisid);
7777     TString prevf = "";
7778     TString thisf = "";
7779     oss.str("");
7780     oss << "SELECT NAME FROM GL_ROOT where ID=" << (UInt_t)prevl0id <<";";
7781     result2 = conn->Query(oss.str().c_str());
7782     if ( !result2 ) throw -4;
7783     row2 = result2->Next();
7784     prevf = (TString)row2->GetField(0);
7785     oss.str("");
7786     oss << "SELECT NAME FROM GL_ROOT where ID=" << (UInt_t)thisl0id <<";";
7787     result2 = conn->Query(oss.str().c_str());
7788     if ( !result2 ) throw -4;;
7789     row2 = result2->Next();
7790     thisf = (TString)row2->GetField(0);
7791     if ( IsDebug() ) printf(" ==> files %s and %s \n",prevf.Data(),thisf.Data());
7792     test = 1;
7793 mocchiut 1.2 // delete result2;
7794 mocchiut 1.1 };
7795     //
7796     if ( (thisrht > thisrtt) && (thisrht != prevrht) ){
7797     if ( IsDebug() ) printf(" IDprev %u ID %u prevrht %u prevrtt %u thisrht %u thisrtt %u \n",previd,thisid,prevrht,prevrtt,thisrht,thisrtt);
7798     printf(" CHECK n.3 TIME SCREW of %i s AROUND RUNs %u and %u \n",(thisrht-thisrtt),previd,thisid);
7799     TString prevf = "";
7800     TString thisf = "";
7801     oss.str("");
7802     oss << "SELECT NAME FROM GL_ROOT where ID=" << (UInt_t)prevl0id <<";";
7803     result2 = conn->Query(oss.str().c_str());
7804     if ( !result2 ) throw -4;;
7805     row2 = result2->Next();
7806     prevf = (TString)row2->GetField(0);
7807     oss.str("");
7808     oss << "SELECT NAME FROM GL_ROOT where ID=" << (UInt_t)thisl0id <<";";
7809     result2 = conn->Query(oss.str().c_str());
7810     if ( !result2 ) throw -4;;
7811     row2 = result2->Next();
7812     thisf = (TString)row2->GetField(0);
7813     if ( IsDebug() ) printf(" ==> files %s and %s \n",prevf.Data(),thisf.Data());
7814     test = 1;
7815 mocchiut 1.2 // delete result2;
7816 mocchiut 1.1 };
7817 mocchiut 1.2 ss:
7818 mocchiut 1.1 //
7819     prevrht = thisrht;
7820     prevrtt = thisrtt;
7821     previd = thisid;
7822     prevl0id = thisl0id;
7823     row = result->Next();
7824 mocchiut 1.2 // if ( result2 ) delete result2;
7825     // if ( result3 ) delete result3;
7826 mocchiut 1.1 };
7827     //
7828     return(test);
7829     //
7830     };

  ViewVC Help
Powered by ViewVC 1.1.23