ATLAS Offline Software
Loading...
Searching...
No Matches
InDet::InDetImprovedJetFitterVxFinder Class Reference

#include <InDetImprovedJetFitterVxFinder.h>

Inheritance diagram for InDet::InDetImprovedJetFitterVxFinder:
Collaboration diagram for InDet::InDetImprovedJetFitterVxFinder:

Public Member Functions

virtual StatusCode initialize () override
 InDetImprovedJetFitterVxFinder (const std::string &t, const std::string &n, const IInterface *p)
 ~InDetImprovedJetFitterVxFinder ()
virtual Trk::VxSecVertexInfofindSecVertex (const xAOD::Vertex &primaryVertex, const TLorentzVector &jetMomentum, const std::vector< const xAOD::IParticle * > &inputTracks) const override
virtual std::vector< std::string > trackDecorationNames () const override
 Return a list of the names of track decorations created by this tool, in order to allow them to be locked when the calling algorithm completes.
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
virtual StatusCode sysInitialize () override
 Perform system initialization for an algorithm.
virtual StatusCode sysStart () override
 Handle START transition.
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles.
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles.
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T, V, H > &t)
void updateVHKA (Gaudi::Details::PropertyBase &)
MsgStream & msg () const
bool msgLvl (const MSG::Level lvl) const

Static Public Member Functions

static const InterfaceID & interfaceID ()

Protected Member Functions

void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution
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.

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t

Private Member Functions

void sortTrackCollectionByPt (std::vector< const Trk::ITrackLink * > &) const
void doTheFit (Trk::VxJetCandidate *myJetCandidate, bool performClustering=true) const
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>

Static Private Member Functions

static Trk::VxJetCandidatefindSecVertex (const Trk::RecVertex &primaryVertex, const TLorentzVector &jetMomentum, const std::vector< const Trk::ITrackLink * > &firstInputTracks, const std::vector< const Trk::ITrackLink * > &secondInputTracks, const Amg::Vector3D &vtxSeedDirection)

Private Attributes

ToolHandle< JetFitterTrackSelectorToolm_theTrackSelector {this,"JetFitterTrackSelectorTool","JetFitterTrackSelectorTool/JetFitterTrackSelectorTool",""}
ToolHandle< JetFitterTwoTrackVtxFinderToolm_theTwoTrackVtxFinderTool {this,"JetFitterTwoTrackVtxFinderTool","JetFitterV0FinderTool/JetFitterTwoTrackVtxFinderTool",""}
ToolHandle< JetFitterV0FinderToolm_theV0FinderTool {this,"JetFitterV0FinderTool","JetFitterV0FinderTool/JetFitterV0FinderTool",""}
ToolHandle< JetFitterMultiStageFitm_multiStageFitter {this,"JetFitterMultiStageFit","JetFitterMultiStageFit/JetFitterMultiStageFit",""}
StoreGateSvc_t m_evtStore
 Pointer to StoreGate (event store by default)
StoreGateSvc_t m_detStore
 Pointer to StoreGate (detector store by default)
std::vector< SG::VarHandleKeyArray * > m_vhka
bool m_varHandleArraysDeclared

Detailed Description

Definition at line 62 of file InDetImprovedJetFitterVxFinder.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

◆ InDetImprovedJetFitterVxFinder()

InDet::InDetImprovedJetFitterVxFinder::InDetImprovedJetFitterVxFinder ( const std::string & t,
const std::string & n,
const IInterface * p )

Definition at line 86 of file InDetImprovedJetFitterVxFinder.cxx.

86 :
87 AthAlgTool(t,n,p)
88 {
89 // new package for hackathon
90 declareInterface< ISecVertexInJetFinder >(this) ;
91 }
AthAlgTool()
Default constructor:

◆ ~InDetImprovedJetFitterVxFinder()

InDet::InDetImprovedJetFitterVxFinder::~InDetImprovedJetFitterVxFinder ( )
default

Member Function Documentation

◆ declareGaudiProperty()

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

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

Definition at line 156 of file AthCommonDataStore.h.

158 {
160 hndl.value(),
161 hndl.documentation());
162
163 }
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)

◆ declareProperty()

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

Definition at line 145 of file AthCommonDataStore.h.

145 {
146 typedef typename SG::HandleClassifier<T>::type htype;
148 }
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>

◆ 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.

◆ doTheFit()

void InDet::InDetImprovedJetFitterVxFinder::doTheFit ( Trk::VxJetCandidate * myJetCandidate,
bool performClustering = true ) const
private

