Calculate deltaEmax2 for egamma objects and store as UD.
More...
#include <egammaDeltaEmax2Alg.h>
Calculate deltaEmax2 for egamma objects and store as UD.
Definition at line 29 of file egammaDeltaEmax2Alg.h.
◆ StoreGateSvc_t
◆ egammaDeltaEmax2Alg()
| D3PD::egammaDeltaEmax2Alg::egammaDeltaEmax2Alg |
( |
const std::string & | name, |
|
|
ISvcLocator * | svcloc ) |
Standard Gaudi algorithm constructor.
- Parameters
-
| name | The algorithm name. |
| svcloc | The service locator. |
Definition at line 21 of file egammaDeltaEmax2Alg.cxx.
25{
27 "Prefix to add to aux data items.");
29 "Getter instance for the input egamma objects.");
31 "If true, don't complain if input objects are missing.");
33 "True if we should use the high-lum definition "
34 "of deltaEmax2.");
35}
AthAlgorithm()
Default constructor:
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
std::string m_auxPrefix
Property: Prefix to add to aux data items.
ToolHandle< ICollectionGetterTool > m_getter
Property: Getter for input photon objects.
bool m_allowMissing
Property: If true, don't complain if input objects are missing.
bool m_highLum
Property: True if we should use the high-lum definition of deltaEmax2.
◆ declareGaudiProperty()
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition at line 156 of file AthCommonDataStore.h.
158 {
161 hndl.documentation());
162
163 }
◆ declareProperty()
Definition at line 145 of file AthCommonDataStore.h.
145 {
148 }
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
◆ detStore()
◆ evtStore()
◆ execute()
| StatusCode D3PD::egammaDeltaEmax2Alg::execute |
( |
| ) |
|
|
overridevirtual |
Standard Gaudi execute method.
Definition at line 53 of file egammaDeltaEmax2Alg.cxx.
54{
55 xAOD::Egamma::Decorator<float> deltaemax2 (
m_auxPrefix +
"deltaEmax2");
56
59 {
60 deltaemax2(*g) = -999;
62 if (cluster) {
63 double eta2 = std::fabs(cluster->
etaBE(2));
64
65 if (eta2 > 900)
66 eta2 = std::fabs(cluster->
eta());
67 double et = cluster->
e()/std::cosh(eta2);
68 float emax2 = 0;
70
72 deltaemax2(*g) = emax2/(1000.+0.0049*
et);
73 else
74 deltaemax2(*g) = emax2/(1000.+0.009*
et);
75 }
76
78 }
79
80 return StatusCode::SUCCESS;
81}
#define CHECK(...)
Evaluate an expression and check for errors.
float et(const xAOD::jFexSRJetRoI *j)
virtual double eta() const
The pseudorapidity ( ) of the particle.
virtual double e() const
The total energy of the particle.
float etaBE(const unsigned layer) const
Get the eta in one layer of the EM Calo.
@ e2tsts1
energy of the cell corresponding to second energy maximum in the first sampling
CaloCluster_v1 CaloCluster
Define the latest version of the calorimeter cluster class.
Egamma_v1 Egamma
Definition of the current "egamma version".
◆ extraDeps_update_handler()
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
◆ extraOutputDeps()
| const DataObjIDColl & AthAlgorithm::extraOutputDeps |
( |
| ) |
const |
|
overridevirtualinherited |
Return the list of extra output dependencies.
This list is extended to include symlinks implied by inheritance relations.
Definition at line 50 of file AthAlgorithm.cxx.
51{
52
53
56 }
57 return Algorithm::extraOutputDeps();
58}
DataObjIDColl m_extendedExtraObjects
◆ initialize()
| StatusCode D3PD::egammaDeltaEmax2Alg::initialize |
( |
| ) |
|
|
overridevirtual |
◆ inputHandles()
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()
◆ msgLvl()
| bool AthCommonMsg< Algorithm >::msgLvl |
( |
const MSG::Level | lvl | ) |
const |
|
inlineinherited |
◆ outputHandles()
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()
Definition at line 380 of file AthCommonDataStore.h.
381 {
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()
◆ sysInitialize()
| StatusCode AthAlgorithm::sysInitialize |
( |
| ) |
|
|
overridevirtualinherited |
Override sysInitialize.
Override sysInitialize from the base class.
Loop through all output handles, and if they're WriteCondHandles, automatically register them and this Algorithm with the CondSvc
Scan through all outputHandles, and if they're WriteCondHandles, register them with the CondSvc
Reimplemented from AthCommonDataStore< AthCommonMsg< Algorithm > >.
Reimplemented in AthAnalysisAlgorithm, AthFilterAlgorithm, AthHistogramAlgorithm, and PyAthena::Alg.
Definition at line 66 of file AthAlgorithm.cxx.
66 {
68
71 }
72 ServiceHandle<ICondSvc> cs(
"CondSvc",
name());
74 if (
h->isCondition() &&
h->mode() == Gaudi::DataHandle::Writer) {
75
76 if ( cs.retrieve().isFailure() ) {
78 return StatusCode::SUCCESS;
79 }
80 if (cs->regHandle(this,*h).isFailure()) {
81 sc = StatusCode::FAILURE;
82 ATH_MSG_ERROR(
"unable to register WriteCondHandle " <<
h->fullKey()
83 << " with CondSvc");
84 }
85 }
86 }
88}
#define ATH_MSG_WARNING(x)
virtual StatusCode sysInitialize() override
Override sysInitialize.
AthCommonDataStore(const std::string &name, T... args)
virtual std::vector< Gaudi::DataHandle * > outputHandles() const override
::StatusCode StatusCode
StatusCode definition for legacy code.
◆ sysStart()
Handle START transition.
We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.
◆ updateVHKA()
Definition at line 308 of file AthCommonDataStore.h.
308 {
309
310
313 for (
auto k :
keys) {
315 }
316 }
317 }
std::vector< SG::VarHandleKeyArray * > m_vhka
◆ m_allowMissing
| bool D3PD::egammaDeltaEmax2Alg::m_allowMissing |
|
private |
◆ m_auxPrefix
| std::string D3PD::egammaDeltaEmax2Alg::m_auxPrefix |
|
private |
◆ m_detStore
◆ m_evtStore
◆ m_extendedExtraObjects
| DataObjIDColl AthAlgorithm::m_extendedExtraObjects |
|
privateinherited |
◆ m_getter
◆ m_highLum
| bool D3PD::egammaDeltaEmax2Alg::m_highLum |
|
private |
◆ m_varHandleArraysDeclared
◆ m_vhka
The documentation for this class was generated from the following files: