//****************************************************************** // DFDCSegment_factory.h: class definition for a factory creating // track segments from pseudopoints //****************************************************************** #ifndef DFACTORY_DFDCSEGMENT_H #define DFACTORY_DFDCSEGMENT_H #include "JANA/JFactory.h" #include "JANA/JException.h" #include "JANA/JStreamLog.h" #include "DFDCSegment.h" #include "DFDCPseudo.h" #include "DFDCHit.h" #include "HDGEOMETRY/DMagneticFieldMap.h" #include "HDGEOMETRY/DLorentzDeflections.h" #include #include #include #include /* The folowing are for interpreting grid of Lorentz deflection data */ /*#define PACKAGE_Z_POINTS 10 #define LORENTZ_X_POINTS 21 #define LORENTZ_Z_POINTS 4*PACKAGE_Z_POINTS */ /// /// class DFDCSegment_factory: definition for a JFactory that /// produces space points from pseudopoints. /// class DFDCSegment_factory : public JFactory { public: /// /// DFDCSegment_factory::DFDCSegment_factory(): /// default constructor -- initializes log file /// DFDCSegment_factory(); /// /// DFDCSegment_factory::~DFDCSegment_factory(): /// default destructor -- closes log file /// ~DFDCSegment_factory(); jerror_t FindSegments(vectorpoints); // jerror_t CorrectPoints(vectorpoint, DMatrix XYZ); jerror_t GetHelicalTrackPosition(double z, const DFDCSegment *segment, double &xpos, double &ypos); jerror_t RiemannHelicalFit(vectorpoints, DMatrix &CR, DMatrix &XYZ); jerror_t RiemannCircleFit(vectorpoints, DMatrix CRPhi); jerror_t RiemannLineFit(vectorpoints, DMatrix CR,DMatrix &XYZ); jerror_t UpdatePositionsAndCovariance(unsigned int n, double r1sq, DMatrix &XYZ, DMatrix &CRPhi,DMatrix &CR); double GetProcessNoise(unsigned int i, DMatrix XYZ); double GetCharge(unsigned int n, DMatrix XYZ, DMatrix CR, DMatrix CRPhi); protected: /// /// DFDCSegment_factory::brun(): /// jerror_t brun(JEventLoop *eventLoop, int eventNo); /// /// DFDCSegment_factory::evnt(): /// this is the place that finds track segments and /// converts pseudopoints into space points. /// jerror_t evnt(JEventLoop *eventLoop, int eventNo); private: JStreamLog* _log; double N[3]; double varN[3][3]; double dist_to_origin,xc,yc,rc; double xavg[3],var_avg; // Track parameters double tanl,z0,zvertex,D,phi0; double var_tanl,Phi1; double charge; unsigned int ref_plane; double chisq; const DMagneticFieldMap *bfield; const DLorentzDeflections *lorentz_def; // double ref_time; // bool use_tof,use_sc; //vector of flags indicating whether or not a hit has been used vectorused; int myeventno; }; #endif // DFACTORY_DFDCSEGMENT_H