#ifndef _DTrackFitterKalman_H_ #define _DTrackFitterKalman_H_ #include #include #include #include #include #include "HDGEOMETRY/DMagneticFieldMap.h" #include "HDGEOMETRY/DGeometry.h" #include "HDGEOMETRY/DLorentzDeflections.h" #include "HDGEOMETRY/DMaterialMap.h" #include "CDC/DCDCTrackHit.h" #include "FDC/DFDCPseudo.h" #include using namespace std; typedef struct{ double x,y,z; double covx,covxy,covy; double dE; }DKalmanHit_t; typedef struct{ int status; double residual; const DCDCTrackHit *hit; }DKalmanCDCHit_t; typedef struct{ double t,cosa,sina; double uwire,vstrip,z; double covu,covv; double xres,yres,dE; double nr,nz; }DKalmanFDCHit_t; typedef struct{ unsigned int h_id; unsigned int num_hits; DVector3 pos; DMatrix *S; DMatrix *J,*Q,*C; double s,t; double A,Z,density,X0; }DKalmanState_t; typedef struct{ DVector3 pos; double q_over_pt,phi,tanl,D,z; }DKalmanCentral_t; typedef struct{ double dE,ds; }DKalman_dedx_t; class DTrackFitterKalman: public DTrackFitter{ public: // enum tracking_level{ // kWireBased, // kTimeBased, // }; DTrackFitterKalman(JEventLoop *loop); ~DTrackFitterKalman(){ for (unsigned int i=0;i >&mycov){ mycov.assign(cov.begin(),cov.end()); }; void GetForwardCovarianceMatrix(vector< vector >&mycov){ mycov.assign(fcov.begin(),fcov.end()); }; double GetCharge(void){return q_over_pt_>0?1.:-1.;}; double GetChiSq(void){return chisq_;} unsigned int GetNDF(void){return ndf;}; double GetActivePathLength(void){ return path_length;} double GetdEdx(double q_over_p,double Z,double A, double rho); double GetEnergyVariance(double ds,double q_over_p,double Z,double A, double rho); protected: private: enum state_types_forward{ state_x, state_y, state_tx, state_ty, state_q_over_p, }; enum state_types_central{ state_q_over_pt, state_phi, state_tanl, state_D, state_z, }; void ResetKalman(void); jerror_t GetProcessNoise(double ds,double z, double X0,const DMatrix &S,DMatrix &Q); double Step(double oldz,double newz, double dEdx,DMatrix &S); jerror_t StepJacobian(double oldz,double newz,const DMatrix &S,double dEdx, DMatrix &J); jerror_t CalcDerivAndJacobian(double z,double dz,const DMatrix &S, double dEdx, DMatrix &J,DMatrix &D); jerror_t CalcDeriv(double z,double dz,const DMatrix &S, double dEdx, DMatrix &D); jerror_t CalcDeriv(double ds,const DVector3 &pos,DVector3 &dpos, const DVector3 &B, const DMatrix &S,double dEdx,DMatrix &D1); jerror_t StepJacobian(const DVector3 &pos,const DVector3 &wire_pos, const DVector3 &wiredir, double ds,const DMatrix &S, double dEdx,DMatrix &J); jerror_t FixedStep(DVector3 &pos,double ds,DMatrix &S, double dEdx); jerror_t FixedStep(DVector3 &pos,double ds,DMatrix &S, double dEdx, double &Bz); jerror_t CalcDerivAndJacobian(double ds,const DVector3 &pos,DVector3 &dpos, DVector3 &B,const DMatrix &S,double dEdx, DMatrix &J1,DMatrix &D1); jerror_t ConvertStateVector(double z,double wire_x,double wire_y, const DMatrix &S,const DMatrix &C,DMatrix &Sc, DMatrix &Cc); jerror_t ConvertStateVector(double z,double wire_x,double wire_y, const DMatrix &S,DMatrix &Sc); jerror_t GetProcessNoiseCentral(double ds,const DVector3 &pos,double X0, const DMatrix &Sc, DMatrix &Q); jerror_t SwimToPlane(DMatrix &S); jerror_t SwimToPlane(double z_start,double z_end, DMatrix &S,DMatrix &C); jerror_t SwimToPlane(double z_end, DMatrix &S); jerror_t SwimToRadius(DVector3 &pos, double Rf,DMatrix &Sc,DMatrix &Cc); jerror_t SwimToRadius(DVector3 &pos, double Rf, DMatrix &Sc); jerror_t SwimCentral(DVector3 &pos,DMatrix &Sc); jerror_t GoldenSection(double &ds,double doca,double dedx,DVector3 &pos, DVector3 origin,DVector3 dir, DMatrix &Sc,DMatrix &Jc); double GoldenSection(double ds1,double ds2,double dedx, DVector3 pos,DVector3 origin,DVector3 dir, DMatrix Sc); jerror_t GoldenSection(double &z,double dz,double dEdx, DVector3 origin, DVector3 dir,DMatrix &S); double BrentsAlgorithm(double ds1,double ds2, double dedx,DVector3 &pos,const DVector3 &origin, const DVector3 &dir, DMatrix &Sc); double BrentsAlgorithm(double z,double dz, double dedx,const DVector3 &origin, const DVector3 &dir,const DMatrix &S); jerror_t PropagateForwardCDC(int length,int &index,double z, double step,DMatrix &S); //const DMagneticFieldMap *bfield; ///< pointer to magnetic field map //const DGeometry *geom; //const DLorentzDeflections *lorentz_def;// pointer to lorentz correction map //const DMaterialMap *material; // pointer to material map //const DRootGeom *RootGeom; // list of hits on track vectormy_cdchits; vectormy_fdchits; // Track parameters for forward region double x_,y_,tx_,ty_,q_over_p_; // Alternate track parameters for central region double z_,phi_,tanl_,q_over_pt_; // chi2 of fit double chisq_; // number of degrees of freedom unsigned int ndf; // Covariance matrix vector< vector > cov; vector< vector > fcov; // Lists containing state, covariance, and jacobian at each step dequecentral_traj; dequeforward_traj; dequeforward_traj_cdc; vectorcdc_resid; vectorcdc_pulls; // path length double len; // flight time double ftime; // For dEdx measurements double track_dedx; int num_dedx; double path_length; // path length in active volume double p_meas; // Average measured momentum in active region // endplate dimensions and location double endplate_z, endplate_dz, endplate_rmin, endplate_rmax; // upstream cdc start position vectorcdc_origin; // upstream fdc start position vectorfdc_origin; // Mass hypothesis double MASS,mass2; bool do_multiple_scattering; bool do_energy_loss; int pass; bool DEBUG_HISTS; int DEBUG_LEVEL; TH2F *cdc_residuals,*fdc_xresiduals,*fdc_yresiduals; TH2F *thetay_vs_thetax; }; #endif // _DTrackFitterKalman_H_