/[PAMELA software]/DarthVader/ToFLevel2/src/ToFLevel2.cpp
ViewVC logotype

Diff of /DarthVader/ToFLevel2/src/ToFLevel2.cpp

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

revision 1.25 by pamelats, Wed Apr 15 10:05:22 2009 UTC revision 1.28 by mocchiut, Mon Dec 28 10:22:39 2009 UTC
# Line 11  Line 11 
11  #include <ToFLevel2.h>  #include <ToFLevel2.h>
12  using namespace std;  using namespace std;
13  ClassImp(ToFPMT);  ClassImp(ToFPMT);
14    ClassImp(ToFdEdx);
15    ClassImp(ToFGeom);
16  ClassImp(ToFTrkVar);  ClassImp(ToFTrkVar);
17  ClassImp(ToFLevel2);  ClassImp(ToFLevel2);
18    
# Line 1147  Int_t ToFLevel2::Process(TrkLevel2 *trk, Line 1149  Int_t ToFLevel2::Process(TrkLevel2 *trk,
1149    //    //
1150    // Copiare qui qualcosa di simile a calonuclei per evitare di riprocessare sempre tutto    // Copiare qui qualcosa di simile a calonuclei per evitare di riprocessare sempre tutto
1151    //    //
1152      printf("\n\n\n ERROR: NOT IMPLEMENTED ANYMORE, write Emiliano if you need this method (Emiliano.Mocchiutti@ts.infn.it) \n\n\n");
1153      return(-1);
1154      //   //
1155      //   // structures to communicate with F77
1156      //   //
1157      //   extern struct ToFInput  tofinput_;
1158    //   extern struct ToFOutput tofoutput_;
1159    //   //
1160    //   // DB connection
1161    //   //
1162    //   TString host;
1163    //   TString user;
1164    //   TString psw;
1165    //   const char *pamdbhost=gSystem->Getenv("PAM_DBHOST");
1166    //   const char *pamdbuser=gSystem->Getenv("PAM_DBUSER");
1167    //   const char *pamdbpsw=gSystem->Getenv("PAM_DBPSW");
1168    //   if ( !pamdbhost ) pamdbhost = "";
1169    //   if ( !pamdbuser ) pamdbuser = "";
1170    //   if ( !pamdbpsw ) pamdbpsw = "";
1171    //   if ( strcmp(pamdbhost,"") ) host = pamdbhost;
1172    //   if ( strcmp(pamdbuser,"") ) user = pamdbuser;
1173    //   if ( strcmp(pamdbpsw,"") ) psw = pamdbpsw;
1174    //   //
1175    //   //
1176    //   TSQLServer *dbc = TSQLServer::Connect(host.Data(),user.Data(),psw.Data());
1177    //   if ( !dbc->IsConnected() ) return 1;
1178    //   stringstream myquery;
1179    //   myquery.str("");
1180    //   myquery << "SET time_zone='+0:00'";
1181    //   dbc->Query(myquery.str().c_str());
1182    //   GL_PARAM *glparam = new GL_PARAM();
1183    //   glparam->Query_GL_PARAM(1,1,dbc); // parameters stored in DB in GL_PRAM table
1184    //   trk->LoadField(glparam->PATH+glparam->NAME);
1185    //   //
1186    //   Bool_t defcal = true;
1187    //   Int_t error=glparam->Query_GL_PARAM(run->RUNHEADER_TIME,201,dbc); // parameters stored in DB in GL_PRAM table
1188    //   if ( error<0 ) {
1189    //     return(1);
1190    //   };
1191    //   printf(" Reading ToF parameter file: %s \n",(glparam->PATH+glparam->NAME).Data());
1192    //   if ( (UInt_t)glparam->TO_TIME != (UInt_t)4294967295UL ) defcal = false;
1193    //   //
1194    //   Int_t nlen = (Int_t)(glparam->PATH+glparam->NAME).Length();
1195    //   rdtofcal((char *)(glparam->PATH+glparam->NAME).Data(),&nlen);
1196    //   //
1197    //   Int_t adc[4][12];
1198    //   Int_t tdc[4][12];
1199    //   Float_t tdcc[4][12];
1200    //   //
1201    //   // process tof data
1202    //   //
1203    //   for (Int_t hh=0; hh<12;hh++){
1204    //     for (Int_t kk=0; kk<4;kk++){
1205    //            adc[kk][hh] = 4095;
1206    //            tdc[kk][hh] = 4095;
1207    //            tdcc[kk][hh] = 4095.;
1208    //            tofinput_.adc[hh][kk] = 4095;
1209    //            tofinput_.tdc[hh][kk] = 4095;
1210    //     };
1211    //   };
1212    //   Int_t ntrkentry = 0;
1213    //   Int_t npmtentry = 0;
1214    //   Int_t gg = 0;
1215    //   Int_t hh = 0;
1216    //   Int_t adcf[48];
1217    //   memset(adcf, 0, 48*sizeof(Int_t));
1218    //   Int_t tdcf[48];
1219    //   memset(tdcf, 0, 48*sizeof(Int_t));
1220    //   for (Int_t pm=0; pm < this->ntrk() ; pm++){
1221    //      ToFTrkVar *ttf = this->GetToFTrkVar(pm);
1222    //      for ( Int_t nc=0; nc < ttf->npmttdc; nc++){
1223    //             if ( (ttf->tdcflag).At(nc) != 0 ) tdcf[(ttf->pmttdc).At(nc)] = 1;
1224    //      };
1225    //      for ( Int_t nc=0; nc < ttf->npmtadc; nc++){
1226    //             if ( (ttf->adcflag).At(nc) != 0 ) adcf[(ttf->pmtadc).At(nc)] = 1;
1227    //      };
1228    //   };
1229    //   //
1230    //   for (Int_t pm=0; pm < this->npmt() ; pm++){
1231    //      ToFPMT *pmt = this->GetToFPMT(pm);
1232    //      this->GetPMTIndex(pmt->pmt_id, gg, hh);
1233    //      if ( adcf[pmt->pmt_id] == 0 ){
1234    //              tofinput_.adc[gg][hh] = (int)pmt->adc;
1235    //              adc[hh][gg] = (int)pmt->adc;
1236    //      };
1237    //      if ( tdcf[pmt->pmt_id] == 0 ){
1238    //              tofinput_.tdc[gg][hh] = (int)pmt->tdc;
1239    //              tdc[hh][gg] = (int)pmt->tdc;
1240    //      };
1241    //      tdcc[hh][gg] = (float)pmt->tdc_tw;
1242    //      // Int_t pppid = this->GetPMTid(hh,gg);
1243    //      //      printf(" pm %i pmt_id %i pppid %i hh %i gg %i tdcc %f tdc %f adc %f \n",pm,pmt->pmt_id,pppid,hh,gg,pmt->tdc_tw,pmt->tdc,pmt->adc);
1244    //   };
1245    //   //
1246    //   Int_t unpackError = this->unpackError;
1247    //   //
1248    //   for (Int_t hh=0; hh<5;hh++){
1249    //      tofinput_.patterntrig[hh]=trg->patterntrig[hh];
1250    //   };
1251    //   //
1252    //   this->Clear();
1253    //   //
1254    //       Int_t pmt_id = 0;
1255    //       ToFPMT *t_pmt = new ToFPMT();
1256    //       if(!(this->PMT)) this->PMT = new TClonesArray("ToFPMT",12); //ELENA
1257    //       TClonesArray &tpmt = *this->PMT;
1258    //       ToFTrkVar *t_tof = new ToFTrkVar();
1259    //       if(!(this->ToFTrk)) this->ToFTrk = new TClonesArray("ToFTrkVar",2); //ELENA
1260    //       TClonesArray &t = *this->ToFTrk;
1261    //       //
1262    //       //
1263    //       // Here we have calibrated data, ready to be passed to the FORTRAN routine which will extract common and track-related  variables.
1264    //       //
1265    //       npmtentry = 0;
1266    //       //
1267    //       ntrkentry = 0;
1268    //       //
1269    //       // Calculate tracks informations from ToF alone
1270    //       //
1271    //       tofl2com();
1272    //       //
1273    //       memcpy(this->tof_j_flag,tofoutput_.tof_j_flag,6*sizeof(Int_t));
1274    //       //
1275    //       t_tof->trkseqno = -1;
1276    //       //
1277    //       // and now we must copy from the output structure to the level2 class:
1278    //       //
1279    //       t_tof->npmttdc = 0;
1280    //       //
1281    //       for (Int_t hh=0; hh<12;hh++){
1282    //         for (Int_t kk=0; kk<4;kk++){
1283    //           if ( tofoutput_.tofmask[hh][kk] != 0 ){
1284    //             pmt_id = this->GetPMTid(kk,hh);
1285    //             t_tof->pmttdc.AddAt(pmt_id,t_tof->npmttdc);
1286    //             t_tof->tdcflag.AddAt(tofoutput_.tdcflagtof[hh][kk],t_tof->npmttdc); // gf: Jan 09/07
1287    //             t_tof->npmttdc++;
1288    //           };
1289    //         };
1290    //       };
1291    //       for (Int_t kk=0; kk<13;kk++){
1292    //         t_tof->beta[kk] = tofoutput_.betatof_a[kk];
1293    //       }
1294    //       //
1295    //       t_tof->npmtadc = 0;
1296    //       for (Int_t hh=0; hh<12;hh++){
1297    //         for (Int_t kk=0; kk<4;kk++){
1298    //           if ( tofoutput_.adctof_c[hh][kk] < 1000 ){
1299    //             t_tof->dedx.AddAt(tofoutput_.adctof_c[hh][kk],t_tof->npmtadc);
1300    //             pmt_id = this->GetPMTid(kk,hh);
1301    //             t_tof->pmtadc.AddAt(pmt_id,t_tof->npmtadc);
1302    //             t_tof->adcflag.AddAt(tofoutput_.adcflagtof[hh][kk],t_tof->npmtadc); // gf: Jan 09/07
1303    //             t_tof->npmtadc++;
1304    //           };
1305    //         };
1306    //       };
1307    //       //
1308    //       memcpy(t_tof->xtofpos,tofoutput_.xtofpos,sizeof(t_tof->xtofpos));
1309    //       memcpy(t_tof->ytofpos,tofoutput_.ytofpos,sizeof(t_tof->ytofpos));
1310    //       memcpy(t_tof->xtr_tof,tofoutput_.xtr_tof,sizeof(t_tof->xtr_tof));
1311    //       memcpy(t_tof->ytr_tof,tofoutput_.ytr_tof,sizeof(t_tof->ytr_tof));
1312    //       //
1313    //       new(t[ntrkentry]) ToFTrkVar(*t_tof);
1314    //       ntrkentry++;
1315    //       t_tof->Clear();
1316    //       //
1317    //       //
1318    //       //
1319    //       t_pmt->Clear();
1320    //       //
1321    //       for (Int_t hh=0; hh<12;hh++){
1322    //         for (Int_t kk=0; kk<4;kk++){
1323    //          // new WM
1324    //           if ( tofoutput_.tdc_c[hh][kk] < 4095 || adc[kk][hh] < 4095  || tdc[kk][hh] < 4095 ){
1325    // //          if ( tdcc[kk][hh] < 4095. || adc[kk][hh] < 4095  || tdc[kk][hh] < 4095 ){
1326    //             //
1327    //             t_pmt->pmt_id = this->GetPMTid(kk,hh);
1328    //             t_pmt->tdc_tw = tofoutput_.tdc_c[hh][kk];
1329    //             t_pmt->adc = (Float_t)adc[kk][hh];
1330    //             t_pmt->tdc = (Float_t)tdc[kk][hh];
1331    //             //
1332    //             new(tpmt[npmtentry]) ToFPMT(*t_pmt);
1333    //             npmtentry++;
1334    //             t_pmt->Clear();
1335    //           };
1336    //         };
1337    //       };
1338    //       //
1339    //       // Calculate track-related variables
1340    //       //
1341    //       if ( trk->ntrk() > 0 ){
1342    //         //
1343    //         // We have at least one track
1344    //         //
1345    //         //
1346    //         // Run over tracks
1347    //         //
1348    //         for(Int_t nt=0; nt < trk->ntrk(); nt++){
1349    //           //
1350    //           TrkTrack *ptt = trk->GetStoredTrack(nt);
1351    //           //
1352    //           // Copy the alpha vector in the input structure
1353    //           //
1354    //           for (Int_t e = 0; e < 5 ; e++){
1355    //             tofinput_.al_pp[e] = ptt->al[e];
1356    //           };
1357    //           //
1358    //           // Get tracker related variables for this track
1359    //           //
1360    //           toftrk();
1361    //           //
1362    //           // Copy values in the class from the structure (we need to use a temporary class to store variables).
1363    //           //
1364    //           t_tof->npmttdc = 0;
1365    //           for (Int_t hh=0; hh<12;hh++){
1366    //             for (Int_t kk=0; kk<4;kk++){
1367    //               if ( tofoutput_.tofmask[hh][kk] != 0 ){
1368    //                 pmt_id = this->GetPMTid(kk,hh);
1369    //                 t_tof->pmttdc.AddAt(pmt_id,t_tof->npmttdc);
1370    //                 t_tof->tdcflag.AddAt(tofoutput_.tdcflag[hh][kk],t_tof->npmttdc); // gf: Jan 09/07
1371    //                 t_tof->npmttdc++;
1372    //               };
1373    //             };
1374    //           };
1375    //           for (Int_t kk=0; kk<13;kk++){
1376    //             t_tof->beta[kk] = tofoutput_.beta_a[kk];
1377    //           };
1378    //           //
1379    //           t_tof->npmtadc = 0;
1380    //           for (Int_t hh=0; hh<12;hh++){
1381    //             for (Int_t kk=0; kk<4;kk++){
1382    //               if ( tofoutput_.adc_c[hh][kk] < 1000 ){
1383    //                 t_tof->dedx.AddAt(tofoutput_.adc_c[hh][kk],t_tof->npmtadc);
1384    //                 pmt_id = this->GetPMTid(kk,hh);
1385    //                 t_tof->pmtadc.AddAt(pmt_id,t_tof->npmtadc);
1386    //                 t_tof->adcflag.AddAt(tofoutput_.adcflag[hh][kk],t_tof->npmtadc); // gf: Jan 09/07
1387    //                 t_tof->npmtadc++;
1388    //               };
1389    //             };
1390    //           };
1391    //           //
1392    //           memcpy(t_tof->xtofpos,tofoutput_.xtofpos,sizeof(t_tof->xtofpos));
1393    //           memcpy(t_tof->ytofpos,tofoutput_.ytofpos,sizeof(t_tof->ytofpos));
1394    //           memcpy(t_tof->xtr_tof,tofoutput_.xtr_tof,sizeof(t_tof->xtr_tof));
1395    //           memcpy(t_tof->ytr_tof,tofoutput_.ytr_tof,sizeof(t_tof->ytr_tof));
1396    //           //
1397    //           // Store the tracker track number in order to be sure to have shyncronized data during analysis
1398    //           //
1399    //           t_tof->trkseqno = nt;
1400    //           //
1401    //           // create a new object for this event with track-related variables
1402    //           //
1403    //           new(t[ntrkentry]) ToFTrkVar(*t_tof);
1404    //           ntrkentry++;
1405    //           t_tof->Clear();
1406    //           //
1407    //         }; // loop on all the tracks
1408    //       //
1409    //       this->unpackError = unpackError;
1410    //       if ( defcal ){
1411    //         this->default_calib = 1;
1412    //       } else {
1413    //         this->default_calib = 0;
1414    //       };
1415    //};
1416    //  return(0);
1417    }
1418    
1419    
1420    ToFdEdx::ToFdEdx()
1421    {
1422      memset(conn,0,12*sizeof(Bool_t));
1423      memset(ts,0,12*sizeof(UInt_t));
1424      memset(te,0,12*sizeof(UInt_t));
1425      Define_PMTsat();
1426      Clear();
1427    }
1428    //------------------------------------------------------------------------
1429    void ToFdEdx::CheckConnectors(UInt_t atime, GL_PARAM *glparam, TSQLServer *dbc)
1430    {
1431      for(int i=0; i<12; i++){
1432        if(atime<=ts[i] || atime>te[i]){
1433          Int_t error=glparam->Query_GL_PARAM(atime,210+i,dbc); // parameters stored in DB in GL_PRAM table
1434          if ( error<0 ) {
1435            conn[i]=false;
1436            ts[i]=0;
1437            te[i]=numeric_limits<UInt_t>::max();
1438          };
1439          if ( !error ){
1440            conn[i]=true;
1441            ts[i]=glparam->FROM_TIME;
1442            te[i]=glparam->TO_TIME;
1443          }
1444          if ( error>0 ){
1445            conn[i]=false;
1446            ts[i]=glparam->TO_TIME;
1447            TSQLResult *pResult;
1448            TSQLRow *row;
1449            TString query= Form("SELECT FROM_TIME FROM GL_PARAM WHERE TYPE=%i AND FROM_TIME>=%i ORDER BY FROM_TIME ASC LIMIT 1;",210+i,atime);
1450            pResult=dbc->Query(query.Data());
1451            if(!pResult->GetRowCount()){
1452              te[i]=numeric_limits<UInt_t>::max();
1453            }else{
1454              row=pResult->Next();
1455              te[i]=(UInt_t)atoll(row->GetField(0));
1456            }
1457          }
1458          //
1459          
1460        }
1461      }
1462    
1463    }
1464    //  //------------------------------------------------------------------------
1465    // structures to communicate with F77  void ToFdEdx::Clear(Option_t *option)
1466    //  {
   extern struct ToFInput  tofinput_;  
   extern struct ToFOutput tofoutput_;  
   //  
   // DB connection  
