ATLAS Offline Software
Loading...
Searching...
No Matches
CP::ElectronChargeEfficiencyCorrectionTool Class Referencefinal

#include <ElectronChargeEfficiencyCorrectionTool.h>

Inheritance diagram for CP::ElectronChargeEfficiencyCorrectionTool:
Collaboration diagram for CP::ElectronChargeEfficiencyCorrectionTool:

Public Member Functions

virtual StatusCode initialize () override final
 Gaudi Service Interface method implementations.
virtual CP::CorrectionCode getEfficiencyScaleFactor (const xAOD::Electron &inputObject, double &sf) const override final
 Retrieve the Scale factor.
virtual CP::CorrectionCode applyEfficiencyScaleFactor (const xAOD::Electron &inputObject) const override final
 Decorate the electron.
virtual bool isAffectedBySystematic (const SystematicVariation &systematic) const override final
 Returns whether this tool is affected by the given systematics.
virtual SystematicSet affectingSystematics () const override final
 Returns the list of all systematics this tool can be affected by.
virtual CP::SystematicSet recommendedSystematics () const override final
 Returns the list of all systematics this tool recommends to use.
virtual StatusCode applySystematicVariation (const SystematicSet &systConfig) override final
 effects: configure this tool for the given list of systematic variations.
virtual const CP::SystematicSetappliedSystematics () const override final
 returns: the currently applied systematics
virtual int systUncorrVariationIndex (const xAOD::Electron &) const override final
virtual CP::CorrectionCode getEfficiencyScaleFactor (const double, const double, const unsigned int, double &) const override final
virtual int getNumberOfToys () const override final
virtual void printCorrelationModels () const override final
 print available/implemented correlation models
virtual void print () const
 Print the state of the tool.
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
Additional helper functions, not directly mimicking Athena
template<class T>
const T * getProperty (const std::string &name) const
 Get one of the tool's properties.
const std::string & msg_level_name () const __attribute__((deprecated))
 A deprecated function for getting the message level's name.
const std::string & getName (const void *ptr) const
 Get the name of an object that is / should be in the event store.
SG::sgkey_t getKey (const void *ptr) const
 Get the (hashed) key of an object that is in the event store.

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

virtual ASG_TOOL_CLASS(ElectronChargeEfficiencyCorrectionTool, IAsgElectronEfficiencyCorrectionTool) public ~ElectronChargeEfficiencyCorrectionTool ()
 Standard destructor.
StatusCode registerSystematics ()
float getChargeFlipRate (double eta, double pt, TH2 *hrates, double &flipRate) const
 Get the charge flip rate rate given pt, eta, histogram.
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>

Private Attributes

int m_dataTypeOverwrite
 Force the data type to a given value.
std::string m_eventInfoCollectionName
 The Event info collection name.
std::map< std::string, std::vector< TH2 * > > m_SF_SS
 Histogram that holds the correction rates for Monte Carlo.
std::map< std::string, std::vector< TH2 * > > m_SF_OS
std::vector< unsigned intm_RunNumbers
bool m_useRandomRunNumber
unsigned int m_defaultRandomRunNumber
std::string m_filename
 The name of the input file that contains the histograms.
std::string m_workingPoint
 The name of the folder defining the LH/iso working point.
double m_eta_lowlimit
 Lower limit of eta range where corrections are available; taken from histogram.
double m_eta_uplimit
 Upper limit of eta range where corrections are available; taken from histogram.
double m_pt_lowlimit
 Lower limit of pt range where corrections are available; taken from histogram.
double m_pt_uplimit
 Upper limit of pt range where corrections are available; taken from histogram.
float m_gevmev
 Factor for GeV <-> MeV switching.
std::vector< std::string > m_systematics
std::map< CP::SystematicSet, CP::SystematicSetm_filtered_sys_sets
CP::SystematicSet m_mySysConf
CP::SystematicSet m_affectingSys
CP::SystematicSetm_appliedSystematics
 Currently applied systematics.
std::string m_sf_decoration_name
 Decorator.
SG::AuxElement::Decorator< float > * m_sfDec
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 26 of file ElectronChargeEfficiencyCorrectionTool.h.

Member Typedef Documentation

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< AlgTool > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

Member Function Documentation

◆ affectingSystematics()

CP::SystematicSet ElectronChargeEfficiencyCorrectionTool::affectingSystematics ( ) const
finaloverridevirtual

Returns the list of all systematics this tool can be affected by.

Implements CP::IReentrantSystematicsTool.

Definition at line 627 of file ElectronChargeEfficiencyCorrectionTool.cxx.

628{
629 CP::SystematicSet result;
630 result.insert(SystematicVariation("EL_CHARGEID_STAT", 1));
631 result.insert(SystematicVariation("EL_CHARGEID_STAT", -1));
632
633 for (unsigned int i = 0; i < m_systematics.size(); i++) {
634 result.insert(SystematicVariation(
635 Form("EL_CHARGEID_SYS%s", m_systematics.at(i).c_str()), 1));
636 result.insert(SystematicVariation(
637 Form("EL_CHARGEID_SYS%s", m_systematics.at(i).c_str()), -1));
638 }
639 return result;
640}

◆ appliedSystematics()

virtual const CP::SystematicSet & CP::ElectronChargeEfficiencyCorrectionTool::appliedSystematics ( ) const
inlinefinaloverridevirtual

returns: the currently applied systematics

Implements IAsgElectronEfficiencyCorrectionTool.

Definition at line 68 of file ElectronChargeEfficiencyCorrectionTool.h.

