|  | ATLAS Offline Software
    | 
 
 
 
#include <CaloHitAnalysis.h>
|  | 
|  | ~CaloHitAnalysis ()=default | 
|  | 
| virtual StatusCode | initialize () override | 
|  | 
| virtual StatusCode | execute () override | 
|  | 
|  | AthHistogramAlgorithm (const std::string &name, ISvcLocator *pSvcLocator) | 
|  | Constructor with parameters:  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 | 
|  | 
|  | 
| 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... 
 | 
|  | 
|  | 
| 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... 
 | 
|  | 
|  | 
| TH1 * | m_h_cell_eta {} | 
|  | Simple variables by Ketevi.  More... 
 | 
|  | 
| TH1 * | m_h_cell_phi {} | 
|  | 
| TH1 * | m_h_cell_e {} | 
|  | 
| TH1 * | m_h_cell_radius {} | 
|  | 
| TH1 * | m_h_cell_layer {} | 
|  | 
| TH1 * | m_h_cell_eta_Eweight {} | 
|  | 
| TH1 * | m_h_cell_phi_Eweight {} | 
|  | 
| TH1 * | m_h_cell_radius_Eweight {} | 
|  | 
| TH1 * | m_h_cell_layer_Eweight {} | 
|  | 
| TH2 * | m_h_xy {} | 
|  | 
| TH2 * | m_h_zr {} | 
|  | 
| TH2 * | m_h_etaphi {} | 
|  | 
| TH2 * | m_h_time_e {} | 
|  | 
| TH2 * | m_h_eta_e {} | 
|  | 
| TH2 * | m_h_phi_e {} | 
|  | 
| TH2 * | m_h_r_e {} | 
|  | 
| TH1 * | m_h_calib_eta {} | 
|  | 
| TH1 * | m_h_calib_phi {} | 
|  | 
| TH2 * | m_h_calib_rz {} | 
|  | 
| TH2 * | m_h_calib_etaphi {} | 
|  | 
| TH1 * | m_h_calib_eEM {} | 
|  | 
| TH1 * | m_h_calib_eNonEM {} | 
|  | 
| TH1 * | m_h_calib_eInv {} | 
|  | 
| TH1 * | m_h_calib_eEsc {} | 
|  | 
| TH1 * | m_h_calib_eTot {} | 
|  | 
| TH1 * | m_h_calib_eTotpartID {} | 
|  | 
| const TileID * | m_tileID {} | 
|  | 
| const TileDetDescrManager * | m_tileMgr {} | 
|  | 
| std::vector< float > * | m_cell_eta {} | 
|  | 
| std::vector< float > * | m_cell_phi {} | 
|  | 
| std::vector< float > * | m_cell_x {} | 
|  | 
| std::vector< float > * | m_cell_y {} | 
|  | 
| std::vector< float > * | m_cell_z {} | 
|  | 
| std::vector< float > * | m_cell_e {} | 
|  | 
| std::vector< float > * | m_cell_radius {} | 
|  | 
| std::vector< int > * | m_cell_layer {} | 
|  | 
| std::vector< float > * | m_time {} | 
|  | 
| std::vector< float > * | m_calib_eta {} | 
|  | 
| std::vector< float > * | m_calib_phi {} | 
|  | 
| std::vector< float > * | m_calib_radius {} | 
|  | 
| std::vector< float > * | m_calib_z {} | 
|  | 
| std::vector< float > * | m_calib_eEM {} | 
|  | 
| std::vector< float > * | m_calib_eNonEM {} | 
|  | 
| std::vector< float > * | m_calib_eInv {} | 
|  | 
| std::vector< float > * | m_calib_eEsc {} | 
|  | 
| std::vector< float > * | m_calib_eTot {} | 
|  | 
| std::vector< float > * | m_calib_partID {} | 
|  | 
| BooleanProperty | m_expert {this, "ExpertMode", false} | 
|  | 
| BooleanProperty | m_calib {this, "UseCalibHits", false} | 
|  | 
| BooleanProperty | m_useLAr {this, "UseLAr", true} | 
|  | 
| BooleanProperty | m_useTile {this, "UseTile", true} | 
|  | 
| TTree * | m_tree {} | 
|  | 
| StringProperty | m_ntupleFileName {this, "NtupleFileName", "/CaloHitAnalysis/"} | 
|  | 
| StringProperty | m_path {this, "HistPath", "/CaloHitAnalysis/"} | 
|  | 
| SG::ReadCondHandleKey< CaloDetDescrManager > | m_caloMgrKey | 
|  | 
| SG::ReadHandleKey< TileHitVector > | m_tileKey {this, "TileKey", "TileHitVec" } | 
|  | 
| SG::ReadHandleKeyArray< LArHitContainer > | m_caloKeys | 
|  | 
| SG::ReadHandleKeyArray< CaloCalibrationHitContainer > | m_caloCalibKeys | 
|  | 
| ServiceHandle< ITHistSvc > | m_histSvc | 
|  | Default constructor: AthHistogramAlgorithm();.  More... 
 | 
