ATLAS Offline Software
Public Member Functions | Private Types | Private Attributes | List of all members
BTagTrackIpAccessor Class Reference

#include <BTagTrackIpAccessor.h>

Collaboration diagram for BTagTrackIpAccessor:

Public Member Functions

 BTagTrackIpAccessor (const std::string &prefix)
 
void augment (const xAOD::TrackParticle &track, const xAOD::Jet &jet) const
 
void augment_with_grades (const xAOD::TrackParticle &track, const xAOD::Jet &jet) const
 
void augment_with_ip (const xAOD::TrackParticle &track, const xAOD::Jet &jet) const
 
double d0 (const xAOD::TrackParticle &track) const
 
double d0Uncertainty (const xAOD::TrackParticle &track) const
 
double z0SinTheta (const xAOD::TrackParticle &track) const
 
double z0SinThetaUncertainty (const xAOD::TrackParticle &track) const
 
BTagSignedIP getSignedIp (const xAOD::TrackParticle &track, const xAOD::Jet &jet) const
 
std::set< std::string > getTrackIpDataDependencyNames () const
 

Private Types

typedef SG::AuxElement AE
 

Private Attributes

AE::ConstAccessor< float > m_ip_d0_sigma
 
AE::ConstAccessor< float > m_ip_z0_sigma
 
AE::ConstAccessor< std::vector< float > > m_track_displacement
 
AE::ConstAccessor< std::vector< float > > m_track_momentum
 
AE::ConstAccessor< std::vector< ElementLink< xAOD::TrackParticleContainer > > > m_ip2d_trackParticleLinks
 
AE::ConstAccessor< std::vector< ElementLink< xAOD::TrackParticleContainer > > > m_ip3d_trackParticleLinks
 
AE::ConstAccessor< std::vector< int > > m_ip2d_gradeOfTracks
 
AE::ConstAccessor< std::vector< int > > m_ip3d_gradeOfTracks
 
AE::Decorator< float > m_ip2d_signed_d0
 
AE::Decorator< float > m_ip3d_signed_d0
 
AE::Decorator< float > m_ip3d_signed_z0
 
AE::Decorator< float > m_ip3d_signed_d0_significance
 
AE::Decorator< float > m_ip3d_signed_z0_significance
 
AE::Decorator< int > m_ip2d_grade
 
AE::Decorator< int > m_ip3d_grade
 
std::string m_prefix
 

Detailed Description

Definition at line 29 of file BTagTrackIpAccessor.h.

Member Typedef Documentation

◆ AE

Definition at line 58 of file BTagTrackIpAccessor.h.

Constructor & Destructor Documentation

◆ BTagTrackIpAccessor()

BTagTrackIpAccessor::BTagTrackIpAccessor ( const std::string &  prefix)

Definition at line 18 of file BTagTrackIpAccessor.cxx.

18  :
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("IP3D_signed_z0"),
30  m_ip3d_signed_d0_significance("IP3D_signed_d0_significance"),
31  m_ip3d_signed_z0_significance("IP3D_signed_z0_significance"),
32  m_ip2d_grade("IP2D_grade"),
33  m_ip3d_grade("IP3D_grade"),
35 {
36 }

Member Function Documentation

◆ augment()

void BTagTrackIpAccessor::augment ( const xAOD::TrackParticle track,
const xAOD::Jet jet 
) const

Definition at line 49 of file BTagTrackIpAccessor.cxx.

49  {
52 }

◆ augment_with_grades()

void BTagTrackIpAccessor::augment_with_grades ( const xAOD::TrackParticle track,
const xAOD::Jet jet 
) const

Definition at line 105 of file BTagTrackIpAccessor.cxx.

105  {
106  int ip3d_grade = -1;
108  const std::vector<ElementLink<xAOD::TrackParticleContainer> > ip3d_tracks = m_ip3d_trackParticleLinks(btagging);
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))) {
111  ip3d_grade = m_ip3d_gradeOfTracks(btagging).at(ip3d_track_index);
112  break;
113  }
114  }
115  m_ip3d_grade(track) = ip3d_grade;
116 
117  int ip2d_grade = -1;
118  const std::vector<ElementLink<xAOD::TrackParticleContainer> > ip2d_tracks = m_ip2d_trackParticleLinks(btagging);
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))) {
121  ip2d_grade = m_ip2d_gradeOfTracks(btagging).at(ip2d_track_index);
122  break;
123  }
124  }
125  m_ip2d_grade(track) = ip2d_grade;
126 }

