|
ATLAS Offline Software
|
Go to the documentation of this file.
48 return StatusCode::FAILURE;
70 return StatusCode::SUCCESS;
86 return StatusCode::SUCCESS;
102 ATH_MSG_FATAL(
"execute - failed to find the InDetTrackParticles");
103 return StatusCode::FAILURE;
112 std::unique_ptr<xAOD::VertexContainer> refitVtxContainer = std::make_unique< xAOD::VertexContainer>();
113 std::unique_ptr<xAOD::VertexAuxContainer> refitVtxContainerAux = std::make_unique< xAOD::VertexAuxContainer>();
115 refitVtxContainer->setStore(refitVtxContainerAux.get());
122 std::move(refitVtxContainer), std::move(refitVtxContainerAux)
129 if (!h_leptonContainer.
isValid()){
130 ATH_MSG_FATAL(
"execute - failed to find the lepton container");
131 return StatusCode::FAILURE;
137 return StatusCode::FAILURE;
146 if(
vertex->vertexType() == 1) {
152 if(!fittingInput.
priVtx) {
153 ATH_MSG_INFO(
"Failed to find primary vertices - save empty containers");
154 return StatusCode::SUCCESS;
160 std::vector<const xAOD::TrackParticle *> priVtx_tracks;
167 priVtx_tracks.push_back(
track);
173 fittingInput, priVtx_tracks,
178 if(!refittedPriVtx) {
179 ATH_MSG_WARNING(
"Failed to refit primary vertex - save empty containers");
180 return StatusCode::SUCCESS;
195 <<
"\n\t\t\t Size of lepton container: " << leptonContainer.
size()
196 <<
"\n-----------------------------------------------------------------");
215 if(
muon->inDetTrackParticleLink().isValid()) {
216 tracklep = *(
muon->inDetTrackParticleLink());
219 ATH_MSG_DEBUG(
"PrimaryVertexReFitter::execute - skip muon without valid inDetTrackParticleLink()");
225 ATH_MSG_WARNING(
"PrimaryVertexReFitter::execute - cannot find muon->inDetTrackParticleLink() nor electron->trackParticle()");
232 h_refitVtxContainer->
push_back(std::move(refittedPriVtx));
239 return StatusCode::SUCCESS;
247 const std::vector<const xAOD::TrackParticle*> &tracks,
256 ATH_MSG_WARNING(
"decorateLepWithReFitPrimaryVertex - invalid input primary vertex pointer");
264 std::vector<const xAOD::TrackParticle*> priVtx_tracks_pass;
265 bool isRefit =
false;
268 if(
track == tracklep) {
270 ATH_MSG_DEBUG(
"decorateLepWithReFitPrimaryVertex -- lepton has been used, lepton pT =" << tracklep->
pt() <<
", track pT =" <<
track->pt());
274 priVtx_tracks_pass.push_back(
track);
280 ATH_MSG_DEBUG(
"decorateLepWithReFitPrimaryVertex -- Skip the primary vertex without lepton track");
282 (*m_lepRefittedRMVtxLinkDec)(*lep) = refittedRM_pv_link;
286 if(priVtx_tracks_pass.size() < 2) {
287 ATH_MSG_DEBUG(
"decorateLepWithReFitPrimaryVertex -- Skip the primary vertex refitting: N tracks =" << priVtx_tracks_pass.size());
289 (*m_lepRefittedRMVtxLinkDec)(*lep) = refittedRM_pv_link;
296 xAOD::Vertex* refittedVtxRMLep = m_vertexFitterTool->fitVertexWithSeed(
297 input, priVtx_tracks_pass,
input.priVtx->position(),
301 if(refittedVtxRMLep) {
305 refitVtxContainer.
push_back(refittedVtxRMLep);
313 ATH_MSG_DEBUG(
"decorateLepWithReFitPrimaryVertex -- save refitted non-prompt primary vertex with NTrack = " << refittedVtxRMLep->
nTrackParticles());
315 if(
input.refittedPriVtx) {
316 (*m_distToRefittedPriVtx) (*refittedVtxRMLep) =
Prompt::getDistance(
input.refittedPriVtx->position(), refittedVtxRMLep->position());
318 input.refittedPriVtx->position(),
319 refittedVtxRMLep->position(),
320 refittedVtxRMLep->covariance(),
326 (*m_lepRefittedRMVtxLinkDec)(*lep) = refittedRM_pv_link;
virtual double pt() const override final
The transverse momentum ( ) of the particle.
size_t nTrackParticles() const
Get the number of tracks associated with this vertex.
bool toContainedElement(BaseConstReference data, ElementType element, IProxyDict *sg=0)
Set from element pointer and a reference to the container (storable)
ToolHandle< Prompt::VertexFittingTool > m_vertexFitterTool
std::unique_ptr< decoratorFloat_t > m_distToRefittedPriVtx
SG::ReadHandleKey< xAOD::IParticleContainer > m_leptonContainerKey
virtual StatusCode finalize() override
SG::WriteHandleKey< xAOD::VertexContainer > m_reFitPrimaryVertexKey
const xAOD::TrackParticle * trackParticle(size_t index=0) const
Pointer to the xAOD::TrackParticle/s that match the electron candidate.
const Amg::Vector3D & position() const
Returns the 3-pos.
std::unique_ptr< decoratorElemVtx_t > m_lepRefittedRMVtxLinkDec
PrimaryVertexReFitter(const std::string &name, ISvcLocator *pSvcLocator)
Class providing the definition of the 4-vector interface.
std::string PrintResetStopWatch(TStopwatch &watch)
std::unique_ptr< decoratorFloat_t > m_normdistToRefittedPriVtx
Gaudi::Property< std::string > m_normDistToRefittedPriVtxName
Gaudi::Property< std::string > m_lepVtxLinkName
def timer(name, disabled=False)
@ kRefittedPriVtxWithoutLep
double getNormDist(const Amg::Vector3D &PrimVtx, const Amg::Vector3D &SecVtx, const std::vector< float > &ErrorMatrix, MsgStream &msg)
bool decorateLepWithReFitPrimaryVertex(const FittingInput &input, const xAOD::TrackParticle *tracklep, const xAOD::IParticle *lep, const std::vector< const xAOD::TrackParticle * > &tracks, xAOD::VertexContainer &refitVtxContainer)
double getDistance(const xAOD::Vertex *vtx1, const xAOD::Vertex *vtx2)
::StatusCode StatusCode
StatusCode definition for legacy code.
virtual StatusCode initialize() override
const TrackParticle * trackParticle(size_t i) const
Get the pointer to a given track that was used in vertex reco.
Gaudi::Property< bool > m_printTime
StatusCode initialize(bool used=true)
If this object is used as a property, then this should be called during the initialize phase.
virtual bool isValid() override final
Can the handle be successfully dereferenced?
ElementLink implementation for ROOT usage.
Gaudi::Property< std::string > m_lepRefittedVtxWithoutLeptonLinkName
value_type push_back(value_type pElem)
Add an element to the end of the collection.
const xAOD::TrackParticle * getOriginalTrackParticleFromGSF(const xAOD::TrackParticle *trkPar)
Helper function for getting the "Original" Track Particle (i.e before GSF) via the GSF Track Particle...
SG::ReadHandleKey< xAOD::TrackParticleContainer > m_inDetTracksKey
SG::ReadHandleKey< xAOD::VertexContainer > m_primaryVertexContainerKey
Class describing a Vertex.
StatusCode record(std::unique_ptr< T > data)
Record a const object to the store.
#define ATH_MSG_WARNING(x)
Gaudi::Property< std::string > m_distToRefittedPriVtxName
Class describing a TrackParticle.
size_type size() const noexcept
Returns the number of elements in the collection.
virtual StatusCode execute() override