ATLAS Offline Software
Loading...
Searching...
No Matches
TestMuonSF::TriggerSFBranches Class Reference

#include <MuonSFTestHelper.h>

Inheritance diagram for TestMuonSF::TriggerSFBranches:
Collaboration diagram for TestMuonSF::TriggerSFBranches:

Public Types

using DataDependency = SG::VarHandleKey*

Public Member Functions

 TriggerSFBranches (MuonVal::MuonTesterTree &tree, const ToolHandle< CP::IMuonTriggerScaleFactors > &Handle, const std::string &muonContainer, const std::string &Trigger)
virtual ~TriggerSFBranches ()=default
bool fill (const EventContext &ctx) override final
 The fill method checks if enough information is provided such that the branch is cleared from the information of the prevoius event and in cases of that updates did no happen befure a default value is provided.
bool init () override final
 The init method checks whether the branch name has already registered to the MuonTree and tries then to add the branch to the tree --> return false if the branch has already been defined or the inclusion of the branch to the tree failed or the name of the branch is empty.
std::string name () const override final
 Returns the name of the branch.
bool initialized () const
 Returns whether the object has been initialized or not The outcome of the variable is bound to a successful call of the addToTree method.
TTree * tree () override final
 Returns the underlying TTree object.
const TTree * tree () const override final
std::vector< DataDependencydata_dependencies () override final
 Returns the data dependencies needed by the MuonTesterBranch.
bool msgLvl (const MSG::Level lvl) const
 Test the output level.
MsgStream & msg () const
 The standard message stream.
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream.
void setLevel (MSG::Level lvl)
 Change the current logging level.

Static Public Member Functions

static std::string eraseWhiteSpaces (const std::string &In)

Protected Member Functions

template<class T>
bool addToTree (T &variable)
 Connects the Memory buffer with the TTree.
template<class Key>
bool declare_dependency (Key &key)
 Declares the ReadHandle/ ReadCondHandleKey as data dependency of the algorithm.
MuonTesterTree & parent ()
 Returns the reference to the MuonTesterTree parent.

Private Member Functions

CP::CorrectionCode getSF (const xAOD::MuonContainer *muons, MuonVal::ScalarBranch< double > &Var, const CP::SystematicVariation &syst)
void initMessaging () const
 Initialize our message level and MessageSvc.

Private Attributes

SG::ReadHandleKey< xAOD::MuonContainerm_key {}
ToolHandle< CP::IMuonTriggerScaleFactorsm_handle {}
std::string m_trigger {}
MuonVal::ScalarBranch< double > m_nominal_SF {tree(), name(), 1.}
MuonVal::ScalarBranch< double > m_stat_up_SF {tree(), name()+"_STAT_UP", 1.}
MuonVal::ScalarBranch< double > m_stat_down_SF {tree(), name()+"_STAT_DN", 1.}
MuonVal::ScalarBranch< double > m_sys_up_SF {tree(), name()+"_SYS_UP", 1.}
MuonVal::ScalarBranch< double > m_sys_down_SF {tree(), name()+"_SYS_DN", 1.}
TTree * m_tree {nullptr}
MuonTesterTree * m_parent {nullptr}
std::string m_name {}
bool m_init {false}
std::vector< DataDependencym_dependencies {}
std::string m_nm
 Message source name.
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels)
std::atomic< IMessageSvc * > m_imsg { nullptr }
 MessageSvc pointer.
std::atomic< MSG::Level > m_lvl { MSG::NIL }
 Current logging level.
std::atomic_flag m_initialized ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
 Messaging initialized (initMessaging)

Detailed Description

Definition at line 35 of file MuonSFTestHelper.h.

Member Typedef Documentation

◆ DataDependency

Constructor & Destructor Documentation

◆ TriggerSFBranches()

TestMuonSF::TriggerSFBranches::TriggerSFBranches ( MuonVal::MuonTesterTree & tree,
const ToolHandle< CP::IMuonTriggerScaleFactors > & Handle,
const std::string & muonContainer,
const std::string & Trigger )

Definition at line 29 of file MuonSFTestHelper.cxx.

32 :
33 MuonVal::MuonTesterBranch{tree, "MuTriggerSF_" +Trigger},
35 m_handle{Handle},
37 }
xAOD::MuonContainer * muonContainer
virtual TTree * tree()=0
Returns the pointer to the underlying TTree object.
ToolHandle< CP::IMuonTriggerScaleFactors > m_handle
SG::ReadHandleKey< xAOD::MuonContainer > m_key

