|  | ATLAS Offline Software
    | 
 
 
 
Algorithm testing file metadata access.  
 More...
#include <UnitTestAlg4.h>
|  | 
|  | UnitTestAlg4 (const std::string &name, ISvcLocator *svcLoc) | 
|  | Standard algorithm constructor.  More... 
 | 
|  | 
| ::StatusCode | requestFileExecute () | 
|  | register this algorithm to have an implementation of fileexecute  More... 
 | 
|  | 
| ::StatusCode | requestBeginInputFile () | 
|  | register this algorithm to have an implementation of beginInputFile  More... 
 | 
|  | 
| ::StatusCode | requestEndInputFile () | 
|  | register this algorithm to have an implementation of endInputFile  More... 
 | 
|  | 
| void | handle (const Incident &inc) | 
|  | receive the given incident  More... 
 | 
|  | 
| virtual StatusCode | sysInitialize () | 
|  | Initialization method invoked by the framework.  More... 
 | 
|  | 
| const ServiceHandle< ITHistSvc > & | histSvc () const | 
|  | The standard THistSvc(for writing histograms and TTrees and more to a root file) Returns (kind of) a pointer to theTHistSvc.  More...
 | 
|  | 
| virtual const DataObjIDColl & | extraOutputDeps () const override | 
|  | Return the list of extra output dependencies.  More... 
 | 
|  | 
| ServiceHandle< StoreGateSvc > & | evtStore () | 
|  | The standard StoreGateSvc(event store) Returns (kind of) a pointer to theStoreGateSvc.  More...
 | 
|  | 
| const ServiceHandle< StoreGateSvc > & | evtStore () const | 
|  | The standard StoreGateSvc(event store) Returns (kind of) a pointer to theStoreGateSvc.  More...
 | 
|  | 
| const ServiceHandle< StoreGateSvc > & | detStore () const | 
|  | The standard StoreGateSvc/DetectorStoreReturns (kind of) a pointer to theStoreGateSvc.  More...
 | 
|  | 
| virtual StatusCode | sysStart () override | 
|  | Handle START transition.  More... 
 | 
|  | 
| virtual std::vector< Gaudi::DataHandle * > | inputHandles () const override | 
|  | Return this algorithm's input handles.  More... 
 | 
|  | 
| virtual std::vector< Gaudi::DataHandle * > | outputHandles () const override | 
|  | Return this algorithm's output handles.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareProperty (Gaudi::Property< T, V, H > &t) | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, SG::VarHandleKey &hndl, const std::string &doc, const SG::VarHandleKeyType &) | 
|  | Declare a new Gaudi property.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, SG::VarHandleBase &hndl, const std::string &doc, const SG::VarHandleType &) | 
|  | Declare a new Gaudi property.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, SG::VarHandleKeyArray &hndArr, const std::string &doc, const SG::VarHandleKeyArrayType &) | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, T &property, const std::string &doc, const SG::NotHandleType &) | 
|  | Declare a new Gaudi property.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, T &property, const std::string &doc="none") | 
|  | Declare a new Gaudi property.  More... 
 | 
|  | 
| void | updateVHKA (Gaudi::Details::PropertyBase &) | 
|  | 
| MsgStream & | msg () const | 
|  | 
| MsgStream & | msg (const MSG::Level lvl) const | 
|  | 
| bool | msgLvl (const MSG::Level lvl) const | 
|  | 
|  | 
| virtual ::StatusCode | initialize () override | 
|  | Function initialising the algorithm.  More... 
 | 
|  | 
| virtual ::StatusCode | execute () override | 
|  | Function executing the algorithm.  More... 
 | 
|  | 
| virtual ::StatusCode | finalize () override | 
|  | Function finalising the algorithm.  More... 
 | 
|  | 
| virtual ::StatusCode | beginInputFile () override | 
|  | Function called whenever a new input file's processing starts.  More... 
 | 
|  | 
|  | 
| virtual void | print () const | 
|  | print the state of the algorithm  More... 
 | 
|  | 
| virtual ::StatusCode | fileExecute () | 
|  | perform the action exactly once for each file in the dataset  More... 
 | 
|  | 
| virtual ::StatusCode | endInputFile () | 
|  | perform the action for the end of an input file  More... 
 | 
|  | 
| void | renounceArray (SG::VarHandleKeyArray &handlesArray) | 
|  | remove all handles from I/O resolution  More... 
 | 
|  | 
| 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.  More... 
 | 
|  | 
| StatusCode | configAthHistogramming (const ServiceHandle< ITHistSvc > &histSvc, const std::string &prefix, const std::string &rootDir, const std::string &histNamePrefix, const std::string &histNamePostfix, const std::string &histTitlePrefix, const std::string &histTitlePostfix) | 
|  | To be called by the derived classes to fill the internal configuration.  More... 
 | 