|  | 
| std::string | m_prefix | 
|  | Name of the ROOT output stream (file)  More... 
 | 
|  | 
| std::string | m_rootDir | 
|  | Name of the ROOT directory.  More... 
 | 
|  | 
| std::string | m_histNamePrefix | 
|  | The prefix for the histogram THx name.  More... 
 | 
|  | 
| std::string | m_histNamePostfix | 
|  | The postfix for the histogram THx name.  More... 
 | 
|  | 
| std::string | m_histTitlePrefix | 
|  | The prefix for the histogram THx title.  More... 
 | 
|  | 
| std::string | m_histTitlePostfix | 
|  | The postfix for the histogram THx title.  More... 
 | 
|  | 
| DataObjIDColl | m_extendedExtraObjects | 
|  | 
| StoreGateSvc_t | m_evtStore | 
|  | Pointer to StoreGate (event store by default)  More... 
 | 
|  | 
| StoreGateSvc_t | m_detStore | 
|  | Pointer to StoreGate (detector store by default)  More... 
 | 
|  | 
| std::vector< SG::VarHandleKeyArray * > | m_vhka | 
|  | 
| bool | m_varHandleArraysDeclared | 
|  | 
| HistMap_t | m_histMap | 
|  | The map of histogram names to their pointers.  More... 
 | 
|  | 
| EffMap_t | m_effMap | 
|  | The map of histogram names to their pointers.  More... 
 | 
|  | 
| TreeMap_t | m_treeMap | 
|  | The map of TTree names to their pointers.  More... 
 | 
|  | 
| GraphMap_t | m_graphMap | 
|  | The map of TGraph names to their pointers.  More... 
 | 
|  | 
| std::string | m_streamName | 
|  | Name of the ROOT output stream (file)  More... 
 | 
|  | 
| std::string | m_name | 
|  | Instance name.  More... 
 | 
|  | 
| MsgStream | m_msg | 
|  | Cached Message Stream.  More... 
 | 
|  | 
Definition at line 28 of file CaloHitAnalysis.h.
 
◆ EffMap_t
◆ GraphMap_t
◆ hash_t
◆ HistMap_t
◆ StoreGateSvc_t
◆ TreeMap_t
◆ ~CaloHitAnalysis()
  
  | 
        
          | CaloHitAnalysis::~CaloHitAnalysis | ( |  | ) |  |  | default | 
 
 
◆ AthHistogramAlgorithm()
      
        
          | AthHistogramAlgorithm::AthHistogramAlgorithm | 
      
 
Constructor with parameters: 
Definition at line 40 of file AthHistogramAlgorithm.cxx.
   43                   "Handle to a THistSvc instance: it will be used to write " 
   44                   "ROOT objects to ROOT files" );
 
   47   declareProperty(
"RootStreamName",    
m_prefix  = 
"/ANALYSIS", 
"Name of the output ROOT stream (file) that the THistSvc uses");
 
   49                   "Name of the ROOT directory inside the ROOT file where the histograms will go");
 
 
 
 
◆ 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]
  
  | 
        
          | StatusCode AthHistogramming::book | ( | const TH1 & | hist, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
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]
  
  | 
        
          | StatusCode AthHistogramming::book | ( | const TTree & | treeRef, |  
          |  |  | const std::string & | tDir = "", |  
          |  |  | const std::string & | stream = "" |  
          |  | ) |  |  |  | inlineprotectedinherited | 
 
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 ) );
 
 
 
 
◆ evtStore() [1/2]
◆ evtStore() [2/2]
◆ execute()
  
  | 
        
          | StatusCode CaloHitAnalysis::execute | ( |  | ) |  |  | overridevirtual | 
 
