116 auto track1Ptr = recoTracks[0]->getRelated<Track>(
"Tracks");
117 auto track2Ptr = recoTracks[1]->getRelated<Track>(
"Tracks");
118 if (!track1Ptr or !track2Ptr)
return false;
121 auto tfr1Ptr = track1Ptr->getTrackFitResultWithClosestMass(
Const::pion);
122 auto tfr2Ptr = track2Ptr->getTrackFitResultWithClosestMass(
Const::pion);
123 if (!tfr1Ptr or !tfr2Ptr)
return false;
126 if (tfr1Ptr->getPValue() <= 0 or tfr2Ptr->getPValue() <= 0)
return false;
129 if (tfr1Ptr->getChargeSign() * tfr2Ptr->getChargeSign() >= 0)
return false;
133 B2DEBUG(20,
"B Field = " << bField <<
" T");
135 analysis::RaveVertexFitter rvf;
137 rvf.addTrack(tfr1Ptr);
138 rvf.addTrack(tfr2Ptr);
140 B2DEBUG(20,
"Adding tracks to RaveVertexFitter failed.");
143 if (rvf.fit() == 0)
return false;
145 auto vertex = rvf.getPos();
153 B2DEBUG(20,
"Vertex = (" <<
m_vx
159 DBObjPtr<BeamSpot> beamSpotDB;
160 auto ip = ROOT::Math::XYZVector(beamSpotDB->getIPPosition());
161 if (tfr1Ptr->getChargeSign() > 0) {
162 m_track_p.setValues(*recoTracks[0], ip, recoTracksName, pxdInterceptsName, pxdTrackClustersName);
163 m_track_m.setValues(*recoTracks[1], ip, recoTracksName, pxdInterceptsName, pxdTrackClustersName);
165 m_track_p.setValues(*recoTracks[1], ip, recoTracksName, pxdInterceptsName, pxdTrackClustersName);
166 m_track_m.setValues(*recoTracks[0], ip, recoTracksName, pxdInterceptsName, pxdTrackClustersName);
static ROOT::Math::XYZVector getFieldInTesla(const ROOT::Math::XYZVector &pos)
return the magnetic field at a given position in Tesla.
static const ChargedStable pion
charged pion particle
float m_vy
Position of the vertex in y.
float m_vz
Position of the vertex in z.
T m_track_m
Track with the negative charge.
float m_vx
Position of the vertex in x.
T m_track_p
Track with the positive charge.
bool isValid() const
Check wether the array was registered.
int getEntries() const
Get the number of objects in the array.
static void initialize(int verbosity=1, double MagneticField=1.5)
Set everything up so everything needed for vertex fitting is there.
static RaveSetup * getInstance()
get the pointer to the instance to get/set any of options stored in RaveSetup
void reset()
frees memory allocated by initialize().