Loading [MathJax]/extensions/tex2jax.js
ATLAS Offline Software
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Private Member Functions | Private Attributes | List of all members
MuonVal::BilateralLinkerBranch Class Reference

#include <LinkerBranch.h>

Inheritance diagram for MuonVal::BilateralLinkerBranch:
Collaboration diagram for MuonVal::BilateralLinkerBranch:

Public Types

using Linker_t = LinkerBranch::Linker_t
 
using ParticleBranch_ptr = LinkerBranch::ParticleBranch_ptr
 
using DataDependency = SG::VarHandleKey *
 
using DataDependency = SG::VarHandleKey *
 

Public Member Functions

void push_back (const xAOD::IParticle *p) override
 Interface methods to handle the particle. More...
 
void push_back (const xAOD::IParticle &p) override
 
void operator+= (const xAOD::IParticle *p) override
 
void operator+= (const xAOD::IParticle &p) override
 
bool fill (const EventContext &ctx) override
 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. More...
 
bool init () override
 Initialized the Branch. More...
 
size_t size () const
 Returns the number of actual saved elements. More...
 
void push_back (const unsigned short &value)
 Adds a new element at the end of the vector. More...
 
void operator+= (const unsigned short &value)
 
unsigned short & operator[] (size_t idx)
 Accesses the idx-th element. More...
 
unsigned short & get (size_t idx)
 
bool & get (size_t idx)
 
bool & get (size_t)
 
const unsigned short & getDefault () const
 
void setDefault (const unsigned short &def)
 
bool isUpdated () const
 
bool hasDefault () const
 
std::string name () const override final
 Returns the name of the branch. More...
 
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. More...
 
TTree * tree () override final
 Returns the underlying TTree object. More...
 
const TTree * tree () const override final
 
std::vector< DataDependencydata_dependencies () override final
 Returns the data dependencies needed by the MuonTesterBranch. More...
 
bool msgLvl (const MSG::Level lvl) const
 Test the output level. More...
 
MsgStream & msg () const
 The standard message stream. More...
 
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream. More...
 
void setLevel (MSG::Level lvl)
 Change the current logging level. More...
 

Static Public Member Functions

static bool connectCollections (ParticleBranch_ptr primColl, ParticleBranch_ptr secondColl, Linker_t fromPrimToSec, const std::string &altPrimName="", const std::string &altSecName="")
 
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. More...
 
template<class Key >
bool declare_dependency (Key &key)
 Declares the ReadHandle/ ReadCondHandleKey as data dependency of the algorithm. More...
 
MuonTesterTreeparent ()
 Returns the reference to the MuonTesterTree parent. More...
 

Private Member Functions

 BilateralLinkerBranch (IParticleFourMomBranch &bilatColl, ParticleBranch_ptr primColl, Linker_t linker, const std::string &altName)
 
void initMessaging () const
 Initialize our message level and MessageSvc. More...
 

Private Attributes

const IParticleFourMomBranchm_parent
 
std::weak_ptr< IParticleFourMomBranchm_linkColl
 
Linker_t m_linkerFunc
 
std::vector< unsigned short > m_variable
 
unsigned short m_default
 
bool m_hasDefault
 
bool m_updated
 
TTree * m_tree {nullptr}
 
std::string m_name {}
 
bool m_init {false}
 
std::vector< DataDependencym_dependencies {}
 
std::string m_nm
 Message source name. More...
 
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels) More...
 
std::atomic< IMessageSvc * > m_imsg { nullptr }
 MessageSvc pointer. More...
 
std::atomic< MSG::Level > m_lvl { MSG::NIL }
 Current logging level. More...
 
std::atomic_flag m_initialized ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
 Messaging initialized (initMessaging) More...
 

Detailed Description

Definition at line 51 of file LinkerBranch.h.

Member Typedef Documentation

◆ DataDependency [1/2]

Definition at line 39 of file IMuonTesterBranch.h.

◆ DataDependency [2/2]

Definition at line 39 of file IMuonTesterBranch.h.

◆ Linker_t

Definition at line 54 of file LinkerBranch.h.

◆ ParticleBranch_ptr

Definition at line 55 of file LinkerBranch.h.

Constructor & Destructor Documentation

◆ BilateralLinkerBranch()

