65 VertexFit(
const std::string& name =
"VertexFit");
81 _max_iteration = nMaxIteration;
82 _tolerance = tolerance;
90 void addHypothesis(
double z,
double sigz = 50.) { z_start.push_back(z); sig_z_start.push_back(sigz); }
129 this->evalFileName = evalFileName;
143 std::vector<TrkPar> _trkpar_curr;
155 double _chisq_vertex;
156 double _chisq_kalman;
159 std::vector<double> z_start;
160 std::vector<double> sig_z_start;
163 std::vector<double> z_vertex;
164 std::vector<double> r_vertex;
165 std::vector<double> chisq_km;
166 std::vector<double> chisq_vx;
177 bool fit_target_center;
179 TGeoManager * _t_geo_manager;
184 std::string evalFileName;
196 int choice_by_kf_eval;
197 int choice_by_vx_eval;
200 double z_start_eval[50];
202 double chisq_kf_eval[50];
203 double chisq_vx_eval[50];
204 double z_vertex_eval[50];
205 double r_vertex_eval[50];
207 double m_chisq_kf_eval;
208 double s_chisq_kf_eval;
209 double m_z_vertex_eval;
210 double s_z_vertex_eval;
transient DST object for field storage and access
static void printMatrix(const TMatrixD &m)
int process_event(PHCompositeNode *topNode)
int setRecEvent(SRecEvent *recEvent, int sign1=1, int sign2=-1)
Set the SRecEvent, main external call the use vertex fit.
void setControlParameter(int nMaxIteration, double tolerance)
Set the convergence control parameters.
void addHypothesis(double z, double sigz=50.)
double findDimuonVertexFast(SRecTrack &track1, SRecTrack &track2)
const std::string & get_eval_file_name() const
double findSingleMuonVertex(SRecTrack &_track)
void set_eval_file_name(const std::string &evalFileName)
void enableOptimization()
Enable the optimization of final dimuon vertex z position.
void enable_fit_target_center()
int findVertex()
Find the primary vertex.
void print()
Debugging output.
void bookEvaluation(std::string evalFileName="vtx_eval.root")
Evaluation.
void addTrack(int index, SRecTrack &_track)
Add one track parameter set into the fit.
void updateVertex()
Core function, update the vertex prediction according to the track info.
void init()
Initialize and reset.
int Init(PHCompositeNode *topNode)
int InitRun(PHCompositeNode *topNode)
int End(PHCompositeNode *topNode)
Called at the end of all processing.
void setStartingVertex(double z_start, double sigz_start)
VertexFit(const std::string &name="VertexFit")
double getVertexZ0()
Gets.
int processOnePair()
After setting both tracks and hypothesis, start the iteration.