Definition at line 222 of file InDetImprovedJetFitterVxFinder.cxx.

223 {
224
225 }

◆ evtStore()

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.

◆ 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

◆ findSecVertex() [1/2]

Trk::VxJetCandidate * InDet::InDetImprovedJetFitterVxFinder::findSecVertex ( const Trk::RecVertex & primaryVertex,
const TLorentzVector & jetMomentum,
const std::vector< const Trk::ITrackLink * > & firstInputTracks,
const std::vector< const Trk::ITrackLink * > & secondInputTracks,
const Amg::Vector3D & vtxSeedDirection )
staticprivate

Definition at line 203 of file InDetImprovedJetFitterVxFinder.cxx.

208 {
209
210 // The overload is legacy. This is where we interface to JetFitter proper
211 // m_jetFitterMultiStageFit->performTwoStageFit(const Trk::RecVertex & primaryVertex,
212 // const TLorentzVector & jetMomentum,
213 // const std::vector<const Trk::ITrackLink*> & firstInputTracks,
214 // const std::vector<const Trk::ITrackLink*> & secondInputTracks,
215 // const Amg::Vector3D & vtxSeedDirection
216
217 // return myOutputInfo
218 return nullptr;
219
220 }

◆ findSecVertex() [2/2]

Trk::VxSecVertexInfo * InDet::InDetImprovedJetFitterVxFinder::findSecVertex ( const xAOD::Vertex & primaryVertex,
const TLorentzVector & jetMomentum,
const std::vector< const xAOD::IParticle * > & inputTracks ) const
overridevirtual

Implements InDet::ISecVertexInJetFinder.

Definition at line 123 of file InDetImprovedJetFitterVxFinder.cxx.

126 {
127 // This function when called performs JetFitter secondary vertex finding
128 // It returns the JetFitter Vertex Info, VxJetFitterVertexInfo:
129 // The VxJetCandidate, the TwoTrackVerticesInJet (V0s and neutrals), the selected tracks (primary and secondary)
130 // So we need to do track selection, v0 finding, and then the fit with JetFitter.
131
132//
133// // Initial track selection, track filter applied, separate primary and secondary tracks
134 const Trk::SelectedTracksInJet* mySelectedTracksInJet = m_theTrackSelector->doTrackSelection( primaryVertex, jetMomentum, inputTracks );
135
136 ATH_MSG_DEBUG( "the selected tracks now are " << mySelectedTracksInJet );
137 std::vector< const Trk::ITrackLink* > primaryTracks = mySelectedTracksInJet->getPrimaryTrackLinks();
138 std::vector< const Trk::ITrackLink* > secondaryTracks = mySelectedTracksInJet->getSecondaryTrackLinks();
139
140 // Two track vertex candidates
141 const Trk::TwoTrackVerticesInJet* twoTrackVertexCandidates = m_theTwoTrackVtxFinderTool->doVertexFinding( primaryVertex, jetMomentum, secondaryTracks );
142 const std::vector< const xAOD::Vertex* > vertexCandidates = twoTrackVertexCandidates->getTwoTrackVertice();
143
144// // V0 finding AND further track selection, these could even be further separated
145// // neutral identification, material interactions, ..., a lot is done here
146 std::vector< const Trk::ITrackLink* > tracksToUseInFirstFit;
147 std::vector< const Trk::ITrackLink* > tracksToUseInSecondFit;
148 Amg::Vector3D JFseedDirection;
149
150 const Trk::TwoTrackVerticesInJet* myTwoTrackVerticesInJet = m_theV0FinderTool->doV0Finding( primaryVertex, jetMomentum, secondaryTracks, vertexCandidates,
151 tracksToUseInFirstFit, tracksToUseInSecondFit, JFseedDirection );
152
153 // Sort track collection by pT
154 ATH_MSG_DEBUG( "Sorting track collection (tracksToUseInFirstFit) by pT..." );
155 sortTrackCollectionByPt( tracksToUseInFirstFit );
156 ATH_MSG_DEBUG( "Sorting track collection (tracksToUseInSecondFit) by pT..." );
157 sortTrackCollectionByPt( tracksToUseInSecondFit );
158
159 delete twoTrackVertexCandidates;
160//
161
162// // One last complication, primaryVertex needs to be a different object (old edm)
163// // see lines 524-537 in old code and create primaryVertexRecVertex using the vertex edm factory
164
165 Trk::RecVertex primaryVertexRecVertex( primaryVertex.position(),
166 primaryVertex.covariancePosition(),
167 primaryVertex.numberDoF(),
168 primaryVertex.chiSquared());
169
170
171 // Refactoring: Instead at this point use JetFitterMultiStageFit:
172 Trk::VxJetCandidate* myJetCandidate= m_multiStageFitter->doTwoStageFit(primaryVertexRecVertex,
173 jetMomentum,
174 tracksToUseInFirstFit,
175 tracksToUseInSecondFit,
176 JFseedDirection);
177
178
179 if (myJetCandidate == nullptr) {
180 ATH_MSG_DEBUG( "JetFitter multi stage fit returned 0" );
181 return nullptr;
182 }
183 else {
184 ATH_MSG_DEBUG( "USING JetFitterMultiStageFit return" );
185 }
186
187// // Lastly create the jetfitter info, ('save' our results)
188
189 std::vector<Trk::VxJetCandidate*> myCandidates;
190 // This push_back is problematic for the migration to xAOD::Vertex, it works simply because VxJetCandidate inherits from VxCandidate
191 myCandidates.push_back(myJetCandidate);
192
193 Trk::VxJetFitterVertexInfo* myOutputInfo=new Trk::VxJetFitterVertexInfo(myCandidates,
194 myTwoTrackVerticesInJet,
195 mySelectedTracksInJet);
196
197 myOutputInfo->setSVOwnership(true);
198 return myOutputInfo;
199 }
#define ATH_MSG_DEBUG(x)
ToolHandle< JetFitterTrackSelectorTool > m_theTrackSelector
void sortTrackCollectionByPt(std::vector< const Trk::ITrackLink * > &) const
ToolHandle< JetFitterMultiStageFit > m_multiStageFitter
ToolHandle< JetFitterTwoTrackVtxFinderTool > m_theTwoTrackVtxFinderTool
ToolHandle< JetFitterV0FinderTool > m_theV0FinderTool
const std::vector< const ITrackLink * > & getSecondaryTrackLinks() const
Get the secondary tracks (please do not delete the pointers)
const std::vector< const ITrackLink * > & getPrimaryTrackLinks() const
Get the priamry tracks (please do not delete the pointers)
const std::vector< const xAOD::Vertex * > & getTwoTrackVertice() const
Get the two track vertices (please do not delete the pointers)
void setSVOwnership(bool Ownership)
float numberDoF() const
Returns the number of degrees of freedom of the vertex fit as float.
float chiSquared() const
Returns the of the vertex fit as float.
const Amg::Vector3D & position() const
Returns the 3-pos.
Eigen::Matrix< double, 3, 1 > Vector3D

