/[PAMELA software]/DarthVader/S4Level2/src/S4Core.cpp
ViewVC logotype

Diff of /DarthVader/S4Level2/src/S4Core.cpp

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.17 by mocchiut, Thu Sep 6 12:49:32 2007 UTC revision 1.23 by mocchiut, Fri Nov 28 09:05:22 2008 UTC
# Line 71  TArrayD *S4_paramfit(UInt_t atime, TSQLS Line 71  TArrayD *S4_paramfit(UInt_t atime, TSQLS
71    //    //
72    GL_S4_CALIB *glS4calib = new GL_S4_CALIB();    GL_S4_CALIB *glS4calib = new GL_S4_CALIB();
73    //    //
74    if ( !dbc->IsConnected() ) throw -504;    //  if ( !dbc->IsConnected() ) throw -504;
75    Int_t s4sig = glS4calib->Query_GL_S4_CALIB(atime, dbc);    Int_t s4sig = glS4calib->Query_GL_S4_CALIB(atime, dbc);
76    if ( s4sig != -57 && s4sig < 0 ){    if ( s4sig != -57 && s4sig < 0 ){
77      parametri->AddAt(0.,0);      parametri->AddAt(0.,0);
# Line 81  TArrayD *S4_paramfit(UInt_t atime, TSQLS Line 81  TArrayD *S4_paramfit(UInt_t atime, TSQLS
81    if ( s4sig < 0 ) throw s4sig;    if ( s4sig < 0 ) throw s4sig;
82    //    //
83    GL_ROOT *glroot = new GL_ROOT();    GL_ROOT *glroot = new GL_ROOT();
84    if ( !dbc->IsConnected() ) throw -504;    //  if ( !dbc->IsConnected() ) throw -504;
85    glroot->Query_GL_ROOT(glS4calib->ID_ROOT_L0,dbc);    glroot->Query_GL_ROOT(glS4calib->ID_ROOT_L0,dbc);
86    //    //
87    stringstream ftmpname;    stringstream ftmpname;
# Line 163  TArrayD *S4_paramfit(UInt_t atime, TSQLS Line 163  TArrayD *S4_paramfit(UInt_t atime, TSQLS
163  // CORE ROUTINE  // CORE ROUTINE
164  //  //
165  //  //
166  int S4Core(UInt_t run, TFile *file, TSQLServer *dbc, Int_t S4argc, char *S4argv[]){  int S4Core(UInt_t run, TFile *file,GL_TABLES *glt, Int_t S4argc, char *S4argv[]){
167    //    //
168    // Set these to true to have a verbose output.    // Set these to true to have a verbose output.
169    //    //
# Line 478  int S4Core(UInt_t run, TFile *file, TSQL Line 478  int S4Core(UInt_t run, TFile *file, TSQL
478      //      //
479      // prepare the timesync for the db      // prepare the timesync for the db
480      //      //
481        TString host = glt->CGetHost();
482        TString user = glt->CGetUser();
483        TString psw = glt->CGetPsw();
484        TSQLServer *dbc = TSQLServer::Connect(host.Data(),user.Data(),psw.Data());    
485      if ( !dbc->IsConnected() ) throw -504;      if ( !dbc->IsConnected() ) throw -504;
486        stringstream myquery;
487        myquery.str("");
488        myquery << "SET time_zone='+0:00'";
489        dbc->Query(myquery.str().c_str());
490      dbtime = new GL_TIMESYNC(runinfo->ID_ROOT_L0,"ID",dbc);      dbtime = new GL_TIMESYNC(runinfo->ID_ROOT_L0,"ID",dbc);
491      //      //
492      // Search in the DB the path and name of the LEVEL0 file to be processed.      // Search in the DB the path and name of the LEVEL0 file to be processed.
493      //      //
494      if ( !dbc->IsConnected() ) throw -504;      //    if ( !dbc->IsConnected() ) throw -504;
495      glroot->Query_GL_ROOT(runinfo->ID_ROOT_L0,dbc);      glroot->Query_GL_ROOT(runinfo->ID_ROOT_L0,dbc);
496      //      //
497      ftmpname.str("");      ftmpname.str("");
# Line 501  int S4Core(UInt_t run, TFile *file, TSQL Line 509  int S4Core(UInt_t run, TFile *file, TSQL
509        printf(" %i events to be processed for run %u: from %u to %u \n\n",totevent,idRun,runinfo->EV_FROM,(runinfo->EV_FROM+totevent));        printf(" %i events to be processed for run %u: from %u to %u \n\n",totevent,idRun,runinfo->EV_FROM,(runinfo->EV_FROM+totevent));
510      }      }
511      //      //
512        //    if ( !totevent ) goto closeandexit;
513        //
514      // Open Level0 file      // Open Level0 file
515      //      //
516      l0File = new TFile(fname.Data());      l0File = new TFile(fname.Data());
# Line 537  int S4Core(UInt_t run, TFile *file, TSQL Line 547  int S4Core(UInt_t run, TFile *file, TSQL
547      //      //
548      nevents = l0S4->GetEntries();      nevents = l0S4->GetEntries();
549      //      //
550      if ( nevents < 1 ) {      if ( nevents < 1 && totevent ) {
551        if ( debug ) printf(" S4 - ERROR: Level0 file is empty\n\n");        if ( debug ) printf(" S4 - ERROR: Level0 file is empty\n\n");
552        l0File->Close();        l0File->Close();
553        code = -11;        code = -11;
554        goto closeandexit;        goto closeandexit;
555      };      };
556      //      //
557      if ( runinfo->EV_TO > nevents-1 ) {      if ( runinfo->EV_TO > nevents-1 && totevent ) {
558        if ( debug ) printf(" S4 - ERROR: too few entries in the S4 tree\n");        if ( debug ) printf(" S4 - ERROR: too few entries in the S4 tree\n");
559        l0File->Close();        l0File->Close();
560        code = -12;        code = -12;
# Line 568  int S4Core(UInt_t run, TFile *file, TSQL Line 578  int S4Core(UInt_t run, TFile *file, TSQL
578      //      //
579      if (verbose) printf("\n Ready to start! \n\n Processed events: \n\n");      if (verbose) printf("\n Ready to start! \n\n Processed events: \n\n");
580      //      //
581        if ( dbc ){
582          dbc->Close();
583          //      delete dbc;
584        };
585        //
586      for ( re = runinfo->EV_FROM; re < (runinfo->EV_FROM+runinfo->NEVENTS); re++){      for ( re = runinfo->EV_FROM; re < (runinfo->EV_FROM+runinfo->NEVENTS); re++){
587        //        //
588        if ( procev%1000 == 0 && procev > 0 && verbose ) printf(" %iK \n",procev/1000);          if ( procev%1000 == 0 && procev > 0 && verbose ) printf(" %iK \n",procev/1000);  
# Line 581  int S4Core(UInt_t run, TFile *file, TSQL Line 596  int S4Core(UInt_t run, TFile *file, TSQL
596        //        //
597        // paranoid check        // paranoid check
598        //        //
599        if ( (atime > runinfo->RUNTRAILER_TIME) || (atime < runinfo->RUNHEADER_TIME)  ) {        if ( (atime > (runinfo->RUNTRAILER_TIME+1)) || (atime < (runinfo->RUNHEADER_TIME-1))  ) {
600          if (verbose) printf(" S4 - WARNING: event at time outside the run time window, skipping it\n");          if (verbose) printf(" S4 - WARNING: event at time outside the run time window, skipping it\n");
601          goto jumpev;          goto jumpev;
602        };        };

Legend:
Removed from v.1.17  
changed lines
  Added in v.1.23

  ViewVC Help
Powered by ViewVC 1.1.23