--- calo/flight/CaloNuclei/src/CaloNuclei.cpp 2007/05/24 07:50:48 1.5 +++ calo/flight/CaloNuclei/src/CaloNuclei.cpp 2007/11/26 08:48:24 1.11 @@ -29,11 +29,14 @@ void CaloNuclei::Clear(){ // + UN = 0; tr = 0; sntr = 0; interplane = 0; preq = 0.; postq = 0.; + stdedx1 = 0.; + ethr = 0.; dedx1 = 0.; dedx3 = 0.; qpremean = 0.; @@ -107,6 +110,8 @@ // Clear(); // + if ( debug ) printf(" Always calculate stdedx1 \n"); + // // Always calculate stdedx1 // Int_t view = 0; @@ -132,6 +137,8 @@ // }; // + if ( debug ) printf(" find energy released along the strip of maximum on the first plane and on the two neighbour strips \n"); + // // find energy released along the strip of maximum on the first plane and on the two neighbour strips // if ( indx > 0 ){ @@ -145,23 +152,33 @@ stdedx1 = 0.; }; // + if ( debug ) printf(" if ( !usetrack ) return: usetrack %i ntr %i \n",usetrack,ntr); // // - if ( !usetrack ) return; + // if ( !usetrack ) return; // PamTrack *ptrack = 0; CaloTrkVar *track = 0; - if ( ntr >= 0 ){ - ptrack = L2->GetTrack(ntr); - track = ptrack->GetCaloTrack(); - } else { - track = L2->GetCaloStoredTrack(ntr); - }; // - if ( !track && ntr >= 0 ){ - printf(" ERROR: cannot find any track!\n"); - printf(" ERROR: CaloNuclei variables not completely filled \n"); - return; + if ( usetrack ){ + if ( ntr >= 0 ){ + ptrack = L2->GetTrack(ntr); + if ( ptrack ) track = ptrack->GetCaloTrack(); + } else { + track = L2->GetCaloStoredTrack(ntr); + }; + // + if ( !track && ntr >= 0 ){ + printf(" ERROR: cannot find any track!\n"); + printf(" ERROR: CaloNuclei variables not completely filled \n"); + return; + }; + } else { + if ( ntr >= 0 ){ + if ( debug ) printf(" ERROR: you asked not to use a track but you are looking for track number %i !\n",ntr); + if ( debug ) printf(" ERROR: CaloNuclei variables not completely filled \n"); + return; + }; }; // // Float_t defethr = 6. * 0.90; @@ -487,6 +504,7 @@ }; // qpremeanN /= (Float_t)RN; + UN = RN; // if ( debug ) printf(" charge is %f \n",sqrt(qpremean)); // @@ -498,7 +516,16 @@ mesethr = mesethr2; }; aldone = true; - if ( mesethr > defethr ) goto retry; + if ( mesethr > defethr ){ + interplane = 0; + preq = 0.; + postq = 0.; + qpremean = 0.; + qpremeanN = 0.; + multhit = false; + gap = false; + goto retry; + }; }; }; //