/[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.7 - (hide annotations) (download)
Tue Nov 4 13:19:36 2008 UTC (16 years, 2 months ago) by mocchiut
Branch: MAIN
Changes since 1.6: +11 -8 lines
Bugs which lead to error -80 and -100 fixed

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

  ViewVC Help
Powered by ViewVC 1.1.23