// $Id$ // // File: DReferenceTrajectory.h // Created: Wed Jul 19 13:42:58 EDT 2006 // Creator: davidl (on Darwin swire-b241.jlab.org 8.7.0 powerpc) // #ifndef _DReferenceTrajectory_ #define _DReferenceTrajectory_ #include using std::vector; #include #include #include #include #include class DMagneticFieldMap; class DTrackCandidate; class DRootGeom; class DReferenceTrajectory{ /// This class is a utility class used by the TRACKING package. It /// is used to swim a particle through the (inhomogeneous) magnetic /// field, accounting for energy loss in the geometry, and recording /// each step so that derivatives and distances can be calculated. /// Because this uses the coordinates defined in the reference /// trajectory method (B. Mecking Nucl. Instr. and Methods. /// 203 (1982) 299-305), the angles needed to rotate into the /// lab frame are saved as well. This used the DMagneticFieldStepper /// class for swimming through the field. public: enum direction_t{ kForward, kBackward }; class swim_step_t:public DCoordinateSystem{ public: DVector3 mom; double Ro; double s; // distance along RT double t; // flight time double dP; // The following are used to calculate the covariance matrix for MULS double itheta02; // running sum of MULS angle theta_0 squared double itheta02s; // ditto but times s double itheta02s2; // ditto but times s^2 }; DReferenceTrajectory(const DMagneticFieldMap * , double q=1.0 , swim_step_t *swim_steps=NULL , int max_swim_steps=0 , double step_size=-1.0); DReferenceTrajectory(const DReferenceTrajectory& rt); DReferenceTrajectory& operator=(const DReferenceTrajectory& rt); virtual ~DReferenceTrajectory(); virtual const char* className(void){return static_className();} static const char* static_className(void){return "DReferenceTrajectory";} void CopyWithShift(const DReferenceTrajectory *rt, DVector3 shift); void Reset(void); double DistToRT(double x, double y, double z) const {return DistToRT(DVector3(x,y,z));} double DistToRT(DVector3 hit, double *s=NULL) const; double DistToRTwithTime(DVector3 hit, double *s=NULL,double *t=NULL) const; double DistToRT(const DCoordinateSystem *wire, double *s=NULL) const; double DistToRTBruteForce(const DCoordinateSystem *wire, double *s=NULL) const; double DistToRT(const DCoordinateSystem *wire, const swim_step_t *step, double *s=NULL) const; double DistToRTBruteForce(const DCoordinateSystem *wire, const swim_step_t *step, double *s=NULL) const; double Straw_dx(const DCoordinateSystem *wire, double radius); swim_step_t* FindClosestSwimStep(const DCoordinateSystem *wire, int *istep_ptr=NULL) const; swim_step_t* FindClosestSwimStep(const DVector3 &origin, DVector3 norm, int *istep_ptr=NULL) const; swim_step_t* FindPlaneCrossing(const DVector3 &origin, DVector3 norm, int *istep_ptr=NULL) const; void Swim(const DVector3 &pos, const DVector3 &mom, double q=-1000.0, double smax=2000.0, const DCoordinateSystem *wire=NULL); void FastSwim(const DVector3 &pos, const DVector3 &mom, DVector3 &last_pos, DVector3 &last_mom, double q,double smax=2000.0, const DCoordinateSystem *wire=NULL); int InsertSteps(const swim_step_t *start_step, double delta_s, double step_size=0.02); void GetIntersectionWithPlane(const DVector3 &origin, const DVector3 &norm, DVector3 &pos, double *s=NULL,double *t=NULL) const; void GetIntersectionWithPlane(const DVector3 &origin, const DVector3 &norm, DVector3 &pos, DVector3 &dir,double *s=NULL,double *t=NULL) const; jerror_t GetIntersectionWithRadius(double R,DVector3 &mypos, double *s=NULL, double *t=NULL) const; DVector3 GetLastDOCAPoint(void) const; void GetLastDOCAPoint(DVector3 &pos, DVector3 &mom) const; double GetLastDistAlongWire(void) const {return last_dist_along_wire;} void SetStepSize(double step_size){this->step_size=step_size;} void SetDRootGeom(const DRootGeom *RootGeom){this->RootGeom = RootGeom;} void SetDGeometry(const DGeometry *geom){this->geom = geom;} const DRootGeom* GetDRootGeom(void) const {return RootGeom;} const DGeometry* GetDGeometry(void) const {return geom;} const DMagneticFieldMap* GetBfield(void) const {return bfield;} double GetMass(void) const {return mass;} double GetStepSize(void) const {return step_size;} void SetMass(double mass){this->mass = mass;} void SetPLossDirection(direction_t direction){ploss_direction=direction;} void SetCheckMaterialBoundaries(bool check_material_boundaries){this->check_material_boundaries = check_material_boundaries;} bool GetCheckMaterialBoundaries(void) const {return check_material_boundaries;} direction_t GetPLossDirection(void) const {return ploss_direction;} double GetBoundaryStepFraction(void) const {return BOUNDARY_STEP_FRACTION;} double GetMinStepSize(void) const {return MIN_STEP_SIZE;} double GetMaxStepSize(void) const {return MAX_STEP_SIZE;} inline double dPdx_from_A_Z_rho(double ptot, double A, double Z, double density) const; inline double dPdx(double ptot, double KrhoZ_overA, double rhoZ_overA,double LogI) const; bool GetHitCDCEndplate(void){return hit_cdc_endplate;} int GetDebugLevel(void){return debug_level;} void SetDebugLevel(int new_level){debug_level=new_level;} void Dump(double zmin=-1000.0, double zmax=1000.0); const swim_step_t *GetLastSwimStep(void) const {return last_swim_step;} swim_step_t *swim_steps; int Nswim_steps; float q; protected: int debug_level; int max_swim_steps; bool own_swim_steps; int dist_to_rt_depth; double step_size; const DMagneticFieldMap *bfield; const DRootGeom *RootGeom; const DGeometry *geom; direction_t ploss_direction; bool check_material_boundaries; mutable double last_phi; ///< last phi found in DistToRT mutable const swim_step_t* last_swim_step; ///< last swim step used in DistToRT mutable double last_dist_along_wire; mutable double last_dz_dphi; double mass; bool hit_cdc_endplate; double BOUNDARY_STEP_FRACTION; double MIN_STEP_SIZE; double MAX_STEP_SIZE; private: DReferenceTrajectory(){} // force use of constructor with arguments. }; #endif // _DReferenceTrajectory_