◆ ~TriggerSFBranches()

virtual TestMuonSF::TriggerSFBranches::~TriggerSFBranches ( )
virtualdefault

Member Function Documentation

◆ addToTree()

template<class T>
bool MuonVal::MuonTesterBranch::addToTree ( T & variable)
protectedinherited

Connects the Memory buffer with the TTree.

◆ data_dependencies()

std::vector< MuonTesterBranch::DataDependency > MuonVal::MuonTesterBranch::data_dependencies ( )
finaloverridevirtualinherited

Returns the data dependencies needed by the MuonTesterBranch.

Implements MuonVal::IMuonTesterBranch.

Definition at line 61 of file MuonTesterBranch.cxx.

61{ return m_dependencies;}
std::vector< DataDependency > m_dependencies

◆ declare_dependency()

template<class Key>
bool MuonVal::MuonTesterBranch::declare_dependency ( Key & key)
protectedinherited

Declares the ReadHandle/ ReadCondHandleKey as data dependency of the algorithm.

◆ eraseWhiteSpaces()

std::string MuonVal::MuonTesterBranch::eraseWhiteSpaces ( const std::string & In)
staticinherited

Definition at line 56 of file MuonTesterBranch.cxx.

56 {
57 std::string out = In;
58 out.erase(std::remove_if(out.begin(), out.end(), isspace), out.end());
59 return out;
60}
DataModel_detail::iterator< DVL > remove_if(typename DataModel_detail::iterator< DVL > beg, typename DataModel_detail::iterator< DVL > end, Predicate pred)
Specialization of remove_if for DataVector/List.

◆ fill()

bool TestMuonSF::TriggerSFBranches::fill ( const EventContext & ctx)
finaloverridevirtual

The fill method checks if enough information is provided such that the branch is cleared from the information of the prevoius event and in cases of that updates did no happen befure a default value is provided.

--> returns false if no update is called or the dummy value has not been defined

Implements MuonVal::IMuonTesterBranch.

Definition at line 48 of file MuonSFTestHelper.cxx.

48 {
49 SG::ReadHandle<xAOD::MuonContainer> readHandle{m_key, ctx};
50 if (!readHandle.isPresent()) {
51 ATH_MSG_FATAL("Failed to retrieve muon container "<<m_key.fullKey());
52 return false;
53 }
54 const xAOD::MuonContainer* muons{readHandle.cptr()};
55 if (getSF(muons, m_nominal_SF, CP::SystematicVariation("", 0)) == CP::CorrectionCode::Error) {
56 return false;
57 } if (getSF(muons, m_stat_up_SF, CP::SystematicVariation("MUON_EFF_TrigStatUncertainty", +1)) == CP::CorrectionCode::Error) {
59 } if (getSF(muons, m_stat_down_SF, CP::SystematicVariation("MUON_EFF_TrigStatUncertainty", -1)) == CP::CorrectionCode::Error) {
61 } if (getSF(muons, m_sys_up_SF, CP::SystematicVariation("MUON_EFF_TrigSystUncertainty", +1)) == CP::CorrectionCode::Error) {
63 } if (getSF(muons, m_sys_down_SF, CP::SystematicVariation("MUON_EFF_TrigSystUncertainty", -1)) == CP::CorrectionCode::Error) {
65 }
66 return true;
67 }
#define ATH_MSG_FATAL(x)
@ Error
Some error happened during the object correction.
const_pointer_type cptr()
Dereference the pointer.
bool isPresent() const
Is the referenced object present in SG?
MuonVal::ScalarBranch< double > m_sys_down_SF
MuonVal::ScalarBranch< double > m_nominal_SF
MuonVal::ScalarBranch< double > m_stat_up_SF
CP::CorrectionCode getSF(const xAOD::MuonContainer *muons, MuonVal::ScalarBranch< double > &Var, const CP::SystematicVariation &syst)
MuonVal::ScalarBranch< double > m_stat_down_SF
MuonVal::ScalarBranch< double > m_sys_up_SF
MuonContainer_v1 MuonContainer
Definition of the current "Muon container version".

◆ getSF()

CP::CorrectionCode TestMuonSF::TriggerSFBranches::getSF ( const xAOD::MuonContainer * muons,
MuonVal::ScalarBranch< double > & Var,
const CP::SystematicVariation & syst )
private

Definition at line 68 of file MuonSFTestHelper.cxx.

70 {
71 if (muons->empty()) {
73 }
74 CP::SystematicSet syst_set;
75 syst_set.insert(syst);
76 if (m_handle->applySystematicVariation(syst_set) != StatusCode::SUCCESS) {
78 }
79 double Var{1.};
80 CP::CorrectionCode code = m_handle->getTriggerScaleFactor(*muons, Var, m_trigger);
81 branch = Var;
82 return code;
83 }
@ Ok
The correction was done successfully.
void insert(const SystematicVariation &systematic)
description: insert a systematic into the set
bool empty() const noexcept
Returns true if the collection is empty.

◆ init()

bool TestMuonSF::TriggerSFBranches::init ( )
finaloverridevirtual

The init method checks whether the branch name has already registered to the MuonTree and tries then to add the branch to the tree --> return false if the branch has already been defined or the inclusion of the branch to the tree failed or the name of the branch is empty.

Implements MuonVal::IMuonTesterBranch.

Definition at line 38 of file MuonSFTestHelper.cxx.

38 {
39 if (!declare_dependency(m_key)) return false;
40 if (!m_nominal_SF.init()) return false;
41 if (!m_stat_up_SF.init()) return false;
42 if (!m_stat_down_SF.init()) return false;
43 if (!m_sys_up_SF.init()) return false;
44 if (!m_sys_down_SF.init()) return false;
45 return true;
46 }
bool declare_dependency(Key &key)
Declares the ReadHandle/ ReadCondHandleKey as data dependency of the algorithm.

◆ initialized()

bool MuonVal::MuonTesterBranch::initialized ( ) const
inherited

Returns whether the object has been initialized or not The outcome of the variable is bound to a successful call of the addToTree method.

Definition at line 52 of file MuonTesterBranch.cxx.

◆ initMessaging()

void AthMessaging::initMessaging ( ) const
privateinherited

Initialize our message level and MessageSvc.

This method should only be called once.

Definition at line 39 of file AthMessaging.cxx.

40{
42 // If user did not set an explicit level, set a default
43 if (m_lvl == MSG::NIL) {
44 m_lvl = m_imsg ?
45 static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
46 MSG::INFO;
47 }
48}
std::string m_nm
Message source name.
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
std::atomic< MSG::Level > m_lvl
Current logging level.
IMessageSvc * getMessageSvc(bool quiet=false)

◆ msg() [1/2]

MsgStream & AthMessaging::msg ( ) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 163 of file AthMessaging.h.

164{
165 MsgStream* ms = m_msg_tls.get();
166 if (!ms) {
167 if (!m_initialized.test_and_set()) initMessaging();
168 ms = new MsgStream(m_imsg,m_nm);
169 m_msg_tls.reset( ms );
170 }
171
172 ms->setLevel (m_lvl);
173 return *ms;
174}
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
void initMessaging() const
Initialize our message level and MessageSvc.

◆ msg() [2/2]

MsgStream & AthMessaging::msg ( const MSG::Level lvl) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 178 of file AthMessaging.h.

179{ return msg() << lvl; }
MsgStream & msg() const
The standard message stream.

◆ msgLvl()

bool AthMessaging::msgLvl ( const MSG::Level lvl) const
inlineinherited

Test the output level.

Parameters
lvlThe message level to test against
Returns
boolean Indicating if messages at given level will be printed
Return values
trueMessages at level "lvl" will be printed

Definition at line 151 of file AthMessaging.h.

152{
153 if (m_lvl <= lvl) {
154 msg() << lvl;
155 return true;
156 } else {
157 return false;
158 }
159}

◆ name()

std::string MuonVal::MuonTesterBranch::name ( ) const
finaloverridevirtualinherited

Returns the name of the branch.

Implements MuonVal::IMuonTesterBranch.

Definition at line 51 of file MuonTesterBranch.cxx.

51{ return m_name; }

◆ parent()

MuonTesterTree & MuonVal::MuonTesterBranch::parent ( )
protectedinherited

Returns the reference to the MuonTesterTree parent.

Definition at line 38 of file MuonTesterBranch.cxx.

38 {
39 if (!m_parent) {
40 ATH_MSG_WARNING("The parent of " << name() << " is null.");
41 }
42 return *m_parent;
43}
#define ATH_MSG_WARNING(x)
std::string name() const override final
Returns the name of the branch.

◆ setLevel()

void AthMessaging::setLevel ( MSG::Level lvl)
inherited

Change the current logging level.

Use this rather than msg().setLevel() for proper operation with MT.

Definition at line 28 of file AthMessaging.cxx.

29{
30 m_lvl = lvl;
31}

◆ tree() [1/2]

const TTree * MuonVal::MuonTesterBranch::tree ( ) const
finaloverridevirtualinherited