69 {
71 }
CP::SystematicSet * m_appliedSystematics
Currently applied systematics.

◆ applyEfficiencyScaleFactor()

CP::CorrectionCode ElectronChargeEfficiencyCorrectionTool::applyEfficiencyScaleFactor ( const xAOD::Electron & inputObject) const
finaloverridevirtual

Decorate the electron.

Implements IAsgElectronEfficiencyCorrectionTool.

Definition at line 575 of file ElectronChargeEfficiencyCorrectionTool.cxx.

577{
579 "In "
580 "CP::ElectronChargeEfficiencyCorrectionTool::applyEfficiencyScaleFactor("
581 "const xAOD::IParticle& part) const");
582 double sf = 0.0;
583 CP::CorrectionCode result = this->getEfficiencyScaleFactor(part, sf);
584 // Decorate the electron
585 (*m_sfDec)(part) = static_cast<float>(sf);
586 return result;
587}
#define ATH_MSG_DEBUG(x)
virtual CP::CorrectionCode getEfficiencyScaleFactor(const xAOD::Electron &inputObject, double &sf) const override final
Retrieve the Scale factor.

◆ applySystematicVariation()

StatusCode ElectronChargeEfficiencyCorrectionTool::applySystematicVariation ( const SystematicSet & systConfig)
finaloverridevirtual

effects: configure this tool for the given list of systematic variations.

any requested systematics that are not affecting this tool will be silently ignored (unless they cause other errors). failures: systematic unknown failures: requesting multiple variations on the same systematic (e.g. up & down) failures: requesting an unsupported variation on an otherwise supported systematic (e.g. a 2 sigma variation and the tool only supports 1 sigma variations) failures: unsupported combination of supported systematic failures: other tool specific errors

Implements CP::ISystematicsTool.

Definition at line 654 of file ElectronChargeEfficiencyCorrectionTool.cxx.

656{
657
659 systConfig, m_affectingSys, m_mySysConf)) {
661 "Unsupported combination of systematics passed to the tool! ");
662 return StatusCode::FAILURE;
663 }
664
665 return StatusCode::SUCCESS;
666}
#define ATH_MSG_ERROR(x)
static StatusCode filterForAffectingSystematics(const SystematicSet &systConfig, const SystematicSet &affectingSystematics, SystematicSet &filteredSystematics)
description: filter the systematics for the affected systematics returns: success guarantee: strong f...

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

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

◆ 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

◆ getChargeFlipRate()

float ElectronChargeEfficiencyCorrectionTool::getChargeFlipRate ( double eta,
double pt,
TH2 * hrates,
double & flipRate ) const
private

Get the charge flip rate rate given pt, eta, histogram.

Definition at line 591 of file ElectronChargeEfficiencyCorrectionTool.cxx.

596{
597 ATH_MSG_VERBOSE(" -> in: getChargeFlipRate(" << pt << ", " << eta
598 << " TH2, double&)");
599
600 if (pt > m_pt_uplimit)
601 pt = m_pt_uplimit * 0.999;
602
603 int bin2D = hrates->FindBin(pt, eta);
604 flipRate = hrates->GetBinContent(bin2D);
605
606 ATH_MSG_VERBOSE(" -> flipRate is " << flipRate << ", for histogram "
607 << hrates->GetName());
608
609 return 0;
610}
Scalar eta() const
pseudorapidity method
#define ATH_MSG_VERBOSE(x)
double m_pt_uplimit
Upper limit of pt range where corrections are available; taken from histogram.
setRcore setEtHad setFside pt

◆ getEfficiencyScaleFactor() [1/2]

virtual CP::CorrectionCode CP::ElectronChargeEfficiencyCorrectionTool::getEfficiencyScaleFactor ( const double ,
const double ,
const unsigned int ,
double &  ) const
inlinefinaloverridevirtual

Implements IAsgElectronEfficiencyCorrectionTool.

Definition at line 81 of file ElectronChargeEfficiencyCorrectionTool.h.

83 {
85 "No toysimplemented in "
86 "ElectronChargeEfficiencyCorrectionTool");
88 }
@ Error
Some error happened during the object correction.

◆ getEfficiencyScaleFactor() [2/2]

CP::CorrectionCode ElectronChargeEfficiencyCorrectionTool::getEfficiencyScaleFactor ( const xAOD::Electron & inputObject,
double & sf ) const
finaloverridevirtual

Retrieve the Scale factor.

STAT

STAT

Implements IAsgElectronEfficiencyCorrectionTool.

Definition at line 336 of file ElectronChargeEfficiencyCorrectionTool.cxx.