MuonVal::BilateralLinkerBranch::BilateralLinkerBranch ( IParticleFourMomBranch bilatColl,
ParticleBranch_ptr  primColl,
Linker_t  linker,
const std::string &  altName 
)
private

Definition at line 42 of file LinkerBranch.cxx.

45  :
46  VectorBranch<unsigned short>{parent.tree(),
47  std::format("{:}_{:}Link", parent.name(), altName.empty() ? primColl->name() : altName)},
49  m_linkColl{primColl},
50  m_linkerFunc{std::move(linker)} {
51  setDefault(-1);
52  }

Member Function Documentation

◆ addToTree()

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

Connects the Memory buffer with the TTree.

◆ connectCollections()

bool MuonVal::BilateralLinkerBranch::connectCollections ( ParticleBranch_ptr  primColl,
ParticleBranch_ptr  secondColl,
Linker_t  fromPrimToSec,
const std::string &  altPrimName = "",
const std::string &  altSecName = "" 
)
static

Definition at line 33 of file LinkerBranch.cxx.

37  {
38  return primColl->addVariable(std::make_unique<LinkerBranch>(*primColl, secondColl, fromPrimToSec, altPrimName)) &&
39  secondColl->addVariable(std::unique_ptr<IParticleDecorationBranch>{new BilateralLinkerBranch(*secondColl, primColl, fromPrimToSec, altSecName)});
40  }

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

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

◆ fill()

bool MuonVal::BilateralLinkerBranch::fill ( const EventContext &  ctx)
overridevirtual

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

Allocate the memory

Implements MuonVal::IMuonTesterBranch.

Definition at line 65 of file LinkerBranch.cxx.

65  {
66  if (m_parent.size()) {
68  get(m_parent.size() -1);
69  ParticleBranch_ptr linkColl = m_linkColl.lock();
70  const std::vector<const xAOD::IParticle*>& linkeMe = linkColl->getCached();
71  for (std::size_t primToSec = 0 ; primToSec < linkeMe.size(); ++primToSec) {
72  const size_t linkIdx = m_parent.find(m_linkerFunc(linkeMe[primToSec]));
73  if (linkIdx < size()) {
74  get(linkIdx) = primToSec;
75  }
76  }
77  }
78  ATH_MSG_VERBOSE("Fill "<<name()<<", size: "<<m_parent.size()<<"/"<<size()<<", "<<m_parent.name());
80  }

◆ get() [1/3]

unsigned short & MuonVal::VectorBranch< unsigned short >::get ( size_t  idx)
inlineinherited

◆ get() [2/3]

bool & MuonVal::VectorBranch< bool >::get ( size_t  idx)
inherited

◆ get() [3/3]

bool & MuonVal::VectorBranch< bool >::get ( size_t  )
inherited

Definition at line 63 of file MuonTesterBranch.cxx.

63  {
64  THROW_EXCEPTION("For boolean branches the get() operator is cumbersome");
65  return m_default;
66 }

◆ getDefault()

const unsigned short & MuonVal::VectorBranch< unsigned short >::getDefault
inlineinherited

◆ hasDefault()

bool MuonVal::VectorBranch< unsigned short >::hasDefault
inlineinherited

◆ init()

bool MuonVal::VectorBranch< unsigned short >::init
overridevirtualinherited

Initialized the Branch.

Implements MuonVal::IMuonTesterBranch.

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

52 { return m_init; }

◆ 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  m_lvl = m_imsg ?
43  static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
44  MSG::INFO;
45 }

◆ isUpdated()

bool MuonVal::VectorBranch< unsigned short >::isUpdated
inlineinherited

◆ 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 164 of file AthMessaging.h.

165 {
166  MsgStream* ms = m_msg_tls.get();
167  if (!ms) {
168  if (!m_initialized.test_and_set()) initMessaging();
169  ms = new MsgStream(m_imsg,m_nm);
170  m_msg_tls.reset( ms );
171  }
172 
173  ms->setLevel (m_lvl);
174  return *ms;
175 }

◆ 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 179 of file AthMessaging.h.

180 { return msg() << lvl; }

◆ 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_initialized.test_and_set()) initMessaging();
154  if (m_lvl <= lvl) {
155  msg() << lvl;
156  return true;
157  } else {
158  return false;
159  }
160 }

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

◆ operator+=() [1/3]