Definition at line 186 of file CaloHitAnalysis.cxx.
  209   const EventContext& ctx{Gaudi::Hive::currentContext()};
 
  214       for (
const auto& i_hit : *hitVec) {
 
  220           double tot_time = 0.;
 
  221           for (
int t=0; 
t<(i_hit).
size(); ++
t) tot_e += (i_hit).energy(
t);
 
  222           for (
int t=0; 
t<(i_hit).
size(); ++
t) tot_time += (i_hit).time(
t);
 
  232           m_h_xy->Fill(ddElement->
x(), ddElement->
y());
 
  233           m_h_zr->Fill(ddElement->
r(), ddElement->
r());
 
  240             m_h_r_e->Fill(ddElement->
r(), tot_e);
 
  250           m_time->push_back(tot_time);
 
  263         for (
auto hi : *
iter ) {
 
  265           double energy = hi->energy();
 
  266           double time = hi->time();
 
  267           double eta = hitElement->
eta();
 
  268           double phi = hitElement->
phi();
 
  269           double radius = hitElement->
r();
 
  271           float x = hitElement->
x();
 
  272           float y = hitElement->
y();
 
  273           double z = hitElement->
z();
 
  312           if (!geoHit) 
continue;
 
  314           double eta = Element->
eta();
 
  315           double phi = Element->
phi();
 
  317           double z = Element->
z();
 
  318           double emEnergy = geoHit.energyEM();
 
  319           double nonEmEnergy = geoHit.energyNonEM();
 
  320           double invEnergy = geoHit.energyInvisible();
 
  321           double escEnergy = geoHit.energyEscaped();
 
  322           double totEnergy = geoHit.energyTotal();
 
  353   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();
 
 
 
 
◆ 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 ) );
 
 
 
 
◆ 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()
  
  | 
        
          | StatusCode CaloHitAnalysis::initialize | ( |  | ) |  |  | overridevirtual | 
 
now add branches and leaves to the tree
Definition at line 32 of file CaloHitAnalysis.cxx.
   45   m_h_cell_e = 
new TH1D(
"h_Calo_cell_e", 
"cell_e", 100,0.,500.);
 
   49   m_h_cell_eta = 
new TH1D(
"h_Calo_cell_eta", 
"cell_eta", 50,-5.,5.);
 
   53   m_h_cell_phi = 
new TH1D(
"h_Calo_cell_phi", 
"cell_phi", 50,-3.1416,3.1416);
 
   57   m_h_cell_radius = 
new TH1D(
"h_Calo_cell_radius", 
"cell_radius", 100, 0., 6000.);
 
   61   m_h_cell_layer = 
new TH1D(
"h_Calo_cell_layer", 
"cell_layer", 24, -0.5, 23.5);
 
   69   m_h_cell_phi_Eweight = 
new TH1D(
"h_Calo_cell_phi_Eweight", 
"cell_phi_Eweight", 50,-3.1416,3.1416);
 
   81   m_h_xy = 
new TH2F(
"h_Calo_xy", 
"xy", 100,-4000,4000,100, -4000, 4000);
 
   85   m_h_zr = 
new TH2D(
"h_Calo_zr", 
"zr", 100,-7000.,7000.,100, 0., 6000.);
 
   89   m_h_etaphi = 
new TH2D(
"h_Calo_etaphi", 
"eta_phi", 50,-5.,5.,50, -3.1416, 3.1416);
 
   94   m_h_time_e = 
new TH2D(
"h_Calo_time_e", 
"energy vs time", 100, 0,50, 100,0,500);
 
   97   m_h_eta_e = 
new TH2D(
"h_Calo_eta_e", 
"energy vs eta", 50, -5,5, 100,0,500);
 
  100   m_h_phi_e = 
new TH2D(
"h_Calo_phi_e", 
"energy vs phi", 50, -3.1416,3.1416, 100,0,500);
 
  103   m_h_r_e = 
new TH2D(
"h_Calo_r_e", 
"energy vs radius", 100, 0,6000, 100,0,500);
 
  114   m_h_calib_eta = 
new TH1D(
"h_calib_eta", 
"calib. hits eta", 50,-5,5);
 
  117   m_h_calib_phi = 
new TH1D(
"h_calib_phi", 
"calib. hits phi", 50,-3.1416,3.1416);
 
  120   m_h_calib_rz = 
new TH2D(
"h_calib_rz", 
"calib. hits r vs z", 100,-7000,7000,1000, 0,6000);
 
  123   m_h_calib_etaphi = 