339{
340
341 // initialize the SF at 1
342 sf = 1.0;
343
344 // checking on the truth electron: up to now if this is not a good ele it's
345 // returning
346 bool goodEle = false;
347 CP::CorrectionCode goodEle_result =
349 if (goodEle_result != CP::CorrectionCode::Ok) {
350 sf = -999.0;
351 ATH_MSG_DEBUG("This is the check of goodeleCC in getscalefactor. Scale "
352 "factor set to -999");
353 return goodEle_result;
354 }
355
356 if (!goodEle) {
357 // electron is background electron and should not be corrected
359 ATH_MSG_DEBUG("Here goodele is false but CC ok");
360 }
361
362 // taking reconstructed variables
363 int reco_ele_charge = ele.charge();
364 const double ele_pt = ele.pt() * m_gevmev;
365 const double ele_eta = std::abs(ele.caloCluster()->etaBE(2));
366
367 // getting the truth charge
368 int truth_ele_charge = 9999;
369 CP::CorrectionCode charge_result =
370 ElectronEfficiencyHelpers::getEleTruthCharge( ele, truth_ele_charge);
371 if (charge_result != CP::CorrectionCode::Ok) {
372 sf = -9999.0;
373 ATH_MSG_VERBOSE("This is check of geteletruthchargeCC in getscalefactor. "
374 "Scale factor set to -9999");
375 return charge_result;
376 }
377
378 if (truth_ele_charge == 0) {
379 ATH_MSG_DEBUG("Here truth charge is =0!!");
381 }
382
383 ATH_MSG_DEBUG("Reco charge = " << reco_ele_charge
384 << "; Truth charge = " << truth_ele_charge);
385
386 // getting the rates from file....
387 float retVal(0.0);
388
390 // here determine, WHICH of the [histid] to choose (after cuuts on runnumber
391 // etc....)
392 std::string cutRunNumber = "all";
393
394 if (!m_RunNumbers.empty()) {
395 unsigned int runnumber = m_defaultRandomRunNumber;
396 ATH_MSG_DEBUG("RandomRunNumber: " << runnumber << " "
399 const xAOD::EventInfo* eventInfo =
401 if (!eventInfo) {
402 ATH_MSG_ERROR("Could not retrieve EventInfo object!");
403 sf = 1.0;
405 }
406 static const SG::AuxElement::Accessor<unsigned int> randomrunnumber(
407 "RandomRunNumber");
408 if (!randomrunnumber.isAvailable(*eventInfo)) {
409 sf = 1.0;
411 "Pileup tool not run before using ElectronEfficiencyTool! SFs do not "
412 "reflect PU distribution in data");
414 }
415 runnumber = randomrunnumber(*(eventInfo));
416 }
417 ATH_MSG_DEBUG("Number of RunNumbers in file: " << m_RunNumbers.size());
418 for (std::size_t r = 0; r < m_RunNumbers.size(); r++) {
419 ATH_MSG_DEBUG( " - " << m_RunNumbers.at(r));
420 }
421 ATH_MSG_VERBOSE("DONE");
422
423 bool isInRunNumberRange = false;
424 for ( std::size_t r=0; r<m_RunNumbers.size()-1; r+=2 ){
425 // increment by two, run numbers always come in pairs (upper and lower bound specified in the histogram name)
426
427 if ( runnumber >= (unsigned int)m_RunNumbers.at(r) &&
428 runnumber <= (unsigned int)m_RunNumbers.at(r+1) ) {
429 cutRunNumber.clear();
430 cutRunNumber =
431 Form("RunNumber%d_%d", m_RunNumbers.at(r), m_RunNumbers.at(r + 1));
432 ATH_MSG_DEBUG("Random run number lies in range " << m_RunNumbers.at(r) << " " << m_RunNumbers.at(r+1));
433 isInRunNumberRange = true;
434 }
435 }
436
437 if (runnumber < m_RunNumbers.at(0) ||
438 (runnumber > m_RunNumbers.at(m_RunNumbers.size() - 1))) {
439 ATH_MSG_DEBUG("RunNumber " << runnumber << " is not in valid RunNumber Range ");
440 sf = 1.0;
442 }
443
444 if ( !isInRunNumberRange ) {
446 }
447 }
448
449 // check if electron is within recommendations in eta/Et
450 if ( ele_eta < m_eta_lowlimit || ele_eta > m_eta_uplimit ) {
451
452 ATH_MSG_DEBUG("Got an electron outside of the range of eta validity " << ele_eta);
454 }
455
456 if ( ele_pt < m_pt_lowlimit ) {
457
458 ATH_MSG_DEBUG("Got an electron outside of the range of pt validity: pt lower than lower limit");
460 }
461
462 // Determine WHICH histograms to use here
463 const std::vector<TH2*>& SShistograms = m_SF_SS.at(cutRunNumber.c_str());
464 const std::vector<TH2*>& OShistograms = m_SF_OS.at(cutRunNumber.c_str());
465
466 // here check OS or SS
467 bool isOS = false;
468
469 if (truth_ele_charge * reco_ele_charge > 0)
470 isOS = true;
471
472 if (isOS) {
473 retVal = this->getChargeFlipRate(ele_eta, ele_pt, OShistograms.at(0), sf);
474 if (retVal != 0) {
475 sf = -9999.0;
477 }
478 } else {
479 ATH_MSG_DEBUG("Get SS his");
480 retVal = this->getChargeFlipRate(ele_eta, ele_pt, SShistograms.at(0), sf);
481 if (retVal != 0) {
482 sf = -9999.0;
484 }
485 }
486
487 ATH_MSG_DEBUG("eta: " << ele_eta << " pt: " << ele_pt);
488 ATH_MSG_DEBUG("SF Rates---- . SF: " << sf);
489
490 // Systematics
491 // ------------------------------------------------------------------------------------------------------
492 double val_stat;
493
495 if (isOS) {
496 retVal =
497 this->getChargeFlipRate(ele_eta, ele_pt, OShistograms.at(1), val_stat);
498 if (retVal != 0) {
499 sf = -9999.0;
501 }
502 } else {
503 ATH_MSG_DEBUG("Get SS his");
504 retVal =
505 this->getChargeFlipRate(ele_eta, ele_pt, SShistograms.at(1), val_stat);
506 if (retVal != 0) {
507 sf = -9999.0;
509 }
510 }
511
512 std::vector<float> systs;
513 double val_sys{ 0.0 };
515 for (unsigned int s = 2; s < OShistograms.size(); s++) {
516 if (isOS) {
517 retVal =
518 this->getChargeFlipRate(ele_eta, ele_pt, OShistograms.at(s), val_sys);
519 if (retVal != 0) {
520 val_sys = -9999.0;
522 }
523 } else {
524 ATH_MSG_DEBUG("Get SS his");
525 retVal =
526 this->getChargeFlipRate(ele_eta, ele_pt, SShistograms.at(s), val_sys);
527 if (retVal != 0) {
528 val_sys = -9999.0;
530 }
531 }
532 systs.push_back(static_cast<float>(val_sys));
533 }
534
535 ATH_MSG_DEBUG(" ... nominal SF: " << sf);
536
537 if (m_mySysConf.empty()) {
538 ATH_MSG_DEBUG(" ... nominal SF: " << sf);
539 } else if (*(m_mySysConf.begin()) ==
540 SystematicVariation("EL_CHARGEID_STAT", 1)) {
541 sf = (sf + (val_stat));
542 ATH_MSG_DEBUG("SF after STATup = " << sf);
543 } else if (*(m_mySysConf.begin()) ==
544 SystematicVariation("EL_CHARGEID_STAT", -1)) {
545 sf = (sf - (val_stat));
546 ATH_MSG_DEBUG("SF after STATdown = " << sf);
547 } else {
548
549 for (unsigned int i = 0; i < m_systematics.size(); i++) {
550 if (*(m_mySysConf.begin()) ==
551 SystematicVariation(
552 Form("EL_CHARGEID_SYS%s", m_systematics.at(i).c_str()), 1)) {
553 sf = (sf + (val_sys));
554 ATH_MSG_DEBUG("SF after SYSup = " << sf);
555 }
556
557 if (*(m_mySysConf.begin()) ==
558 SystematicVariation(
559 Form("EL_CHARGEID_SYS%s", m_systematics.at(i).c_str()), -1)) {
560 sf = (sf - (val_sys));
561 ATH_MSG_DEBUG("SF after SYSdown = " << sf);
562 }
563 }
564
565 }
566
568}
#define ATH_MSG_WARNING(x)
ServiceHandle< StoreGateSvc > & evtStore()
@ OutOfValidityRange
Input object is out of validity range.
@ Ok
The correction was done successfully.
std::map< std::string, std::vector< TH2 * > > m_SF_OS
double m_pt_lowlimit
Lower limit of pt range where corrections are available; taken from histogram.
std::map< std::string, std::vector< TH2 * > > m_SF_SS
Histogram that holds the correction rates for Monte Carlo.
double m_eta_uplimit
Upper limit of eta range where corrections are available; taken from histogram.
float getChargeFlipRate(double eta, double pt, TH2 *hrates, double &flipRate) const
Get the charge flip rate rate given pt, eta, histogram.
std::string m_eventInfoCollectionName
The Event info collection name.
SG::Accessor< T, ALLOC > Accessor
Definition AuxElement.h:573
int r
Definition globals.cxx:22
static std::vector< uint32_t > runnumber
Definition iLumiCalc.h:37
CP::CorrectionCode getEleTruthCharge(const xAOD::Electron &ele, int &truthcharge)
Get the charge of the original electron.
CP::CorrectionCode isGoodEle(const xAOD::Electron &ele, bool &goodEle)
Return true if it's good ele for charge flip measurements.
EventInfo_v1 EventInfo
Definition of the latest event info version.

