// $Id$ // // File: DTrackTimeBased_factory_THROWN.cc // Created: Wed Nov 18 06:25:19 EST 2009 // Creator: davidl (on Darwin Amelia.local 9.8.0 i386) // #include using namespace std; #include #include #include #include #include "DTrackTimeBased_factory_THROWN.h" #include "DMCThrown.h" #include "DReferenceTrajectory.h" #include "DRandom.h" #include "DMatrix.h" #include "DTrackHitSelector.h" //------------------ // DTrackTimeBased_factory_THROWN //------------------ DTrackTimeBased_factory_THROWN::DTrackTimeBased_factory_THROWN() { fitter = NULL; hitselector=NULL; RootGeom = NULL; geom = NULL; } //------------------ // brun //------------------ jerror_t DTrackTimeBased_factory_THROWN::brun(jana::JEventLoop *loop, int runnumber) { // Get pointer to DTrackFitter object that actually fits a track vector fitters; loop->Get(fitters); if(fitters.size()<1){ _DBG_<<"Unable to get a DTrackFitter object! NO Charged track fitting will be done!"<(fitters[0]); // Warn user if something happened that caused us NOT to get a fitter object pointer if(!fitter){ _DBG_<<"ERROR: Unable to get a DTrackFitter object! Chisq for DTrackTimeBased:THROWN will NOT be calculated!"< hitselectors; loop->Get(hitselectors); if(hitselectors.size()<1){ _DBG_<<"ERROR: Unable to get a DTrackHitSelector object! NO DTrackTimeBased:THROWN objects will be created!"<(loop->GetJApplication()); geom = dapp->GetDGeometry(runnumber); // Set magnetic field pointer bfield = dapp->GetBfield(); return NOERROR; } //------------------ // evnt //------------------ jerror_t DTrackTimeBased_factory_THROWN::evnt(JEventLoop *loop, int eventnumber) { vector mcthrowns; vector cdctrackhits; vector fdcpseudos; vector wbtracks; loop->Get(mcthrowns); loop->Get(cdctrackhits); loop->Get(fdcpseudos); loop->Get(wbtracks, "THROWN"); for(unsigned int i=0; i< mcthrowns.size(); i++){ const DMCThrown *thrown = mcthrowns[i]; const DKinematicData *kd_thrown = thrown; if(fabs(thrown->charge())<1)continue; // First, copy over the DKinematicData part DTrackTimeBased *track = new DTrackTimeBased; DKinematicData *kd_track = track; *kd_track = *kd_thrown; // Add DMCThrown as associated object track->AddAssociatedObject(thrown); // We need to swim a reference trajectory here. To avoid the overhead // of allocating/deallocating them every event, we keep a pool and // re-use them. If the pool is not big enough, then add one to the // pool. unsigned int locNumInitialReferenceTrajectories = rt_pool.size(); if(rt_pool.size()<=_data.size()){ // This is a little ugly, but only gets called a few times throughout the life of the process // Note: these never get deleted, even at the end of process. rt_pool.push_back(new DReferenceTrajectory(bfield)); } DReferenceTrajectory *rt = rt_pool[_data.size()]; if(locNumInitialReferenceTrajectories == rt_pool.size()) //didn't create a new one rt->Reset(); rt->q = track->charge(); track->rt = rt; DVector3 pos = track->position(); DVector3 mom = track->momentum(); rt->SetMass(thrown->mass()); rt->SetDGeometry(geom); rt->SetDRootGeom(RootGeom); rt->Swim(pos, mom, track->charge()); // Find hits that should be on this track and add them as associated objects vector cdchits; vector fdchits; if(hitselector && cdctrackhits.size()>0)hitselector->GetCDCHits(DTrackHitSelector::kHelical, rt, cdctrackhits, cdchits); if(hitselector && fdcpseudos.size()>0)hitselector->GetFDCHits(DTrackHitSelector::kHelical, rt, fdcpseudos, fdchits); for(unsigned int i=0; iAddAssociatedObject(cdchits[i]); for(unsigned int i=0; iAddAssociatedObject(fdchits[i]); // We want to get chisq and Ndof values for this track using the hits from above. // We do this using the DTrackFitter object. This more or less guarantees that the // chisq calculation is done in the same way as it is for track fitting. Note // that no fitting is actually done here so this should be reasonably fast if(fitter){ fitter->Reset(); fitter->AddHits(cdchits); fitter->AddHits(fdchits); double chisq; int Ndof; vector pulls; fitter->ChiSq(DTrackFitter::kTimeBased, rt, &chisq, &Ndof, &pulls); track->chisq = chisq; track->Ndof = Ndof; track->pulls = pulls; }else{ track->chisq = 0.0; track->Ndof = 0; } // For this to work properly with DChargedTrack, we need to put something // in for the candidateid and the FOM (figure of merit) used to decide if // this is the right mass hypothesis for the candidate. Since there is no // candidate and we *know* it's the right hypothesis, we set the candidateid // to the thrown object's oid and set the FOM to 1. track->candidateid = thrown->id; track->trackid = thrown->id; track->FOM = 1.0; // Add wire-based track as associated object. Even though they should // be in the same order, we verify it is the correct one by checking // that the candidateid is the same as ours (i.e. the same thrown track) for(unsigned int j=0; jcandidateid == track->candidateid){ track->AddAssociatedObject(wbtracks[j]); break; } } _data.push_back(track); } return NOERROR; }