◆ augment_with_ip()

void BTagTrackIpAccessor::augment_with_ip ( const xAOD::TrackParticle track,
const xAOD::Jet jet 
) const

Definition at line 97 of file BTagTrackIpAccessor.cxx.

97  {
99  m_ip2d_signed_d0(track) = ip.ip2d_signed_d0;
100  m_ip3d_signed_d0(track) = ip.ip3d_signed_d0;
101  m_ip3d_signed_d0_significance(track) = ip.ip3d_signed_d0_significance;
102  m_ip3d_signed_z0(track) = ip.ip3d_signed_z0;
103  m_ip3d_signed_z0_significance(track) = ip.ip3d_signed_z0_significance;
104 }

◆ d0()

double BTagTrackIpAccessor::d0 ( const xAOD::TrackParticle track) const

Definition at line 76 of file BTagTrackIpAccessor.cxx.

76  {
77  const Amg::Vector3D track_displacement = get_vector3d(m_track_displacement(track));
78  const Amg::Vector3D track_momentum = get_vector3d(m_track_momentum(track));
79  return std::copysign(
80  std::hypot(track_displacement[Amg::x], track_displacement[Amg::y]),
81  track_momentum.cross(track_displacement)[Amg::z]);
82 }

◆ d0Uncertainty()

double BTagTrackIpAccessor::d0Uncertainty ( const xAOD::TrackParticle track) const

Definition at line 83 of file BTagTrackIpAccessor.cxx.

84  {
85  return m_ip_d0_sigma(track);
86 }

◆ getSignedIp()

BTagSignedIP BTagTrackIpAccessor::getSignedIp ( const xAOD::TrackParticle track,
const xAOD::Jet jet 
) const

Definition at line 54 of file BTagTrackIpAccessor.cxx.

54  {
55  const TLorentzVector jet_fourVector = jet.p4();
56  const Amg::Vector3D jet_threeVector(jet_fourVector.X(),jet_fourVector.Y(),jet_fourVector.Z());
57  const Amg::Vector3D track_displacement = get_vector3d(m_track_displacement(track));
58  const Amg::Vector3D track_momentum = get_vector3d(m_track_momentum(track));
59 
61  const double ip_d0 = d0(track);
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;
65  ip.ip3d_signed_d0_significance = ip3d_signed_d0 / m_ip_d0_sigma(track);
66 
67  const double ip_z0 = z0SinTheta(track);
68  const double signed_z0 = std::copysign(ip_z0, (jet_threeVector.eta() - track_momentum.eta()) * ip_z0);
69  ip.ip3d_signed_z0 = signed_z0;
70  ip.ip3d_signed_z0_significance = signed_z0 / m_ip_z0_sigma(track);
71  ip.ip2d_grade = 0;
72  ip.ip3d_grade = 0;
73  return ip;
74 }

◆ getTrackIpDataDependencyNames()

std::set< std::string > BTagTrackIpAccessor::getTrackIpDataDependencyNames ( ) const

Definition at line 128 of file BTagTrackIpAccessor.cxx.

◆ z0SinTheta()

double BTagTrackIpAccessor::z0SinTheta ( const xAOD::TrackParticle track) const

Definition at line 87 of file BTagTrackIpAccessor.cxx.

87  {
88  const Amg::Vector3D track_displacement = get_vector3d(m_track_displacement(track));
89  const Amg::Vector3D track_momentum = get_vector3d(m_track_momentum(track));
90  return track_displacement[Amg::z] * std::sqrt(
91  1 - std::pow(track_momentum[Amg::z],2) / track_momentum.squaredNorm());
92 }

◆ z0SinThetaUncertainty()

double BTagTrackIpAccessor::z0SinThetaUncertainty ( const xAOD::TrackParticle track) const

Definition at line 93 of file BTagTrackIpAccessor.cxx.

93  {
94  return m_ip_z0_sigma(track);
95 }

Member Data Documentation

◆ m_ip2d_grade

AE::Decorator<int> BTagTrackIpAccessor::m_ip2d_grade
private

Definition at line 73 of file BTagTrackIpAccessor.h.

◆ m_ip2d_gradeOfTracks

AE::ConstAccessor<std::vector<int> > BTagTrackIpAccessor::m_ip2d_gradeOfTracks
private