new TH2D(
"h_calib_etaphi", 
"calib. hits eta vs phi",50,-5.,5., 50,-3.1416,3.1416);
 
  126   m_h_calib_eEM = 
new TH1D(
"h_calib_eEM", 
"calib. hits EM energy", 100,0,100);
 
  129   m_h_calib_eNonEM = 
new TH1D(
"h_calib_nonEM", 
"calib. hits non EM energy", 100,0,100);
 
  132   m_h_calib_eInv = 
new TH1D(
"h_calib_eInv", 
"calib. hits invisible energy", 100,0,100);
 
  135   m_h_calib_eEsc = 
new TH1D(
"h_calib_eEsc", 
"calib. hits escaped energy", 100,0,100);
 
  138   m_h_calib_eTot = 
new TH1D(
"h_calib_eTot", 
"calib. hits energy", 100,0,100);
 
  141   m_h_calib_eTotpartID = 
new TH1D(
"h_calib_eTotpartID", 
"calib. hits partID weighted with energy",600,0,300000);
 
  158   m_tree = 
new TTree(
"Calo", 
"Calo");
 
  182   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. 
 
 
◆ 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. 
 
 
◆ renounce()
◆ renounceArray()
◆ 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_calib
  
  | 
        
          | BooleanProperty CaloHitAnalysis::m_calib {this, "UseCalibHits", false} |  | private | 
 
 
◆ m_calib_eEM
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_calib_eEM {} |  | private | 
 
 
◆ m_calib_eEsc
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_calib_eEsc {} |  | private | 
 
 
◆ m_calib_eInv
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_calib_eInv {} |  | private | 
 
 
◆ m_calib_eNonEM
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_calib_eNonEM {} |  | private | 
 
 
◆ m_calib_eta
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_calib_eta {} |  | private | 
 
 
◆ m_calib_eTot
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_calib_eTot {} |  | private | 
 
 
◆ m_calib_partID
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_calib_partID {} |  | private | 
 
 
◆ m_calib_phi
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_calib_phi {} |  | private | 
 
 
◆ m_calib_radius
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_calib_radius {} |  | private | 
 
 
◆ m_calib_z
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_calib_z {} |  | private | 
 
 
◆ m_caloCalibKeys
Initial value:{this, "CaloCalibKeys",
                                                                      {"LArCalibrationHitActive", "LArCalibrationHitInactive","LArCalibrationHitDeadMaterial"}}
Definition at line 109 of file CaloHitAnalysis.h.
 
 
◆ m_caloKeys
Initial value:{this, "CaloKeys",    
                                          {"LArHitEMB", "LArHitEMEC", "LArHitFCAL", "LArHitHEC"} }
Definition at line 105 of file CaloHitAnalysis.h.
 
 
◆ m_caloMgrKey
Initial value:{ this
    , "CaloDetDescrManager"
    , "CaloDetDescrManager"
    , "SG Key for CaloDetDescrManager in the Condition Store" }
Definition at line 100 of file CaloHitAnalysis.h.
 
 
◆ m_cell_e
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_cell_e {} |  | private | 
 
 
◆ m_cell_eta
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_cell_eta {} |  | private | 
 
 
◆ m_cell_layer
  
  | 
        
          | std::vector<int>* CaloHitAnalysis::m_cell_layer {} |  | private | 
 
 
◆ m_cell_phi
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_cell_phi {} |  | private | 
 
 
◆ m_cell_radius
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_cell_radius {} |  | private | 
 
 
◆ m_cell_x
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_cell_x {} |  | private | 
 
 
◆ m_cell_y
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_cell_y {} |  | private | 
 
 
◆ m_cell_z
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_cell_z {} |  | private | 
 
 
◆ m_detStore
◆ m_effMap
◆ m_evtStore
◆ m_expert
  
  | 
        
          | BooleanProperty CaloHitAnalysis::m_expert {this, "ExpertMode", false} |  | private | 
 
 
◆ m_extendedExtraObjects
  
  | 
        
          | DataObjIDColl AthAlgorithm::m_extendedExtraObjects |  | privateinherited | 
 
 