void MuonVal::VectorBranch< unsigned short >::operator+= ( const unsigned short &  value)
inlineinherited

◆ operator+=() [2/3]

void MuonVal::BilateralLinkerBranch::operator+= ( const xAOD::IParticle p)
overridevirtual

Implements MuonVal::IParticleDecorationBranch.

Definition at line 62 of file LinkerBranch.cxx.

62  {
63  push_back(p);
64  }

◆ operator+=() [3/3]

void MuonVal::BilateralLinkerBranch::operator+= ( const xAOD::IParticle p)
overridevirtual

Implements MuonVal::IParticleDecorationBranch.

Definition at line 59 of file LinkerBranch.cxx.

59  {
60  push_back(p);
61  }

◆ operator[]()

unsigned short & MuonVal::VectorBranch< unsigned short >::operator[] ( size_t  idx)
inlineinherited

Accesses the idx-th element.

If the index is larger than the size of the vector it is then enlarged with the default_value

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

◆ push_back() [1/3]

void MuonVal::VectorBranch< unsigned short >::push_back ( const unsigned short &  value)
inlineinherited

Adds a new element at the end of the vector.

◆ push_back() [2/3]

void MuonVal::BilateralLinkerBranch::push_back ( const xAOD::IParticle p)
overridevirtual

Implements MuonVal::IParticleDecorationBranch.

Definition at line 56 of file LinkerBranch.cxx.

56  {
57  push_back(&p);
58  }

◆ push_back() [3/3]

void MuonVal::BilateralLinkerBranch::push_back ( const xAOD::IParticle p)
overridevirtual

Interface methods to handle the particle.

Implements MuonVal::IParticleDecorationBranch.

Definition at line 54 of file LinkerBranch.cxx.

54  {
55  }

◆ setDefault()

void MuonVal::VectorBranch< unsigned short >::setDefault ( const unsigned short &  def)
inherited

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

◆ size()

size_t MuonVal::VectorBranch< unsigned short >::size
inlineinherited

Returns the number of actual saved elements.

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

unsigned short MuonVal::VectorBranch< unsigned short >::m_default
privateinherited

Definition at line 55 of file VectorBranch.h.

◆ m_dependencies

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

Definition at line 62 of file MuonTesterBranch.h.

◆ m_hasDefault

bool MuonVal::VectorBranch< unsigned short >::m_hasDefault
privateinherited

Definition at line 56 of file VectorBranch.h.

◆ m_imsg

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

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

◆ m_init

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

Definition at line 61 of file MuonTesterBranch.h.

◆ m_linkColl

std::weak_ptr<IParticleFourMomBranch> MuonVal::BilateralLinkerBranch::m_linkColl
private

Definition at line 77 of file LinkerBranch.h.

◆ m_linkerFunc

Linker_t MuonVal::BilateralLinkerBranch::m_linkerFunc
private

Definition at line 78 of file LinkerBranch.h.

◆ m_lvl

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

Current logging level.

Definition at line 138 of file AthMessaging.h.

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

◆ m_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.h.

◆ m_parent

const IParticleFourMomBranch& MuonVal::BilateralLinkerBranch::m_parent
private

Definition at line 76 of file LinkerBranch.h.

◆ m_tree

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

Definition at line 58 of file MuonTesterBranch.h.

◆ m_updated

bool MuonVal::VectorBranch< unsigned short >::m_updated
privateinherited

Definition at line 57 of file VectorBranch.h.

◆ m_variable

std::vector<unsigned short > MuonVal::VectorBranch< unsigned short >::m_variable
privateinherited

Definition at line 54 of file VectorBranch.h.