Definition at line 66 of file BTagTrackIpAccessor.h.

◆ m_ip2d_signed_d0

AE::Decorator<float> BTagTrackIpAccessor::m_ip2d_signed_d0
private

Definition at line 68 of file BTagTrackIpAccessor.h.

◆ m_ip2d_trackParticleLinks

AE::ConstAccessor<std::vector<ElementLink<xAOD::TrackParticleContainer> > > BTagTrackIpAccessor::m_ip2d_trackParticleLinks
private

Definition at line 64 of file BTagTrackIpAccessor.h.

◆ m_ip3d_grade

AE::Decorator<int> BTagTrackIpAccessor::m_ip3d_grade
private

Definition at line 74 of file BTagTrackIpAccessor.h.

◆ m_ip3d_gradeOfTracks

AE::ConstAccessor<std::vector<int> > BTagTrackIpAccessor::m_ip3d_gradeOfTracks
private

Definition at line 67 of file BTagTrackIpAccessor.h.

◆ m_ip3d_signed_d0

AE::Decorator<float> BTagTrackIpAccessor::m_ip3d_signed_d0
private

Definition at line 69 of file BTagTrackIpAccessor.h.

◆ m_ip3d_signed_d0_significance

AE::Decorator<float> BTagTrackIpAccessor::m_ip3d_signed_d0_significance
private

Definition at line 71 of file BTagTrackIpAccessor.h.

◆ m_ip3d_signed_z0

AE::Decorator<float> BTagTrackIpAccessor::m_ip3d_signed_z0
private

Definition at line 70 of file BTagTrackIpAccessor.h.

◆ m_ip3d_signed_z0_significance

AE::Decorator<float> BTagTrackIpAccessor::m_ip3d_signed_z0_significance
private

Definition at line 72 of file BTagTrackIpAccessor.h.

◆ m_ip3d_trackParticleLinks

AE::ConstAccessor<std::vector<ElementLink<xAOD::TrackParticleContainer> > > BTagTrackIpAccessor::m_ip3d_trackParticleLinks
private

Definition at line 65 of file BTagTrackIpAccessor.h.

◆ m_ip_d0_sigma

AE::ConstAccessor<float> BTagTrackIpAccessor::m_ip_d0_sigma
private

Definition at line 60 of file BTagTrackIpAccessor.h.

◆ m_ip_z0_sigma

AE::ConstAccessor<float> BTagTrackIpAccessor::m_ip_z0_sigma
private

Definition at line 61 of file BTagTrackIpAccessor.h.

◆ m_prefix

std::string BTagTrackIpAccessor::m_prefix
private

Definition at line 76 of file BTagTrackIpAccessor.h.

◆ m_track_displacement

AE::ConstAccessor<std::vector<float> > BTagTrackIpAccessor::m_track_displacement
private

Definition at line 62 of file BTagTrackIpAccessor.h.

◆ m_track_momentum

AE::ConstAccessor<std::vector<float> > BTagTrackIpAccessor::m_track_momentum
private

Definition at line 63 of file BTagTrackIpAccessor.h.