◆ initialize()

StatusCode InDet::InDetImprovedJetFitterVxFinder::initialize ( )
overridevirtual

Definition at line 97 of file InDetImprovedJetFitterVxFinder.cxx.

97 {
98
99 if (m_theTrackSelector.retrieve().isFailure()) {
100 msg(MSG::ERROR) << "Could not find TrackSelector tool." << endmsg;
101 return StatusCode::FAILURE;
102 } else msg(MSG::INFO) << " JetFitterTrackSelector retrieved" << endmsg;
103
104 if (m_theTwoTrackVtxFinderTool.retrieve().isFailure()) {
105 msg(MSG::ERROR) << "Could not find TwoTrackVtxFinder tool." << endmsg;
106 return StatusCode::FAILURE;
107 } else msg(MSG::INFO) << " JetFitterTwoTrackVtxFinder retrieved" << endmsg;
108
109 if (m_theV0FinderTool.retrieve().isFailure()) {
110 msg(MSG::ERROR) << "Could not find V0Finder tool." << endmsg;
111 return StatusCode::FAILURE;
112 } else msg(MSG::INFO) << " JetFitterV0Finder retrieved" << endmsg;
113
114 if (m_multiStageFitter.retrieve().isFailure()) {
115 msg(MSG::ERROR) << "Could not find JetFitterMultiStageFit tool." << endmsg;
116 return StatusCode::FAILURE;
117 } else msg(MSG::INFO) << " JetFitterMultiStageFit retrieved" << endmsg;
118
119 return StatusCode::SUCCESS;
120 }
#define endmsg
MsgStream & msg() const

◆ 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.

◆ interfaceID()

const InterfaceID & InDet::ISecVertexInJetFinder::interfaceID ( )
inlinestaticinherited

Definition at line 58 of file ISecVertexInJetFinder.h.

59 {
61 };
static const InterfaceID IID_ISecVertexInJetFinder("ISecVertexInJetFinder", 1, 0)

◆ msg()

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

Definition at line 24 of file AthCommonMsg.h.

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

◆ 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.