1467    //    //
1468    TString host;    // Set arrays and initialize structure
1469    TString user;    eDEDXpmt.Set(48);    eDEDXpmt.Reset(-1);   // Set array size  and reset structure
   TString psw;  
   const char *pamdbhost=gSystem->Getenv("PAM_DBHOST");  
   const char *pamdbuser=gSystem->Getenv("PAM_DBUSER");  
   const char *pamdbpsw=gSystem->Getenv("PAM_DBPSW");  
   if ( !pamdbhost ) pamdbhost = "";  
   if ( !pamdbuser ) pamdbuser = "";  
   if ( !pamdbpsw ) pamdbpsw = "";  
   if ( strcmp(pamdbhost,"") ) host = pamdbhost;  
   if ( strcmp(pamdbuser,"") ) user = pamdbuser;  
   if ( strcmp(pamdbpsw,"") ) psw = pamdbpsw;  
   //  
   //  
   TSQLServer *dbc = TSQLServer::Connect(host.Data(),user.Data(),psw.Data());  
   if ( !dbc->IsConnected() ) return 1;  
   stringstream myquery;  
   myquery.str("");  
   myquery << "SET time_zone='+0:00'";  
   dbc->Query(myquery.str().c_str());  
   GL_PARAM *glparam = new GL_PARAM();  
   glparam->Query_GL_PARAM(1,1,dbc); // parameters stored in DB in GL_PRAM table  
   trk->LoadField(glparam->PATH+glparam->NAME);  
   //  
   Bool_t defcal = true;  
   Int_t error=glparam->Query_GL_PARAM(run->RUNHEADER_TIME,201,dbc); // parameters stored in DB in GL_PRAM table  
   if ( error<0 ) {  
     return(1);  
   };  
   printf(" Reading ToF parameter file: %s \n",(glparam->PATH+glparam->NAME).Data());  
   if ( (UInt_t)glparam->TO_TIME != (UInt_t)4294967295UL ) defcal = false;  
