// $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 #include "DHelicalFit.h" /// \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(const DFDCSegment *segment); jerror_t GetPositionAndMomentum(DFDCSegment *segment, DVector3 &pos, DVector3 &mom); jerror_t GetPositionAndMomentum(double z,DVector3 &pos,DVector3 &mom); jerror_t GetPositionAndMomentum(double zmin, vectorsegments, DVector3 &pos,DVector3 &mom); double GetCharge(const DVector3 &pos,const DFDCSegment *segment); double GetCharge(const DVector3 &pos,vectorsegments); double DocaSqToHelix(const DFDCPseudo *hit); DFDCSegment *GetTrackMatch(DFDCSegment *segment,vectorpackage, unsigned int &match_id); void LinkSegments(unsigned int pack1,vectorpackages[4]); double Match(double p); bool GetTrackMatch(double q,DVector3 &pos,DVector3 &mom, const DFDCSegment *segment); bool LinkStraySegment(const DFDCSegment *segment); bool DEBUG_HISTS,USE_FDC,APPLY_MOMENTUM_CORRECTION; double p_factor1,p_factor2; TH2F *match_dist_fdc; TH1F *Hcircle_fit_prob; vectorz_wires; double endplate_z; double TARGET_Z; double MAX_R_VERTEX_LIMIT; double zpack[4]; double FactorForSenseOfRotation; // Fit parameters double xc,yc,rc,z_vertex,q,phi0,tanl; // vector of fit results vectorfit_results; // Parameters at the end of the segment double xs,ys,zs; double p,cosphi,sinphi,twokappa,one_over_twokappa,cotl; }; inline double DTrackCandidate_factory_FDCCathodes::Match(double p){ // return 1000.; if (p<1.) p=1.; if (p>3.) p=3.; return (12.-3.*p+20./p); } #endif // _DTrackCandidate_factory_FDCCathodes_