◆ getKey()

SG::sgkey_t asg::AsgTool::getKey ( const void * ptr) const
inherited

Get the (hashed) key of an object that is in the event store.

This is a bit of a special one. StoreGateSvc and xAOD::TEvent both provide ways for getting the SG::sgkey_t key for an object that is in the store, based on a bare pointer. But they provide different interfaces for doing so.

In order to allow tools to efficiently perform this operation, they can use this helper function.

See also
asg::AsgTool::getName
Parameters
ptrThe bare pointer to the object that the event store should know about
Returns
The hashed key of the object in the store. If not found, an invalid (zero) key.

Definition at line 119 of file AsgTool.cxx.

119 {
120
121#ifdef XAOD_STANDALONE
122 // In case we use @c xAOD::TEvent, we have a direct function call
123 // for this.
124 return evtStore()->event()->getKey( ptr );
125#else
126 const SG::DataProxy* proxy = evtStore()->proxy( ptr );
127 return ( proxy == nullptr ? 0 : proxy->sgkey() );
128#endif // XAOD_STANDALONE
129 }

◆ getName()

const std::string & asg::AsgTool::getName ( const void * ptr) const
inherited

Get the name of an object that is / should be in the event store.

This is a bit of a special one. StoreGateSvc and xAOD::TEvent both provide ways for getting the std::string name for an object that is in the store, based on a bare pointer. But they provide different interfaces for doing so.

In order to allow tools to efficiently perform this operation, they can use this helper function.

See also
asg::AsgTool::getKey
Parameters
ptrThe bare pointer to the object that the event store should know about
Returns
The string name of the object in the store. If not found, an empty string.

Definition at line 106 of file AsgTool.cxx.

106 {
107
108#ifdef XAOD_STANDALONE
109 // In case we use @c xAOD::TEvent, we have a direct function call
110 // for this.
111 return evtStore()->event()->getName( ptr );
112#else
113 const SG::DataProxy* proxy = evtStore()->proxy( ptr );
114 static const std::string dummy = "";
115 return ( proxy == nullptr ? dummy : proxy->name() );
116#endif // XAOD_STANDALONE
117 }