◆ 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();
384 }
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)

◆ 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 {
366 }

◆ sortTrackCollectionByPt()

void InDet::InDetImprovedJetFitterVxFinder::sortTrackCollectionByPt ( std::vector< const Trk::ITrackLink * > & trackCollection) const
private

Definition at line 227 of file InDetImprovedJetFitterVxFinder.cxx.

227 {
228
229 if ( trackCollection.empty() ) return;
230
231 ATH_MSG_DEBUG("re-order the tracks by pT: " <<
232 ( trackCollection.front()->parameters() )->pT() <<
233 " -- " <<
234 ( trackCollection.back()->parameters() )->pT() );
235
236 std::sort( trackCollection.begin(),
237 trackCollection.end(),
238 //Lambda func to sort by pt
239 [](const Trk::ITrackLink* TL1, const Trk::ITrackLink* TL2) {
240 return ( (TL1->parameters())->pT() < (TL2->parameters())->pT() );
241 } );
242
243 ATH_MSG_DEBUG("after re-order the tracks by pT: " <<
244 ( trackCollection.front()->parameters() )->pT() <<
245 " -- " <<
246 ( trackCollection.back()->parameters() )->pT() );
247
248 }
void sort(typename DataModel_detail::iterator< DVL > beg, typename DataModel_detail::iterator< DVL > end)
Specialization of sort for DataVector/List.

◆ 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 asg::AsgMetadataTool, AthCheckedComponent< AthAlgTool >, AthCheckedComponent<::AthAlgTool >, and DerivationFramework::CfAthAlgTool.

◆ 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.

◆ trackDecorationNames()

std::vector< std::string > InDet::InDetImprovedJetFitterVxFinder::trackDecorationNames ( ) const
overridevirtual

Return a list of the names of track decorations created by this tool, in order to allow them to be locked when the calling algorithm completes.

Reimplemented from InDet::ISecVertexInJetFinder.

Definition at line 254 of file InDetImprovedJetFitterVxFinder.cxx.

255 {
256 return m_theTrackSelector->trackDecorationNames();
257 }

◆ 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) {
313 for (auto k : keys) {
314 k->setOwner(this);
315 }
316 }
317 }
std::vector< SG::VarHandleKeyArray * > m_vhka

Member Data Documentation

◆ 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_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_multiStageFitter

ToolHandle< JetFitterMultiStageFit > InDet::InDetImprovedJetFitterVxFinder::m_multiStageFitter {this,"JetFitterMultiStageFit","JetFitterMultiStageFit/JetFitterMultiStageFit",""}
private

Definition at line 103 of file InDetImprovedJetFitterVxFinder.h.

103{this,"JetFitterMultiStageFit","JetFitterMultiStageFit/JetFitterMultiStageFit",""}; //Hackathon addition

◆ m_theTrackSelector

ToolHandle< JetFitterTrackSelectorTool > InDet::InDetImprovedJetFitterVxFinder::m_theTrackSelector {this,"JetFitterTrackSelectorTool","JetFitterTrackSelectorTool/JetFitterTrackSelectorTool",""}
private

Definition at line 100 of file InDetImprovedJetFitterVxFinder.h.

100{this,"JetFitterTrackSelectorTool","JetFitterTrackSelectorTool/JetFitterTrackSelectorTool",""}; //Hackathon addition

◆ m_theTwoTrackVtxFinderTool

ToolHandle< JetFitterTwoTrackVtxFinderTool > InDet::InDetImprovedJetFitterVxFinder::m_theTwoTrackVtxFinderTool {this,"JetFitterTwoTrackVtxFinderTool","JetFitterV0FinderTool/JetFitterTwoTrackVtxFinderTool",""}
private

Definition at line 101 of file InDetImprovedJetFitterVxFinder.h.

101{this,"JetFitterTwoTrackVtxFinderTool","JetFitterV0FinderTool/JetFitterTwoTrackVtxFinderTool",""}; //Hackathon addition

◆ m_theV0FinderTool

ToolHandle< JetFitterV0FinderTool > InDet::InDetImprovedJetFitterVxFinder::m_theV0FinderTool {this,"JetFitterV0FinderTool","JetFitterV0FinderTool/JetFitterV0FinderTool",""}
private

Definition at line 102 of file InDetImprovedJetFitterVxFinder.h.

102{this,"JetFitterV0FinderTool","JetFitterV0FinderTool/JetFitterV0FinderTool",""}; //Hackathon addition

◆ m_varHandleArraysDeclared

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

Definition at line 399 of file AthCommonDataStore.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: