// $Id$ // // File: DTrackHitSelectorALT1.cc // Created: Fri Feb 6 08:22:58 EST 2009 // Creator: davidl (on Darwin harriet.jlab.org 9.6.0 i386) // #include #include "DTrackHitSelectorALT1.h" //--------------------------------- // DTrackHitSelectorALT1 (Constructor) //--------------------------------- DTrackHitSelectorALT1::DTrackHitSelectorALT1(jana::JEventLoop *loop):DTrackHitSelector(loop) { HS_DEBUG_LEVEL = 0; gPARMS->SetDefaultParameter("TRKFIT:HS_DEBUG_LEVEL", HS_DEBUG_LEVEL); } //--------------------------------- // ~DTrackHitSelectorALT1 (Destructor) //--------------------------------- DTrackHitSelectorALT1::~DTrackHitSelectorALT1() { } //--------------------------------- // GetCDCHits //--------------------------------- void DTrackHitSelectorALT1::GetCDCHits(fit_type_t fit_type, DReferenceTrajectory *rt, const vector &cdchits_in, vector &cdchits_out) const { /// Determine the probability that for each CDC hit that it came from the track with the given trajectory. /// /// This will calculate a probability for each CDC hit that /// it came from the track represented by the given /// DReference trajectory. The probability is based on /// the residual between the distance of closest approach /// of the trajectory to the wire and the drift time. // Calculate beta of particle assuming its a pion for now. If the // particles is really a proton or an electron, the residual // calculated below will only be off by a little. double beta = 1.0/sqrt(1.0+pow(rt->GetMass(),2.0)/rt->swim_steps[0].mom.Mag2()); // The error on the residual. This will be different based on the // quality of the track and whether MULS is on or not etc. // In principle, this could also depend on the momentum parameters // of the track. double sigma; switch(fit_type){ case kTimeBased: sigma = 0.8/sqrt(12.0); break; case kWireBased: sigma = 2.0*0.8/sqrt(12.0); break; case kHelical: default: sigma = 10.0*0.8/sqrt(12.0); } // Minimum probability of hit belonging to wire and still be accepted double MIN_HIT_PROB = 0.01; vector::const_iterator iter; for(iter=cdchits_in.begin(); iter!=cdchits_in.end(); iter++){ const DCDCTrackHit *hit = *iter; // Find the DOCA to this wire double s; double doca = rt->DistToRT(hit->wire, &s); // Get "measured" distance to wire. For time-based tracks // this is calculated from the drift time. For all other // tracks, this is assumed to be half a cell size double dist; if(kTimeBased){ // Distance using drift time // NOTE: Right now we assume pions for the TOF // and a constant drift velocity of 55um/ns double tof = s/(beta*3E10*1E-9); dist = (hit->tdrift - tof)*55E-4; }else{ dist = 0.8/2.0; // half cell-size } // Residual double resi = dist - doca; double chisq = pow(resi/sigma, 2.0); // Use chi-sq probaility function with Ndof=1 to calculate probability double probability = TMath::Prob(chisq, 1); if(probability>=MIN_HIT_PROB)cdchits_out.push_back(hit); if(HS_DEBUG_LEVEL>10)_DBG_<<"s="<time - tof)*55E-4; }else{ dist = 0.5/2.0; // half cell-size } // Anode Residual double resi = dist - doca; // Cathode Residual double u=rt->GetLastDistAlongWire(); double resic = u - hit->s; // Probability of this hit being on the track double chisq = pow(resi/sigma_anode, 2.0) + pow(resic/sigma_cathode, 2.0); double probability = TMath::Prob(chisq, 2); if(probability>=MIN_HIT_PROB)fdchits_out.push_back(hit); if(HS_DEBUG_LEVEL>10)_DBG_<<"s="<