◆ getNumberOfToys()

virtual int CP::ElectronChargeEfficiencyCorrectionTool::getNumberOfToys ( ) const
inlinefinaloverridevirtual

Implements IAsgElectronEfficiencyCorrectionTool.

Definition at line 90 of file ElectronChargeEfficiencyCorrectionTool.h.

91 {
93 "No toysimplemented in "
94 "ElectronChargeEfficiencyCorrectionTool");
95 return -1;
96 };

◆ getProperty()

template<class T>
const T * asg::AsgTool::getProperty ( const std::string & name) const
inherited

Get one of the tool's properties.

◆ initialize()

StatusCode ElectronChargeEfficiencyCorrectionTool::initialize ( void )
finaloverridevirtual

Gaudi Service Interface method implementations.

STAT ERROR

STAT ERROR

end // if ( name.find(Form("SYST") ) != std::string::npos)

here: need to use iterator over map!!!

Reimplemented from asg::AsgTool.

Definition at line 88 of file ElectronChargeEfficiencyCorrectionTool.cxx.

89{
90 ATH_MSG_DEBUG("initializing");
91
92 // initialize the random number generator (used in case of charge flip
93 // approach)
94 // m_Rndm = new TRandom3(1);
95
96 if (m_sfDec)
97 delete m_sfDec;
98 m_sfDec = new SG::AuxElement::Decorator<float>(m_sf_decoration_name); // xxxx
99
100 // Resolve the path to the input file for the charge flip rates
101 const std::string rootfilename = PathResolverFindCalibFile(m_filename);
102 if (m_filename.empty()) {
103 ATH_MSG_ERROR(" PathResolver was not able to find the file ... aborting");
104 return StatusCode::FAILURE;
105 }
106
107 // Getting the root file and histograms
108 TFile* rootFile = TFile::Open(rootfilename.c_str());
109
110 // protection against bad file
111 if (rootFile == nullptr) {
112 ATH_MSG_ERROR(" Was not able to open file: " << rootfilename
113 << " ...... aborting");
114 return StatusCode::FAILURE;
115 }
116
118 //
119 // explanation: attempt to loop generally over a file
120 // -- if certain SINGALWORD is present -- then this is taken as a signal,
121 // that this is another dimension... can be dynamically added.
122 // e.g.
123 // SFSyst<number>_RunNumber<minRN>-<maxRN>_Nvtx<minNvtx>-<maxNvtx>
124 // SFStat_RunNumber<minRN>-<maxRN>_Nvtx<minNvtx>-<maxNvtx>
125 // SFCentral_RunNumber<minRN>-<maxRN>_Nvtx<minNvtx>-<maxNvtx>
126
127 // Then can create a key that will dynamically give us access to a map:
128 // std::map<std::string key, std::vector<TH2 *>> m_SF_SS; // keys (e.g.
129 // RunNumber223333_319200_Nvtx0_10_Phi1.5_1.6) mapping to vector of SF
130 // histograms --> vector m_SF: 0=nominal, 1=stat, 2,3,4...n=syst
131 // std::map<std::string key, std::vector<TH2 *>> m_SF_OS; // keys
132 // (e.g. RunNumber223333_319200_Nvtx0_10_Phi1.5_1.6) mapping to vector of
133 // SF histograms --> vector m_SF: 0=nominal, 1=stat, 2,3,4...n=syst
134 // TFile* data/ChMisIDSF_TightLL_FixedCutTight.root
135 // KEY: TH2F SFCentral_RunNumber296939_311481_SS;1
136 // SFCentral_RunNumber296939_311481_SS KEY: TH2F
137 // SFCentral_RunNumber296939_311481_OS;1 SFCentral_RunNumber296939_311481_OS
138 // KEY: TH2F STAT_RunNumber296939_311481_SS;1
139 // STAT_RunNumber296939_311481_SS KEY: TH2F STAT_RunNumber296939_311481_OS;1
140 // STAT_RunNumber296939_311481_OS KEY: TH2F
141 // SYST_RunNumber296939_311481_total_SS;1 SYST_RunNumber296939_311481_SS:
142 // total KEY: TH2F SYST_RunNumber296939_311481_total_OS;1
143 // SYST_RunNumber296939_311481_OS: total
144
145 m_SF_SS.clear();
146 m_SF_OS.clear();
147 TList* keyListfolder = rootFile->GetListOfKeys();
148 std::vector<std::string> names;
149 std::set<std::string> set_systematics;
150
151 names.reserve(keyListfolder->GetEntries());
152 for (int j = 0; j < keyListfolder->GetEntries(); j++) {
153 names.emplace_back((keyListfolder->At(j)->GetName()));
154 }
155 std::sort(names.begin(), names.end());
156
157 for (unsigned int j = 0; j < names.size(); j++) {
158
159 std::string name = names.at(j);
160 ATH_MSG_DEBUG("Got ROOT object with name: " << name);
161 if (name.find(Form("SFCentral_")) != std::string::npos) {
162 ATH_MSG_VERBOSE("Found name 'SFCentral_' in ROOT object name");
163 // Check for opposite-sign (=opposite-charge)
164 bool isOS = false;
165 if (name.find(Form("_OS")) != std::string::npos) {
166 isOS = true;
167 ATH_MSG_VERBOSE("Found name '_OS' in ROOT object name");
168 }
169 if (isOS) {
170 std::string histid = (names.at(j));
171 histid.erase(0, 10);
172 histid.erase(histid.size() - 3, 3); // remove _SS, _OS
173 ATH_MSG_VERBOSE("Using histid: " << histid);
174
175 if (histid.find("RunNumber") != std::string::npos) {
176 ATH_MSG_VERBOSE("Found name 'RunNumber' in histid");
177 std::string runlow = histid;
178 runlow.erase(histid.find(Form("RunNumber")), 9);
179 runlow.erase(runlow.find('_'), runlow.size());
180 m_RunNumbers.push_back(
181 static_cast<unsigned int>(atoi(runlow.c_str())));
182 std::string runhigh = histid;
183 runhigh.erase(histid.find(Form("RunNumber")), 9);
184 runhigh.erase(0, runhigh.find('_') + 1);
185 m_RunNumbers.push_back(
186 static_cast<unsigned int>(atoi(runhigh.c_str())));
187 }
188 ATH_MSG_VERBOSE("Using histid (OS hid): " << histid);
189 m_SF_OS[histid].push_back((TH2*)rootFile->Get(names.at(j).c_str()));
190 } else {
191 std::string histid = (names.at(j));
192 histid.erase(0, 10);
193 histid.erase(histid.size() - 3, 3); // remove _SS, _OS
194 ATH_MSG_VERBOSE("Using histid (do we this in ? SS): " << histid);
195 m_SF_SS[histid].push_back((TH2*)rootFile->Get(names.at(j).c_str()));
196 }
197 }
198
200 if (name.find(Form("STAT_")) != std::string::npos) {
201 ATH_MSG_VERBOSE("Found name 'STAT_' in ROOT object name");
202 bool isOS = false;
203 if (name.find(Form("_OS")) != std::string::npos) {
204 isOS = true;
205 ATH_MSG_VERBOSE("Found name '_OS' in ROOT object name");
206 }
207 if (isOS) {
208 std::string histid = (names.at(j));
209 histid.erase(0, 5);
210 histid.erase(histid.size() - 3, 3); // remove _SS, _OS
211 ATH_MSG_VERBOSE("Using histid: " << histid);
212
213 if (histid.find("RunNumber") != std::string::npos) {
214 ATH_MSG_VERBOSE("Found name 'RunNumber' in histid");
215 std::string runlow = histid;
216 runlow.erase(histid.find(Form("RunNumber")), 9);
217 runlow.erase(runlow.find('_'), runlow.size());
218 // m_RunNumbers.push_back( static_cast<unsigned
219 // int>(atoi(runlow.c_str())) );
220 std::string runhigh = histid;
221 runhigh.erase(histid.find(Form("RunNumber")), 9);
222 runhigh.erase(0, runhigh.find('_') + 1);
223 // m_RunNumbers.push_back( static_cast<unsigned
224 // int>(atoi(runhigh.c_str())) );
225 }
226 ATH_MSG_VERBOSE("Using histid (OS hid): " << histid);
227 m_SF_OS[histid].push_back((TH2*)rootFile->Get(names.at(j).c_str()));
228 } else {
229 std::string histid = (names.at(j));
230 ATH_MSG_VERBOSE("Found histid: " << histid);
231 histid.erase(0, 5);
232 histid.erase(histid.size() - 3, 3); // remove _SS, _OS
233 ATH_MSG_VERBOSE("Using histid (do we this in ? SS): " << histid);
234 m_SF_SS[histid].push_back((TH2*)rootFile->Get(names.at(j).c_str()));
235 }
236
237 }
238
240 if (name.find(Form("SYST")) != std::string::npos) {
241 ATH_MSG_VERBOSE("Found name 'SYST' in ROOT object name");
242 bool isOS = false;
243 if (name.find(Form("_OS")) != std::string::npos) {
244 isOS = true;
245 ATH_MSG_VERBOSE("Found name '_OS' in ROOT object name");
246 }
247 if (isOS) {
248 std::string histid = (names.at(j));
249 histid.erase(0, 4);
250 histid.erase(histid.size() - 3, 3); // remove _SS, _OS
251
252 std::string sysname = histid;
253 sysname.erase(sysname.find('_'), sysname.size());
254 set_systematics.insert(sysname);
255
256 histid.erase(0, histid.find('_') + 1); // remove _SS, _OS
257 ATH_MSG_VERBOSE("Using syst histid: " << histid);
258
259 if (histid.find("RunNumber") != std::string::npos) {
260 std::string runlow = histid;
261 runlow.erase(histid.find(Form("RunNumber")), 9);
262 runlow.erase(runlow.find('_'), runlow.size());
263 // m_RunNumbers.push_back( static_cast<unsigned
264 // int>(atoi(runlow.c_str())) );
265 std::string runhigh = histid;
266 runhigh.erase(histid.find(Form("RunNumber")), 9);
267 runhigh.erase(0, runhigh.find('_') + 1);
268 // m_RunNumbers.push_back( static_cast<unsigned
269 // int>(atoi(runhigh.c_str())) );
270 }
271 ATH_MSG_VERBOSE("Using histid (OS hid): " << histid);
272 m_SF_OS[histid].push_back((TH2*)rootFile->Get(names.at(j).c_str()));
273 } else {
274 std::string histid = (names.at(j));
275 histid.erase(0, 4);
276 histid.erase(histid.size() - 3, 3); // remove _SS, _OS
277 histid.erase(0, histid.find('_') + 1); // remove _SS, _OS
278 ATH_MSG_VERBOSE("Using histid (sys ? SS): " << histid);
279 m_SF_SS[histid].push_back((TH2*)rootFile->Get(names.at(j).c_str()));
280 }
281
282 }
283 }
284
286
287 if (m_SF_OS.empty() || m_SF_SS.empty() || m_SF_SS.size() != m_SF_OS.size()) {
289 "OS/SS SF vectors not filled or of different size. -- Problem with "
290 "files. -- Report to <hn-atlas-EGammaWG@cern.ch>");
291 return StatusCode::FAILURE;
292 }
293
294 m_systematics.insert(m_systematics.end(), set_systematics.begin(), set_systematics.end());
295
296 std::sort(m_RunNumbers.begin(), m_RunNumbers.end());
298 // Determine the limits of validity
299
301 ATH_MSG_DEBUG("Having m_SF_OS.size() = " << m_SF_OS.size());
302 std::map<std::string, std::vector<TH2*>>::iterator it = m_SF_OS.begin();
303
304 // Get the kinematic limits
305 m_eta_lowlimit = (*it).second.at(0)->GetYaxis()->GetXmin();
306 m_eta_uplimit = (*it).second.at(0)->GetYaxis()->GetXmax();
307 ATH_MSG_VERBOSE("|eta| limits " << m_eta_lowlimit << ", " << m_eta_uplimit);
308
309 m_pt_lowlimit = (*it).second.at(0)->GetXaxis()->GetXmin();
310 m_pt_uplimit = (*it).second.at(0)->GetXaxis()->GetXmax();
311 ATH_MSG_VERBOSE("pt limits " << m_pt_lowlimit << ", " << m_pt_uplimit);
312
313 ATH_MSG_VERBOSE("Rates in input file are in GeV");
314 m_gevmev = 0.001;
315
316 // Systematics // dynamic too?
318
319 // Add the recommended systematics to the registry
320 if (registerSystematics() != StatusCode::SUCCESS) {
321 ATH_MSG_ERROR("(registerSystematics() != CP::SystematicCode::Ok)");
322 return StatusCode::FAILURE;
323 }
324
325 return StatusCode::SUCCESS;
326}
std::string PathResolverFindCalibFile(const std::string &logical_file_name)
std::string m_filename
The name of the input file that contains the histograms.
double m_eta_lowlimit
Lower limit of eta range where corrections are available; taken from histogram.
virtual SystematicSet affectingSystematics() const override final
Returns the list of all systematics this tool can be affected by.
int atoi(std::string_view str)
Helper functions to unpack numbers decoded in string into integers and doubles The strings are requir...
float j(const xAOD::IParticle &, const xAOD::TrackMeasurementValidation &hit, const Eigen::Matrix3d &jab_inv)
void sort(typename DataModel_detail::iterator< DVL > beg, typename DataModel_detail::iterator< DVL > end)
Specialization of sort for DataVector/List.
static const SG::AuxElement::Accessor< std::vector< std::string > > names("thrNames")
Accessor for the names of the passed thresholds.
JetConstituentVector::iterator iterator

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

