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 EventContext &ctx, 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
 DeclareInterfaceID (ISecVertexInJetFinder, 1, 0)

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)

◆ DeclareInterfaceID()

InDet::ISecVertexInJetFinder::DeclareInterfaceID ( ISecVertexInJetFinder ,
1 ,
0  )
inherited

◆ 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 223 of file InDetImprovedJetFitterVxFinder.cxx.

224 {
225
226 }

◆ 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::VxSecVertexInfo * InDet::InDetImprovedJetFitterVxFinder::findSecVertex ( const EventContext & ctx,
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.

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

◆ findSecVertex() [2/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 204 of file InDetImprovedJetFitterVxFinder.cxx.

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

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

◆ 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 228 of file InDetImprovedJetFitterVxFinder.cxx.

228 {
229
230 if ( trackCollection.empty() ) return;
231
232 ATH_MSG_DEBUG("re-order the tracks by pT: " <<
233 ( trackCollection.front()->parameters() )->pT() <<
234 " -- " <<
235 ( trackCollection.back()->parameters() )->pT() );
236
237 std::sort( trackCollection.begin(),
238 trackCollection.end(),
239 //Lambda func to sort by pt
240 [](const Trk::ITrackLink* TL1, const Trk::ITrackLink* TL2) {
241 return ( (TL1->parameters())->pT() < (TL2->parameters())->pT() );
242 } );
243
244 ATH_MSG_DEBUG("after re-order the tracks by pT: " <<
245 ( trackCollection.front()->parameters() )->pT() <<
246 " -- " <<
247 ( trackCollection.back()->parameters() )->pT() );
248
249 }
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 255 of file InDetImprovedJetFitterVxFinder.cxx.

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

◆ 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 104 of file InDetImprovedJetFitterVxFinder.h.

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

◆ m_theTrackSelector

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

Definition at line 101 of file InDetImprovedJetFitterVxFinder.h.

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

◆ m_theTwoTrackVtxFinderTool

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

Definition at line 102 of file InDetImprovedJetFitterVxFinder.h.

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

◆ m_theV0FinderTool

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

Definition at line 103 of file InDetImprovedJetFitterVxFinder.h.

103{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: