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

Steven Schramm
February 2014. More...

#include <JetTrackMomentsTool.h>

Inheritance diagram for JetTrackMomentsTool:
Collaboration diagram for JetTrackMomentsTool:

Classes

struct  TrackMomentStruct
 

Public Member Functions

 JetTrackMomentsTool (const std::string &name)
 
StatusCode initialize () override
 Dummy implementation of the initialisation function. More...
 
virtual StatusCode decorate (const xAOD::JetContainer &jets) const override
 Decorate a jet collection without otherwise modifying it. More...
 
virtual void print () const
 Print the state of the tool. More...
 
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc. More...
 
const ServiceHandle< StoreGateSvc > & evtStore () const
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc. More...
 
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc. More...
 
virtual StatusCode sysInitialize () override
 Perform system initialization for an algorithm. More...
 
virtual StatusCode sysStart () override
 Handle START transition. More...
 
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles. More...
 
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles. More...
 
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T > &t)
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleKey &hndl, const std::string &doc, const SG::VarHandleKeyType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleBase &hndl, const std::string &doc, const SG::VarHandleType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleKeyArray &hndArr, const std::string &doc, const SG::VarHandleKeyArrayType &)
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, T &property, const std::string &doc, const SG::NotHandleType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, T &property, const std::string &doc="none")
 Declare a new Gaudi property. More...
 
void updateVHKA (Gaudi::Details::PropertyBase &)
 
MsgStream & msg () const
 
MsgStream & msg (const MSG::Level lvl) const
 
bool msgLvl (const MSG::Level lvl) const
 
virtual StatusCode modify (xAOD::JetContainer &jets) const override final
 Concrete implementation of the function inherited from IJetModifier. More...
 

Protected Member Functions

void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution More...
 
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce (T &h)
 
void extraDeps_update_handler (Gaudi::Details::PropertyBase &ExtraDeps)
 Add StoreName to extra input/output deps as needed. More...
 

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t
 

Private Member Functions

const std::vector< TrackMomentStructgetTrackMoments (const xAOD::Jet &jet, const xAOD::VertexContainer *vertices, const float minTrackPt, const std::vector< const xAOD::TrackParticle * > &tracks, const jet::TrackVertexAssociation *tva) const
 
TrackMomentStruct getTrackMoments (const xAOD::Jet &, const xAOD::Vertex *vertex, const float minTrackPt, const std::vector< const xAOD::TrackParticle * > &tracks, const jet::TrackVertexAssociation *tva) const
 
const std::string getMomentBaseName (const float minTrackPt) const
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleKeyArrayType &)
 specialization for handling Gaudi::Property<SG::VarHandleKeyArray> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleType &)
 specialization for handling Gaudi::Property<SG::VarHandleBase> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &t, const SG::NotHandleType &)
 specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray> More...
 

Private Attributes

Gaudi::Property< std::string > m_jetContainerName {this, "JetContainer", "", "SG key for input jet container"}
 
Gaudi::Property< std::string > m_assocTracksName {this, "AssociatedTracks", "", "Name of associated tracks collection"}
 
Gaudi::Property< std::string > m_suffix {this, "MomentSuffix", "", "Suffix for track moment decorations"}
 
Gaudi::Property< std::vector< float > > m_minTrackPt {this, "TrackMinPtCuts", {}, "Vector of track pt cuts"}
 
Gaudi::Property< bool > m_doPFlowMoments {this, "DoPFlowMoments", false, "Calculate PFlow Object track moments?"}
 
ToolHandle< InDet::IInDetTrackSelectionToolm_htsel {this, "TrackSelector", "", "track selection tool"}
 
SG::ReadHandleKey< xAOD::VertexContainerm_vertexContainer_key {this, "VertexContainer", "", "SG key for vertex container"}
 
SG::ReadHandleKey< jet::TrackVertexAssociationm_tva_key {this, "TrackVertexAssociation", "", "SG key for track-vertex association"}
 
SG::WriteDecorHandleKeyArray< xAOD::JetContainerm_keysNumTrk {this, "NumTrkDecorKeys", {}, "SG keys for NumTrk decoration (not to be configured manually!)"}
 
SG::WriteDecorHandleKeyArray< xAOD::JetContainerm_keysSumPtTrk {this, "SumPtTrkDecorKeys", {}, "SG keys for SumPtTrk decoration (not to be configured manually!)"}
 
SG::WriteDecorHandleKeyArray< xAOD::JetContainerm_keysTrkWidth {this, "TrackWidthDecorKeys", {}, "SG keys for TrackWidth decoration (not to be configured manually!)"}
 
SG::WriteDecorHandleKeyArray< xAOD::JetContainerm_keysNumCPFO {this, "NumChargedPFODecorKeys", {}, "SG keys for NumChargedPFO decoration (not to be configured manually!)"}
 
SG::WriteDecorHandleKeyArray< xAOD::JetContainerm_keysSumPtCPFO {this, "SumPtChargedPFODecorKeys", {}, "SG keys for SumPtChargedPFO decoration (not to be configured manually!)"}
 
SG::WriteDecorHandleKeyArray< xAOD::JetContainerm_keysCPFOWidth {this, "ChargedPFOWidthDecorKeys", {}, "SG keys for ChargedPFO Width decoration (not to be configured manually!)"}
 
StoreGateSvc_t m_evtStore
 Pointer to StoreGate (event store by default) More...
 
StoreGateSvc_t m_detStore
 Pointer to StoreGate (detector store by default) More...
 
std::vector< SG::VarHandleKeyArray * > m_vhka
 
bool m_varHandleArraysDeclared
 

Detailed Description

Steven Schramm
February 2014.

Updated for Run 3 by Bill Balunas March 2020

Tool to calculate general track-based jet moments

Moments to calculate: NumTrkPtXXX SumPtTrkPtXXX TrackWidthPtXXX where the track pT threshold is XXX MeV.

Definition at line 41 of file JetTrackMomentsTool.h.

Member Typedef Documentation

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< AlgTool > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

Constructor & Destructor Documentation

◆ JetTrackMomentsTool()

JetTrackMomentsTool::JetTrackMomentsTool ( const std::string &  name)

Definition at line 13 of file JetTrackMomentsTool.cxx.

15 {
16 }

Member Function Documentation

◆ declareGaudiProperty() [1/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T > &  hndl,
const SG::VarHandleKeyArrayType  
)
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleKeyArray>

Definition at line 170 of file AthCommonDataStore.h.

172  {
173  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
174  hndl.value(),
175  hndl.documentation());
176 
177  }

◆ declareGaudiProperty() [2/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T > &  hndl,
const SG::VarHandleKeyType  
)
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleKey>

Definition at line 156 of file AthCommonDataStore.h.

158  {
159  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
160  hndl.value(),
161  hndl.documentation());
162 
163  }

◆ declareGaudiProperty() [3/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T > &  hndl,
const SG::VarHandleType  
)
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleBase>

Definition at line 184 of file AthCommonDataStore.h.

186  {
187  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
188  hndl.value(),
189  hndl.documentation());
190  }

◆ declareGaudiProperty() [4/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T > &  t,
const SG::NotHandleType  
)
inlineprivateinherited

specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray>

Definition at line 199 of file AthCommonDataStore.h.

200  {
201  return PBASE::declareProperty(t);
202  }