The documentation for this class was generated from the following files:
AthMessaging::m_lvl
std::atomic< MSG::Level > m_lvl
Current logging level.
Definition: AthMessaging.h:138
MuonVal::BilateralLinkerBranch::m_parent
const IParticleFourMomBranch & m_parent
Definition: LinkerBranch.h:76
vtune_athena.format
format
Definition: vtune_athena.py:14
MuonVal::VectorBranch< unsigned short >::setDefault
void setDefault(const unsigned short &def)
MuonVal::BilateralLinkerBranch::push_back
void push_back(const xAOD::IParticle *p) override
Interface methods to handle the particle.
Definition: LinkerBranch.cxx:54
MuonVal::MuonTesterBranch::m_dependencies
std::vector< DataDependency > m_dependencies
Definition: MuonTesterBranch.h:62
MuonVal::MuonTesterBranch::m_tree
TTree * m_tree
Definition: MuonTesterBranch.h:58
python.AthDsoLogger.out
out
Definition: AthDsoLogger.py:71
ATH_MSG_VERBOSE
#define ATH_MSG_VERBOSE(x)
Definition: AthMsgStreamMacros.h:28
AthMessaging::m_imsg
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
Definition: AthMessaging.h:135
python.SystemOfUnits.ms
int ms
Definition: SystemOfUnits.py:132
Athena::getMessageSvc
IMessageSvc * getMessageSvc(bool quiet=false)
Definition: getMessageSvc.cxx:20
MuonVal::MuonTesterBranch::m_parent
MuonTesterTree * m_parent
Definition: MuonTesterBranch.h:59
MuonVal::BilateralLinkerBranch::ParticleBranch_ptr
LinkerBranch::ParticleBranch_ptr ParticleBranch_ptr
Definition: LinkerBranch.h:55
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:210
TrigConf::MSGTC::Level
Level
Definition: Trigger/TrigConfiguration/TrigConfBase/TrigConfBase/MsgStream.h:21
MuonVal::BilateralLinkerBranch::m_linkerFunc
Linker_t m_linkerFunc
Definition: LinkerBranch.h:78
MuonVal::VectorBranch::fill
bool fill(const EventContext &ctx) override
Clears vector in cases that it has not been updated in this event Retursn falls if the vector has not...
MuonVal::IParticleFourMomBranch::size
size_t size() const
How many particles have been pushed back already.
Definition: IParticleFourMomBranch.cxx:29
MuonVal::MuonTesterBranch::m_init
bool m_init
Definition: MuonTesterBranch.h:61
AthMessaging::msg
MsgStream & msg() const
The standard message stream.
Definition: AthMessaging.h:164
MuonVal::MuonTesterBranch::name
std::string name() const override final
Returns the name of the branch.
Definition: MuonTesterBranch.cxx:51
MuonVal::MuonTesterTree::name
std::string name() const
Name of the tree.
Definition: MuonTesterTree.cxx:20
THROW_EXCEPTION
#define THROW_EXCEPTION(MESSAGE)
Definition: throwExcept.h:10
MuonVal::VectorBranch< unsigned short >::m_default
unsigned short m_default
Definition: VectorBranch.h:55
MuonVal::BilateralLinkerBranch::m_linkColl
std::weak_ptr< IParticleFourMomBranch > m_linkColl
Definition: LinkerBranch.h:77
MuonVal::MuonTesterBranch::parent
MuonTesterTree & parent()
Returns the reference to the MuonTesterTree parent.
Definition: MuonTesterBranch.cxx:38
MuonVal::IMuonTesterBranch::name
virtual std::string name() const =0
Returns the name of the branch.
MuonVal::MuonTesterBranch::m_name
std::string m_name
Definition: MuonTesterBranch.h:60
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
MuonVal::IParticleFourMomBranch::name
std::string name() const override
Name of the four momentum branch.
Definition: IParticleFourMomBranch.cxx:30
AthMessaging::m_nm
std::string m_nm
Message source name.
Definition: AthMessaging.h:129
MuonVal::BilateralLinkerBranch::BilateralLinkerBranch
BilateralLinkerBranch(IParticleFourMomBranch &bilatColl, ParticleBranch_ptr primColl, Linker_t linker, const std::string &altName)
Definition: LinkerBranch.cxx:42
MuonVal::VectorBranch< unsigned short >::get
unsigned short & get(size_t idx)
MuonVal::VectorBranch< unsigned short >::size
size_t size() const
Returns the number of actual saved elements.
AthMessaging::initMessaging
void initMessaging() const
Initialize our message level and MessageSvc.
Definition: AthMessaging.cxx:39
AthMessaging::m_msg_tls
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
Definition: AthMessaging.h:132
MuonVal::MuonTesterTree::tree
TTree * tree()
TTree object.
Definition: MuonTesterTree.cxx:22
MuonVal::IParticleFourMomBranch::find
size_t find(const xAOD::IParticle &p) const
Returns the position at which the particle has already be inserted in the chain – If the particle is ...
Definition: IParticleFourMomBranch.cxx:68