◆ isAffectedBySystematic()

bool ElectronChargeEfficiencyCorrectionTool::isAffectedBySystematic ( const SystematicVariation & systematic) const
finaloverridevirtual

Returns whether this tool is affected by the given systematics.

Implements CP::ISystematicsTool.

Definition at line 615 of file ElectronChargeEfficiencyCorrectionTool.cxx.

617{
618
619 CP::SystematicSet sys = affectingSystematics();
620 return sys.find(systematic) != sys.end();
621}

◆ msg()

MsgStream & AthCommonMsg< AlgTool >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

24 {
25 return this->msgStream();
26 }

◆ msg_level_name()

const std::string & asg::AsgTool::msg_level_name ( ) const
inherited

A deprecated function for getting the message level's name.

Instead of using this, weirdly named function, user code should get the string name of the current minimum message level (in case they really need it...), with:

MSG::name( msg().level() )

This function's name doesn't follow the ATLAS coding rules, and as such will be removed in the not too distant future.

Returns
The string name of the current minimum message level that's printed

Definition at line 101 of file AsgTool.cxx.

101 {
102
103 return MSG::name( msg().level() );
104 }
MsgStream & msg() const
const std::string & name(Level lvl)
Convenience function for translating message levels to strings.
Definition MsgLevel.cxx:19

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