◆ declareProperty() [1/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
SG::VarHandleBase hndl,
const std::string &  doc,
const SG::VarHandleType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
hndlObject holding the property value.
docDocumentation string for the property.

This is the version for types that derive from SG::VarHandleBase. The property value object is put on the input and output lists as appropriate; then we forward to the base class.

Definition at line 245 of file AthCommonDataStore.h.

249  {
250  this->declare(hndl.vhKey());
251  hndl.vhKey().setOwner(this);
252 
253  return PBASE::declareProperty(name,hndl,doc);
254  }

◆ declareProperty() [2/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
SG::VarHandleKey hndl,
const std::string &  doc,
const SG::VarHandleKeyType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
hndlObject holding the property value.
docDocumentation string for the property.

This is the version for types that derive from SG::VarHandleKey. The property value object is put on the input and output lists as appropriate; then we forward to the base class.

Definition at line 221 of file AthCommonDataStore.h.

225  {
226  this->declare(hndl);
227  hndl.setOwner(this);
228 
229  return PBASE::declareProperty(name,hndl,doc);
230  }

◆ declareProperty() [3/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
SG::VarHandleKeyArray hndArr,
const std::string &  doc,
const SG::VarHandleKeyArrayType  
)
inlineinherited

Definition at line 259 of file AthCommonDataStore.h.

263  {
264 
265  // std::ostringstream ost;
266  // ost << Algorithm::name() << " VHKA declareProp: " << name
267  // << " size: " << hndArr.keys().size()
268  // << " mode: " << hndArr.mode()
269  // << " vhka size: " << m_vhka.size()
270  // << "\n";
271  // debug() << ost.str() << endmsg;
272 
273  hndArr.setOwner(this);
274  m_vhka.push_back(&hndArr);
275 
276  Gaudi::Details::PropertyBase* p = PBASE::declareProperty(name, hndArr, doc);
277  if (p != 0) {
278  p->declareUpdateHandler(&AthCommonDataStore<PBASE>::updateVHKA, this);
279  } else {
280  ATH_MSG_ERROR("unable to call declareProperty on VarHandleKeyArray "
281  << name);
282  }
283 
284  return p;
285 
286  }

◆ declareProperty() [4/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
T &  property,
const std::string &  doc,
const SG::NotHandleType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
propertyObject holding the property value.
docDocumentation string for the property.

This is the generic version, for types that do not derive from SG::VarHandleKey. It just forwards to the base class version of declareProperty.

Definition at line 333 of file AthCommonDataStore.h.

337  {
338  return PBASE::declareProperty(name, property, doc);
339  }

◆ declareProperty() [5/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
T &  property,
const std::string &  doc = "none" 
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
propertyObject holding the property value.
docDocumentation string for the property.

This dispatches to either the generic declareProperty or the one for VarHandle/Key/KeyArray.

Definition at line 352 of file AthCommonDataStore.h.

355  {
356  typedef typename SG::HandleClassifier<T>::type htype;
357  return declareProperty (name, property, doc, htype());
358  }

◆ declareProperty() [6/6]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( Gaudi::Property< T > &  t)
inlineinherited

Definition at line 145 of file AthCommonDataStore.h.

145  {
146  typedef typename SG::HandleClassifier<T>::type htype;
148  }

◆ decorate()

StatusCode JetTrackMomentsTool::decorate ( const xAOD::JetContainer jets) const
overridevirtual

Decorate a jet collection without otherwise modifying it.

Implements IJetDecorator.

Definition at line 64 of file JetTrackMomentsTool.cxx.

64  {
65 
66  // Get input vertex collection
67  auto handle_v = SG::makeHandle (m_vertexContainer_key);
68  if (!handle_v.isValid()){
69  ATH_MSG_ERROR("Could not retrieve the VertexContainer: "
70  << m_vertexContainer_key.key());
71  return StatusCode::FAILURE;
72  }
73 
74  const auto *vertexContainer = handle_v.cptr();
75 
76  // Get the track-vertex association
77  auto handle_tva = SG::makeHandle (m_tva_key);
78  if (!handle_tva.isValid()){
79  ATH_MSG_ERROR("Could not retrieve the TrackVertexAssociation: "
80  << m_tva_key.key());
81  return StatusCode::FAILURE;
82  }
83 
84  const auto *tva = handle_tva.cptr();
85 
86  for(const xAOD::Jet* jet : jets){
87  ATH_MSG_VERBOSE("On jet " << jet->index());
88 
89  // Retrieve the associated tracks.
90  std::vector<const xAOD::TrackParticle*> tracks;
91  bool havetracks = jet->getAssociatedObjects(m_assocTracksName, tracks);
92  if(!havetracks) ATH_MSG_WARNING("Associated tracks not found: " << m_assocTracksName);
93  ATH_MSG_VERBOSE("Successfully retrieved track particles for jet " << jet->index());
94 
95  std::vector<const xAOD::TrackParticle*> pflowTracks;
96  bool isPFlowJet = false;
97  if(m_doPFlowMoments) {
98  // Check if this is a PFlow jet. If so, get the PFO tracks.
99  xAOD::Type::ObjectType ctype = jet->rawConstituent(0)->type();
100  if (ctype == xAOD::Type::ParticleFlow) {
101  isPFlowJet = true;
102  size_t numConstit = jet->numConstituents();
103  for ( size_t i=0; i<numConstit; i++ ) {
104  const xAOD::PFO* constit = dynamic_cast<const xAOD::PFO*>(jet->rawConstituent(i));
105  if (constit->isCharged()){
106  const xAOD::TrackParticle *thisTrack = constit->track(0);//by construction xAOD::PFO can only have one track, in eflowRec usage
107  pflowTracks.push_back(thisTrack);
108  }// We have a charged PFO
109  }// Loop on jet constituents
110  }// This jet is either a PFlow jet (constituent type: xAOD::FlowElement::PFlow) or UFO jets
111  else if (ctype == xAOD::Type::FlowElement) {
112  isPFlowJet = true;
113  size_t numConstit = jet->numConstituents();
114  for ( size_t i=0; i<numConstit; i++ ) {
115  const xAOD::FlowElement* constit = dynamic_cast<const xAOD::FlowElement*>(jet->rawConstituent(i));
116  // UFO jet constituents have signalType xAOD::FlowElement::Charged or xAOD::FlowElement::Neutral
117  // PFlow jet constituents have signalType xAOD::FlowElement::ChargedPFlow or xAOD::FlowElement::NeutralPFlow
118  if(constit != nullptr && ((constit->signalType() & xAOD::FlowElement::PFlow) || constit->signalType() == xAOD::FlowElement::Charged)){
119  if (constit->isCharged()){
120  const xAOD::TrackParticle *thisTrack = dynamic_cast<const xAOD::TrackParticle*>(constit->chargedObject(0));//PFO should have only 1 track
121  if(thisTrack != nullptr) pflowTracks.push_back(thisTrack);
122  else ATH_MSG_WARNING("Charged PFO had no associated TrackParticle");
123  }// We have a charged PFO
124  }// The FlowElement is a PFO
125  }// Loop on jet constituents
126  }// This jet is made from xAOD::FlowElement, so we calculate the pflow moments if they're PFOs
127  }// We actually want to calculate the PFlow moments
128 
129  // For each track cut, compute and set the associated moments
130  for (size_t iCut = 0; iCut < m_minTrackPt.size(); ++iCut) {
134  // Get info
135  const float minPt = m_minTrackPt[iCut];
136  const std::vector<TrackMomentStruct> moments = getTrackMoments(*jet,vertexContainer,minPt,tracks,tva);
137  // Collate info
138  std::vector<int> numTrkVec; numTrkVec.resize(moments.size());
139  std::vector<float> sumPtTrkVec; sumPtTrkVec.resize(moments.size());
140  std::vector<float> trackWidthVec; trackWidthVec.resize(moments.size());
141  for ( size_t iVertex = 0; iVertex < moments.size(); ++iVertex ) {
142  numTrkVec[iVertex] = moments.at(iVertex).numTrk;
143  sumPtTrkVec[iVertex] = moments.at(iVertex).sumPtTrk;
144  trackWidthVec[iVertex] = moments.at(iVertex).trackWidth;
145  }
146  // Set moment decorations
147  numTrkHandle(*jet) = numTrkVec;
148  sumPtTrkHandle(*jet) = sumPtTrkVec;
149  trkWidthHandle(*jet) = trackWidthVec;
150 
151  if(m_doPFlowMoments) {
155  if(isPFlowJet){
156 
157  const std::vector<TrackMomentStruct> pflowMoments = getTrackMoments(*jet,vertexContainer,minPt,pflowTracks,tva);
158 
159  std::vector<int> pflowNumTrkVec; pflowNumTrkVec.resize(pflowMoments.size());
160  std::vector<float> pflowSumPtTrkVec; pflowSumPtTrkVec.resize(pflowMoments.size());
161  std::vector<float> pflowTrackWidthVec; pflowTrackWidthVec.resize(pflowMoments.size());
162  for ( size_t iVertex = 0; iVertex < pflowMoments.size(); ++iVertex ) {
163  pflowNumTrkVec[iVertex] = pflowMoments.at(iVertex).numTrk;
164  pflowSumPtTrkVec[iVertex] = pflowMoments.at(iVertex).sumPtTrk;
165  pflowTrackWidthVec[iVertex] = pflowMoments.at(iVertex).trackWidth;
166  }
167  // Set moment decorations
168  numCPFOHandle(*jet) = pflowNumTrkVec;
169  sumPtCPFOHandle(*jet) = pflowSumPtTrkVec;
170  cPFOWidthHandle(*jet) = pflowTrackWidthVec;
171  }
172  else{
173  // User configured for PFO track moments but this isn't a PFlow jet. Set them to empty vectors.
174  numCPFOHandle(*jet) = std::vector<int>();
175  sumPtCPFOHandle(*jet) = std::vector<float>();
176  cPFOWidthHandle(*jet) = std::vector<float>();
177  } // Should find a more graceful way to complain?
178  }// do PF moments
179  }
180  }
181 
182  return StatusCode::SUCCESS;
183 }

◆ detStore()

const ServiceHandle<StoreGateSvc>& AthCommonDataStore< AthCommonMsg< AlgTool > >::detStore ( ) const
inlineinherited

The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 95 of file AthCommonDataStore.h.

95 { return m_detStore; }

◆ evtStore() [1/2]

ServiceHandle<StoreGateSvc>& AthCommonDataStore< AthCommonMsg< AlgTool > >::evtStore ( )
inlineinherited

The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 85 of file AthCommonDataStore.h.

85 { return m_evtStore; }

◆ evtStore() [2/2]

const ServiceHandle<StoreGateSvc>& AthCommonDataStore< AthCommonMsg< AlgTool > >::evtStore ( ) const
inlineinherited

The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 90 of file AthCommonDataStore.h.

90 { return m_evtStore; }

◆ extraDeps_update_handler()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::extraDeps_update_handler ( Gaudi::Details::PropertyBase &  ExtraDeps)
protectedinherited

Add StoreName to extra input/output deps as needed.

use the logic of the VarHandleKey to parse the DataObjID keys supplied via the ExtraInputs and ExtraOuputs Properties to add the StoreName if it's not explicitly given

◆ getKey()

SG::sgkey_t asg::AsgTool::getKey ( const void *  ptr) const
inherited

Get the (hashed) key of an object that is in the event store.

This is a bit of a special one. StoreGateSvc and xAOD::TEvent both provide ways for getting the SG::sgkey_t key for an object that is in the store, based on a bare pointer. But they provide different interfaces for doing so.

In order to allow tools to efficiently perform this operation, they can use this helper function.

See also
asg::AsgTool::getName
Parameters
ptrThe bare pointer to the object that the event store should know about
Returns
The hashed key of the object in the store. If not found, an invalid (zero) key.

Definition at line 119 of file AsgTool.cxx.

119  {
120 
121 #ifdef XAOD_STANDALONE
122  // In case we use @c xAOD::TEvent, we have a direct function call
123  // for this.
124  return evtStore()->event()->getKey( ptr );
125 #else
126  const SG::DataProxy* proxy = evtStore()->proxy( ptr );
127  return ( proxy == nullptr ? 0 : proxy->sgkey() );
128 #endif // XAOD_STANDALONE
129  }

◆ getMomentBaseName()

const std::string JetTrackMomentsTool::getMomentBaseName ( const float  minTrackPt) const
private

Definition at line 251 of file JetTrackMomentsTool.cxx.

252 {
253  int value = round(minTrackPt);
254  if (fabs(value - minTrackPt) > 0.1)
255  ATH_MSG_WARNING("Cut float and int disagree: " << minTrackPt << " float vs " << value << " int");
256 
257  std::ostringstream sout;
258  sout << "Pt" << value;
259  return sout.str();
260 }

◆ getName()

const std::string & asg::AsgTool::getName ( const void *  ptr) const
inherited

Get the name of an object that is / should be in the event store.

This is a bit of a special one. StoreGateSvc and xAOD::TEvent both provide ways for getting the std::string name for an object that is in the store, based on a bare pointer. But they provide different interfaces for doing so.

In order to allow tools to efficiently perform this operation, they can use this helper function.

See also
asg::AsgTool::getKey
Parameters
ptrThe bare pointer to the object that the event store should know about
Returns
The string name of the object in the store. If not found, an empty string.

Definition at line 106 of file AsgTool.cxx.

106  {
107 
108 #ifdef XAOD_STANDALONE
109  // In case we use @c xAOD::TEvent, we have a direct function call
110  // for this.
111  return evtStore()->event()->getName( ptr );
112 #else
113  const SG::DataProxy* proxy = evtStore()->proxy( ptr );
114  static const std::string dummy = "";
115  return ( proxy == nullptr ? dummy : proxy->name() );
116 #endif // XAOD_STANDALONE
117  }

◆ getProperty()

template<class T >
const T* asg::AsgTool::getProperty ( const std::string &  name) const
inherited

Get one of the tool's properties.

◆ getTrackMoments() [1/2]

JetTrackMomentsTool::TrackMomentStruct JetTrackMomentsTool::getTrackMoments ( const xAOD::Jet jet,
const xAOD::Vertex vertex,
const float  minTrackPt,
const std::vector< const xAOD::TrackParticle * > &  tracks,
const jet::TrackVertexAssociation tva 
) const
private

Definition at line 197 of file JetTrackMomentsTool.cxx.

198 {
199  // Prepare the moments
200  TrackMomentStruct moments{};
201  moments.numTrk = 0;
202  moments.sumPtTrk = 0;
203  moments.trackWidth = 0;
204 
205  // Prepare const vars for jet eta/phi
206  const float jetEta = jet.eta();
207  const float jetPhi = jet.phi();
208 
209  // Track selection and counters
210  bool notsel = m_htsel.empty();
211  unsigned int nkeep = 0;
212  unsigned int nskip = 0;
213 
214  // Loop over the tracks
215  for (size_t iTrack = 0; iTrack < tracks.size(); ++iTrack)
216  {
217  const xAOD::TrackParticle* track = tracks.at(iTrack);
218  const float trackPt = track->pt();
219 
220  // Skip the track if it doesn't pass the cut
221  if (trackPt < minTrackPt)
222  continue;
223 
224  // Skip the track if it's not from the vertex in question
225  if( vertex == nullptr || vertex != tva->associatedVertex(track) ) continue ;
226 
227  // Check track passes track selection, otherwise mark as skipped
228  if ( notsel || m_htsel->accept(*track) ) {
229  ++nkeep;
230 
231  // Calculate necessary info for the moments
232  const double deltaR = xAOD::P4Helpers::deltaR(jetEta, jetPhi, track->eta(), track->phi() );
233 
234  // Adjust values as necessary for this track
235  moments.numTrk += 1;
236  moments.sumPtTrk += trackPt;
237  moments.trackWidth += deltaR * trackPt;
238  }
239  else { ++nskip;}
240  }
241 
242  // Finish processing the moments
243  moments.trackWidth = moments.sumPtTrk > 0 ? moments.trackWidth / moments.sumPtTrk : -1;
244 
245  ATH_MSG_DEBUG(" jet index= " << jet.index() << " pt="<<jet.pt()
246  << ": nsel=" << nkeep
247  << ", nrej=" << nskip << " minpt="<<minTrackPt);
248  return moments;
249 }

◆ getTrackMoments() [2/2]

const std::vector< JetTrackMomentsTool::TrackMomentStruct > JetTrackMomentsTool::getTrackMoments ( const xAOD::Jet jet,
const xAOD::VertexContainer vertices,
const float  minTrackPt,
const std::vector< const xAOD::TrackParticle * > &  tracks,
const jet::TrackVertexAssociation tva 
) const
private

Definition at line 186 of file JetTrackMomentsTool.cxx.

187 {
188  std::vector<TrackMomentStruct> moments;
189  moments.resize(vertices->size());
190 
191  for (size_t iVertex = 0; iVertex < vertices->size(); ++iVertex)
192  moments[iVertex] = getTrackMoments(jet,vertices->at(iVertex),minTrackPt,tracks,tva);
193 
194  return moments;
195 }

◆ initialize()

StatusCode JetTrackMomentsTool::initialize ( )
overridevirtual

Dummy implementation of the initialisation function.

It's here to allow the dual-use tools to skip defining an initialisation function. Since many are doing so...

Reimplemented from asg::AsgTool.

Definition at line 21 of file JetTrackMomentsTool.cxx.

21  {
22 
23  ATH_MSG_INFO("Initializing JetTrackMomentsTool " << name());
24  if ( m_htsel.empty() ) {
25  ATH_MSG_INFO(" No track selector.");
26  } else {
27  ATH_MSG_INFO(" Track selector: " << m_htsel->name());
28  }
29 
30  if(m_jetContainerName.empty()){
31  ATH_MSG_ERROR("JetTrackMomentsTool needs to have its input container name configured!");
32  return StatusCode::FAILURE;
33  }
34 
35  // Set up the decoration names for each track pt cut
36  for (size_t iCut = 0; iCut < m_minTrackPt.size(); ++iCut) {
37  const float minPt = m_minTrackPt[iCut];
38  const std::string baseName = getMomentBaseName(minPt);
39  m_keysNumTrk.emplace_back( m_jetContainerName + ".NumTrk" + baseName + m_suffix);
40  m_keysSumPtTrk.emplace_back(m_jetContainerName + ".SumPtTrk" + baseName + m_suffix);
41  m_keysTrkWidth.emplace_back(m_jetContainerName + ".TrackWidth" + baseName + m_suffix);
42  if(m_doPFlowMoments){
43  m_keysNumCPFO.emplace_back( m_jetContainerName + ".NumChargedPFO" + baseName + m_suffix);
44  m_keysSumPtCPFO.emplace_back(m_jetContainerName + ".SumPtChargedPFO" + baseName + m_suffix);
45  m_keysCPFOWidth.emplace_back(m_jetContainerName + ".ChargedPFOWidth" + baseName + m_suffix);
46  }
47  }
48 
49  ATH_CHECK(m_vertexContainer_key.initialize());
51  ATH_CHECK(m_keysNumTrk.initialize());
52  ATH_CHECK(m_keysSumPtTrk.initialize());
53  ATH_CHECK(m_keysTrkWidth.initialize());
57 
58  return StatusCode::SUCCESS;
59 }

◆ inputHandles()

virtual std::vector<Gaudi::DataHandle*> AthCommonDataStore< AthCommonMsg< AlgTool > >::inputHandles ( ) const
overridevirtualinherited

Return this algorithm's input handles.

We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.

◆ modify()

virtual StatusCode IJetDecorator::modify ( xAOD::JetContainer jets) const
inlinefinaloverridevirtualinherited

Concrete implementation of the function inherited from IJetModifier.

Implements IJetModifier.

Definition at line 32 of file IJetDecorator.h.

32 {return decorate(jets);};

◆ msg() [1/2]

MsgStream& AthCommonMsg< AlgTool >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

24  {
25  return this->msgStream();
26  }

◆ msg() [2/2]

MsgStream& AthCommonMsg< AlgTool >::msg ( const MSG::Level  lvl) const
inlineinherited

Definition at line 27 of file AthCommonMsg.h.

27  {
28  return this->msgStream(lvl);
29  }

◆ msg_level_name()

const std::string & asg::AsgTool::msg_level_name ( ) const
inherited

A deprecated function for getting the message level's name.

Instead of using this, weirdly named function, user code should get the string name of the current minimum message level (in case they really need it...), with:

MSG::name( msg().level() )

This function's name doesn't follow the ATLAS coding rules, and as such will be removed in the not too distant future.

Returns
The string name of the current minimum message level that's printed

Definition at line 101 of file AsgTool.cxx.

101  {
102 
103  return MSG::name( msg().level() );
104  }

◆ msgLvl()

bool AthCommonMsg< AlgTool >::msgLvl ( const MSG::Level  lvl) const
inlineinherited

Definition at line 30 of file AthCommonMsg.h.

30  {
31  return this->msgLevel(lvl);
32  }

◆ outputHandles()

virtual std::vector<Gaudi::DataHandle*> AthCommonDataStore< AthCommonMsg< AlgTool > >::outputHandles ( ) const
overridevirtualinherited

Return this algorithm's output handles.

We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.

◆ print()

void asg::AsgTool::print ( ) const
virtualinherited

◆ renounce()

std::enable_if_t<std::is_void_v<std::result_of_t<decltype(&T::renounce)(T)> > && !std::is_base_of_v<SG::VarHandleKeyArray, T> && std::is_base_of_v<Gaudi::DataHandle, T>, void> AthCommonDataStore< AthCommonMsg< AlgTool > >::renounce ( T &  h)
inlineprotectedinherited

Definition at line 380 of file AthCommonDataStore.h.

381  {
382  h.renounce();
383  PBASE::renounce (h);
384  }

◆ renounceArray()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::renounceArray ( SG::VarHandleKeyArray handlesArray)
inlineprotectedinherited

remove all handles from I/O resolution

Definition at line 364 of file AthCommonDataStore.h.

364  {
365  handlesArray.renounce();
366  }

◆ sysInitialize()

virtual StatusCode AthCommonDataStore< AthCommonMsg< AlgTool > >::sysInitialize ( )
overridevirtualinherited

Perform system initialization for an algorithm.

We override this to declare all the elements of handle key arrays at the end of initialization. See comments on updateVHKA.

Reimplemented in DerivationFramework::CfAthAlgTool, AthCheckedComponent< AthAlgTool >, AthCheckedComponent<::AthAlgTool >, and asg::AsgMetadataTool.

◆ sysStart()

virtual StatusCode AthCommonDataStore< AthCommonMsg< AlgTool > >::sysStart ( )
overridevirtualinherited

Handle START transition.

We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.

◆ updateVHKA()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::updateVHKA ( Gaudi::Details::PropertyBase &  )
inlineinherited

Definition at line 308 of file AthCommonDataStore.h.

308  {
309  // debug() << "updateVHKA for property " << p.name() << " " << p.toString()
310  // << " size: " << m_vhka.size() << endmsg;
311  for (auto &a : m_vhka) {
312  std::vector<SG::VarHandleKey*> keys = a->keys();
313  for (auto k : keys) {
314  k->setOwner(this);
315  }
316  }
317  }

Member Data Documentation

◆ m_assocTracksName

Gaudi::Property<std::string> JetTrackMomentsTool::m_assocTracksName {this, "AssociatedTracks", "", "Name of associated tracks collection"}
private

Definition at line 60 of file JetTrackMomentsTool.h.

◆ m_detStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< AlgTool > >::m_detStore
privateinherited

Pointer to StoreGate (detector store by default)

Definition at line 393 of file AthCommonDataStore.h.

◆ m_doPFlowMoments

Gaudi::Property<bool> JetTrackMomentsTool::m_doPFlowMoments {this, "DoPFlowMoments", false, "Calculate PFlow Object track moments?"}
private

Definition at line 63 of file JetTrackMomentsTool.h.

◆ m_evtStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< AlgTool > >::m_evtStore
privateinherited

Pointer to StoreGate (event store by default)

Definition at line 390 of file AthCommonDataStore.h.

◆ m_htsel

ToolHandle<InDet::IInDetTrackSelectionTool> JetTrackMomentsTool::m_htsel {this, "TrackSelector", "", "track selection tool"}
private

Definition at line 65 of file JetTrackMomentsTool.h.

◆ m_jetContainerName

Gaudi::Property<std::string> JetTrackMomentsTool::m_jetContainerName {this, "JetContainer", "", "SG key for input jet container"}
private

Definition at line 59 of file JetTrackMomentsTool.h.

◆ m_keysCPFOWidth

SG::WriteDecorHandleKeyArray<xAOD::JetContainer> JetTrackMomentsTool::m_keysCPFOWidth {this, "ChargedPFOWidthDecorKeys", {}, "SG keys for ChargedPFO Width decoration (not to be configured manually!)"}
private

Definition at line 75 of file JetTrackMomentsTool.h.

◆ m_keysNumCPFO

SG::WriteDecorHandleKeyArray<xAOD::JetContainer> JetTrackMomentsTool::m_keysNumCPFO {this, "NumChargedPFODecorKeys", {}, "SG keys for NumChargedPFO decoration (not to be configured manually!)"}
private

Definition at line 73 of file JetTrackMomentsTool.h.

◆ m_keysNumTrk

SG::WriteDecorHandleKeyArray<xAOD::JetContainer> JetTrackMomentsTool::m_keysNumTrk {this, "NumTrkDecorKeys", {}, "SG keys for NumTrk decoration (not to be configured manually!)"}
private

Definition at line 70 of file JetTrackMomentsTool.h.

◆ m_keysSumPtCPFO

SG::WriteDecorHandleKeyArray<xAOD::JetContainer> JetTrackMomentsTool::m_keysSumPtCPFO {this, "SumPtChargedPFODecorKeys", {}, "SG keys for SumPtChargedPFO decoration (not to be configured manually!)"}
private

Definition at line 74 of file JetTrackMomentsTool.h.

◆ m_keysSumPtTrk

SG::WriteDecorHandleKeyArray<xAOD::JetContainer> JetTrackMomentsTool::m_keysSumPtTrk {this, "SumPtTrkDecorKeys", {}, "SG keys for SumPtTrk decoration (not to be configured manually!)"}
private

Definition at line 71 of file JetTrackMomentsTool.h.

◆ m_keysTrkWidth

SG::WriteDecorHandleKeyArray<xAOD::JetContainer> JetTrackMomentsTool::m_keysTrkWidth {this, "TrackWidthDecorKeys", {}, "SG keys for TrackWidth decoration (not to be configured manually!)"}
private

Definition at line 72 of file JetTrackMomentsTool.h.

◆ m_minTrackPt

Gaudi::Property<std::vector<float> > JetTrackMomentsTool::m_minTrackPt {this, "TrackMinPtCuts", {}, "Vector of track pt cuts"}
private

Definition at line 62 of file JetTrackMomentsTool.h.

◆ m_suffix

Gaudi::Property<std::string> JetTrackMomentsTool::m_suffix {this, "MomentSuffix", "", "Suffix for track moment decorations"}
private

Definition at line 61 of file JetTrackMomentsTool.h.

◆ m_tva_key

SG::ReadHandleKey<jet::TrackVertexAssociation> JetTrackMomentsTool::m_tva_key {this, "TrackVertexAssociation", "", "SG key for track-vertex association"}
private

Definition at line 68 of file JetTrackMomentsTool.h.

◆ m_varHandleArraysDeclared

bool AthCommonDataStore< AthCommonMsg< AlgTool > >::m_varHandleArraysDeclared
privateinherited

Definition at line 399 of file AthCommonDataStore.h.

◆ m_vertexContainer_key

SG::ReadHandleKey<xAOD::VertexContainer> JetTrackMomentsTool::m_vertexContainer_key {this, "VertexContainer", "", "SG key for vertex container"}
private

Definition at line 67 of file JetTrackMomentsTool.h.

◆ m_vhka

std::vector<SG::VarHandleKeyArray*> AthCommonDataStore< AthCommonMsg< AlgTool > >::m_vhka
privateinherited

Definition at line 398 of file AthCommonDataStore.h.


The documentation for this class was generated from the following files:
asg::AsgTool
Base class for the dual-use tool implementation classes.
Definition: AsgTool.h:47
StateLessPT_NewConfig.proxy
proxy
Definition: StateLessPT_NewConfig.py:392
xAOD::FlowElement_v1::Charged
@ Charged
Definition: FlowElement_v1.h:38
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
JetTrackMomentsTool::m_vertexContainer_key
SG::ReadHandleKey< xAOD::VertexContainer > m_vertexContainer_key
Definition: JetTrackMomentsTool.h:67
JetTrackMomentsTool::m_htsel
ToolHandle< InDet::IInDetTrackSelectionTool > m_htsel
Definition: JetTrackMomentsTool.h:65
ObjectType
ObjectType
Definition: BaseObject.h:11
JetTrackMomentsTool::m_assocTracksName
Gaudi::Property< std::string > m_assocTracksName
Definition: JetTrackMomentsTool.h:60
AthCommonDataStore::declareProperty
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T > &t)
Definition: AthCommonDataStore.h:145
xAOD::PFO_v1::track
const TrackParticle * track(unsigned int index) const
Retrieve a const pointer to a Rec::TrackParticle.
Definition: PFO_v1.cxx:691
MuonGM::round
float round(const float toRound, const unsigned int decimals)
Definition: Mdt.cxx:27
AthCommonDataStore< AthCommonMsg< AlgTool > >::m_evtStore
StoreGateSvc_t m_evtStore
Pointer to StoreGate (event store by default)
Definition: AthCommonDataStore.h:390
AthCommonDataStore< AthCommonMsg< AlgTool > >::m_vhka
std::vector< SG::VarHandleKeyArray * > m_vhka
Definition: AthCommonDataStore.h:398
athena.value
value
Definition: athena.py:124
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
ATH_MSG_VERBOSE
#define ATH_MSG_VERBOSE(x)
Definition: AthMsgStreamMacros.h:28
SG::VarHandleKey::key
const std::string & key() const
Return the StoreGate ID for the referenced object.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:141
dbg::ptr
void * ptr(T *p)
Definition: SGImplSvc.cxx:74
JetTrackMomentsTool::getMomentBaseName
const std::string getMomentBaseName(const float minTrackPt) const
Definition: JetTrackMomentsTool.cxx:251
JetTrackMomentsTool::m_suffix
Gaudi::Property< std::string > m_suffix
Definition: JetTrackMomentsTool.h:61
python.iconfTool.models.loaders.level
level
Definition: loaders.py:20
SG::VarHandleKeyArray::setOwner
virtual void setOwner(IDataHandleHolder *o)=0
JetTrackMomentsTool::m_minTrackPt
Gaudi::Property< std::vector< float > > m_minTrackPt
Definition: JetTrackMomentsTool.h:62
IDTPMcnv.htype
htype
Definition: IDTPMcnv.py:27
JetTrackMomentsTool::m_keysTrkWidth
SG::WriteDecorHandleKeyArray< xAOD::JetContainer > m_keysTrkWidth
Definition: JetTrackMomentsTool.h:72
xAOD::FlowElement_v1::PFlow
@ PFlow
Definition: FlowElement_v1.h:45
SG::makeHandle
SG::ReadCondHandle< T > makeHandle(const SG::ReadCondHandleKey< T > &key, const EventContext &ctx=Gaudi::Hive::currentContext())
Definition: ReadCondHandle.h:270
xAOD::FlowElement_v1::isCharged
bool isCharged() const
Definition: FlowElement_v1.cxx:56
AthCommonDataStore< AthCommonMsg< AlgTool > >::evtStore
ServiceHandle< StoreGateSvc > & evtStore()
The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
Definition: AthCommonDataStore.h:85
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:210
jet
Definition: JetCalibTools_PlotJESFactors.cxx:23
AthCommonDataStore
Definition: AthCommonDataStore.h:52
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
lumiFormat.i
int i
Definition: lumiFormat.py:85
xAOD::P4Helpers::deltaR
double deltaR(double rapidity1, double phi1, double rapidity2, double phi2)
from bare bare rapidity,phi
Definition: xAODP4Helpers.h:150
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
xAOD::FlowElement
FlowElement_v1 FlowElement
Definition of the current "pfo version".
Definition: FlowElement.h:16
SG::WriteDecorHandle
Handle class for adding a decoration to an object.
Definition: StoreGate/StoreGate/WriteDecorHandle.h:100
xAOD::FlowElement_v1::signalType
signal_t signalType() const
JetTrackMomentsTool::m_jetContainerName
Gaudi::Property< std::string > m_jetContainerName
Definition: JetTrackMomentsTool.h:59
python.xAODType.dummy
dummy
Definition: xAODType.py:4
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
xAODType::ParticleFlow
@ ParticleFlow
The object is a particle-flow object.
Definition: ObjectType.h:41
MSG::name
const std::string & name(Level lvl)
Convenience function for translating message levels to strings.
Definition: MsgLevel.cxx:19
AthCommonDataStore< AthCommonMsg< AlgTool > >::m_detStore
StoreGateSvc_t m_detStore
Pointer to StoreGate (detector store by default)
Definition: AthCommonDataStore.h:393
SG::VarHandleKey::initialize
StatusCode initialize(bool used=true)
If this object is used as a property, then this should be called during the initialize phase.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:103
JetTrackMomentsTool::m_keysNumCPFO
SG::WriteDecorHandleKeyArray< xAOD::JetContainer > m_keysNumCPFO
Definition: JetTrackMomentsTool.h:73
jet::TrackVertexAssociation::associatedVertex
const xAOD::Vertex * associatedVertex(const xAOD::TrackParticle *trk) const
Definition: TrackVertexAssociation.cxx:23
xAOD::PFO_v1::isCharged
bool isCharged() const
is a charged PFO
Definition: PFO_v1.cxx:251
TauGNNUtils::Variables::Track::trackPt
bool trackPt(const xAOD::TauJet &, const xAOD::TauTrack &track, double &out)
Definition: TauGNNUtils.cxx:472
SG::VarHandleKeyArray::renounce
virtual void renounce()=0
SG::HandleClassifier::type
std::conditional< std::is_base_of< SG::VarHandleKeyArray, T >::value, VarHandleKeyArrayType, type2 >::type type
Definition: HandleClassifier.h:54
JetTrackMomentsTool::getTrackMoments
const std::vector< TrackMomentStruct > getTrackMoments(const xAOD::Jet &jet, const xAOD::VertexContainer *vertices, const float minTrackPt, const std::vector< const xAOD::TrackParticle * > &tracks, const jet::TrackVertexAssociation *tva) const
Definition: JetTrackMomentsTool.cxx:186
xAOD::FlowElement_v1::chargedObject
const xAOD::IParticle * chargedObject(std::size_t i) const
Definition: FlowElement_v1.cxx:127
merge_scale_histograms.doc
string doc
Definition: merge_scale_histograms.py:9
xAOD::PFO_v1
Class describing a particle flow object.
Definition: PFO_v1.h:35
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:221
JetTrackMomentsTool::m_keysSumPtTrk
SG::WriteDecorHandleKeyArray< xAOD::JetContainer > m_keysSumPtTrk
Definition: JetTrackMomentsTool.h:71
mc.nskip
nskip
Definition: mc.PhPy8EG_Hto4l_NNLOPS_nnlo_30_ggH125_ZZ4l.py:41
xAOD::Jet_v1
Class describing a jet.
Definition: Jet_v1.h:57
Trk::vertex
@ vertex
Definition: MeasurementType.h:21
a
TList * a
Definition: liststreamerinfos.cxx:10
h
IJetDecorator::decorate
virtual StatusCode decorate(const xAOD::JetContainer &jets) const =0
Decorate a jet collection without otherwise modifying it.
JetTrackMomentsTool::m_doPFlowMoments
Gaudi::Property< bool > m_doPFlowMoments
Definition: JetTrackMomentsTool.h:63
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
AthCommonMsg< AlgTool >::msg
MsgStream & msg() const
Definition: AthCommonMsg.h:24
JetTrackMomentsTool::m_tva_key
SG::ReadHandleKey< jet::TrackVertexAssociation > m_tva_key
Definition: JetTrackMomentsTool.h:68
SG::VarHandleBase::vhKey
SG::VarHandleKey & vhKey()
Return a non-const reference to the HandleKey.
Definition: StoreGate/src/VarHandleBase.cxx:623
defineDB.jets
list jets
Definition: JetTagCalibration/share/defineDB.py:24
python.Bindings.keys
keys
Definition: Control/AthenaPython/python/Bindings.py:798
xAOD::track
@ track
Definition: TrackingPrimitives.h:512
xAOD::TrackParticle_v1
Class describing a TrackParticle.
Definition: TrackParticle_v1.h:43
DataVector::at
const T * at(size_type n) const
Access an element, as an rvalue.
JetTrackMomentsTool::m_keysNumTrk
SG::WriteDecorHandleKeyArray< xAOD::JetContainer > m_keysNumTrk
Definition: JetTrackMomentsTool.h:70
SG::DataProxy
Definition: DataProxy.h:44
JetTrackMomentsTool::m_keysSumPtCPFO
SG::WriteDecorHandleKeyArray< xAOD::JetContainer > m_keysSumPtCPFO
Definition: JetTrackMomentsTool.h:74
makeComparison.deltaR
float deltaR
Definition: makeComparison.py:36
DataVector::size
size_type size() const noexcept
Returns the number of elements in the collection.
AthCommonDataStore::declareGaudiProperty
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition: AthCommonDataStore.h:156
fitman.k
k
Definition: fitman.py:528
JetTrackMomentsTool::m_keysCPFOWidth
SG::WriteDecorHandleKeyArray< xAOD::JetContainer > m_keysCPFOWidth
Definition: JetTrackMomentsTool.h:75
xAOD::FlowElement_v1
A detector object made of other lower level object(s)
Definition: FlowElement_v1.h:25