◆ m_graphMap
◆ m_h_calib_eEM
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_calib_eEM {} |  | private | 
 
 
◆ m_h_calib_eEsc
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_calib_eEsc {} |  | private | 
 
 
◆ m_h_calib_eInv
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_calib_eInv {} |  | private | 
 
 
◆ m_h_calib_eNonEM
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_calib_eNonEM {} |  | private | 
 
 
◆ m_h_calib_eta
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_calib_eta {} |  | private | 
 
 
◆ m_h_calib_etaphi
  
  | 
        
          | TH2* CaloHitAnalysis::m_h_calib_etaphi {} |  | private | 
 
 
◆ m_h_calib_eTot
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_calib_eTot {} |  | private | 
 
 
◆ m_h_calib_eTotpartID
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_calib_eTotpartID {} |  | private | 
 
 
◆ m_h_calib_phi
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_calib_phi {} |  | private | 
 
 
◆ m_h_calib_rz
  
  | 
        
          | TH2* CaloHitAnalysis::m_h_calib_rz {} |  | private | 
 
 
◆ m_h_cell_e
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_cell_e {} |  | private | 
 
 
◆ m_h_cell_eta
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_cell_eta {} |  | private | 
 
 
◆ m_h_cell_eta_Eweight
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_cell_eta_Eweight {} |  | private | 
 
 
◆ m_h_cell_layer
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_cell_layer {} |  | private | 
 
 
◆ m_h_cell_layer_Eweight
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_cell_layer_Eweight {} |  | private | 
 
 
◆ m_h_cell_phi
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_cell_phi {} |  | private | 
 
 
◆ m_h_cell_phi_Eweight
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_cell_phi_Eweight {} |  | private | 
 
 
◆ m_h_cell_radius
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_cell_radius {} |  | private | 
 
 
◆ m_h_cell_radius_Eweight
  
  | 
        
          | TH1* CaloHitAnalysis::m_h_cell_radius_Eweight {} |  | private | 
 
 
◆ m_h_eta_e
  
  | 
        
          | TH2* CaloHitAnalysis::m_h_eta_e {} |  | private | 
 
 
◆ m_h_etaphi
  
  | 
        
          | TH2* CaloHitAnalysis::m_h_etaphi {} |  | private | 
 
 
◆ m_h_phi_e
  
  | 
        
          | TH2* CaloHitAnalysis::m_h_phi_e {} |  | private | 
 
 
◆ m_h_r_e
  
  | 
        
          | TH2* CaloHitAnalysis::m_h_r_e {} |  | private | 
 
 
◆ m_h_time_e
  
  | 
        
          | TH2* CaloHitAnalysis::m_h_time_e {} |  | private | 
 
 
◆ m_h_xy
  
  | 
        
          | TH2* CaloHitAnalysis::m_h_xy {} |  | private | 
 
 
◆ m_h_zr
  
  | 
        
          | TH2* CaloHitAnalysis::m_h_zr {} |  | private | 
 
 
◆ 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_msg
  
  | 
        
          | MsgStream AthHistogramming::m_msg |  | privateinherited | 
 
 
◆ m_name
  
  | 
        
          | std::string AthHistogramming::m_name |  | privateinherited | 
 
 
◆ m_ntupleFileName
  
  | 
        
          | StringProperty CaloHitAnalysis::m_ntupleFileName {this, "NtupleFileName", "/CaloHitAnalysis/"} |  | private | 
 
 
◆ m_path
  
  | 
        
          | StringProperty CaloHitAnalysis::m_path {this, "HistPath", "/CaloHitAnalysis/"} |  | private | 
 
 
◆ 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_tileID
◆ m_tileKey
◆ m_tileMgr
◆ m_time
  
  | 
        
          | std::vector<float>* CaloHitAnalysis::m_time {} |  | private | 
 
 
◆ m_tree
  
  | 
        
          | TTree* CaloHitAnalysis::m_tree {} |  | private | 
 
 
◆ m_treeMap
◆ m_useLAr
  
  | 
        
          | BooleanProperty CaloHitAnalysis::m_useLAr {this, "UseLAr", true} |  | private | 
 
 
◆ m_useTile
  
  | 
        
          | BooleanProperty CaloHitAnalysis::m_useTile {this, "UseTile", true} |  | private | 
 
 
