23 m_ip2d_trackParticleLinks(
"IP2D_TrackParticleLinks"),
24 m_ip3d_trackParticleLinks(
"IP3D_TrackParticleLinks"),
25 m_ip2d_gradeOfTracks(
"IP2D_gradeOfTracks"),
26 m_ip3d_gradeOfTracks(
"IP3D_gradeOfTracks"),
27 m_ip2d_signed_d0(
"IP2D_signed_d0"),
28 m_ip3d_signed_d0(
"IP3D_signed_d0"),
29 m_ip3d_signed_z0_sin_theta(
"IP3D_signed_z0"),
30 m_ip3d_signed_d0_significance(
"IP3D_signed_d0_significance"),
31 m_ip3d_signed_z0_sin_theta_significance(
"IP3D_signed_z0_significance"),
32 m_ip2d_grade(
"IP2D_grade"),
33 m_ip3d_grade(
"IP3D_grade"),
39 Amg::Vector3D get_vector3d(
const std::vector<float> &input_vector) {
40 if (input_vector.size() != 3) {
42 throw std::logic_error(
43 "Tried to build an Eigen 3-vector from " +
size +
" elements");
45 return Eigen::Vector3f(input_vector.data()).cast<
double>();
55 const TLorentzVector jet_fourVector =
jet.p4();
56 const Amg::Vector3D jet_threeVector(jet_fourVector.X(),jet_fourVector.Y(),jet_fourVector.Z());
62 ip.ip2d_signed_d0 = std::copysign(ip_d0,
std::sin(jet_threeVector.phi() - track_momentum.phi()) * ip_d0);
63 const double ip3d_signed_d0 = std::copysign(ip_d0, jet_threeVector.cross(track_momentum).dot(track_momentum.cross(-track_displacement)));
64 ip.ip3d_signed_d0 = ip3d_signed_d0;
68 const double signed_z0_sin_theta = std::copysign(ip_z0, (jet_threeVector.eta() - track_momentum.eta()) * ip_z0);
69 ip.ip3d_signed_z0_sin_theta = signed_z0_sin_theta;
80 std::hypot(track_displacement[
Amg::x], track_displacement[
Amg::y]),
81 track_momentum.cross(track_displacement)[
Amg::z]);
90 return track_displacement[
Amg::z] * std::sqrt(
91 1 -
std::pow(track_momentum[
Amg::z],2) / track_momentum.squaredNorm());
109 for (std::size_t ip3d_track_index = 0; ip3d_track_index < ip3d_tracks.size(); ++ip3d_track_index) {
110 if (&
track == *(ip3d_tracks.at(ip3d_track_index))) {
119 for (std::size_t ip2d_track_index = 0; ip2d_track_index < ip2d_tracks.size(); ++ip2d_track_index) {
120 if (&
track == *(ip2d_tracks.at(ip2d_track_index))) {