|
ATLAS Offline Software
|
For every electron find jets in a cone and store lifetime, signed IP, and PTRel of relation.
More...
#include <ElectronJetDRAssociator.h>
|
| ElectronJetDRAssociator (const std::string &type, const std::string &name, const IInterface *parent) |
| Standard Gaudi tool constructor. More...
|
|
virtual StatusCode | initialize () override |
| Standard Gaudi initialize method. More...
|
|
virtual StatusCode | configureD3PD (IAddVariable *tree, const std::type_info &ti) override |
| Configure during initialization: type-check. More...
|
|
virtual StatusCode | reset (const xAOD::Electron &eg) override |
| Start the iteration for a new association. More...
|
|
virtual const xAOD::Jet * | next () override |
| Return a pointer to the next element in the association. More...
|
|
virtual StatusCode | book () final |
| Create any needed tuple variables. More...
|
|
virtual const std::type_info & | fromTypeinfo () const |
| Return the std::type_info for the source of the association. More...
|
|
virtual const std::type_info & | fromTypeinfo () const =0 |
| Return the std::type_info for the source of the association. More...
|
|
virtual StatusCode | resetUntyped (const void *p) |
| Start the iteration for a new association. More...
|
|
virtual const std::type_info & | elementTypeinfo () const |
| Return the element type for the target of the association. More...
|
|
virtual const void * | nextUntyped () |
| Return a pointer to the next element in the association. More...
|
|
virtual void | releaseElementUntyped (const void *p) |
| Release an object retrieved from the association. More...
|
|
virtual void | releaseElement (const xAOD::Jet *p) |
| Release an object retrieved from the association. More...
|
|
| MultiAssociationToolImpl (const std::string &type, const std::string &name, const IInterface *parent) |
| Standard Gaudi tool constructor. More...
|
|
StatusCode | configureD3PD (IAddVariable *tree) |
| Configure the parent tree. More...
|
|
virtual StatusCode | addVariable (const std::string &name, const std::type_info &ti, void *&ptr, const std::string &docstring="", const void *defval=0) |
| Add a variable to the tuple. More...
|
|
template<class T > |
StatusCode | addVariable (const std::string &name, T *&ptr, const std::string &docstring="") |
| Make the template implementation from IAddVariable visible. More...
|
|
template<class T , class U > |
StatusCode | addVariable (const std::string &name, T *&ptr, const std::string &docstring, const U &defval) |
| Make the template implementation from IAddVariable visible. More...
|
|
virtual StatusCode | addVariable (const std::string &name, const std::type_info &ti, void *&ptr, const std::string &docstring="", const void *defval=0)=0 |
| Make the template implementation from IAddVariable visible. More...
|
|
template<class T > |
StatusCode | addVariable (const std::string &name, T *&ptr, const std::string &docstring="") |
| Add a variable to the tuple. More...
|
|
template<class T , class U > |
StatusCode | addVariable (const std::string &name, T *&ptr, const std::string &docstring, const U &defval) |
| Add a variable to the tuple. More...
|
|
virtual StatusCode | addDimensionedVariable (const std::string &name, const std::type_info &ti, void *&ptr, const std::string &dim, const std::string &docstring="", const void *defval=0) |
| Add a variable to the tuple. More...
|
|
template<class T > |
StatusCode | addDimensionedVariable (const std::string &name, T *&ptr, const std::string &dim, const std::string &docstring="") |
| Add a variable to the tuple. More...
|
|
template<class T , class U > |
StatusCode | addDimensionedVariable (const std::string &name, T *&ptr, const std::string &dim, const std::string &docstring, const U &defval) |
| Add a variable to the tuple. More...
|
|
virtual StatusCode | addDimensionedVariable (const std::string &name, const std::type_info &ti, void *&ptr, const std::string &dim, const std::string &docstring="", const void *defval=0)=0 |
| Add a variable to the tuple. More...
|
|
template<class T > |
StatusCode | addDimensionedVariable (const std::string &name, T *&ptr, const std::string &dim, const std::string &docstring="") |
| Add a variable to the tuple. More...
|
|
template<class T , class U > |
StatusCode | addDimensionedVariable (const std::string &name, T *&ptr, const std::string &dim, const std::string &docstring, const U &defval) |
| Add a variable to the tuple. More...
|
|
For every electron find jets in a cone and store lifetime, signed IP, and PTRel of relation.
Definition at line 42 of file ElectronJetDRAssociator.h.
◆ Base
◆ ElectronJetDRAssociator()
D3PD::ElectronJetDRAssociator::ElectronJetDRAssociator |
( |
const std::string & |
type, |
|
|
const std::string & |
name, |
|
|
const IInterface * |
parent |
|
) |
| |
Standard Gaudi tool constructor.
- Parameters
-
type | The name of the tool type. |
name | The tool name. |
parent | The tool's Gaudi parent. |
Definition at line 36 of file ElectronJetDRAssociator.cxx.
44 "Target label for the getter for the jets to which"
47 declareProperty (
"VertexContainerName",
49 "Primary vertex container name");
51 declareProperty (
"DRCut",
m_drcut = 0.7,
52 "DR cut between electrons and jets");
54 declareProperty (
"CollectionGetterRegistry",
m_registry,
55 "The ICollectionGetterRegistryTool instance.");
◆ addDimensionedVariable() [1/6]
StatusCode D3PD::AddVariable::addDimensionedVariable |
( |
const std::string & |
name, |
|
|
const std::type_info & |
ti, |
|
|
void *& |
ptr, |
|
|
const std::string & |
dim, |
|
|
const std::string & |
docstring = "" , |
|
|
const void * |
defval = 0 |
|
) |
| |
|
virtualinherited |
Add a variable to the tuple.
- Parameters
-
name | The name of the variable. |
type | The type of the variable. |
ptr | Pointer to the type of the variable. The pointer need not be initialized; the D3PD software will set the pointer prior to calling fill() . |
dim | Dimension for the variable. (Presently unimplemented!) |
docstring | Documentation string for this variable. |
defval | Pointer to the default value to use for this variable. Null for no default (generally means to fill with zeros). Of the type given by ti . Only works for basic types. |
If called from the constructor, the only effect is to clear ptr
.
Implements D3PD::IAddVariable.
Definition at line 123 of file AddVariable.cxx.
133 return StatusCode::SUCCESS;
138 docstring, defval ) );
◆ addDimensionedVariable() [2/6]
virtual StatusCode D3PD::IAddVariable::addDimensionedVariable |
|
inherited |
Add a variable to the tuple.
- Parameters
-
name | The name of the variable. |
type | The type of the variable. |
ptr | Pointer to the type of the variable. The pointer need not be initialized; the D3PD software will set the pointer prior to calling fill() . |
dim | Dimension for the variable. (Presently unimplemented!) |
docstring | Documentation string for this variable. |
defval | Pointer to the default value to use for this variable. Null for no default (generally means to fill with zeros). Of the type given by ti . Only works for basic types. |
If called from the constructor, the only effect is to clear ptr
.
◆ addDimensionedVariable() [3/6]
template<class T , class U >
StatusCode D3PD::IAddVariable::addDimensionedVariable |
( |
class T |
, |
|
|
class U |
|
|
) |
| |
|
inherited |
Add a variable to the tuple.
- Parameters
-
name | The name of the variable. |
ptr | Pointer to the type of the variable. The pointer need not be initialized; the D3PD software will set the pointer prior to calling fill() . |
dim | Dimension for the variable. (Presently unimplemented!) |
docstring | Documentation string for this variable. |
defval | Pointer to the default value to use for this variable. Only works for basic types. |
If called from the constructor, the only effect is to clear ptr
.
◆ addDimensionedVariable() [4/6]
template<class T , class U >
StatusCode D3PD::IAddVariable::addDimensionedVariable |
( |
const std::string & |
name, |
|
|
T *& |
ptr, |
|
|
const std::string & |
dim, |
|
|
const std::string & |
docstring, |
|
|
const U & |
defval |
|
) |
| |
|
inherited |
Add a variable to the tuple.
- Parameters
-
name | The name of the variable. |
ptr | Pointer to the type of the variable. The pointer need not be initialized; the D3PD software will set the pointer prior to calling fill() . |
dim | Dimension for the variable. (Presently unimplemented!) |
docstring | Documentation string for this variable. |
defval | Pointer to the default value to use for this variable. Only works for basic types. |
If called from the constructor, the only effect is to clear ptr
.
◆ addDimensionedVariable() [5/6]
template<class T >
StatusCode D3PD::IAddVariable::addDimensionedVariable |
( |
class T |
| ) |
|
|
inherited |
Add a variable to the tuple.
- Parameters
-
name | The name of the variable. |
ptr | Pointer to the type of the variable. The pointer need not be initialized; the D3PD software will set the pointer prior to calling fill() . |
dim | Dimension for the variable. (Presently unimplemented!) |
docstring | Documentation string for this variable. |
If called from the constructor, the only effect is to clear ptr
.
◆ addDimensionedVariable() [6/6]
template<class T >
StatusCode D3PD::IAddVariable::addDimensionedVariable |
( |
const std::string & |
name, |
|
|
T *& |
ptr, |
|
|
const std::string & |
dim, |
|
|
const std::string & |
docstring = "" |
|
) |
| |
|
inherited |
Add a variable to the tuple.
- Parameters
-
name | The name of the variable. |
ptr | Pointer to the type of the variable. The pointer need not be initialized; the D3PD software will set the pointer prior to calling fill() . |
dim | Dimension for the variable. (Presently unimplemented!) |
docstring | Documentation string for this variable. |
If called from the constructor, the only effect is to clear ptr
.
◆ addVariable() [1/6]
StatusCode D3PD::AddVariable::addVariable |
( |
const std::string & |
name, |
|
|
const std::type_info & |
ti, |
|
|
void *& |
ptr, |
|
|
const std::string & |
docstring = "" , |
|
|
const void * |
defval = 0 |
|
) |
| |
|
virtualinherited |
Add a variable to the tuple.
- Parameters
-
name | The name of the variable. |
type | The type of the variable. |
ptr | Pointer to the type of the variable. The pointer need not be initialized; the D3PD software will set the pointer prior to calling fill() . |
docstring | Documentation string for this variable. |
defval | Pointer to the default value to use for this variable. Null for no default (generally means to fill with zeros). Of the type given by ti . Only works for basic types. |
If called from the constructor, the only effect is to clear ptr
.
Implements D3PD::IAddVariable.
Definition at line 85 of file AddVariable.cxx.
94 return StatusCode::SUCCESS;
98 ti,
ptr, docstring, defval ) );
100 ti,
ptr, docstring, defval);
◆ addVariable() [2/6]
virtual StatusCode D3PD::IAddVariable::addVariable |
|
inherited |
◆ addVariable() [3/6]
template<class T , class U >
StatusCode D3PD::IAddVariable::addVariable |
( |
class T |
, |
|
|
class U |
|
|
) |
| |
|
inherited |
◆ addVariable() [4/6]
template<class T , class U >
StatusCode D3PD::IAddVariable::addVariable |
( |
const std::string & |
name, |
|
|
T *& |
ptr, |
|
|
const std::string & |
docstring, |
|
|
const U & |
defval |
|
) |
| |
|
inherited |
Add a variable to the tuple.
- Parameters
-
name | The name of the variable. |
ptr | Pointer to the type of the variable. The pointer need not be initialized; the D3PD software will set the pointer prior to calling fill() . |
docstring | Documentation string for this variable. |
defval | Pointer to the default value to use for this variable. Only works for basic types. |
If called from the constructor, the only effect is to clear ptr
.
◆ addVariable() [5/6]
template<class T >
StatusCode D3PD::IAddVariable::addVariable |
( |
class T |
| ) |
|
|
inherited |
◆ addVariable() [6/6]
template<class T >
StatusCode D3PD::IAddVariable::addVariable |
( |
const std::string & |
name, |
|
|
T *& |
ptr, |
|
|
const std::string & |
docstring = "" |
|
) |
| |
|
inherited |
Add a variable to the tuple.
- Parameters
-
name | The name of the variable. |
ptr | Pointer to the type of the variable. The pointer need not be initialized; the D3PD software will set the pointer prior to calling fill() . |
docstring | Documentation string for this variable. |
If called from the constructor, the only effect is to clear ptr
.
◆ book()
StatusCode D3PD::ElectronJetDRAssociator::book |
( |
| ) |
|
|
finalvirtual |
Create any needed tuple variables.
This is called at the start of the first event.
Reimplemented from D3PD::MultiAssociationToolImpl.
Definition at line 158 of file ElectronJetDRAssociator.cxx.
161 "DR between electron and associated jet.") );
163 "Signed impact parameter between electron and jet.") );
165 "Relative Pt between electron and jet.") );
167 "Number of jet constituents.") );
169 "Jet Pt with electron removed.") );
171 return StatusCode::SUCCESS;
◆ configureD3PD() [1/2]
StatusCode D3PD::AddVariable::configureD3PD |
( |
IAddVariable * |
tree | ) |
|
|
inherited |
Configure the parent tree.
- Parameters
-
Definition at line 61 of file AddVariable.cxx.
65 return StatusCode::SUCCESS;
◆ configureD3PD() [2/2]
StatusCode D3PD::ElectronJetDRAssociator::configureD3PD |
( |
IAddVariable * |
tree, |
|
|
const std::type_info & |
ti |
|
) |
| |
|
overridevirtual |
Configure during initialization: type-check.
- Parameters
-
tree | Our parent for tuple making. |
ti | Gives the type of the object being passed to resetUntyped . |
configureD3PD
should check that the type of the object coming as input (to getUntyped
) is compatible with what it expects, and raise an error otherwise.
Reimplemented from D3PD::MultiAssociationToolImpl.
Definition at line 81 of file ElectronJetDRAssociator.cxx.
87 return StatusCode::SUCCESS;
◆ configureMulti()
StatusCode D3PD::MultiAssociationToolImpl::configureMulti |
( |
D3PD::IAddVariable * |
tree, |
|
|
const std::type_info & |
ti, |
|
|
const std::vector< const std::type_info * > & |
tis, |
|
|
size_t & |
which |
|
) |
| |
|
protectedinherited |
Configure during initialization: type-check.
Alternate implementation for the case where we have to choose among multiple possible input types.
- Parameters
-
| tree | Our parent for tuple making. |
| ti | Gives the type of the object being passed to getUntyped . |
| tis | List of possible input types that we can accept. |
[out] | which | Index of the accepted type. |
configureMulti
should check that the type of the object coming as input (to getUntyped
) is compatible with what it expects, and raise an error otherwise.
Definition at line 74 of file MultiAssociationToolImpl.cxx.
81 return StatusCode::SUCCESS;
◆ doConversion()
const void * D3PD::MultiAssociationToolImpl::doConversion |
( |
const void * |
p | ) |
|
|
protectedinherited |
Helper to convert pointers to source objects.
- Parameters
-
p | Source object, as a pointer to the type passed to configureD3PD . return Source object, as a pointer to the type given by fromTypeinfo . |
Definition at line 104 of file MultiAssociationToolImpl.cxx.
◆ elementTypeinfo()
Return the element type for the target of the association.
I.e., nextUntyped
returns a pointer to this type.
◆ findReducedPt()
Find the pT of the jet with electron removed.
- Parameters
-
| eg | The egamma object to analyze. |
| j | The jet under consideration. |
[out] | reducedPt | Jet Pt calculated after subtraction of electron momentum. |
| eg | The egamma object to analyze. |
| j | The jet under consideration. @reducedPt[out] Jet Pt calculated after subtraction of electron momentum. |
Definition at line 181 of file ElectronJetDRAssociator.cxx.
188 return StatusCode::SUCCESS;
193 return StatusCode::SUCCESS;
198 reducedPt = hypot (
px,
py);
200 return StatusCode::SUCCESS;
◆ findSignedIPAndPTRelEleJetPair()
Find the signed impact parameter and PTRel of EG's track relative to the beamspot.
Find the impact parameter of EG's track relative to the beamspot.
- Parameters
-
eg | The egamma object to analyze. |
signedIP[out] | Transverse impact parameter wrt the beamspot. |
PTRel[out] | Longitudinal impact parameter wrt the beamspot. |
eg | The egamma object to analyze. |
d0beam[out] | Transverse impact parameter wrt the beamspot. |
z0beam[out] | Longitudinal impact parameter wrt the beamspot. |
Definition at line 211 of file ElectronJetDRAssociator.cxx.
220 return StatusCode::SUCCESS;
225 return StatusCode::SUCCESS;
228 PTRel=
track->p4().Perp (j0->
p4().Vect());
230 CLHEP::Hep3Vector jetDirection( (j0)->
px(), (j0)->
py(), (j0)->
pz());
231 CLHEP::Hep3Vector
unit = jetDirection.unit();
234 return StatusCode::SUCCESS;
242 <<
" not found in StoreGate!";
243 else if (!vxcontainer->
empty())
244 vx = vxcontainer->
front();
249 <<
"No vertex found.";
250 return StatusCode::SUCCESS;
256 return StatusCode::SUCCESS;
◆ fromTypeinfo() [1/2]
Return the std::type_info
for the source of the association.
◆ fromTypeinfo() [2/2]
virtual const std::type_info& D3PD::MultiAssociationToolImpl::fromTypeinfo |
( |
| ) |
const |
|
pure virtualinherited |
◆ initialize()
StatusCode D3PD::ElectronJetDRAssociator::initialize |
( |
| ) |
|
|
overridevirtual |
◆ MultiAssociationToolImpl()
D3PD::MultiAssociationToolImpl::MultiAssociationToolImpl |
|
inherited |
Standard Gaudi tool constructor.
- Parameters
-
type | The name of the tool type. |
name | The tool name. |
parent | The tool's Gaudi parent. |
Definition at line 39 of file MultiAssociationToolImpl.cxx.
34 declareProperty (
"Prefix",
m_prefix =
"",
35 "Tuple variable prefix for this block.");
37 "The name of this block.");
◆ next()
Return a pointer to the next element in the association.
Return 0 when the association has been exhausted.
Implements D3PD::MultiAssociationToolTo< xAOD::Jet >.
Definition at line 109 of file ElectronJetDRAssociator.cxx.
121 float dr = hypot (clus->
p4().DeltaPhi(myjet->p4()),
122 myjet->eta() - clus->
etaBE(2));
125 float signedIP=-9999.9;
127 float reducedPt=-9999.9;
130 signedIP, PTRel ).isFailure() )
◆ nextUntyped()
Return a pointer to the next element in the association.
Return 0 when the association has been exhausted.
◆ releaseElement()
Release an object retrieved from the association.
- Parameters
-
Call this when you are done with the object returned by next()
. The default implementation is a no-op, but if the association dynamically allocated the object which it returned, this gives it a chance to free it.
◆ releaseElementUntyped()
Release an object retrieved from the association.
- Parameters
-
Call this when you are done with the object returned by nextUntyped()
. The default implementation is a no-op, but if the association dynamically allocated the object which it returned, this gives it a chance to free it.
◆ reset()
◆ resetUntyped()
Start the iteration for a new association.
- Parameters
-
p | The object from which to associate. |
◆ m_blockName
std::string D3PD::MultiAssociationToolImpl::m_blockName |
|
privateinherited |
◆ m_dr
float* D3PD::ElectronJetDRAssociator::m_dr |
|
private |
◆ m_drcut
double D3PD::ElectronJetDRAssociator::m_drcut |
|
private |
◆ m_eg
◆ m_inputConverter
◆ m_jetSize
unsigned int* D3PD::ElectronJetDRAssociator::m_jetSize |
|
private |
◆ m_metadata
Metadata about the variables created by this object.
Definition at line 129 of file AddVariable.h.
◆ m_prefix
std::string D3PD::MultiAssociationToolImpl::m_prefix |
|
privateinherited |
◆ m_ptrel
float* D3PD::ElectronJetDRAssociator::m_ptrel |
|
private |
◆ m_reducedPt
float* D3PD::ElectronJetDRAssociator::m_reducedPt |
|
private |
◆ m_registry
◆ m_signedIP
float* D3PD::ElectronJetDRAssociator::m_signedIP |
|
private |
◆ m_suffix
const std::string& D3PD::AddVariable::m_suffix |
|
privateinherited |
◆ m_target
◆ m_targetLabel
std::string D3PD::ElectronJetDRAssociator::m_targetLabel |
|
private |
◆ m_trackToVertexIPEstimator
◆ m_tree
◆ m_vertexContainerName
std::string D3PD::ElectronJetDRAssociator::m_vertexContainerName |
|
private |
◆ s_emptyString
const std::string D3PD::AddVariable::s_emptyString |
|
staticprivateinherited |
Used to provide a default value for blockName.
Definition at line 41 of file AddVariable.h.
The documentation for this class was generated from the following files:
def retrieve(aClass, aKey=None)
float * m_reducedPt
Variable: Jet pT with electron removed.
ToolHandle< Trk::ITrackToVertexIPEstimator > m_trackToVertexIPEstimator
Property: Tool for the estimation of the IPs to the vertex.
float * m_ptrel
Variable: Relative Pt between electron and jet.
std::string dstName() const
Return the name of the destination type, or an empty string.
StatusCode configureD3PD(IAddVariable *tree)
Configure the parent tree.
AddVariable(const std::string &prefix, const std::string &blockName=s_emptyString)
Constructor.
const std::string & m_suffix
Reference to the variable suffix.
float * m_signedIP
Variable: Signed impact parameter between electron and jet.
std::string m_targetLabel
Property: Target label for the getter for the jets to which to associate.
const std::string & m_prefix
Reference to the variable prefix.
virtual StatusCode addVariable(const std::string &name, const std::type_info &ti, void *&ptr, const std::string &docstring="", const void *defval=0)
Add a variable to the tuple.
ToolHandle< ICollectionGetterRegistryTool > m_registry
Property: The ICollectionGetterRegistryTool instance.
StatusCode findReducedPt(const xAOD::Electron *eg, const xAOD::Jet *j, float &reducedPt)
Find the pT of the jet with electron removed.
IAddVariable * m_tree
Reference to the block name.
StatusCode init(const std::type_info &src_ti, const std::type_info &dst_ti)
Initialize the converter.
unsigned int * m_jetSize
Variable: Number of jet constituents.
std::string srcName() const
Return the name of the source type, or an empty string.
const xAOD::Electron * m_eg
float etaBE(const unsigned layer) const
Get the eta in one layer of the EM Calo.
ObjectMetadata m_metadata
Metadata about the variables created by this object.
Description of a calorimeter cluster.
const void * convertUntyped(const void *p) const
Convert pointer.
double m_drcut
Property: DR cut between electrons and jets.
virtual StatusCode book() final
Create any needed tuple variables.
const xAOD::CaloCluster * caloCluster(size_t index=0) const
Pointer to the xAOD::CaloCluster/s that define the electron candidate.
const T * front() const
Access the first element in the collection as an rvalue.
MultiAssociationTool< xAOD::Electron, xAOD::Jet > Base
#define CHECK(...)
Evaluate an expression and check for errors.
float py() const
The y-component of the jet's momentum.
virtual FourMom_t p4() const
The full 4-momentum of the particle.
std::string m_vertexContainerName
Property: Vertex container name.
ICollectionGetterTool * m_target
Getter defining the collection within which to index.
float px() const
The x-component of the jet's momentum.
#define REPORT_MESSAGE(LVL)
Report a message.
virtual FourMom_t p4() const
The full 4-momentum of the particle.
Class describing a Vertex.
#define ATH_MSG_WARNING(x)
const PlainObject unit() const
This is a plugin that makes Eigen look like CLHEP & defines some convenience methods.
StatusCode addVariable(const std::string &name, T *&ptr, const std::string &docstring="")
Add a variable to the tuple.
StatusCode findSignedIPAndPTRelEleJetPair(const xAOD::Electron *eg, const xAOD::Jet *j0, float &signedIP, float &PTRel)
Find the signed impact parameter and PTRel of EG's track relative to the beamspot.
StatusCode addDimensionedVariable(const std::string &name, T *&ptr, const std::string &dim, const std::string &docstring="")
Add a variable to the tuple.
Class describing a TrackParticle.
float * m_dr
Variable: DR between electron and jet.
bool empty() const noexcept
Returns true if the collection is empty.