◆ 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)
JetConstituentVector::iterator iterator
const ServiceHandle< ITHistSvc > & histSvc() const
The standard THistSvc (for writing histograms and TTrees and more to a root file) Returns (kind of) a...
SG::ReadHandleKey< TileHitVector > m_tileKey
const ServiceHandle< ITHistSvc > & histSvc() const
The standard THistSvc (for writing histograms and TTrees and more to a root file) Returns (kind of) a...
bool is_tile_aux(const Identifier &id) const
TH1 * m_h_calib_eTotpartID
const Identifier & identify(const UncalibratedMeasurement *meas)
Returns the associated identifier from the muon measurement.
TH1 * m_h_cell_phi_Eweight
void myReplace(std::string &str, const std::string &oldStr, const std::string &newStr)
Helper method to replace sub-string.
std::vector< float > * m_calib_z
MsgStream m_msg
Cached Message Stream.
HistMap_t m_histMap
The map of histogram names to their pointers.
Adaptor for CaloCalibHits.
std::vector< float > * m_calib_partID
Scalar phi() const
phi method
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.
Scalar eta() const
pseudorapidity method
This class groups all DetDescr information related to a CaloCell. Provides a generic interface for al...
std::vector< float > * m_calib_phi
std::vector< float > * m_cell_y
std::vector< float > * m_cell_radius
std::vector< float > * m_time
std::string m_prefix
Name of the ROOT output stream (file)
std::vector< float > * m_calib_radius
StoreGateSvc_t m_evtStore
Pointer to StoreGate (event store by default)
std::vector< SG::VarHandleKeyArray * > m_vhka
TH1 * m_h_cell_radius_Eweight
std::string m_histNamePrefix
The prefix for the histogram THx name.
std::string m_histTitlePrefix
The prefix for the histogram THx title.
std::vector< float > * m_calib_eTot
def TH2F(name, title, nxbins, bins_par2, bins_par3, bins_par4, bins_par5=None, bins_par6=None, path='', **kwargs)
SG::ReadCondHandleKey< CaloDetDescrManager > m_caloMgrKey
std::string m_histNamePostfix
The postfix for the histogram THx name.
std::string getTree(const std::string &file_name)
std::vector< float > * m_calib_eEsc
const ServiceHandle< StoreGateSvc > & detStore() const
The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
virtual void setOwner(IDataHandleHolder *o)=0
const TileDetDescrManager * m_tileMgr
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
std::vector< float > * m_calib_eInv
virtual StatusCode sysInitialize() override
Override sysInitialize.
TH1 * m_h_cell_layer_Eweight
const T * get(const ReadCondHandleKey< T > &key, const EventContext &ctx)
Convenience function to retrieve an object given a ReadCondHandleKey.
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
std::vector< float > * m_calib_eNonEM
TH1 * m_h_cell_eta
Simple variables by Ketevi.
std::vector< int > * m_cell_layer
BooleanProperty m_useTile
#define CHECK(...)
Evaluate an expression and check for errors.
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)
SG::ReadHandleKeyArray< LArHitContainer > m_caloKeys
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.
StringProperty m_ntupleFileName
std::vector< float > * m_cell_z
CaloDetDescrElement * get_cell_element(unsigned int cell_hash) const
virtual void renounce()=0
std::conditional< std::is_base_of< SG::VarHandleKeyArray, T >::value, VarHandleKeyArrayType, type2 >::type type
std::vector< float > * m_calib_eEM
std::vector< float > * m_cell_e
hash_t hash(const std::string &histName) const
Method to calculate a 32-bit hash from a string.
StatusCode initialize(bool used=true)
def getHist(name, makehist)
std::uint64_t hash64(const void *data, std::size_t size)
Passthrough to XXH3_64bits.
AthHistogramming(const std::string &name)
Constructor with parameters:
DataObjIDColl m_extendedExtraObjects
EffMap_t m_effMap
The map of histogram names to their pointers.
TH1 * m_h_cell_eta_Eweight
This class provides the client interface for accessing the detector description information common to...
std::string m_histTitlePrefix
The prefix for the histogram THx title.
def time(flags, cells_name, *args, **kw)
CaloCell_ID::CaloSample getSampling() const
cell sampling
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.
SG::VarHandleKey & vhKey()
Return a non-const reference to the HandleKey.
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)
float eta() const
cell eta
AthAlgorithm()
Default constructor:
SG::ReadHandleKeyArray< CaloCalibrationHitContainer > m_caloCalibKeys
std::vector< float > * m_cell_eta
float phi() const
cell phi
std::vector< float > * m_calib_eta
std::string m_name
Instance name.
Identifier cell_id(const Identifier &any_id) const
std::vector< float > * m_cell_phi
std::string m_rootDir
Name of the ROOT directory.
std::vector< float > * m_cell_x
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.