--- calo/flight/CaloNuclei/src/CaloNuclei.cpp 2008/11/28 16:01:26 1.16 +++ calo/flight/CaloNuclei/src/CaloNuclei.cpp 2015/04/20 09:12:05 1.20 @@ -7,11 +7,11 @@ /** * Default constructor */ -CaloNuclei::CaloNuclei(){ - Clear(); -}; +// CaloNuclei::CaloNuclei(){ +// Clear(); +// }; -CaloNuclei::CaloNuclei(PamLevel2 *l2p){ +CaloNuclei::CaloNuclei(PamLevel2 *l2p,const char* alg){ // Clear(); // @@ -28,6 +28,8 @@ debug = false; // debug = true; usetrack = true; + usepl18x = false; + trkAlg = alg; // }; @@ -146,6 +148,9 @@ // mip = L2->GetCaloLevel1()->DecodeEstrip(i,view,plane,strip); // + if ( !usepl18x && view==0 && plane==18 ) mip = 0.; + // + // // put in vfpl vector the energy release on the first plane // if ( strip != -1 && view == 1 && plane == 0 ) { @@ -186,14 +191,15 @@ // if ( usetrack ){ if ( ntr >= 0 ){ - ptrack = L2->GetTrack(ntr); + ptrack = L2->GetTrack(ntr,trkAlg); if ( ptrack ) track = ptrack->GetCaloTrack(); } else { track = L2->GetCaloStoredTrack(ntr); }; // if ( !track && ntr >= 0 ){ - printf(" ERROR: cannot find any track!\n"); + printf(" ERROR: cannot find any track! \n"); + cout << "ERROR: trk.algorythm --> "<GetCaloLevel1()->DecodeEstrip(i,view,plane,strip); // + if ( !usepl18x && view==0 && plane==18 ) mip = 0.; + // if ( ntr >= 0 ){ // if ( strip != -1 && @@ -283,6 +291,9 @@ // mip = L2->GetCaloLevel1()->DecodeEstrip(ii,view,plane,strip); // + if ( !usepl18x && view==0 && plane==18 ) mip = 0.; + // + // if ( ntr >= 0 ){ if ( strip != -1 && mip > ethr && !wmulthit[view] && !wgap[view] && ( strip == (track->tibar[plane][view]-1) || strip == (track->tibar[plane][view]-2) || strip == (track->tibar[plane][view]) ) @@ -411,6 +422,9 @@ // mip = L2->GetCaloLevel1()->DecodeEstrip(ii,view,plane,strip); // + if ( !usepl18x && view==0 && plane==18 ) mip = 0.; + // + // if ( strip != -1 ){ if ( view == 0 ){ ipl = (1 + plane) * 2; @@ -620,8 +634,8 @@ Float_t beta = 100.; //------- First try track dependent beta - if( L2->GetTrkLevel2()->GetNTracks()>=1 ){ - PamTrack *TRKtrack = L2->GetTrack(0); + if( L2->GetNTracks(trkAlg)>=1 ){ + PamTrack *TRKtrack = L2->GetTrack(0,trkAlg); if (fabs(TRKtrack->GetToFTrack()->beta[12]) < 100.) beta = fabs(TRKtrack->GetToFTrack()->beta[12]); } //------- If no beta found, try standalone beta @@ -665,15 +679,15 @@ // //======================================================================= // //=========== charge determination Maximum release vs. beta =============== // //====================== Rome method =========================== -// //======================================================================= - - Float_t D0[7] = {0, 3 , 4 , 5 , 6, 8, 90}; - Float_t E1[7] = {0 ,923.553 , 659.842, 1113.97, 3037.25, 3034.84, 0}; - Float_t E2[7] = {0 ,6.92574 , 5.08865, 5.29349, 6.41442, 5.52969, 0}; - Float_t E3[7] = {0 ,9.7227 , 13.18, 23.5444, 38.2057, 63.6784, 80000}; +// //======================================================================= - Float_t xx1[7],yy1[7]; - n1 = 7; + Float_t D0[9] = {0, 1, 2, 3 , 4 , 5 , 6, 8, 90}; + Float_t E1[9] = {0, 500, 500, 923.553 , 659.842, 1113.97, 3037.25, 3034.84, 0}; + Float_t E2[9] = {0, 11.0, 7.5, 6.92574 , 5.08865, 5.29349, 6.41442, 5.52969, 0}; + Float_t E3[9] = {0, 1.2, 4, 9.7227 , 13.18, 23.5444, 38.2057, 63.6784, 80000}; + + Float_t xx1[9],yy1[9]; + n1 = 9; charge = 1000.; mip=0; @@ -714,12 +728,12 @@ // ======================================================================= // =========== charge determination dedx vs. beta =============== // ====================== Rome method =========================== -// ======================================================================= - - Float_t F0[7] = {0.,3. ,4., 5. , 6., 8, 90}; - Float_t G1[7] = {0 ,642.935 , 848.684, 1346.05, 3238.82, 3468.6, 0}; - Float_t G2[7] = {0 ,6.2038 , 5.51723, 5.65265, 6.54089, 5.72723, 0}; - Float_t G3[7] = {0 ,9.2421 , 13.9858, 25.3912, 39.6332, 64.5674, 80000}; +// ======================================================================= + + Float_t F0[9] = {0., 1., 2., 3. ,4., 5. , 6., 8, 90}; + Float_t G1[9] = {0, 500, 500, 642.935 , 848.684, 1346.05, 3238.82, 3468.6, 0}; + Float_t G2[9] = {0, 11, 7.5, 6.2038 , 5.51723, 5.65265, 6.54089, 5.72723, 0}; + Float_t G3[9] = {0, 1.2, 4, 9.2421 , 13.9858, 25.3912, 39.6332, 64.5674, 80000}; charge = 1000.; @@ -729,7 +743,7 @@ if (beta<2.) { // it makes no sense to allow beta=5 or so... - if( L2->GetTrkLevel2()->GetNTracks()>=1 ){ + if( L2->GetNTracks(trkAlg)>=1 ){ mip=dedx1; } if (mip==0) mip=stdedx1; @@ -763,20 +777,12 @@ //======================================================================= //=========== charge determination dedx vs. defl =============== //====================== Rome method =========================== -//======================================================================= - - //new - Float_t H0[7] = {0, 3 , 4 , 5 , 6, 8, 90 }; - Float_t I1[7] = {0 , 56.1019, 101.673, 109.225, 150.599, 388.531, 0}; - Float_t I2[7] = {0 , -12.5581, -22.5543, -15.9823, -28.2207, -93.6871, 0}; - Float_t I3[7] = {0 , 11.6218, 19.664, 32.1817, 45.7527, 84.5992, 80000}; - - -// Float_t H0[7] = {0, 3 , 4 , 5 , 6, 8, 90 }; -// Float_t I1[7] = {0 , 56.1019, 101.673, 155, 150.599, 388.531, 0}; -// Float_t I2[7] = {0 , -12.5581, -22.5543, -35.6217, -28.2207, -93.6871, 0}; -// Float_t I3[7] = {0 , 11.6218, 19.664, 34.3311, 45.7527, 84.5992, 8000}; +//======================================================================= + Float_t H0[9] = {0, 1, 2, 3 , 4 , 5 , 6, 8, 90 }; + Float_t I1[9] = {0, 3.5, 40, 56.1019, 101.673, 109.225, 150.599, 388.531, 0}; + Float_t I2[9] = {0, -1, -13.6, -12.5581, -22.5543, -15.9823, -28.2207, -93.6871, 0}; + Float_t I3[9] = {0, 1, 5.3, 11.6218, 19.664, 32.1817, 45.7527, 84.5992, 80000}; charge = 1000.; @@ -786,8 +792,8 @@ if (beta<2.) { // it makes no sense to allow beta=5 or so... - if( L2->GetTrkLevel2()->GetNTracks()>=1 ){ - PamTrack *TRKtrack = L2->GetTrack(0); + if( L2->GetNTracks(trkAlg)>=1 ){ + PamTrack *TRKtrack = L2->GetTrack(0,trkAlg); mip=dedx1; if (mip==0) mip=stdedx1; defl=TRKtrack->GetTrkTrack()->al[4]; @@ -822,12 +828,12 @@ //============================================================================================ //=========== charge determination Truncated mean (N-1 planes) vs. defl =================== //================================ Rome method ======================================== -//============================================================================================ - - Float_t L0[7] = {0, 3 , 4 , 5 , 6, 8, 90}; - Float_t M1[7] = {0 , 63.0145, 120.504, 173.663, 245.33, 236.517, 0}; - Float_t M2[7] = {0 , -15.005, -31.0635, -39.4988, -60.5011, -46.3992, 0}; - Float_t M3[7] = {0 , 12.5037, 22.8652, 35.2907, 51.4678, 86.4155, 8000}; +//============================================================================================ + + Float_t L0[9] = {0, 1, 2, 3 , 4 , 5 , 6, 8, 90}; + Float_t M1[9] = {0, 3.5, 27, 63.0145, 120.504, 173.663, 245.33, 236.517, 0}; + Float_t M2[9] = {0, -1, -10.6, -15.005, -31.0635, -39.4988, -60.5011, -46.3992, 0}; + Float_t M3[9] = {0, 1, 7, 12.5037, 22.8652, 35.2907, 51.4678, 86.4155, 80000}; charge = 1000.; mip=0; @@ -835,7 +841,7 @@ if (beta<2.) { // it makes no sense to allow beta=5 or so... - if( L2->GetTrkLevel2()->GetNTracks()>=1 ){ + if( L2->GetNTracks(trkAlg)>=1 ){ mip=qNmin1; if (mip>0 && defl<0.7 && defl>0) {