◆ print()

void asg::AsgTool::print ( ) const
virtualinherited

◆ printCorrelationModels()

virtual void CP::ElectronChargeEfficiencyCorrectionTool::printCorrelationModels ( ) const
inlinefinaloverridevirtual

print available/implemented correlation models

Implements IAsgElectronEfficiencyCorrectionTool.

Definition at line 98 of file ElectronChargeEfficiencyCorrectionTool.h.

99 {
101 "ONLY A DEFAULT Correlation model available for now");
102 };

◆ recommendedSystematics()

CP::SystematicSet ElectronChargeEfficiencyCorrectionTool::recommendedSystematics ( ) const
finaloverridevirtual

Returns the list of all systematics this tool recommends to use.

Implements CP::IReentrantSystematicsTool.

Definition at line 645 of file ElectronChargeEfficiencyCorrectionTool.cxx.

646{
647
648 return affectingSystematics();
649}

◆ registerSystematics()

StatusCode ElectronChargeEfficiencyCorrectionTool::registerSystematics ( )
private

Definition at line 669 of file ElectronChargeEfficiencyCorrectionTool.cxx.

669 {
670 CP::SystematicRegistry &registry = CP::SystematicRegistry::getInstance();
671
672 if (registry.registerSystematics(*this) != StatusCode::SUCCESS) {
673 ATH_MSG_ERROR("Failed to add systematic to list of recommended systematics.");
674 return StatusCode::FAILURE;
675 }
676
677 return StatusCode::SUCCESS;
678}
static SystematicRegistry & getInstance()
Get the singleton instance of the registry for the curren thread.
StatusCode registerSystematics(const IReentrantSystematicsTool &tool)
effects: register all the systematics from the tool

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

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