The documentation for this class was generated from the following files:
str::trackMomentum
const std::string trackMomentum
Definition: BTagTrackIpAccessor.cxx:15
BTagTrackIpAccessor::m_ip3d_signed_z0
AE::Decorator< float > m_ip3d_signed_z0
Definition: BTagTrackIpAccessor.h:70
BTagTrackIpAccessor::m_track_displacement
AE::ConstAccessor< std::vector< float > > m_track_displacement
Definition: BTagTrackIpAccessor.h:62
BTagTrackIpAccessor::d0
double d0(const xAOD::TrackParticle &track) const
Definition: BTagTrackIpAccessor.cxx:76
conifer::pow
constexpr int pow(int x)
Definition: conifer.h:20
Amg::y
@ y
Definition: GeoPrimitives.h:35
BTagTrackIpAccessor::m_ip3d_signed_z0_significance
AE::Decorator< float > m_ip3d_signed_z0_significance
Definition: BTagTrackIpAccessor.h:72
str::z0SinThetaUncertainty
const std::string z0SinThetaUncertainty
Definition: BTagTrackIpAccessor.cxx:13
BTagSignedIP
Definition: BTagTrackIpAccessor.h:19
Amg::z
@ z
Definition: GeoPrimitives.h:36
BTagTrackIpAccessor::augment_with_ip
void augment_with_ip(const xAOD::TrackParticle &track, const xAOD::Jet &jet) const
Definition: BTagTrackIpAccessor.cxx:97
jet
Definition: JetCalibTools_PlotJESFactors.cxx:23
BTagTrackIpAccessor::m_ip3d_gradeOfTracks
AE::ConstAccessor< std::vector< int > > m_ip3d_gradeOfTracks
Definition: BTagTrackIpAccessor.h:67
Amg::x
@ x
Definition: GeoPrimitives.h:34
BTagTrackIpAccessor::m_prefix
std::string m_prefix
Definition: BTagTrackIpAccessor.h:76
str::trackDisplacement
const std::string trackDisplacement
Definition: BTagTrackIpAccessor.cxx:14
checkCorrelInHIST.prefix
dictionary prefix
Definition: checkCorrelInHIST.py:391
BTagTrackIpAccessor::m_ip2d_signed_d0
AE::Decorator< float > m_ip2d_signed_d0
Definition: BTagTrackIpAccessor.h:68
find_tgc_unfilled_channelids.ip
ip
Definition: find_tgc_unfilled_channelids.py:3
BTagTrackIpAccessor::m_ip_d0_sigma
AE::ConstAccessor< float > m_ip_d0_sigma
Definition: BTagTrackIpAccessor.h:60
BTagTrackIpAccessor::m_ip2d_trackParticleLinks
AE::ConstAccessor< std::vector< ElementLink< xAOD::TrackParticleContainer > > > m_ip2d_trackParticleLinks
Definition: BTagTrackIpAccessor.h:64
xAOD::BTagging_v1
Definition: BTagging_v1.h:39
BTagTrackIpAccessor::m_ip3d_signed_d0
AE::Decorator< float > m_ip3d_signed_d0
Definition: BTagTrackIpAccessor.h:69
BTagTrackIpAccessor::z0SinTheta
double z0SinTheta(const xAOD::TrackParticle &track) const
Definition: BTagTrackIpAccessor.cxx:87
Amg::Vector3D
Eigen::Matrix< double, 3, 1 > Vector3D
Definition: GeoPrimitives.h:47
BTagTrackIpAccessor::m_ip3d_signed_d0_significance
AE::Decorator< float > m_ip3d_signed_d0_significance
Definition: BTagTrackIpAccessor.h:71
BTagTrackIpAccessor::m_ip_z0_sigma
AE::ConstAccessor< float > m_ip_z0_sigma
Definition: BTagTrackIpAccessor.h:61
xAOD::BTaggingUtilities::getBTagging
const BTagging * getBTagging(const SG::AuxElement &part)
Access the default xAOD::BTagging object associated to an object.
Definition: BTaggingUtilities.cxx:37
BTagTrackIpAccessor::m_ip2d_grade
AE::Decorator< int > m_ip2d_grade
Definition: BTagTrackIpAccessor.h:73
xAOD::track
@ track
Definition: TrackingPrimitives.h:512
drawFromPickle.sin
sin
Definition: drawFromPickle.py:36
BTagTrackIpAccessor::m_track_momentum
AE::ConstAccessor< std::vector< float > > m_track_momentum
Definition: BTagTrackIpAccessor.h:63
BTagTrackIpAccessor::m_ip3d_trackParticleLinks
AE::ConstAccessor< std::vector< ElementLink< xAOD::TrackParticleContainer > > > m_ip3d_trackParticleLinks
Definition: BTagTrackIpAccessor.h:65
BTagTrackIpAccessor::m_ip2d_gradeOfTracks
AE::ConstAccessor< std::vector< int > > m_ip2d_gradeOfTracks
Definition: BTagTrackIpAccessor.h:66
BTagTrackIpAccessor::m_ip3d_grade
AE::Decorator< int > m_ip3d_grade
Definition: BTagTrackIpAccessor.h:74
BTagTrackIpAccessor::augment_with_grades
void augment_with_grades(const xAOD::TrackParticle &track, const xAOD::Jet &jet) const
Definition: BTagTrackIpAccessor.cxx:105
str::d0Uncertainty
const std::string d0Uncertainty
Definition: BTagTrackIpAccessor.cxx:12
BTagTrackIpAccessor::getSignedIp
BTagSignedIP getSignedIp(const xAOD::TrackParticle &track, const xAOD::Jet &jet) const
Definition: BTagTrackIpAccessor.cxx:54