|  | 
| TH1 * | bookGetPointer (const TH1 &hist, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the booking and registering (into THistSvc) of histograms.  More... 
 | 
|  | 
| TH1 * | bookGetPointer (TH1 *hist, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the booking and registering (into THistSvc) of histograms.  More... 
 | 
|  | 
| TH1 * | bookGetPointer (TH1 &histRef, std::string tDir="", std::string stream="") | 
|  | Simplify the booking and registering (into THistSvc) of histograms.  More... 
 | 
|  | 
| TTree * | bookGetPointer (const TTree &treeRef, std::string tDir="", std::string stream="") | 
|  | Simplify the booking and registering (into THistSvc) of TTrees.  More... 
 | 
|  | 
| TGraph * | bookGetPointer (const TGraph &graphRef, std::string tDir="", std::string stream="") | 
|  | Simplify the booking and registering (into THistSvc) of TGraphs.  More... 
 | 
|  | 
| TEfficiency * | bookGetPointer (const TEfficiency &eff, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the booking and registering (into THistSvc) of TEfficiency.  More... 
 | 
|  | 
| TEfficiency * | bookGetPointer (TEfficiency *eff, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the booking and registering (into THistSvc) of TEfficiency.  More... 
 | 
|  | 
| TEfficiency * | bookGetPointer (TEfficiency &effRef, std::string tDir="", std::string stream="") | 
|  | Simplify the booking and registering (into THistSvc) of TEfficiency.  More... 
 | 
|  | 
| StatusCode | book (const TH1 &hist, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the booking and registering (into THistSvc) of histograms.  More... 
 | 
|  | 
| StatusCode | book (TH1 *hist, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the booking and registering (into THistSvc) of histograms.  More... 
 | 
|  | 
| StatusCode | book (TH1 &histRef, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the booking and registering (into THistSvc) of histograms.  More... 
 | 
|  | 
| StatusCode | book (const TTree &treeRef, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the booking and registering (into THistSvc) of TTrees.  More... 
 | 
|  | 
| StatusCode | book (const TGraph &graphRef, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the booking and registering (into THistSvc) of TGraphs.  More... 
 | 
|  | 
| StatusCode | book (const TEfficiency &eff, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the booking and registering (into THistSvc) of TEfficiency.  More... 
 | 
|  | 
| StatusCode | book (TEfficiency *eff, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the booking and registering (into THistSvc) of TEfficiency.  More... 
 | 
|  | 
| StatusCode | book (TEfficiency &effRef, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the booking and registering (into THistSvc) of TEfficiency.  More... 
 | 
|  | 
| TH1 * | hist (const std::string &histName, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the retrieval of registered histograms of any type.  More... 
 | 
|  | 
| TH2 * | hist2d (const std::string &histName, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the retrieval of registered 2-d histograms.  More... 
 | 
|  | 
| TH3 * | hist3d (const std::string &histName, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the retrieval of registered 3-d histograms.  More... 
 | 
|  | 
| TTree * | tree (const std::string &treeName, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the retrieval of registered TTrees.  More... 
 | 
|  | 
| TGraph * | graph (const std::string &graphName, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the retrieval of registered TGraphs.  More... 
 | 
|  | 
| TEfficiency * | efficiency (const std::string &effName, const std::string &tDir="", const std::string &stream="") | 
|  | Simplify the retrieval of registered TEfficiency.  More... 
 | 
|  | 
|  | 
| StatusCode | readFileMetaData () | 
|  | Function reading some in-file metadata.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &) | 
|  | specialization for handling Gaudi::Property<SG::VarHandleKey>  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyArrayType &) | 
|  | specialization for handling Gaudi::Property<SG::VarHandleKeyArray>  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleType &) | 
|  | specialization for handling Gaudi::Property<SG::VarHandleBase>  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &t, const SG::NotHandleType &) | 
|  | specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray>  More... 
 | 
|  | 
| void | buildBookingString (std::string &bookingString, std::string &histName, std::string &tDir, std::string &stream, bool usePrefixPostfix=false) | 
|  | Method to build individual booking string.  More... 
 | 
|  | 
| void | myReplace (std::string &str, const std::string &oldStr, const std::string &newStr) | 
|  | Helper method to replace sub-string.  More... 
 | 
|  | 
| hash_t | hash (const std::string &histName) const | 
|  | Method to calculate a 32-bit hash from a string.  More... 
 | 
|  | 
Algorithm testing file metadata access. 
This is meant to serve as a test of the metadata capabilities of EL::AnaAlgorithm.
- Author
- Attila Krasznahorkay Attil.nosp@m.a.Kr.nosp@m.aszna.nosp@m.hork.nosp@m.ay@ce.nosp@m.rn.c.nosp@m.h 
Definition at line 20 of file UnitTestAlg4.h.
◆ ConstMetaStorePtr_t
◆ EffMap_t
◆ GraphMap_t
◆ hash_t
◆ HistMap_t
◆ MetaStore_t
◆ MetaStorePtr_t
Type of the metadata store pointer in standalone mode. 
Definition at line 110 of file AnaAlgorithm.h.
 
 
◆ StoreGateSvc_t
◆ TreeMap_t
◆ UnitTestAlg4()
      
        
          | EL::UnitTestAlg4::UnitTestAlg4 | ( | const std::string & | name, | 
        
          |  |  | ISvcLocator * | svcLoc | 
        
          |  | ) |  |  | 
      
 
 
◆ beginInputFile()
Function called whenever a new input file's processing starts. 
Definition at line 63 of file UnitTestAlg4.cxx.
   72       return ::StatusCode::SUCCESS;
 
 
 
 
◆ book() [1/8]
  
  | 
        
          | StatusCode AthHistogramming::book | ( | const TEfficiency & | eff, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
Simplify the booking and registering (into THistSvc) of TEfficiency. 
Definition at line 335 of file AthHistogramming.h.
  338   TEfficiency* effClone = 
dynamic_cast< TEfficiency* 
>( 
eff.Clone() );
 
  340     m_msg << MSG::ERROR << 
"Couldn't create a TEfficiency clone" << 
endmsg;
 
  341     return StatusCode::FAILURE;
 
 
 
 
◆ book() [2/8]
  
  | 
        
          | StatusCode AthHistogramming::book | ( | const TGraph & | graphRef, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
Simplify the booking and registering (into THistSvc) of TGraphs. 
 
 
◆ book() [3/8]
Simplify the booking and registering (into THistSvc) of histograms. 
Definition at line 303 of file AthHistogramming.h.
  306   TH1* histClone = 
dynamic_cast< TH1* 
>( 
hist.Clone() );
 
  308     m_msg << MSG::ERROR << 
"Couldn't create a TH1 clone" << 
endmsg;
 
  309     return StatusCode::FAILURE;
 
  311   return this->
book( *histClone, tDir, 
stream );
 
 
 
 
◆ book() [4/8]
Simplify the booking and registering (into THistSvc) of TTrees. 
Definition at line 403 of file AthHistogramming.h.
  409       return StatusCode::SUCCESS;
 
  413       return StatusCode::FAILURE;
 
 
 
 
◆ book() [5/8]
  
  | 
        
          | StatusCode AthHistogramming::book | ( | TEfficiency & | effRef, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
Simplify the booking and registering (into THistSvc) of TEfficiency. 
Definition at line 356 of file AthHistogramming.h.
  361     m_msg << MSG::ERROR << 
"Couldn't book a TEfficiency" << 
endmsg;
 
  362     return StatusCode::FAILURE;
 
  364   return StatusCode::SUCCESS;
 
 
 
 
◆ book() [6/8]
  
  | 
        
          | StatusCode AthHistogramming::book | ( | TEfficiency * | eff, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
Simplify the booking and registering (into THistSvc) of TEfficiency. 
Definition at line 346 of file AthHistogramming.h.
  349     m_msg << MSG::ERROR << 
"Got a zero pointer to a TEfficiency" << 
endmsg;
 
  350     return StatusCode::FAILURE;
 
 
 
 
◆ book() [7/8]
  
  | 
        
          | StatusCode AthHistogramming::book | ( | TH1 & | histRef, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
Simplify the booking and registering (into THistSvc) of histograms. 
Definition at line 324 of file AthHistogramming.h.
  328   if ( !histPointer ) {
 
  329     m_msg << MSG::ERROR << 
"Couldn't book a TH1" << 
endmsg;
 
  330     return StatusCode::FAILURE;
 
  332   return StatusCode::SUCCESS;
 
 
 
 
◆ book() [8/8]
  
  | 
        
          | StatusCode AthHistogramming::book | ( | TH1 * | hist, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
Simplify the booking and registering (into THistSvc) of histograms. 
Definition at line 314 of file AthHistogramming.h.
  317     m_msg << MSG::ERROR << 
"Got a zero pointer to a TH1" << 
endmsg;
 
  318     return StatusCode::FAILURE;
 
 
 
 
◆ bookGetPointer() [1/8]
  
  | 
        
          | TEfficiency * AthHistogramming::bookGetPointer | ( | const TEfficiency & | eff, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
Simplify the booking and registering (into THistSvc) of TEfficiency. 
Definition at line 281 of file AthHistogramming.h.
  284   TEfficiency* histClone = 
dynamic_cast< TEfficiency* 
>( 
hist.Clone() );
 
  286     m_msg << MSG::ERROR << 
"Couldn't create a TEfficiency clone in bookGetPointer" << 
endmsg;
 
 
 
 
◆ bookGetPointer() [2/8]
  
  | 
        
          | TGraph * AthHistogramming::bookGetPointer | ( | const TGraph & | graphRef, |  
          |  |  | std::string | tDir = "", |  
          |  |  | std::string | stream = "" |  
          |  | ) |  |  |  | protectedinherited | 
 
Simplify the booking and registering (into THistSvc) of TGraphs. 
Definition at line 427 of file AthHistogramming.cxx.
  430   const TGraph* graphPointer = &graphRef;
 
  435       m_msg << MSG::WARNING
 
  436             << 
"We got an invalid TGraph pointer in the BookGetPointer(TGraph*) method of the class" << 
m_name 
  442   std::string graphName  = graphPointer->GetName();
 
  443   const std::string graphTitle = graphPointer->GetTitle();
 
  446   const hash_t graphHash = this->
hash(graphName);
 
  447   GraphMap_t::const_iterator 
it = 
m_graphMap.find( graphHash );
 
  450       m_msg << MSG::WARNING
 
  451             << 
"Detected a hash collision. The hash for the TGraph with name=" << graphName
 
  452             << 
" already exists and points to a TGraph with name=" << 
it->second->GetName()
 
  453             << 
" NOT going to book the new histogram and returning a NULL pointer!" << 
endmsg;
 
  461       m_msg << MSG::WARNING
 
  462             << 
"We couldn't clone the TGraph in the BookGetPointer(TGraph&) method of the class" << 
m_name 
  469   std::string bookingString(
"");
 
  473   if ( !((
histSvc()->regGraph(bookingString, graphClone)).isSuccess()) )
 
  475       m_msg << MSG::WARNING
 
  476             << 
"Problem registering TGraph with name " << graphName
 
  477             << 
", title " << graphTitle
 
  483   m_graphMap.insert( 
m_graphMap.end(), std::pair< const hash_t, TGraph* >( graphHash, graphClone ) );
 
 
 
 
◆ bookGetPointer() [3/8]
  
  | 
        
          | TH1 * AthHistogramming::bookGetPointer | ( | const TH1 & | hist, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
Simplify the booking and registering (into THistSvc) of histograms. 
Definition at line 260 of file AthHistogramming.h.
  263   TH1* histClone = 
dynamic_cast< TH1* 
>( 
hist.Clone() );
 
  265     m_msg << MSG::ERROR << 
"Couldn't create a TH1 clone in bookGetPointer" << 
endmsg;
 
 
 
 
◆ bookGetPointer() [4/8]
  
  | 
        
          | TTree * AthHistogramming::bookGetPointer | ( | const TTree & | treeRef, |  
          |  |  | std::string | tDir = "", |  
          |  |  | std::string | stream = "" |  
          |  | ) |  |  |  | protectedinherited | 
 
Simplify the booking and registering (into THistSvc) of TTrees. 
Definition at line 312 of file AthHistogramming.cxx.
  315   const TTree* treePointer = &treeRef;
 
  320       m_msg << MSG::WARNING
 
  321             << 
"We got an invalid TTree pointer in the BookGetPointer(TTree*) method of the class" << 
m_name 
  327   std::string 
treeName  = treePointer->GetName();
 
  328   const std::string treeTitle = treePointer->GetTitle();
 
  332   TreeMap_t::const_iterator 
it = 
m_treeMap.find( treeHash );
 
  335       m_msg << MSG::WARNING
 
  336             << 
"Detected a hash collision. The hash for the TTree with name=" << 
treeName 
  337             << 
" already exists and points to a TTree with name=" << 
it->second->GetName()
 
  338             << 
" NOT going to book the new histogram and returning a NULL pointer!" << 
endmsg;
 
  343   TTree* treeClone = 
dynamic_cast< TTree* 
>( treePointer->Clone(
treeName.c_str()) );
 
  346       m_msg << MSG::WARNING
 
  347             << 
"We couldn't clone the TTree in the BookGetPointer(TTree&) method of the class" << 
m_name 
  351   treeClone->SetTitle (treeTitle.c_str());
 
  354   std::string bookingString(
"");
 
  358   if ( !((
histSvc()->regTree(bookingString, treeClone)).isSuccess()) )
 
  360       m_msg << MSG::WARNING
 
  361             << 
"Problem registering TTree with name " << 
treeName 
  362             << 
", title " << treeTitle
 
  368   m_treeMap.insert( 
m_treeMap.end(), std::pair< const hash_t, TTree* >( treeHash, treeClone ) );
 
 
 
 
◆ bookGetPointer() [5/8]
  
  | 
        
          | TEfficiency * AthHistogramming::bookGetPointer | ( | TEfficiency & | effRef, |  
          |  |  | std::string | tDir = "", |  
          |  |  | std::string | stream = "" |  
          |  | ) |  |  |  | protectedinherited | 
 
Simplify the booking and registering (into THistSvc) of TEfficiency. 
Definition at line 146 of file AthHistogramming.cxx.
  149   std::string effName(effRef.GetName());
 
  150   const std::string effTitle(effRef.GetTitle());
 
  151   std::string bookingString(
"");
 
  155   effRef.SetName(effName.c_str());
 
  159   EffMap_t::const_iterator 
it = 
m_effMap.find( effHash );
 
  162       m_msg << MSG::WARNING
 
  163             << 
"Detected a hash collision. The hash for the TEfficiency with name=" << effName
 
  164             << 
" already exists and points to a TEfficiency with name=" << 
it->second->GetName()
 
  165             << 
" NOT going to book the new TEfficiency and returning a NULL pointer!" << 
endmsg;
 
  175   if ( !((
histSvc()->regEfficiency(bookingString, &effRef)).isSuccess()) )
 
  177       m_msg << MSG::WARNING
 
  178             << 
"Problem registering TEfficiency with name " << effName
 
  180             << 
", title " << effTitle
 
  188   m_effMap.insert( 
m_effMap.end(), std::pair< const hash_t, TEfficiency* >( effHash, &effRef ) );
 
 
 
 
◆ bookGetPointer() [6/8]
  
  | 
        
          | TEfficiency * AthHistogramming::bookGetPointer | ( | TEfficiency * | eff, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
Simplify the booking and registering (into THistSvc) of TEfficiency. 
Definition at line 293 of file AthHistogramming.h.
  296     m_msg << MSG::ERROR << 
"Got a zero pointer to a TEfficiency in bookGetPointer" << 
endmsg;
 
 
 
 
◆ bookGetPointer() [7/8]
  
  | 
        
          | TH1 * AthHistogramming::bookGetPointer | ( | TH1 & | histRef, |  
          |  |  | std::string | tDir = "", |  
          |  |  | std::string | stream = "" |  
          |  | ) |  |  |  | protectedinherited | 
 
Simplify the booking and registering (into THistSvc) of histograms. 
Definition at line 98 of file AthHistogramming.cxx.
  101   std::string 
histName(histRef.GetName());
 
  102   const std::string histTitle(histRef.GetTitle());
 
  103   std::string bookingString(
"");
 
  111   HistMap_t::const_iterator 
it = 
m_histMap.find( histHash );
 
  114       m_msg << MSG::WARNING
 
  115             << 
"Detected a hash collision. The hash for the histogram with name=" << 
histName 
  116             << 
" already exists and points to a histogram with name=" << 
it->second->GetName()
 
  117             << 
" NOT going to book the new histogram and returning a NULL pointer!" << 
endmsg;
 
  127   if ( !((
histSvc()->regHist(bookingString, &histRef)).isSuccess()) )
 
  129       m_msg << MSG::WARNING
 
  130             << 
"Problem registering histogram with name " << 
histName 
  132             << 
", title " << histTitle
 
  140   m_histMap.insert( 
m_histMap.end(), std::pair< const hash_t, TH1* >( histHash, &histRef ) );
 
 
 
 
◆ bookGetPointer() [8/8]
  
  | 
        
          | TH1 * AthHistogramming::bookGetPointer | ( | TH1 * | hist, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
Simplify the booking and registering (into THistSvc) of histograms. 
Definition at line 272 of file AthHistogramming.h.
  275     m_msg << MSG::ERROR << 
"Got a zero pointer to a TH1 in bookGetPointer" << 
endmsg;
 
 
 
 
◆ buildBookingString()
  
  | 
        
          | void AthHistogramming::buildBookingString | ( | std::string & | bookingString, |  
          |  |  | std::string & | histName, |  
          |  |  | std::string & | tDir, |  
          |  |  | std::string & | stream, |  
          |  |  | bool | usePrefixPostfix = false |  
          |  | ) |  |  |  | privateinherited | 
 
Method to build individual booking string. 
Definition at line 560 of file AthHistogramming.cxx.
  569   if(
pos != std::string::npos){
 
  576   if(usePrefixPostfix){
 
  581   while(bookingString.find(
"//") != std::string::npos){
 
 
 
 
◆ configAthHistogramming()
  
  | 
        
          | StatusCode AthHistogramming::configAthHistogramming | ( | const ServiceHandle< ITHistSvc > & | histSvc, |  
          |  |  | const std::string & | prefix, |  
          |  |  | const std::string & | rootDir, |  
          |  |  | const std::string & | histNamePrefix, |  
          |  |  | const std::string & | histNamePostfix, |  
          |  |  | const std::string & | histTitlePrefix, |  
          |  |  | const std::string & | histTitlePostfix |  
          |  | ) |  |  |  | protectedinherited | 
 
To be called by the derived classes to fill the internal configuration. 
Definition at line 66 of file AthHistogramming.cxx.
   79   return StatusCode::SUCCESS;
 
 
 
 
◆ declareGaudiProperty() [1/4]
specialization for handling Gaudi::Property<SG::VarHandleKeyArray> 
Definition at line 170 of file AthCommonDataStore.h.
  175                                                        hndl.documentation());
 
 
 
 
◆ declareGaudiProperty() [2/4]
specialization for handling Gaudi::Property<SG::VarHandleKey> 
Definition at line 156 of file AthCommonDataStore.h.
  161                                                        hndl.documentation());
 
 
 
 
◆ declareGaudiProperty() [3/4]
specialization for handling Gaudi::Property<SG::VarHandleBase> 
Definition at line 184 of file AthCommonDataStore.h.
  189                                                        hndl.documentation());
 
 
 
 
◆ declareGaudiProperty() [4/4]
◆ declareProperty() [1/6]
Declare a new Gaudi property. 
- Parameters
- 
  
    | name | Name of the property. |  | hndl | Object holding the property value. |  | doc | Documentation string for the property. |  
 
This is the version for types that derive from SG::VarHandleBase. The property value object is put on the input and output lists as appropriate; then we forward to the base class. 
Definition at line 245 of file AthCommonDataStore.h.
  250     this->declare(hndl.
vhKey());
 
  251     hndl.
vhKey().setOwner(
this);
 
  253     return PBASE::declareProperty(
name,hndl,
doc);
 
 
 
 
◆ declareProperty() [2/6]
Declare a new Gaudi property. 
- Parameters
- 
  
    | name | Name of the property. |  | hndl | Object holding the property value. |  | doc | Documentation string for the property. |  
 
This is the version for types that derive from SG::VarHandleKey. The property value object is put on the input and output lists as appropriate; then we forward to the base class. 
Definition at line 221 of file AthCommonDataStore.h.
  229     return PBASE::declareProperty(
name,hndl,
doc);
 
 
 
 
◆ declareProperty() [3/6]
◆ declareProperty() [4/6]
Declare a new Gaudi property. 
- Parameters
- 
  
    | name | Name of the property. |  | property | Object holding the property value. |  | doc | Documentation string for the property. |  
 
This is the generic version, for types that do not derive from SG::VarHandleKey. It just forwards to the base class version of declareProperty. 
Definition at line 333 of file AthCommonDataStore.h.
  338     return PBASE::declareProperty(
name, property, 
doc);
 
 
 
 
◆ declareProperty() [5/6]
Declare a new Gaudi property. 
- Parameters
- 
  
    | name | Name of the property. |  | property | Object holding the property value. |  | doc | Documentation string for the property. |  
 
This dispatches to either the generic declareProperty or the one for VarHandle/Key/KeyArray. 
Definition at line 352 of file AthCommonDataStore.h.
 
 
◆ declareProperty() [6/6]
◆ detStore()
◆ efficiency()
  
  | 
        
          | TEfficiency * AthHistogramming::efficiency | ( | const std::string & | effName, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | protectedinherited | 
 
Simplify the retrieval of registered TEfficiency. 
Definition at line 250 of file AthHistogramming.cxx.
  256   EffMap_t::const_iterator 
it = 
m_effMap.find( effHash );
 
  261       std::string effNameCopy = effName;
 
  262       std::string tDirCopy     = tDir;
 
  263       std::string streamCopy   = 
stream;
 
  266       std::string bookingString(
"");
 
  269       TEfficiency* effPointer(NULL);
 
  270       if ( !((
histSvc()->getEfficiency(bookingString, effPointer)).isSuccess()) )
 
  273           std::string bookingString(
"");
 
  276           if ( !((
histSvc()->getEfficiency(bookingString, effPointer)).isSuccess()) )
 
  278               m_msg << MSG::WARNING
 
  279                     << 
"Problem retrieving the TEfficiency with name (including pre- and post-fixes) " 
  281                     << 
" or with name " << effNameCopy
 
  282                     << 
" in " << 
m_name << 
"... it doesn't exist, neither in the cached map nor in the THistSvc!" 
  283                     << 
" Will return an NULL pointer... you have to handle it correctly!" << 
endmsg;
 
  288           m_effMap.insert( 
m_effMap.end(), std::pair< const hash_t, TEfficiency* >( effHash, effPointer ) );
 
  293       m_effMap.insert( 
m_effMap.end(), std::pair< const hash_t, TEfficiency* >( effHash, effPointer ) );
 
 
 
 
◆ endInputFile()
perform the action for the end of an input file 
Ideally you don't use this, but instead rely on meta-data tools instead. However, there are enough people asking for it that I decided to implement it anyways.
\warn To use this you have to call requestEndInputFile to use this.
\warn If a file is split across multiple jobs this will be called more than once. This only happens for specific batch drivers and/or if it is explicitly configured by the user. With PROOF it could even happen multiple times within the same job, and while PROOF is no longer supported that behavior may come back if support for a similar framework is added in the future. As such, this method should not be used for accounting that relies to be called exactly once per file, take a look at fileExecute if you want something that is guaranteed to be executed exactly once per input file.
\warn The execution order of endInputFile and fileExecute is currently unspecified. 
Definition at line 358 of file AnaAlgorithm.cxx.
  361     return StatusCode::SUCCESS;
 
 
 
 
◆ evtStore() [1/2]
◆ evtStore() [2/2]
◆ execute()
Function executing the algorithm. 
Definition at line 41 of file UnitTestAlg4.cxx.
   48       return ::StatusCode::SUCCESS;
 
 
 
 
◆ extraDeps_update_handler()
Add StoreName to extra input/output deps as needed. 
use the logic of the VarHandleKey to parse the DataObjID keys supplied via the ExtraInputs and ExtraOuputs Properties to add the StoreName if it's not explicitly given 
 
 
◆ extraOutputDeps()
  
  | 
        
          | const DataObjIDColl & AthAlgorithm::extraOutputDeps | ( |  | ) | const |  | overridevirtualinherited | 
 
Return the list of extra output dependencies. 
This list is extended to include symlinks implied by inheritance relations. 
Definition at line 50 of file AthAlgorithm.cxx.
   57   return Algorithm::extraOutputDeps();
 
 
 
 
◆ fileExecute()
perform the action exactly once for each file in the dataset 
Ideally you don't use this, but instead rely on meta-data tools instead. However, there are enough people asking for it that I decided to implement it anyways.
\warn To use this you have to call requestFileExecute to use this.
\warn The user should not expect this to be called at any particular point in execution. If a file is split between multiple jobs this will be called in only one of these jobs, and not the others. It usually gets called before the first event in a file, but that is not guaranteed and relying on this is a bug.
\warn The execution order of beginInputFile and fileExecute is currently unspecified.
\warn fileExecute does not work with sub-file splitting in Athena, i.e. processing half the events of a file in one job the other half in another job. this should not normally happen, unless you do crazy things like run AthenaMP or explicitly select sub-file splitting in panda. in that case you are on your own. 
Definition at line 342 of file AnaAlgorithm.cxx.
  345     return StatusCode::SUCCESS;
 
 
 
 
◆ finalize()
Function finalising the algorithm. 
Definition at line 51 of file UnitTestAlg4.cxx.
   56          return ::StatusCode::FAILURE;
 
   60       return ::StatusCode::SUCCESS;
 
 
 
 
◆ graph()
  
  | 
        
          | TGraph * AthHistogramming::graph | ( | const std::string & | graphName, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | protectedinherited | 
 
Simplify the retrieval of registered TGraphs. 
Definition at line 492 of file AthHistogramming.cxx.
  495   const hash_t graphHash = this->
hash(graphName);
 
  498   GraphMap_t::const_iterator 
it = 
m_graphMap.find( graphHash );
 
  503       std::string graphNameCopy = graphName;
 
  504       std::string tDirCopy      = tDir;
 
  505       std::string streamCopy    = 
stream;
 
  508       std::string bookingString(
"");
 
  511       TGraph* graphPointer(NULL);
 
  512       if ( !((
histSvc()->getGraph(bookingString, graphPointer)).isSuccess()) )
 
  515           std::string bookingString(
"");
 
  516           this->
buildBookingString( bookingString, graphNameCopy, tDirCopy, streamCopy, 
false );
 
  518           if ( !((
histSvc()->getGraph(bookingString, graphPointer)).isSuccess()) )
 
  520               m_msg << MSG::WARNING
 
  521                     << 
"Problem retrieving the TGraph with name (including pre- and post-fixes) " 
  523                     << 
" or with name " << graphNameCopy
 
  524                     << 
" in " << 
m_name << 
"... it doesn't exist, neither in the cached map nor in the THistSvc!" 
  525                     << 
" Will return an NULL pointer... you have to handle it correctly!" << 
endmsg;
 
  530           m_graphMap.insert( 
m_graphMap.end(), std::pair< const hash_t, TGraph* >( graphHash, graphPointer ) );
 
  535       m_graphMap.insert( 
m_graphMap.end(), std::pair< const hash_t, TGraph* >( graphHash, graphPointer ) );
 
 
 
 
◆ handle()
  
  | 
        
          | void EL::AnaAlgorithm::handle | ( | const Incident & | inc | ) |  |  | inherited | 
 
receive the given incident 
- Guarantee
- basic 
- Failures
- incident handling errors 
Definition at line 520 of file AnaAlgorithm.cxx.
  523     if (inc.type() == IncidentType::BeginInputFile)
 
  529     } 
else if (inc.type() == IncidentType::EndInputFile)
 
 
 
 
◆ hash()
◆ hist()
  
  | 
        
          | TH1 * AthHistogramming::hist | ( | const std::string & | histName, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | protectedinherited | 
 
Simplify the retrieval of registered histograms of any type. 
Definition at line 198 of file AthHistogramming.cxx.
  204   HistMap_t::const_iterator 
it = 
m_histMap.find( histHash );
 
  209       std::string histNameCopy = 
histName;
 
  210       std::string tDirCopy     = tDir;
 
  211       std::string streamCopy   = 
stream;
 
  214       std::string bookingString(
"");
 
  217       TH1* histPointer(NULL);
 
  218       if ( !((
histSvc()->
getHist(bookingString, histPointer)).isSuccess()) )
 
  221           std::string bookingString(
"");
 
  224           if ( !((
histSvc()->
getHist(bookingString, histPointer)).isSuccess()) )
 
  226               m_msg << MSG::WARNING
 
  227                     << 
"Problem retrieving the histogram with name (including pre- and post-fixes) " 
  229                     << 
" or with name " << histNameCopy
 
  230                     << 
" in " << 
m_name << 
"... it doesn't exist, neither in the cached map nor in the THistSvc!" 
  231                     << 
" Will return an NULL pointer... you have to handle it correctly!" << 
endmsg;
 
  236           m_histMap.insert( 
m_histMap.end(), std::pair< const hash_t, TH1* >( histHash, histPointer ) );
 
  241       m_histMap.insert( 
m_histMap.end(), std::pair< const hash_t, TH1* >( histHash, histPointer ) );
 
 
 
 
◆ hist2d()
  
  | 
        
          | TH2 * AthHistogramming::hist2d | ( | const std::string & | histName, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
Simplify the retrieval of registered 2-d histograms. 
Definition at line 369 of file AthHistogramming.h.
  376             << 
"Cannot get a 2-d histogram with name " << 
histName 
  377             << 
"... will probably seg-fault!" << 
endmsg;
 
  381   return dynamic_cast<TH2*
>( th1Pointer );
 
 
 
 
◆ hist3d()
  
  | 
        
          | TH3 * AthHistogramming::hist3d | ( | const std::string & | histName, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
Simplify the retrieval of registered 3-d histograms. 
Definition at line 386 of file AthHistogramming.h.
  393             << 
"Cannot get a 3-d histogram with name " << 
histName 
  394             << 
"... will probably seg-fault!" << 
endmsg;
 
  398   return dynamic_cast<TH3*
>( th1Pointer );
 
 
 
 
◆ histSvc()
The standard THistSvc (for writing histograms and TTrees and more to a root file) Returns (kind of) a pointer to the THistSvc. 
Definition at line 113 of file AthHistogramAlgorithm.h.
 
 
◆ initialize()
Function initialising the algorithm. 
Definition at line 19 of file UnitTestAlg4.cxx.
   33          ATH_MSG_FATAL( 
"Event information should not be available yet!" );
 
   34          return ::StatusCode::FAILURE;
 
   38       return ::StatusCode::SUCCESS;
 
 
 
 
◆ inputHandles()
Return this algorithm's input handles. 
We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA. 
 
 
◆ inputMetaStore() [1/2]
Definition at line 81 of file AnaAlgorithm.cxx.
   83 #ifdef XAOD_STANDALONE 
   87 #endif // XAOD_STANDALONE 
 
 
 
◆ inputMetaStore() [2/2]
Accessor for the input metadata store 
Definition at line 72 of file AnaAlgorithm.cxx.
   74 #ifdef XAOD_STANDALONE 
   78 #endif // XAOD_STANDALONE 
 
 
 
◆ msg() [1/2]
◆ msg() [2/2]
◆ msgLvl()
◆ myReplace()
  
  | 
        
          | void AthHistogramming::myReplace | ( | std::string & | str, |  
          |  |  | const std::string & | oldStr, |  
          |  |  | const std::string & | newStr |  
          |  | ) |  |  |  | privateinherited | 
 
Helper method to replace sub-string. 
Definition at line 590 of file AthHistogramming.cxx.
  595   while((
pos = 
str.find(oldStr, 
pos)) != std::string::npos)
 
  597       str.replace(
pos, oldStr.length(), newStr);
 
  598       pos += newStr.length();
 
 
 
 
◆ outputHandles()
Return this algorithm's output handles. 
We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA. 
 
 
◆ outputMetaStore() [1/2]
Definition at line 101 of file AnaAlgorithm.cxx.
  103 #ifdef XAOD_STANDALONE 
  107 #endif // XAOD_STANDALONE 
 
 
 
◆ outputMetaStore() [2/2]
Accessor for the output metadata store 
Definition at line 92 of file AnaAlgorithm.cxx.
   94 #ifdef XAOD_STANDALONE 
   98 #endif // XAOD_STANDALONE 
 
 
 
◆ print()
  
  | 
        
          | void EL::AnaAlgorithm::print | ( |  | ) | const |  | protectedvirtualinherited | 
 
print the state of the algorithm 
This is mostly to allow algorithms to add a little debugging information if they feel like it. 
Definition at line 336 of file AnaAlgorithm.cxx.
 
 
◆ readFileMetaData()
Function reading some in-file metadata. 
Definition at line 75 of file UnitTestAlg4.cxx.
   92       return ::StatusCode::SUCCESS;
 
 
 
 
◆ renounce()
◆ renounceArray()
◆ requestBeginInputFile()
  
  | 
        
          | StatusCode EL::AnaAlgorithm::requestBeginInputFile | ( |  | ) |  |  | inherited | 
 
register this algorithm to have an implementation of beginInputFile 
- Guarantee
- strong 
- Failures
- beginInputFile not supported 
Definition at line 270 of file AnaAlgorithm.cxx.
  275 #ifndef XAOD_STANDALONE 
  282     incSvc->removeListener( 
this, IncidentType::BeginInputFile );
 
  283     incSvc->addListener( 
this, IncidentType::BeginInputFile, 0, 
true );
 
  286     return StatusCode::SUCCESS;
 
 
 
 
◆ requestEndInputFile()
  
  | 
        
          | StatusCode EL::AnaAlgorithm::requestEndInputFile | ( |  | ) |  |  | inherited | 
 
register this algorithm to have an implementation of endInputFile 
- Guarantee
- strong 
- Failures
- endInputFile not supported 
Definition at line 291 of file AnaAlgorithm.cxx.
  296 #ifndef XAOD_STANDALONE 
  303     incSvc->removeListener( 
this, IncidentType::EndInputFile );
 
  304     incSvc->addListener( 
this, IncidentType::EndInputFile, 0, 
true );
 
  307     return StatusCode::SUCCESS;
 
 
 
 
◆ requestFileExecute()
  
  | 
        
          | StatusCode EL::AnaAlgorithm::requestFileExecute | ( |  | ) |  |  | inherited | 
 
register this algorithm to have an implementation of fileexecute 
- Guarantee
- strong 
- Failures
- fileExecute not supported 
Definition at line 249 of file AnaAlgorithm.cxx.
  254 #ifndef XAOD_STANDALONE 
  261     incSvc->removeListener( 
this, IncidentType::BeginInputFile );
 
  262     incSvc->addListener( 
this, IncidentType::BeginInputFile, 0, 
true );
 
  265     return StatusCode::SUCCESS;
 
 
 
 
◆ sysInitialize()
  
  | 
        
          | StatusCode AthHistogramAlgorithm::sysInitialize | ( |  | ) |  |  | virtualinherited | 
 
Initialization method invoked by the framework. 
This method is responsible for any bookkeeping of initialization required by the framework itself. It will in turn invoke the initialize() method of the derived algorithm, and of any sub-algorithms which it creates. 
Reimplemented from AthAlgorithm.
Reimplemented in AthAnalysisAlgorithm.
Definition at line 75 of file AthHistogramAlgorithm.cxx.
   80   if ( Gaudi::StateMachine::INITIALIZED <= FSMState() ) 
return StatusCode::SUCCESS;
 
   83   bindPropertiesTo( serviceLocator()->getOptsSvc() );
 
   87   if ( !isEnabled( ) ) 
return StatusCode::SUCCESS;
 
 
 
 
◆ sysStart()
Handle START transition. 
We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container. 
 
 
◆ tree()
  
  | 
        
          | TTree * AthHistogramming::tree | ( | const std::string & | treeName, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | protectedinherited | 
 
Simplify the retrieval of registered TTrees. 
Definition at line 378 of file AthHistogramming.cxx.
  384   TreeMap_t::const_iterator 
it = 
m_treeMap.find( treeHash );
 
  389       std::string treeNameCopy = 
treeName;
 
  390       std::string tDirCopy     = tDir;
 
  391       std::string streamCopy   = 
stream;
 
  394       std::string bookingString(
"");
 
  397       TTree* treePointer(NULL);
 
  398       if ( !((
histSvc()->
getTree(bookingString, treePointer)).isSuccess()) )
 
  400           m_msg << MSG::WARNING
 
  401                 << 
"Problem retrieving the TTree with name " << treeNameCopy
 
  402                 << 
" in " << 
m_name << 
"... it doesn't exist, neither in the cached map nor in the THistSvc!" 
  403                 << 
" Will return an NULL pointer... you have to handle it correctly!" << 
endmsg;
 
  408       m_treeMap.insert( 
m_treeMap.end(), std::pair< const hash_t, TTree* >( treeHash, treePointer ) );
 
 
 
 
◆ updateVHKA()
◆ m_callCount
  
  | 
        
          | int EL::UnitTestAlg4::m_callCount = 0 |  | private | 
 
 
◆ m_detStore
◆ m_effMap
◆ m_evtStore
◆ m_extendedExtraObjects
  
  | 
        
          | DataObjIDColl AthAlgorithm::m_extendedExtraObjects |  | privateinherited | 
 
 
◆ m_graphMap
◆ m_hasBeginInputFile
  
  | 
        
          | bool EL::AnaAlgorithm::m_hasBeginInputFile {false} |  | privateinherited | 
 
 
◆ m_hasEndInputFile
  
  | 
        
          | bool EL::AnaAlgorithm::m_hasEndInputFile {false} |  | privateinherited | 
 
 
◆ m_hasFileExecute
  
  | 
        
          | bool EL::AnaAlgorithm::m_hasFileExecute {false} |  | privateinherited | 
 
 
◆ m_histMap
◆ m_histNamePostfix
  
  | 
        
          | std::string AthHistogramAlgorithm::m_histNamePostfix |  | privateinherited | 
 
 
◆ m_histNamePrefix
  
  | 
        
          | std::string AthHistogramAlgorithm::m_histNamePrefix |  | privateinherited | 
 
 
◆ m_histSvc
◆ m_histTitlePostfix
  
  | 
        
          | std::string AthHistogramAlgorithm::m_histTitlePostfix |  | privateinherited | 
 
 
◆ m_histTitlePrefix
  
  | 
        
          | std::string AthHistogramAlgorithm::m_histTitlePrefix |  | privateinherited | 
 
 
◆ m_inputMetaStore
Object accessing the input metadata store. 
Definition at line 551 of file AnaAlgorithm.h.
 
 
◆ m_msg
  
  | 
        
          | MsgStream AthHistogramming::m_msg |  | privateinherited | 
 
 
◆ m_name
  
  | 
        
          | std::string AthHistogramming::m_name |  | privateinherited | 
 
 
◆ m_outputMetaStore
Object accessing the output metadata store. 
Definition at line 555 of file AnaAlgorithm.h.
 
 
◆ m_prefix
  
  | 
        
          | std::string AthHistogramAlgorithm::m_prefix |  | privateinherited | 
 
 
◆ m_rootDir
  
  | 
        
          | std::string AthHistogramAlgorithm::m_rootDir |  | privateinherited | 
 
 
◆ m_streamName
  
  | 
        
          | std::string AthHistogramming::m_streamName |  | privateinherited | 
 
 
◆ m_treeMap
◆ m_varHandleArraysDeclared
◆ m_vhka
The documentation for this class was generated from the following files:
 
std::string m_rootDir
Name of the ROOT directory.
def retrieve(aClass, aKey=None)
const ServiceHandle< ITHistSvc > & histSvc() const
The standard THistSvc (for writing histograms and TTrees and more to a root file) Returns (kind of) a...
const ServiceHandle< ITHistSvc > & histSvc() const
The standard THistSvc (for writing histograms and TTrees and more to a root file) Returns (kind of) a...
bool m_hasBeginInputFile
the value of hasBeginInputFile
virtual ::StatusCode endInputFile()
perform the action for the end of an input file
void myReplace(std::string &str, const std::string &oldStr, const std::string &newStr)
Helper method to replace sub-string.
MsgStream m_msg
Cached Message Stream.
HistMap_t m_histMap
The map of histogram names to their pointers.
ServiceHandle< ITHistSvc > m_histSvc
Default constructor: AthHistogramAlgorithm();.
StatusCode book(const TH1 &hist, const std::string &tDir="", const std::string &stream="")
Simplify the booking and registering (into THistSvc) of histograms.
MetaStore_t m_inputMetaStore
Object accessing the input metadata store.
MetaStore_t m_outputMetaStore
Object accessing the output metadata store.
ConstMetaStorePtr_t inputMetaStore() const
std::string m_prefix
Name of the ROOT output stream (file)
virtual ::StatusCode beginInputFile()
perform the action for the beginning of an input file
StoreGateSvc_t m_evtStore
Pointer to StoreGate (event store by default)
std::vector< SG::VarHandleKeyArray * > m_vhka
std::string m_histNamePrefix
The prefix for the histogram THx name.
std::string m_histTitlePrefix
The prefix for the histogram THx title.
std::string m_histNamePostfix
The postfix for the histogram THx name.
AnaAlgorithm(const std::string &name, ISvcLocator *pSvcLocator)
constructor with parameters
virtual ::StatusCode fileExecute()
perform the action exactly once for each file in the dataset
std::string getTree(const std::string &file_name)
virtual void setOwner(IDataHandleHolder *o)=0
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
ServiceHandle< StoreGateSvc > & evtStore()
The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
virtual StatusCode sysInitialize() override
Override sysInitialize.
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
::StatusCode requestBeginInputFile()
register this algorithm to have an implementation of beginInputFile
bool m_hasFileExecute
the value of hasFileExecute
GraphMap_t m_graphMap
The map of TGraph names to their pointers.
StoreGateSvc_t m_detStore
Pointer to StoreGate (detector store by default)
std::string m_streamName
Name of the ROOT output stream (file)
StatusCode configAthHistogramming(const ServiceHandle< ITHistSvc > &histSvc, const std::string &prefix, const std::string &rootDir, const std::string &histNamePrefix, const std::string &histNamePostfix, const std::string &histTitlePrefix, const std::string &histTitlePostfix)
To be called by the derived classes to fill the internal configuration.
uint32_t hash_t
typedef for the internal hash
uint64_t crc64(const CRCTable &table, const char *data, size_t data_len)
Find the CRC-64 of a string,.
std::string m_histTitlePostfix
The postfix for the histogram THx title.
virtual void renounce()=0
std::conditional< std::is_base_of< SG::VarHandleKeyArray, T >::value, VarHandleKeyArrayType, type2 >::type type
hash_t hash(const std::string &histName) const
Method to calculate a 32-bit hash from a string.
def getHist(name, makehist)
Class describing the basic event information.
std::uint64_t hash64(const void *data, std::size_t size)
Passthrough to XXH3_64bits.
DataObjIDColl m_extendedExtraObjects
EffMap_t m_effMap
The map of histogram names to their pointers.
std::string m_histTitlePrefix
The prefix for the histogram THx title.
#define ATH_MSG_WARNING(x)
std::string m_histNamePostfix
The postfix for the histogram THx name.
TreeMap_t m_treeMap
The map of TTree names to their pointers.
std::string m_histNamePrefix
The prefix for the histogram THx name.
bool m_hasEndInputFile
the value of hasEndInputFile
SG::VarHandleKey & vhKey()
Return a non-const reference to the HandleKey.
StatusCode readFileMetaData()
Function reading some in-file metadata.
std::string m_histTitlePostfix
The postfix for the histogram THx title.
TH1 * hist(const std::string &histName, const std::string &tDir="", const std::string &stream="")
Simplify the retrieval of registered histograms of any type.
ServiceHandle< ITHistSvc > m_histSvc
Pointer to the THistSvc (event store by default)
int m_callCount
Internal status flag.
std::string m_name
Instance name.
std::string m_rootDir
Name of the ROOT directory.
void buildBookingString(std::string &bookingString, std::string &histName, std::string &tDir, std::string &stream, bool usePrefixPostfix=false)
Method to build individual booking string.
TH1 * bookGetPointer(const TH1 &hist, const std::string &tDir="", const std::string &stream="")
Simplify the booking and registering (into THistSvc) of histograms.