Implements MuonVal::IMuonTesterBranch.

Definition at line 54 of file MuonTesterBranch.cxx.

54{ return m_tree; }

◆ tree() [2/2]

TTree * MuonVal::MuonTesterBranch::tree ( )
finaloverridevirtualinherited

Returns the underlying TTree object.

Implements MuonVal::IMuonTesterBranch.

Definition at line 53 of file MuonTesterBranch.cxx.

53{ return m_tree; }

Member Data Documentation

◆ ATLAS_THREAD_SAFE

std::atomic_flag m_initialized AthMessaging::ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
mutableprivateinherited

Messaging initialized (initMessaging)

Definition at line 141 of file AthMessaging.h.

◆ m_dependencies

std::vector<DataDependency> MuonVal::MuonTesterBranch::m_dependencies {}
privateinherited

Definition at line 62 of file MuonTesterBranch.h.

62{};

◆ m_handle

ToolHandle<CP::IMuonTriggerScaleFactors> TestMuonSF::TriggerSFBranches::m_handle {}
private

Definition at line 53 of file MuonSFTestHelper.h.

53{};

◆ m_imsg

std::atomic<IMessageSvc*> AthMessaging::m_imsg { nullptr }
mutableprivateinherited

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

135{ nullptr };

◆ m_init

bool MuonVal::MuonTesterBranch::m_init {false}
privateinherited

Definition at line 61 of file MuonTesterBranch.h.

61{false};

◆ m_key

SG::ReadHandleKey<xAOD::MuonContainer> TestMuonSF::TriggerSFBranches::m_key {}
private

Definition at line 51 of file MuonSFTestHelper.h.

51{};

◆ m_lvl

std::atomic<MSG::Level> AthMessaging::m_lvl { MSG::NIL }
mutableprivateinherited

Current logging level.

Definition at line 138 of file AthMessaging.h.

138{ MSG::NIL };

◆ m_msg_tls

boost::thread_specific_ptr<MsgStream> AthMessaging::m_msg_tls
mutableprivateinherited

MsgStream instance (a std::cout like with print-out levels)

Definition at line 132 of file AthMessaging.h.

◆ m_name

std::string MuonVal::MuonTesterBranch::m_name {}
privateinherited

Definition at line 60 of file MuonTesterBranch.h.

60{};

◆ m_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.h.

◆ m_nominal_SF

MuonVal::ScalarBranch<double> TestMuonSF::TriggerSFBranches::m_nominal_SF {tree(), name(), 1.}
private

Definition at line 55 of file MuonSFTestHelper.h.

55{tree(), name(), 1.};
TTree * tree() override final
Returns the underlying TTree object.

◆ m_parent

MuonTesterTree* MuonVal::MuonTesterBranch::m_parent {nullptr}
privateinherited

Definition at line 59 of file MuonTesterBranch.h.

59{nullptr};

◆ m_stat_down_SF

MuonVal::ScalarBranch<double> TestMuonSF::TriggerSFBranches::m_stat_down_SF {tree(), name()+"_STAT_DN", 1.}
private

Definition at line 57 of file MuonSFTestHelper.h.

57{tree(), name()+"_STAT_DN", 1.};

◆ m_stat_up_SF

MuonVal::ScalarBranch<double> TestMuonSF::TriggerSFBranches::m_stat_up_SF {tree(), name()+"_STAT_UP", 1.}
private

Definition at line 56 of file MuonSFTestHelper.h.

56{tree(), name()+"_STAT_UP", 1.};

◆ m_sys_down_SF

MuonVal::ScalarBranch<double> TestMuonSF::TriggerSFBranches::m_sys_down_SF {tree(), name()+"_SYS_DN", 1.}
private

Definition at line 59 of file MuonSFTestHelper.h.

59{tree(), name()+"_SYS_DN", 1.};

◆ m_sys_up_SF

MuonVal::ScalarBranch<double> TestMuonSF::TriggerSFBranches::m_sys_up_SF {tree(), name()+"_SYS_UP", 1.}
private

Definition at line 58 of file MuonSFTestHelper.h.

58{tree(), name()+"_SYS_UP", 1.};

◆ m_tree

TTree* MuonVal::MuonTesterBranch::m_tree {nullptr}
privateinherited

Definition at line 58 of file MuonTesterBranch.h.

58{nullptr};

◆ m_trigger

std::string TestMuonSF::TriggerSFBranches::m_trigger {}
private

Definition at line 54 of file MuonSFTestHelper.h.

54{};

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