1470    //    //
1471    Int_t nlen = (Int_t)(glparam->PATH+glparam->NAME).Length();  };
1472    rdtofcal((char *)(glparam->PATH+glparam->NAME).Data(),&nlen);  
1473    //------------------------------------------------------------------------
1474    void ToFdEdx::Print(Option_t *option)
1475    {
1476    //    //
1477    Int_t adc[4][12];    printf("========================================================================\n");
1478    Int_t tdc[4][12];  
1479    Float_t tdcc[4][12];  };
1480    //  
1481    // process tof data  //------------------------------------------------------------------------
1482    //  void ToFdEdx::Init(pamela::tof::TofEvent *tofl0)
1483    for (Int_t hh=0; hh<12;hh++){  {
     for (Int_t kk=0; kk<4;kk++){  
            adc[kk][hh] = 4095;  
            tdc[kk][hh] = 4095;  
            tdcc[kk][hh] = 4095.;  
            tofinput_.adc[hh][kk] = 4095;  
            tofinput_.tdc[hh][kk] = 4095;  
     };  
   };  
   Int_t ntrkentry = 0;  
   Int_t npmtentry = 0;  
   Int_t gg = 0;  
   Int_t hh = 0;  
   Int_t adcf[48];  
   memset(adcf, 0, 48*sizeof(Int_t));  
   Int_t tdcf[48];  
   memset(tdcf, 0, 48*sizeof(Int_t));  
   for (Int_t pm=0; pm < this->ntrk() ; pm++){  
      ToFTrkVar *ttf = this->GetToFTrkVar(pm);  
      for ( Int_t nc=0; nc < ttf->npmttdc; nc++){  
             if ( (ttf->tdcflag).At(nc) != 0 ) tdcf[(ttf->pmttdc).At(nc)] = 1;  
      };  
      for ( Int_t nc=0; nc < ttf->npmtadc; nc++){  
             if ( (ttf->adcflag).At(nc) != 0 ) adcf[(ttf->pmtadc).At(nc)] = 1;  
      };  
   };  
1484    //    //
1485    for (Int_t pm=0; pm < this->npmt() ; pm++){    ToFLevel2 tf;
1486       ToFPMT *pmt = this->GetToFPMT(pm);    for (Int_t gg=0; gg<4;gg++){
1487       this->GetPMTIndex(pmt->pmt_id, gg, hh);      for (Int_t hh=0; hh<12;hh++){
1488       if ( adcf[pmt->pmt_id] == 0 ){        //          tofinput_.tdc[hh][gg]=tofEvent->tdc[gg][hh];          
1489               tofinput_.adc[gg][hh] = (int)pmt->adc;        int mm = tf.GetPMTid(gg,hh);        
1490               adc[hh][gg] = (int)pmt->adc;        adc[mm]=tofl0->adc[gg][hh];
1491       };      };      
      if ( tdcf[pmt->pmt_id] == 0 ){  
              tofinput_.tdc[gg][hh] = (int)pmt->tdc;  
              tdc[hh][gg] = (int)pmt->tdc;  
      };  
      tdcc[hh][gg] = (float)pmt->tdc_tw;  
      // Int_t pppid = this->GetPMTid(hh,gg);  
      //      printf(" pm %i pmt_id %i pppid %i hh %i gg %i tdcc %f tdc %f adc %f \n",pm,pmt->pmt_id,pppid,hh,gg,pmt->tdc_tw,pmt->tdc,pmt->adc);  
1492    };    };
1493      
1494    };
1495    
1496    //------------------------------------------------------------------------
1497    void ToFdEdx::Init(Int_t gg, Int_t hh, Float_t adce)
1498    {
1499    //    //
1500    Int_t unpackError = this->unpackError;    ToFLevel2 tf;
1501      //  for (Int_t gg=0; gg<4;gg++){
1502      //    for (Int_t hh=0; hh<12;hh++){
1503      int mm = tf.GetPMTid(gg,hh);    
1504      adc[mm]=adce;
1505      
1506    };
1507    //------------------------------------------------------------------------
1508    void ToFdEdx::Process(UInt_t atime, Float_t betamean, Float_t *xtr_tof, Float_t *ytr_tof)
1509    {
1510      // the parameters should be already initialised by InitPar()
1511      Clear();
1512    
1513     // define angle:  
1514      double dx   = xtr_tof[1] - xtr_tof[5];
1515      double dy   = ytr_tof[0] - ytr_tof[4];
1516      double dr   = sqrt(dx*dx+dy*dy);
1517      double theta=atan(dr/76.81);
1518    //    //
1519    for (Int_t hh=0; hh<5;hh++){    if ( xtr_tof[1] > 99. ||  xtr_tof[5] > 99. || ytr_tof[0] > 99. ||  ytr_tof[4] > 99. ) theta = 0.;
      tofinput_.patterntrig[hh]=trg->patterntrig[hh];  
   };  
1520    //    //
1521    this->Clear();    
1522    
1523      for( int ii=0; ii<48; ii++ ) {
1524        //
1525        //    printf(" ii %i beta %f atime %u xtr 1 %f ytr 1 %f adc %f \n",ii,betamean,atime,xtr_tof[0],ytr_tof[0],adc[ii]);
1526        if( adc[ii] >= PMTsat[ii]-5 )  continue;
1527        if( adc[ii] <= 0. )            continue;
1528        //
1529        double adcpC   = f_adcPC( adc[ii] );    // - adc conversion in pC
1530        double adccorr = adcpC*fabs(cos(theta));
1531        //
1532        if(adccorr<=0.)           continue;
1533    
1534        //--------------------- TABLE OF PERIODS WITH HV PROBLEMS ----------------------------
1535    
1536        int Aconn=conn[0];    // PMT 0,20,22,24
1537        int Bconn=conn[1];    // PMT 6,12,26,34
1538        int Cconn=conn[2];    // PMT 4,14,28,32
1539        int Dconn=conn[3];    // PMT 2,8,10,30
1540        int Econn=conn[4];    // PMT 42,43,44,47
1541        int Fconn=conn[5];    // PMT 7,19,23,27
1542        int Gconn=conn[6];    // PMT 3,11,25,33
1543        int Hconn=conn[7];    // PMT 1,9,13,21
1544        int Iconn=conn[8];    // PMT 5,29,31,35
1545        int Lconn=conn[9];    // PMT 37,40,45,46
1546        int Mconn=conn[10];    // PMT 15,16,17,18
1547        int Nconn=conn[11];    // PMT 36,38,39,41
1548    
1549        //    int standard=0;
1550        if( false ) cout << Gconn << Iconn << Lconn <<endl;
1551        int S115B_ok=0;
1552        int S115B_break=0;
1553    
1554        if(atime<1158720000)S115B_ok=1;
1555        else S115B_break=1;
1556    
1557    
1558        //------------------------------------------------------------------------
1559    
1560        //---------------------------------------------------- Z reconstruction
1561    
1562        double adcHe, adcnorm, adclin, dEdx, Zeta;
1563    
1564        adcHe=-2;
1565        adcnorm=-2;
1566        adclin=-2;
1567        dEdx=-2;
1568        Zeta=-2;
1569    
1570        if(Aconn==1 && (ii==0 || ii==20 || ii==22 || ii==24)){
1571          adcHe   = (Get_adc_he(ii, xtr_tof, ytr_tof))/1.675;
1572        }
1573        else if(Bconn==1 && (ii==6 || ii==12 || ii==26 || ii==34)){
1574          adcHe   = (Get_adc_he(ii, xtr_tof, ytr_tof))/2.482;
1575        }
1576        else if(Cconn==1 && (ii==4 || ii==14 || ii==28 || ii==32)){
1577          adcHe   = (Get_adc_he(ii, xtr_tof, ytr_tof))/1.464;
1578        }
1579        else if(Dconn==1 && (ii==2 || ii==8 || ii==10 || ii==30)){
1580          adcHe   = (Get_adc_he(ii, xtr_tof, ytr_tof))/1.995;
1581        }
1582        else if(Econn==1 && (ii==42 || ii==43 || ii==44 || ii==47)){
1583          adcHe   = (Get_adc_he(ii, xtr_tof, ytr_tof))/1.273;
1584        }
1585        else if(Fconn==1 && (ii==7 || ii==19 || ii==23 || ii==27)){
1586          adcHe   = (Get_adc_he(ii, xtr_tof, ytr_tof))/1.565;
1587        }
1588        else if(Mconn==1 && (ii==15 || ii==16 || ii==17 || ii==18)){
1589          adcHe   = (Get_adc_he(ii, xtr_tof, ytr_tof))/1.565;
1590        }
1591        else if(Nconn==1 && (ii==36 || ii==38 || ii==39 || ii==41)){
1592          adcHe   = (Get_adc_he(ii, xtr_tof, ytr_tof))/1.018;
1593        }
1594        else if(Hconn==1 && (ii==1 || ii==13 || ii==21 || (ii==9&&S115B_ok==1))){
1595          adcHe   = (Get_adc_he(ii, xtr_tof, ytr_tof))/1.84;
1596        }
1597        else if(S115B_break==1 && ii==9 && Hconn==0){
1598          adcHe   = f_att5B( ytr_tof[0] );   //N.B.: this function refers to the Carbon!!!
1599        }
1600        else if(S115B_break==1 && ii==9 && Hconn==1){
1601          adcHe   = (f_att5B( ytr_tof[0] ))/1.64;
1602        }
1603        else  adcHe   = Get_adc_he(ii, xtr_tof, ytr_tof);
1604    
1605        if(adcHe<=0)   continue;
1606    
1607        if(ii==9 && S115B_break==1)  adcnorm = f_pos5B(adccorr);
1608        else adcnorm = f_pos( (parPos[ii]), adccorr);
1609    
1610        if(adcnorm<=0) continue;
1611    
1612        if(ii==9 && S115B_break==1)  adclin  = 36.*adcnorm/adcHe;
1613        else  adclin  = 4.*adcnorm/adcHe;
1614    
1615        if(adclin<=0)  continue;
1616        //
1617        if ( betamean > 99. ){
1618          eDEDXpmt[ii]=(Float_t)adclin;
1619          continue;
1620        };
1621        //
1622        double dEdxHe=-2;
1623        if(ii==9 && S115B_break==1){
1624          if( betamean <1. ) dEdxHe = f_BB5B( betamean );
1625          else                       dEdxHe = 33;
1626        } else {
1627          if( betamean <1. ) dEdxHe = f_BB( (parBBneg[ii]), betamean );
1628          else                       dEdxHe = parBBpos[ii];
1629        }
1630        
1631        if(dEdxHe<=0)  continue;
1632    
1633        if(ii==9 && S115B_break==1)  dEdx = f_desatBB5B( adclin );
1634        else  dEdx = f_desatBB((parDesatBB[ii]), adclin );
1635    
1636        if(dEdx<=0)    continue;
1637    
1638        eDEDXpmt[ii]=(Float_t)dEdx;
1639    
1640    
1641      }  //end loop on 48 PMT
1642    
1643    };
1644    
1645    
1646    //------------------------------------------------------------------------
1647    void ToFdEdx::Define_PMTsat()
1648    {
1649      Float_t  sat[48] = {
1650        3176.35,3178.19,3167.38,3099.73,3117.00,3126.29,3111.44,3092.27,
1651        3146.48,3094.41,3132.13,3115.37,3099.32,3110.97,3111.80,3143.14,
1652        3106.72,3153.44,3136.00,3188.96,3104.73,3140.45,3073.18,3106.62,
1653        3112.48,3146.92,3127.24,3136.52,3109.59,3112.89,3045.15,3147.26,
1654        3095.92,3121.05,3083.25,3123.62,3150.92,3125.30,3067.60,3160.18,
1655        3119.36,3108.92,3164.77,3133.64,3111.47,3131.98,3128.87,3135.56 };
1656      PMTsat.Set(48,sat);
1657    }
1658    
1659    //------------------------------------------------------------------------
1660    void ToFdEdx::ReadParBBpos( const char *fname )
1661    {
1662      //  printf("read %s\n",fname);
1663      parBBpos.Set(48);
1664      FILE *fattin = fopen( fname , "r" );
1665      for (int i=0; i<48; i++) {
1666        int   tid=0;
1667        float  tp;
1668        if(fscanf(fattin,"%d %f",
1669                  &tid, &tp )!=2) break;
1670        parBBpos[i]=tp;
1671      }
1672      fclose(fattin);
1673    }
1674    
1675    //------------------------------------------------------------------------
1676    void ToFdEdx::ReadParDesatBB( const char *fname )
1677    {
1678      //  printf("read %s\n",fname);
1679      FILE *fattin = fopen( fname , "r" );
1680      for (int i=0; i<48; i++) {
1681        int   tid=0;
1682        float  tp[3];
1683        if(fscanf(fattin,"%d %f %f %f",
1684                  &tid, &tp[0], &tp[1], &tp[2] )!=4) break;
1685        parDesatBB[i].Set(3,tp);
1686      }
1687      fclose(fattin);
1688    }
1689    
1690    
1691    //------------------------------------------------------------------------
1692    void ToFdEdx::ReadParBBneg( const char *fname )
1693    
1694    {
1695      //  printf("read %s\n",fname);
1696      FILE *fattin = fopen( fname , "r" );
1697      for (int i=0; i<48; i++) {
1698        int   tid=0;
1699        float  tp[3];
1700        if(fscanf(fattin,"%d %f %f %f",
1701                  &tid, &tp[0], &tp[1], &tp[2] )!=4) break;
1702        parBBneg[i].Set(3,tp);
1703      }
1704      fclose(fattin);
1705    }
1706    
1707    //------------------------------------------------------------------------
1708    void ToFdEdx::ReadParPos( const char *fname )
1709    {
1710      //  printf("read %s\n",fname);
1711      FILE *fattin = fopen( fname , "r" );
1712      for (int i=0; i<48; i++) {
1713        int   tid=0;
1714        float  tp[4];
1715        if(fscanf(fattin,"%d %f %f %f %f",
1716                  &tid, &tp[0], &tp[1], &tp[2], &tp[3])!=5) break;
1717        parPos[i].Set(4,tp);
1718      }
1719      fclose(fattin);
1720    }
1721    
1722    //------------------------------------------------------------------------
1723    void ToFdEdx::ReadParAtt( const char *fname )
1724    {
1725      //  printf("read %s\n",fname);
1726      FILE *fattin = fopen( fname , "r" );
1727      for (int i=0; i<48; i++) {
1728        int   tid=0;
1729        float  tp[6];
1730        if(fscanf(fattin,"%d %f %f %f %f %f %f",
1731                  &tid, &tp[0], &tp[1], &tp[2], &tp[3], &tp[4], &tp[5] )!=7) break;
1732        parAtt[i].Set(6,tp);
1733      }
1734      fclose(fattin);
1735    }
1736    
1737    
1738    
1739    
1740    
1741    
1742    double ToFdEdx::f_att( TArrayF &p, float x )
1743    {
1744      return
1745        p[0] +
1746        p[1]*x +
1747        p[2]*x*x +
1748        p[3]*x*x*x +
1749        p[4]*x*x*x*x +
1750        p[5]*x*x*x*x*x;
1751    }
1752    //------------------------------------------------------------------------
1753    double ToFdEdx::f_att5B( float x )
1754    {
1755      return
1756        101.9409 +
1757        6.643781*x +
1758        0.2765518*x*x +
1759        0.004617647*x*x*x +
1760        0.0006195132*x*x*x*x +
1761        0.00002813734*x*x*x*x*x;
1762    }
1763    
1764    
1765    double ToFdEdx::f_pos( TArrayF &p, float x )
1766    {
1767      return
1768        p[0] +
1769        p[1]*x +
1770        p[2]*x*x +
1771        p[3]*x*x*x;
1772    }
1773    
1774    double ToFdEdx::f_pos5B( float x )
1775    {
1776      return
1777        15.45132 +
1778        0.8369721*x +
1779        0.0005*x*x;
1780    }
1781    
1782    
1783    
1784    double ToFdEdx::f_adcPC( float x )
1785    {
1786      return 28.12+0.6312*x-5.647e-05*x*x+3.064e-08*x*x*x;
1787    }
1788    
1789    
1790    float ToFdEdx::Get_adc_he( int id, float pl_x[6], float pl_y[6])
1791    {
1792    
1793    //    //
1794        Int_t pmt_id = 0;    // input: id - pmt [0:47}
1795        ToFPMT *t_pmt = new ToFPMT();    //             pl_x - coord x of the tof plane
1796        if(!(this->PMT)) this->PMT = new TClonesArray("ToFPMT",12); //ELENA    //             pl_y - coord y
1797        TClonesArray &tpmt = *this->PMT;  
1798        ToFTrkVar *t_tof = new ToFTrkVar();    adc_he = 0;
1799        if(!(this->ToFTrk)) this->ToFTrk = new TClonesArray("ToFTrkVar",2); //ELENA    if( eGeom.GetXY(id)==1 )  adc_he = f_att( (parAtt[id]), pl_x[eGeom.GetPlane(id)] );
1800        TClonesArray &t = *this->ToFTrk;    if( eGeom.GetXY(id)==2 )  adc_he = f_att( (parAtt[id]), pl_y[eGeom.GetPlane(id)] );
1801        //    return adc_he;
1802        //  }
       // Here we have calibrated data, ready to be passed to the FORTRAN routine which will extract common and track-related  variables.  
       //  
       npmtentry = 0;  
       //  
       ntrkentry = 0;  
       //  
       // Calculate tracks informations from ToF alone  
       //  
       tofl2com();  
       //  
       memcpy(this->tof_j_flag,tofoutput_.tof_j_flag,6*sizeof(Int_t));  
       //  
       t_tof->trkseqno = -1;  
       //  
       // and now we must copy from the output structure to the level2 class:  
       //  
       t_tof->npmttdc = 0;  
       //  
       for (Int_t hh=0; hh<12;hh++){  
         for (Int_t kk=0; kk<4;kk++){  
           if ( tofoutput_.tofmask[hh][kk] != 0 ){  
             pmt_id = this->GetPMTid(kk,hh);  
             t_tof->pmttdc.AddAt(pmt_id,t_tof->npmttdc);  
             t_tof->tdcflag.AddAt(tofoutput_.tdcflagtof[hh][kk],t_tof->npmttdc); // gf: Jan 09/07  
             t_tof->npmttdc++;  
           };  
         };  
       };  
       for (Int_t kk=0; kk<13;kk++){  
         t_tof->beta[kk] = tofoutput_.betatof_a[kk];  
       }  
       //  
       t_tof->npmtadc = 0;  
       for (Int_t hh=0; hh<12;hh++){  
         for (Int_t kk=0; kk<4;kk++){  
           if ( tofoutput_.adctof_c[hh][kk] < 1000 ){  
             t_tof->dedx.AddAt(tofoutput_.adctof_c[hh][kk],t_tof->npmtadc);  
             pmt_id = this->GetPMTid(kk,hh);  
             t_tof->pmtadc.AddAt(pmt_id,t_tof->npmtadc);  
             t_tof->adcflag.AddAt(tofoutput_.adcflagtof[hh][kk],t_tof->npmtadc); // gf: Jan 09/07  
             t_tof->npmtadc++;  
           };  
         };  
       };  
       //  
       memcpy(t_tof->xtofpos,tofoutput_.xtofpos,sizeof(t_tof->xtofpos));  
       memcpy(t_tof->ytofpos,tofoutput_.ytofpos,sizeof(t_tof->ytofpos));  
       memcpy(t_tof->xtr_tof,tofoutput_.xtr_tof,sizeof(t_tof->xtr_tof));  
       memcpy(t_tof->ytr_tof,tofoutput_.ytr_tof,sizeof(t_tof->ytr_tof));  
       //  
       new(t[ntrkentry]) ToFTrkVar(*t_tof);  
       ntrkentry++;  
       t_tof->Clear();  
       //  
       //  
       //  
       t_pmt->Clear();  
       //  
       for (Int_t hh=0; hh<12;hh++){  
         for (Int_t kk=0; kk<4;kk++){  
          // new WM  
           if ( tofoutput_.tdc_c[hh][kk] < 4095 || adc[kk][hh] < 4095  || tdc[kk][hh] < 4095 ){  
 //          if ( tdcc[kk][hh] < 4095. || adc[kk][hh] < 4095  || tdc[kk][hh] < 4095 ){  
             //  
             t_pmt->pmt_id = this->GetPMTid(kk,hh);  
             t_pmt->tdc_tw = tofoutput_.tdc_c[hh][kk];  
             t_pmt->adc = (Float_t)adc[kk][hh];  
             t_pmt->tdc = (Float_t)tdc[kk][hh];  
             //  
             new(tpmt[npmtentry]) ToFPMT(*t_pmt);  
             npmtentry++;  
             t_pmt->Clear();  
           };  
         };  
       };  
       //  
       // Calculate track-related variables  
       //  
       if ( trk->ntrk() > 0 ){  
         //  
         // We have at least one track  
         //  
         //  
         // Run over tracks  
         //  
         for(Int_t nt=0; nt < trk->ntrk(); nt++){  
           //  
           TrkTrack *ptt = trk->GetStoredTrack(nt);  
           //  
           // Copy the alpha vector in the input structure  
           //  
           for (Int_t e = 0; e < 5 ; e++){  
             tofinput_.al_pp[e] = ptt->al[e];  
           };  
           //  
           // Get tracker related variables for this track  
           //  
           toftrk();  
           //  
           // Copy values in the class from the structure (we need to use a temporary class to store variables).  
           //  
           t_tof->npmttdc = 0;  
           for (Int_t hh=0; hh<12;hh++){  
             for (Int_t kk=0; kk<4;kk++){  
               if ( tofoutput_.tofmask[hh][kk] != 0 ){  
                 pmt_id = this->GetPMTid(kk,hh);  
                 t_tof->pmttdc.AddAt(pmt_id,t_tof->npmttdc);  
                 t_tof->tdcflag.AddAt(tofoutput_.tdcflag[hh][kk],t_tof->npmttdc); // gf: Jan 09/07  
                 t_tof->npmttdc++;  
               };  
             };  
           };  
           for (Int_t kk=0; kk<13;kk++){  
             t_tof->beta[kk] = tofoutput_.beta_a[kk];  
           };  
           //  
           t_tof->npmtadc = 0;  
           for (Int_t hh=0; hh<12;hh++){  
             for (Int_t kk=0; kk<4;kk++){  
               if ( tofoutput_.adc_c[hh][kk] < 1000 ){  
                 t_tof->dedx.AddAt(tofoutput_.adc_c[hh][kk],t_tof->npmtadc);  
                 pmt_id = this->GetPMTid(kk,hh);  
                 t_tof->pmtadc.AddAt(pmt_id,t_tof->npmtadc);  
                 t_tof->adcflag.AddAt(tofoutput_.adcflag[hh][kk],t_tof->npmtadc); // gf: Jan 09/07  
                 t_tof->npmtadc++;  
               };  
             };  
           };  
           //  
           memcpy(t_tof->xtofpos,tofoutput_.xtofpos,sizeof(t_tof->xtofpos));  
           memcpy(t_tof->ytofpos,tofoutput_.ytofpos,sizeof(t_tof->ytofpos));  
           memcpy(t_tof->xtr_tof,tofoutput_.xtr_tof,sizeof(t_tof->xtr_tof));  
           memcpy(t_tof->ytr_tof,tofoutput_.ytr_tof,sizeof(t_tof->ytr_tof));  
           //  
           // Store the tracker track number in order to be sure to have shyncronized data during analysis  
           //  
           t_tof->trkseqno = nt;  
           //  
           // create a new object for this event with track-related variables  
           //  
           new(t[ntrkentry]) ToFTrkVar(*t_tof);  
           ntrkentry++;  
           t_tof->Clear();  
           //  
         }; // loop on all the tracks  
       //  
       this->unpackError = unpackError;  
       if ( defcal ){  
         this->default_calib = 1;  
       } else {  
         this->default_calib = 0;  
       };  
  };  
1803    
1804    //------------------------------------------------------------------------
1805    double ToFdEdx::f_BB( TArrayF &p, float x )
1806    {
1807      return  p[0]/(x*x)*(log(x*x/(1-x*x)) - p[1]*x*x - p[2]);
1808    }
1809    
1810    //------------------------------------------------------------------------
1811    double ToFdEdx::f_BB5B( float x )
1812    {
1813      return  0.165797/(x*x)*(log(x*x/(1-x*x)) + 140.481*x*x + 52.9258);
1814    }
1815    //------------------------------------------------------------------------
1816    double ToFdEdx::f_desatBB( TArrayF &p, float x )
1817    {
1818      return
1819        p[0] +
1820        p[1]*x +
1821        p[2]*x*x;
1822    }
1823    
1824    return(0);  //------------------------------------------------------------------------
1825    double ToFdEdx::f_desatBB5B( float x )
1826    {
1827      return
1828        -2.4 +
1829        0.75*x +
1830        0.009*x*x;
1831  }  }
1832    
1833    
1834    
1835    
1836    
1837    
1838    
1839    
1840    
1841    
1842    
1843    
1844    
1845    
1846    
1847    

Legend:
Removed from v.1.25  
changed lines
  Added in v.1.28

  ViewVC Help
Powered by ViewVC 1.1.23