ATLAS Offline Software
Reconstruction
tauRecTools
Root
TauVertexedClusterDecorator.cxx
Go to the documentation of this file.
1
/*
2
Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3
*/
4
5
#include "
tauRecTools/TauVertexedClusterDecorator.h
"
6
7
#include "
xAODCaloEvent/CaloVertexedTopoCluster.h
"
8
9
TauVertexedClusterDecorator::TauVertexedClusterDecorator
(
const
std::string&
name
):
10
TauRecToolBase
(
name
) {
11
}
12
13
14
15
StatusCode
TauVertexedClusterDecorator::initialize
() {
16
17
if
(std::string(
m_seedJet
).
find
(
"LC"
) != std::string::npos) {
18
ATH_MSG_INFO
(
"Set the cluster state to CALIBRATED"
);
19
m_clusterState
= xAOD::CaloCluster::State::CALIBRATED;
20
}
21
else
if
(std::string(
m_seedJet
).
find
(
"EM"
) != std::string::npos) {
22
ATH_MSG_INFO
(
"Set the cluster state to UNCALIBRATED"
);
23
m_clusterState
= xAOD::CaloCluster::State::UNCALIBRATED;
24
}
25
else
if
(!
inTrigger
()) {
26
ATH_MSG_ERROR
(
"Seed jet "
<<
m_seedJet
<<
" not supported !"
);
27
return
StatusCode::FAILURE;
28
}
29
30
return
StatusCode::SUCCESS;
31
}
32
33
34
35
StatusCode
TauVertexedClusterDecorator::execute
(
xAOD::TauJet
& tau)
const
{
36
37
// Obtain the vertex to correct the cluster
38
const
xAOD::Vertex
*
vertex
= tau.
vertex
();
39
40
std::vector<const xAOD::IParticle*> particleList = tau.
clusters
();
41
42
std::vector<xAOD::CaloVertexedTopoCluster> vertexedClusterList;
43
for
(
const
xAOD::IParticle
*
particle
: particleList) {
44
const
xAOD::CaloCluster
* cluster =
static_cast<
const
xAOD::CaloCluster
*
>
(
particle
);
45
46
if
(
inTrigger
()) {
// In trigger, we use the default calibration state
47
if
(
vertex
) {
48
vertexedClusterList.emplace_back(*cluster,
vertex
->position());
49
}
50
else
{
51
vertexedClusterList.emplace_back(*cluster);
52
}
53
}
54
else
{
// In offline reconstruction, the calibration state is based on the name of seed jet
55
if
(
vertex
) {
56
vertexedClusterList.emplace_back(*cluster,
m_clusterState
,
vertex
->position());
57
}
58
else
{
59
vertexedClusterList.emplace_back(*cluster,
m_clusterState
);
60
}
61
}
62
}
63
64
static
const
SG::Accessor<std::vector<xAOD::CaloVertexedTopoCluster>
> vertexedClustersAcc(
"VertexedClusters"
);
65
vertexedClustersAcc(tau) = vertexedClusterList;
66
67
return
StatusCode::SUCCESS;
68
}
TauVertexedClusterDecorator::m_seedJet
Gaudi::Property< std::string > m_seedJet
Definition:
TauVertexedClusterDecorator.h:35
Trk::ParticleSwitcher::particle
constexpr ParticleHypothesis particle[PARTICLEHYPOTHESES]
the array of masses
Definition:
ParticleHypothesis.h:79
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition:
AthMsgStreamMacros.h:31
find
std::string find(const std::string &s)
return a remapped string
Definition:
hcg.cxx:135
SG::Accessor
Helper class to provide type-safe access to aux data.
Definition:
Control/AthContainers/AthContainers/Accessor.h:68
TauVertexedClusterDecorator::execute
virtual StatusCode execute(xAOD::TauJet &tau) const override
Execute - called for each tau candidate.
Definition:
TauVertexedClusterDecorator.cxx:35
TauRecToolBase
The base class for all tau tools.
Definition:
TauRecToolBase.h:21
TauRecToolBase::inTrigger
bool inTrigger() const
Definition:
TauRecToolBase.h:87
xAOD::IParticle
Class providing the definition of the 4-vector interface.
Definition:
Event/xAOD/xAODBase/xAODBase/IParticle.h:41
xAOD::TauJet_v3::clusters
std::vector< const IParticle * > clusters() const
Definition:
TauJet_v3.cxx:545
TauVertexedClusterDecorator::m_clusterState
xAOD::CaloCluster::State m_clusterState
Calibration state of cluster.
Definition:
TauVertexedClusterDecorator.h:38
xAOD::CaloCluster_v1
Description of a calorimeter cluster.
Definition:
CaloCluster_v1.h:62
TauVertexedClusterDecorator::TauVertexedClusterDecorator
TauVertexedClusterDecorator(const std::string &name)
Definition:
TauVertexedClusterDecorator.cxx:9
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition:
AthMsgStreamMacros.h:33
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition:
PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
xAOD::TauJet_v3
Class describing a tau jet.
Definition:
TauJet_v3.h:41
name
std::string name
Definition:
Control/AthContainers/Root/debug.cxx:240
CaloVertexedTopoCluster.h
Evaluate cluster kinematics with a different vertex / signal state.
Trk::vertex
@ vertex
Definition:
MeasurementType.h:21
xAOD::Vertex_v1
Class describing a Vertex.
Definition:
Vertex_v1.h:42
xAOD::TauJet_v3::vertex
const Vertex * vertex() const
TauVertexedClusterDecorator.h
TauVertexedClusterDecorator::initialize
virtual StatusCode initialize() override
Tool initializer.
Definition:
TauVertexedClusterDecorator.cxx:15
Generated on Sat Oct 25 2025 21:18:36 for ATLAS Offline Software by
1.8.18