5#ifndef ASGANALYSISALGORITHMS_TREEBRANCHHELPERS_H
6#define ASGANALYSISALGORITHMS_TREEBRANCHHELPERS_H
8#include <unordered_map>
25#include <ROOT/RNTupleModel.hxx>
34class TVirtualCollectionProxy;
119 StatusCode
configureTypes (std::set<std::string>& decosWithoutType, MsgStream&
msg);
270 std::unique_ptr< SG::TypelessConstAccessor >
m_acc;
274 std::unique_ptr< SG::IAuxTypeVector >
m_data;
313 StatusCode
resize(
size_t size, MsgStream&
msg );
322 std::unique_ptr< SG::TypelessConstAccessor >
m_acc;
326 std::unique_ptr< SG::IAuxTypeVector >
m_data;
389 std::vector<std::unique_ptr<ElementBranchProcessor>>
m_branches;
455 std::vector<std::unique_ptr<ContainerBranchProcessor>>
m_branches;
522 std::vector<std::unique_ptr<ElementBranchProcessor>>
m_branches;
535 using AsgMessagingForward::AsgMessagingForward;
542 StatusCode
setupTree(
const std::vector<std::string>& branches, std::unordered_set<std::string> nonContainers,
ISystematicsSvc& sysSvc, TTree&
tree );
558 std::unordered_map< std::string, std::unique_ptr<IObjectProcessor>>
m_processors;
Base class for elements of a container that can have aux data.
Abstract interface for manipulating vectors of arbitrary types.
Define macros for attributes used to control the static checker.
the interface for the central systematics service
Class to wrap a set of SystematicVariations.
std::string m_branchName
Name of the branch being written.
StatusCode resize(size_t size, MsgStream &msg)
Function (re)sizing the variable for a new event.
std::unique_ptr< SG::IAuxTypeVector > m_data
The object managing the memory of the written variable.
std::unique_ptr< SG::TypelessConstAccessor > m_acc
Object accessing the variable in question.
virtual StatusCode setup(TTree &tree, const BranchConfig &branchConfig, OutputBranchData &outputData, MsgStream &msg) override
Function setting up the object, and the branch.
ContainerBranchProcessor(const ContainerBranchProcessor &)=delete
ContainerBranchProcessor & operator=(const ContainerBranchProcessor &)=delete
const SG::IAuxTypeVectorFactory * m_factory
Pointer to the helper object that handles this variable.
virtual ~ContainerBranchProcessor()=default
void * m_dataPtr
Helper variable, pointing at the object to be written.
ContainerBranchProcessor()=default
ContainerProcessorRegular & operator=(const ContainerProcessorRegular &)=delete
TVirtualCollectionProxy * m_collProxy
Collection proxy used for iterating over the container.
std::string m_sgName
Name of the object in the event store.
int m_auxElementOffset
Offset of the element type to SG::AuxElement.
virtual ~ContainerProcessorRegular()=default
virtual StatusCode retrieveProcess(StoreType &evtStore) override
retrieve and process the object
virtual StatusCode addBranch(TTree &tree, const BranchConfig &branchConfig, OutputBranchData &outputData) override
Add one branch to the output tree.
std::vector< std::unique_ptr< ContainerBranchProcessor > > m_branches
List of branch processors set up for this xAOD object.
ContainerProcessorRegular(const ContainerProcessorRegular &)=delete
ContainerProcessorRegular(const std::string &sgName)
Default constructor.
std::unique_ptr< SG::IAuxTypeVector > m_data
The object managing the memory of the written variable.
ElementBranchProcessor()=default
ElementBranchProcessor & operator=(const ElementBranchProcessor &)=delete
void * m_dataPtr
Helper variable, pointing at the object to be written.
const SG::IAuxTypeVectorFactory * m_factory
Pointer to the helper object that handles this variable.
std::string m_branchName
Name of the branch being written.
virtual ~ElementBranchProcessor()=default
ElementBranchProcessor(const ElementBranchProcessor &)=delete
virtual StatusCode setup(TTree &tree, const BranchConfig &branchConfig, OutputBranchData &outputData, MsgStream &msg) override
Function setting up the object, and the branch.
std::unique_ptr< SG::TypelessConstAccessor > m_acc
Object accessing the variable in question.
virtual ~ElementProcessorMet()=default
std::vector< std::unique_ptr< ElementBranchProcessor > > m_branches
List of branch processors set up for this xAOD object.
std::string m_termName
Name of the MET term to retrieve.
virtual StatusCode addBranch(TTree &tree, const BranchConfig &branchConfig, OutputBranchData &outputData) override
Add one branch to the output tree.
ElementProcessorMet(const std::string &sgName, const std::string &termName)
Default constructor.
ElementProcessorMet(const ElementProcessorMet &)=delete
virtual StatusCode retrieveProcess(StoreType &evtStore) override
retrieve and process the object
ElementProcessorMet & operator=(const ElementProcessorMet &)=delete
std::string m_sgName
Name of the object in the event store.
ElementProcessorRegular(const ElementProcessorRegular &)=delete
virtual StatusCode retrieveProcess(StoreType &evtStore) override
retrieve and process the object
virtual StatusCode addBranch(TTree &tree, const BranchConfig &branchConfig, OutputBranchData &outputData) override
Add one branch to the output tree.
virtual ~ElementProcessorRegular()=default
ElementProcessorRegular & operator=(const ElementProcessorRegular &)=delete
std::string m_sgName
Name of the object in the event store.
ElementProcessorRegular(const std::string &sgName)
Default constructor.
std::vector< std::unique_ptr< ElementBranchProcessor > > m_branches
List of branch processors set up for this xAOD object.
the interface class for branch processors
virtual StatusCode setup(ROOT::RNTupleModel &, const BranchConfig &, OutputBranchData &, MsgStream &msg)=0
virtual ~IComponentProcessor()=default
virtual destructor
virtual StatusCode setup(TTree &, const BranchConfig &, OutputBranchData &, MsgStream &msg)=0
the interface class for classes reading an object from the event store and processing it
virtual StatusCode addBranch(ROOT::RNTupleModel &, const BranchConfig &, OutputBranchData &)=0
virtual StatusCode retrieveProcess(StoreType &evtStore)=0
retrieve and process the object
virtual StatusCode addBranch(TTree &, const BranchConfig &, OutputBranchData &)=0
Add one branch to the output tree.
virtual ~IObjectProcessor()=default
virtual destructor
ProcessorList(const ProcessorList &)=delete
virtual ~ProcessorList()=default
StatusCode setupBranch(const BranchConfig &branchConfig, OutputBranchData &outputData, TTree &tree)
Function setting up an individual branch on the first event.
std::unordered_set< std::string > m_nonContainers
the non-containers
IObjectProcessor & getObjectProcessor(const BranchConfig &branchConfig, const std::string &sgName)
StatusCode setupTree(const std::vector< std::string > &branches, std::unordered_set< std::string > nonContainers, ISystematicsSvc &sysSvc, TTree &tree)
Function setting up the internal data structures on the first event for regular branches.
std::optional< int > defaultBasketSize
the default basket size
std::unordered_map< std::string, std::unique_ptr< IObjectProcessor > > m_processors
object processors
ProcessorList & operator=(const ProcessorList &)=delete
Base class for elements of a container that can have aux data.
Manage index tracking and synchronization of auxiliary data.
Interface for factory objects that create vectors.
The Athena Transient Store API.
base class to forward messages to another class
Class mimicking the AthMessaging class from the offline software.
Wrapper for TEvent to make it look like StoreGate.
const std::string process
a namespace for helper functions and objects for filling tree branches
StoreGateSvc StoreType
the type of the event store in the current environment
Select isolated Photons, Electrons and Muons.
static const auxid_t null_auxid
To signal no aux data item.
size_t auxid_t
Identifier for a particular aux data item.
void ErrorHandler ATLAS_NOT_THREAD_SAFE(Int_t level, Bool_t abort, const char *location, const char *message)
Function filtering the warnings coming from ROOT.
the user configuration of an output branch
std::string branchDecl
the original user configuration string
std::string sgName
the SG name of the object to read from
const SG::IAuxTypeVectorFactory * auxFactory
pointer to the aux vector factory
std::string auxName
the aux data variable name to read from
const std::type_info * auxVecType
the vector type of the decoration we read
std::optional< int > basketSize
the basket size for this branch
CP::SystematicSet auxNameFilterSys
the affecting systematics for the auxName
CP::SystematicSet sgNameFilterSys
the affecting systematics for the sgName
CP::SystematicSet branchNameFilterSys
the affecting systematics for the branchName
const std::type_info * auxType
the type of the decoration we read
StatusCode configureSystematics(ISystematicsSvc &sysSvc, MsgStream &msg)
configure the systematics
SG::auxid_t nominalAuxId
the aux-id for the nominal decoration
std::string branchName
the name of the output branch
std::string metTermName
MET ONLY: the name of the MET term to write out.
bool nominalOnly
whether we only want to write out the nominal
StatusCode configureTypes(std::set< std::string > &decosWithoutType, MsgStream &msg)
configure the associated decoration types
StatusCode parse(const std::string &branchDecl, MsgStream &msg)
parse the user configuration string
std::string typeName
the name of the type (or empty to read from aux-registry)
the data for a single output branch
bool isNominal
whether this is unaffected by systematics (i.e. nominal)
const BranchConfig * branchConfig
the BranchConfig we are based on
std::size_t sysIndex
the index in the systematics list
StatusCode configureNames(const BranchConfig &branchConfig, const CP::SystematicSet &sys, ISystematicsSvc &sysSvc, MsgStream &msg)
configure names for systematics
std::string auxName
the name of the decoration in the aux-store
std::string sgName
the SG name of the object to read from
std::string branchName
the name of the output branch