// $Id$ // // File: DTrackTimeBased.h // Created: Thu Sep 4 14:02:44 EDT 2008 // Creator: davidl (on Darwin harriet.jlab.org 8.11.1 i386) // #ifndef _DTrackTimeBased_ #define _DTrackTimeBased_ #include #include #include #include class DReferenceTrajectory; class DTrackTimeBased:public DKinematicData{ public: JOBJECT_PUBLIC(DTrackTimeBased); typedef struct{ unsigned int inner_layer; unsigned int outer_layer; unsigned int total_hits; }hit_usage_t; hit_usage_t cdc_hit_usage; hit_usage_t fdc_hit_usage; oid_t trackid; ///< id of DTrackWireBased corresponding to this track oid_t candidateid; ///< id of DTrackCandidate corresponding to this track float chisq; ///< Chi-squared for the track (not chisq/dof!) int Ndof; ///< Number of degrees of freedom in the fit vector pulls; ///< Holds pulls used in chisq calc. (not including off-diagonals) const DReferenceTrajectory *rt; ///< pointer to reference trjectory representing this track typedef struct{ double t0,t0_sigma; DetectorSystem_t system; }DStartTime_t; vectorstart_times; double FOM; double ddEdx_FDC; double ddx_FDC; unsigned int dNumHitsUsedFordEdx_FDC; double ddEdx_CDC; double ddx_CDC; unsigned int dNumHitsUsedFordEdx_CDC; // Hit CDC Rings & FDC Planes // use the DParticleID Get_CDCRings & Get_FDCPlanes functions to extract the information from these unsigned int dCDCRings; //CDC rings where the track has an associated DCDCTrackHit //rings correspond to bits (1 -> 28) unsigned int dFDCPlanes; //FDC planes where the track has an associated DFDCPseudoHit //planes correspond to bits (1 -> 24) // Matching to MC: Highest % of track hits matched to a thrown int dMCThrownMatchMyID; //MC track match myid (-1 if somehow no match) int dNumHitsMatchedToThrown; void toStrings(vector > &items)const{ DKinematicData::toStrings(items); AddString(items, "candidate","%d",candidateid); AddString(items, "wirebased","%d",trackid); AddString(items, "chisq", "%f", chisq); AddString(items, "Ndof", "%d", Ndof); AddString(items, "FOM", "%f",(float)FOM); AddString(items, "MCMatchID", "%d",dMCThrownMatchMyID); AddString(items, "#HitsMCMatched", "%d",dNumHitsMatchedToThrown); } }; #endif // _DTrackTimeBased_