// $Id$ // // File: DTrackCandidate_factory_FDCCathodes.h // Created: Tue Nov 6 13:37:08 EST 2007 // Creator: staylor (on Linux ifarml1.jlab.org 2.4.21-47.0.1.ELsmp i686) // #ifndef _DTrackCandidate_factory_FDCCathodes_ #define _DTrackCandidate_factory_FDCCathodes_ #include #include "DTrackCandidate.h" #include #include "FDC/DFDCSegment_factory.h" #include "HDGEOMETRY/DMagneticFieldMap.h" #include "DMagneticFieldStepper.h" #include #include /// \htmlonly /// /// /// /// \endhtmlonly /// Find track candidates in the Forward Drift Chambers (FDC). /// This will try to form candidates from hits found in the FDC. /// Roughly, clusters of hits in single packages (6 wire planes) /// are found and fit. The fit is propagated to adjacent packages /// to link them up with hit clusters there. Eventually, all hits /// are used to fit using a Reimann method to obtain the parameters /// of the candidate. /// /// These candidates will be merged with those from the FDC in /// the DTrackCandidate_factory class. class DTrackCandidate_factory_FDCCathodes:public JFactory{ public: DTrackCandidate_factory_FDCCathodes(){ DEBUG_HISTS = false; //DEBUG_HISTS = true; }; ~DTrackCandidate_factory_FDCCathodes(){}; const char* Tag(void){return "FDCCathodes";} private: const DMagneticFieldMap *bfield; DMagneticFieldStepper *stepper; //jerror_t init(void); ///< Called once at program start. jerror_t brun(JEventLoop *eventLoop, int runnumber); ///< Called everytime a new run number is detected. jerror_t evnt(JEventLoop *eventLoop, int eventnumber); ///< Called every event. jerror_t erun(void); ///< Called everytime run number changes, provided brun has been called. jerror_t fini(void); ///< Called after last event of last event source has been processed. jerror_t GetPositionAndMomentum(DFDCSegment *segment, DVector3 &pos, DVector3 &mom); jerror_t GetPositionAndMomentum(const double Bz_avg, DVector3 &pos,DVector3 &mom); double GetCharge(const DVector3 &pos, const DFDCSegment *segment); DFDCSegment *GetTrackMatch(double z, DFDCSegment *segment, vectorpackage, unsigned int &match_id); bool DEBUG_HISTS,USE_FDC,APPLY_MOMENTUM_CORRECTION; double p_factor1,p_factor2; TH2F *match_dist_fdc; vectorz_wires; double endplate_z; double TARGET_Z; // Fit parameters double xc,yc,rc,z_vertex,q,phi0,tanl; }; #endif // _DTrackCandidate_factory_FDCCathodes_