◆ systUncorrVariationIndex()

virtual int CP::ElectronChargeEfficiencyCorrectionTool::systUncorrVariationIndex ( const xAOD::Electron & ) const
inlinefinaloverridevirtual

Implements IAsgElectronEfficiencyCorrectionTool.

Definition at line 73 of file ElectronChargeEfficiencyCorrectionTool.h.

74 {
76 "systUncorrVariationIndex is not implemented in "
77 "ElectronChargeEfficiencyCorrectionTool");
78 return -999;
79 }

◆ 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

◆ ~ElectronChargeEfficiencyCorrectionTool()

ElectronChargeEfficiencyCorrectionTool::~ElectronChargeEfficiencyCorrectionTool ( )
privatevirtual

Standard destructor.

Definition at line 77 of file ElectronChargeEfficiencyCorrectionTool.cxx.

79{
80 if (m_sfDec)
81 delete m_sfDec;
82}

Member Data Documentation

◆ m_affectingSys

CP::SystematicSet CP::ElectronChargeEfficiencyCorrectionTool::m_affectingSys
private

Definition at line 166 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_appliedSystematics

CP::SystematicSet* CP::ElectronChargeEfficiencyCorrectionTool::m_appliedSystematics
private

Currently applied systematics.

Definition at line 169 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_dataTypeOverwrite

int CP::ElectronChargeEfficiencyCorrectionTool::m_dataTypeOverwrite
private

Force the data type to a given value.

Definition at line 114 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_defaultRandomRunNumber

unsigned int CP::ElectronChargeEfficiencyCorrectionTool::m_defaultRandomRunNumber
private

Definition at line 133 of file ElectronChargeEfficiencyCorrectionTool.h.

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

double CP::ElectronChargeEfficiencyCorrectionTool::m_eta_lowlimit
private

Lower limit of eta range where corrections are available; taken from histogram.

Definition at line 143 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_eta_uplimit

double CP::ElectronChargeEfficiencyCorrectionTool::m_eta_uplimit
private

Upper limit of eta range where corrections are available; taken from histogram.

Definition at line 147 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_eventInfoCollectionName

std::string CP::ElectronChargeEfficiencyCorrectionTool::m_eventInfoCollectionName
private

The Event info collection name.

Definition at line 118 of file ElectronChargeEfficiencyCorrectionTool.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_filename

std::string CP::ElectronChargeEfficiencyCorrectionTool::m_filename
private

The name of the input file that contains the histograms.

Definition at line 136 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_filtered_sys_sets

std::map<CP::SystematicSet, CP::SystematicSet> CP::ElectronChargeEfficiencyCorrectionTool::m_filtered_sys_sets
private

Definition at line 163 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_gevmev

float CP::ElectronChargeEfficiencyCorrectionTool::m_gevmev
private

Factor for GeV <-> MeV switching.

Definition at line 158 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_mySysConf

CP::SystematicSet CP::ElectronChargeEfficiencyCorrectionTool::m_mySysConf
private

Definition at line 165 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_pt_lowlimit

double CP::ElectronChargeEfficiencyCorrectionTool::m_pt_lowlimit
private

Lower limit of pt range where corrections are available; taken from histogram.

Definition at line 151 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_pt_uplimit

double CP::ElectronChargeEfficiencyCorrectionTool::m_pt_uplimit
private

Upper limit of pt range where corrections are available; taken from histogram.

Definition at line 155 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_RunNumbers

std::vector<unsigned int> CP::ElectronChargeEfficiencyCorrectionTool::m_RunNumbers
private

Definition at line 131 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_sf_decoration_name

std::string CP::ElectronChargeEfficiencyCorrectionTool::m_sf_decoration_name
private

Decorator.

Definition at line 172 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_SF_OS

std::map<std::string, std::vector<TH2*> > CP::ElectronChargeEfficiencyCorrectionTool::m_SF_OS
private

Definition at line 126 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_SF_SS

std::map<std::string, std::vector<TH2*> > CP::ElectronChargeEfficiencyCorrectionTool::m_SF_SS
private

Histogram that holds the correction rates for Monte Carlo.

Definition at line 122 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_sfDec

SG::AuxElement::Decorator<float>* CP::ElectronChargeEfficiencyCorrectionTool::m_sfDec
private

Definition at line 173 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_systematics

std::vector<std::string> CP::ElectronChargeEfficiencyCorrectionTool::m_systematics
private

Definition at line 161 of file ElectronChargeEfficiencyCorrectionTool.h.

◆ m_useRandomRunNumber

bool CP::ElectronChargeEfficiencyCorrectionTool::m_useRandomRunNumber
private

Definition at line 132 of file ElectronChargeEfficiencyCorrectionTool.h.

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

◆ m_workingPoint

std::string CP::ElectronChargeEfficiencyCorrectionTool::m_workingPoint
private

The name of the folder defining the LH/iso working point.

Definition at line 139 of file ElectronChargeEfficiencyCorrectionTool.h.


The documentation for this class was generated from the following files: