The Gaudi Framework  v36r9p1 (5c15b2bb)
GaudiHistos< PBASE > Class Template Reference

#include <GaudiAlg/GaudiHistos.h>

Inheritance diagram for GaudiHistos< PBASE >:
Collaboration diagram for GaudiHistos< PBASE >:

Public Types

typedef GaudiAlg::HistoID HistoID
 the actual type for histogram identifier More...
 
typedef GaudiAlg::Histo1DMapID Histo1DMapID
 the actual type for (ID)->(1D histogram) mapping More...
 
typedef GaudiAlg::Histo1DMapTitle Histo1DMapTitle
 the actual type for title->(1D histogram) mapping More...
 
typedef GaudiAlg::Histo2DMapID Histo2DMapID
 the actual type for (ID)->(2D histogram) mapping More...
 
typedef GaudiAlg::Histo2DMapTitle Histo2DMapTitle
 the actual type for title->(2D histogram) mapping More...
 
typedef GaudiAlg::Histo3DMapID Histo3DMapID
 the actual type for (ID)->(3D histogram) mapping More...
 
typedef GaudiAlg::Histo3DMapTitle Histo3DMapTitle
 the actual type for title->(3D histogram) mapping More...
 
typedef GaudiAlg::Profile1DMapID Profile1DMapID
 the actual type for (ID)->(1D profile histogram) mapping More...
 
typedef GaudiAlg::Profile1DMapTitle Profile1DMapTitle
 the actual type for title->(1D profile histogram) mapping More...
 
typedef GaudiAlg::Profile2DMapID Profile2DMapID
 the actual type for (ID)->(2D profile histogram) mapping More...
 
typedef GaudiAlg::Profile2DMapTitle Profile2DMapTitle
 the actual type for title->(2D profile histogram) mapping More...
 
typedef GaudiAlg::HistoBinEdges HistoBinEdges
 Edges for variable binning. More...
 

Public Member Functions

AIDA::IHistogram1D * plot1D (const double value, const std::string &title, const double low, const double high, const unsigned long bins=100, const double weight=1.0) const
 fill the 1D histogram (book on demand) More...
 
AIDA::IHistogram1D * plot (const double value, const std::string &title, const double low, const double high, const unsigned long bins=100, const double weight=1.0) const
 fill the 1D histogram (book on demand) More...
 
AIDA::IHistogram1D * plot1D (const double value, const Gaudi::Histo1DDef &hdef, const double weight=1.0) const
 fill the 1D histogram (book on demand) More...
 
AIDA::IHistogram1D * plot (const double value, const Gaudi::Histo1DDef &hdef, const double weight=1.0) const
 fill the 1D histogram (book on demand) More...
 
AIDA::IHistogram1D * plot1D (const double value, const HistoID &ID, const std::string &title, const double low, const double high, const unsigned long bins=100, const double weight=1.0) const
 fill the 1D histogram with forced ID assignment (book on demand) More...
 
AIDA::IHistogram1D * plot (const double value, const HistoID &ID, const std::string &title, const double low, const double high, const unsigned long bins=100, const double weight=1.0) const
 fill the 1D histogram with forced ID assignment (book on demand) More...
 
AIDA::IHistogram1D * plot1D (const double value, const HistoID &ID, const Gaudi::Histo1DDef &hdef, const double weight=1.0) const
 fill the 1D histogram with forced ID assignment (book on demand) More...
 
AIDA::IHistogram1D * plot (const double value, const HistoID &ID, const Gaudi::Histo1DDef &hdef, const double weight=1.0) const
 fill the 1D histogram (book on demand) More...
 
template<class FUNCTION , class OBJECT >
AIDA::IHistogram1D * plot (const FUNCTION &func, OBJECT first, OBJECT last, const std::string &title, const double low, const double high, const unsigned long bins=100) const
 fill the 1D histogram with information from [first,last) sequence More...
 
template<class FUNCTION , class OBJECT >
AIDA::IHistogram1D * plot (const FUNCTION &func, OBJECT first, OBJECT last, const HistoID &ID, const std::string &title, const double low, const double high, const unsigned long bins=100) const
 fill the 1D histogram with forced ID and information from [first,last) sequence More...
 
template<class FUNCTION , class OBJECT , class WEIGHT >
AIDA::IHistogram1D * plot (const FUNCTION &func, OBJECT first, OBJECT last, const std::string &title, const double low, const double high, const unsigned long bins, const WEIGHT &weight) const
 book and fill the 1D histogram with information from [first,last) sequence with given weight More...
 
template<class FUNCTION , class OBJECT , class WEIGHT >
AIDA::IHistogram1D * plot (const FUNCTION &func, OBJECT first, OBJECT last, const HistoID &ID, const std::string &title, const double low, const double high, const unsigned long bins, const WEIGHT &weight) const
 book and fill the 1D histogram with forced ID and information from [first,last) sequence with given weight More...
 
AIDA::IHistogram1D * plot1D (const double value, const std::string &title, const HistoBinEdges &edges, const double weight=1.0) const
 Fill the 1D variable binning histogram (book on demand) More...
 
AIDA::IHistogram1D * plot1D (const double value, const HistoID &ID, const std::string &title, const HistoBinEdges &edges, const double weight=1.0) const
 fill the 1D variable binning histogram with forced ID assignment (book on demand) More...
 
AIDA::IHistogram2D * plot2D (const double valueX, const double valueY, const std::string &title, const double lowX, const double highX, const double lowY, const double highY, const unsigned long binsX=50, const unsigned long binsY=50, const double weight=1.0) const
 fill the 2D histogram (book on demand) More...
 
AIDA::IHistogram2D * plot2D (const double valueX, const double valueY, const HistoID &ID, const std::string &title, const double lowX, const double highX, const double lowY, const double highY, const unsigned long binsX=50, const unsigned long binsY=50, const double weight=1.0) const
 fill the 2D histogram with forced ID assignment (book on demand) More...
 
AIDA::IHistogram2D * plot2D (const double valueX, const double valueY, const std::string &title, const HistoBinEdges &edgesX, const HistoBinEdges &edgesY, const double weight=1.0) const
 Fill the 2D variable binning histogram (book on demand) More...
 
AIDA::IHistogram2D * plot2D (const double valueX, const double valueY, const HistoID &ID, const std::string &title, const HistoBinEdges &edgesX, const HistoBinEdges &edgesY, const double weight=1.0) const
 fill the 2D variable histogram with forced ID assignment (book on demand) More...
 
AIDA::IHistogram3D * plot3D (const double valueX, const double valueY, const double valueZ, const std::string &title, const double lowX, const double highX, const double lowY, const double highY, const double lowZ, const double highZ, const unsigned long binsX=10, const unsigned long binsY=10, const unsigned long binsZ=10, const double weight=1.0) const
 fill the 3D histogram (book on demand) More...
 
AIDA::IHistogram3D * plot3D (const double valueX, const double valueY, const double valueZ, const HistoID &ID, const std::string &title, const double lowX, const double highX, const double lowY, const double highY, const double lowZ, const double highZ, const unsigned long binsX=10, const unsigned long binsY=10, const unsigned long binsZ=10, const double weight=1.0) const
 fill the 3D histogram with forced ID assignment (book on demand) More...
 
AIDA::IHistogram3D * plot3D (const double valueX, const double valueY, const double valueZ, const std::string &title, const HistoBinEdges &edgesX, const HistoBinEdges &edgesY, const HistoBinEdges &edgesZ, const double weight=1.0) const
 Fill the 3D variable binning histogram (book on demand) More...
 
AIDA::IHistogram3D * plot3D (const double valueX, const double valueY, const double valueZ, const HistoID &ID, const std::string &title, const HistoBinEdges &edgesX, const HistoBinEdges &edgesY, const HistoBinEdges &edgesZ, const double weight=1.0) const
 fill the 3D histogram with forced ID assignment (book on demand) More...
 
AIDA::IProfile1D * profile1D (const double valueX, const double valueY, const std::string &title, const double lowX, const double highX, const unsigned long binsX=100, const std::string &opt="", const double lowY=-std::numeric_limits< double >::max(), const double highY=std::numeric_limits< double >::max(), const double weight=1.0) const
 fill the 1D profile histogram (book on demand) More...
 
AIDA::IProfile1D * profile1D (const double valueX, const double valueY, const HistoID &ID, const std::string &title, const double lowX, const double highX, const unsigned long binsX=100, const std::string &opt="", const double lowY=-std::numeric_limits< double >::max(), const double highY=std::numeric_limits< double >::max(), const double weight=1.0) const
 fill the 1D profile histogram with forced ID assignment (book on demand) More...
 
AIDA::IProfile1D * profile1D (const double valueX, const double valueY, const std::string &title, const HistoBinEdges &edges, const double weight=1.0) const
 fill the 1D variable binning profile histogram (book on demand) More...
 
AIDA::IProfile1D * profile1D (const double valueX, const double valueY, const HistoID &ID, const std::string &title, const HistoBinEdges &edges, const double weight=1.0) const
 fill the 1D variable binning profile histogram with forced ID assignment (book on demand) More...
 
AIDA::IProfile2D * profile2D (const double valueX, const double valueY, const double valueZ, const std::string &title, const double lowX, const double highX, const double lowY, const double highY, const unsigned long binsX=50, const unsigned long binsY=50, const double weight=1.0) const
 fill the 2D profile histogram (book on demand) More...
 
AIDA::IProfile2D * profile2D (const double valueX, const double valueY, const double valueZ, const HistoID &ID, const std::string &title, const double lowX, const double highX, const double lowY, const double highY, const unsigned long binsX=50, const unsigned long binsY=50, const double weight=1.0) const
 fill the 2D profile histogram with forced ID assignment (book on demand) More...
 
AIDA::IProfile2D * profile2D (const double valueX, const double valueY, const double valueZ, const std::string &title, const HistoBinEdges &edgesX, const HistoBinEdges &edgesY, const double weight=1.0) const
 fill the 2D variable binning profile histogram (book on demand) More...
 
AIDA::IProfile2D * profile2D (const double valueX, const double valueY, const double valueZ, const HistoID &ID, const std::string &title, const HistoBinEdges &edgesX, const HistoBinEdges &edgesY, const double weight=1.0) const
 fill the 2D variable binning profile histogram with forced ID assignment (book on demand) More...
 
AIDA::IHistogram1D * book1D (const std::string &title, const double low=0, const double high=100, const unsigned long bins=100) const
 book the 1D histogram More...
 
AIDA::IHistogram1D * book (const std::string &title, const double low=0, const double high=100, const unsigned long bins=100) const
 book the 1D histogram More...
 
AIDA::IHistogram1D * book (const Gaudi::Histo1DDef &hdef) const
 book the 1D histogram More...
 
AIDA::IHistogram1D * book1D (const HistoID &ID, const std::string &title, const double low=0, const double high=100, const unsigned long bins=100) const
 book the 1D histogram with forced ID More...
 
AIDA::IHistogram1D * book (const HistoID &ID, const std::string &title, const double low=0, const double high=100, const unsigned long bins=100) const
 book the 1D histogram with forced ID More...
 
AIDA::IHistogram1D * book (const HistoID &ID, const Gaudi::Histo1DDef &hdef) const
 book the 1D histogram with forced ID More...
 
AIDA::IHistogram1D * book1D (const std::string &title, const HistoBinEdges &edges) const
 book the 1D variable binning histogram More...
 
AIDA::IHistogram1D * book1D (const HistoID &ID, const std::string &title, const HistoBinEdges &edges) const
 book the 1D variable binning histogram with given ID More...
 
AIDA::IHistogram2D * book2D (const std::string &title, const double lowX=0, const double highX=100, const unsigned long binsX=50, const double lowY=0, const double highY=100, const unsigned long binsY=50) const
 book the 2D histogram More...
 
AIDA::IHistogram2D * book2D (const HistoID &ID, const std::string &title, const double lowX=0, const double highX=100, const unsigned long binsX=50, const double lowY=0, const double highY=100, const unsigned long binsY=50) const
 book the 2D histogram with forced ID More...
 
AIDA::IHistogram2D * book2D (const std::string &title, const HistoBinEdges &edgesX, const HistoBinEdges &edgesY) const
 book the 2D variable binning histogram More...
 
AIDA::IHistogram2D * book2D (const HistoID &ID, const std::string &title, const HistoBinEdges &edgesX, const HistoBinEdges &edgesY) const
 book the 2D variable binning histogram with given ID More...
 
AIDA::IHistogram3D * book3D (const std::string &title, const double lowX=0, const double highX=100, const unsigned long binsX=10, const double lowY=0, const double highY=100, const unsigned long binsY=10, const double lowZ=0, const double highZ=100, const unsigned long binsZ=10) const
 book the 3D histogram More...
 
AIDA::IHistogram3D * book3D (const HistoID &ID, const std::string &title, const double lowX=0, const double highX=100, const unsigned long binsX=10, const double lowY=0, const double highY=100, const unsigned long binsY=10, const double lowZ=0, const double highZ=100, const unsigned long binsZ=10) const
 book the 3D histogram with forced ID More...
 
AIDA::IHistogram3D * book3D (const std::string &title, const HistoBinEdges &edgesX, const HistoBinEdges &edgesY, const HistoBinEdges &edgesZ) const
 book the 3D variable binning histogram More...
 
AIDA::IHistogram3D * book3D (const HistoID &ID, const std::string &title, const HistoBinEdges &edgesX, const HistoBinEdges &edgesY, const HistoBinEdges &edgesZ) const
 book the 3D variable binning histogram with given ID More...
 
AIDA::IProfile1D * bookProfile1D (const std::string &title, const double low=0, const double high=100, const unsigned long bins=100, const std::string &opt="", const double lowY=-std::numeric_limits< double >::max(), const double highY=std::numeric_limits< double >::max()) const
 book the 1D profile histogram More...
 
AIDA::IProfile1D * bookProfile1D (const HistoID &ID, const std::string &title, const double low=0, const double high=100, const unsigned long bins=100, const std::string &opt="", const double lowY=-std::numeric_limits< double >::max(), const double highY=std::numeric_limits< double >::max()) const
 book the 1D profile histogram More...
 
AIDA::IProfile1D * bookProfile1D (const std::string &title, const HistoBinEdges &edges) const
 book the 1D profile histogram More...
 
AIDA::IProfile1D * bookProfile1D (const HistoID &ID, const std::string &title, const HistoBinEdges &edges) const
 book the 1D profile histogram More...
 
AIDA::IProfile2D * bookProfile2D (const std::string &title, const double lowX=0, const double highX=100, const unsigned long binsX=50, const double lowY=0, const double highY=100, const unsigned long binsY=50) const
 book the 2D profile histogram More...
 
AIDA::IProfile2D * bookProfile2D (const HistoID &ID, const std::string &title, const double lowX=0, const double highX=100, const unsigned long binsX=50, const double lowY=0, const double highY=100, const unsigned long binsY=50) const
 book the 2D profile histogram with forced ID More...
 
AIDA::IProfile2D * bookProfile2D (const std::string &title, const HistoBinEdges &edgesX, const HistoBinEdges &edgesY) const
 book the 2D profile histogram More...
 
AIDA::IProfile2D * bookProfile2D (const HistoID &ID, const std::string &title, const HistoBinEdges &edgesX, const HistoBinEdges &edgesY) const
 book the 2D profile histogram with forced ID More...
 
AIDA::IHistogram1D * fill (AIDA::IHistogram1D *histo, const double value, const double weight, const std::string &title="") const
 fill the 1D histogram with the value and weight More...
 
AIDA::IHistogram2D * fill (AIDA::IHistogram2D *histo, const double valueX, const double valueY, const double weight, const std::string &title="") const
 fill the 2D histogram with the value and weight More...
 
AIDA::IHistogram3D * fill (AIDA::IHistogram3D *histo, const double valueX, const double valueY, const double valueZ, const double weight, const std::string &title="") const
 fill the 3D histogram with the value and weight More...
 
AIDA::IProfile1D * fill (AIDA::IProfile1D *histo, const double valueX, const double valueY, const double weight, const std::string &title="") const
 fill the 1D profile histogram with the values and weight More...
 
AIDA::IProfile2D * fill (AIDA::IProfile2D *histo, const double valueX, const double valueY, const double valueZ, const double weight, const std::string &title="") const
 fill the 2D profile histogram with the values and weight More...
 
AIDA::IHistogram1D * histo1D (const std::string &title) const
 access the EXISTING 1D histogram by title return the pointer to existing 1D histogram or NULL More...
 
AIDA::IHistogram1D * histo (const std::string &title) const
 access the EXISTING 1D histogram by title More...
 
AIDA::IHistogram2D * histo2D (const std::string &title) const
 access the EXISTING 2D histogram by title return the pointer to existing 2D histogram or NULL More...
 
AIDA::IHistogram3D * histo3D (const std::string &title) const
 access the EXISTING 3D histogram by title return the pointer to existing 3D histogram or NULL More...
 
AIDA::IProfile1D * profile1D (const std::string &title) const
 access the EXISTING 1D profile histogram by title return the pointer to existing 1D profile histogram or NULL More...
 
AIDA::IProfile2D * profile2D (const std::string &title) const
 access the EXISTING 2D profile histogram by title return the pointer to existing 2D profile histogram or NULL More...
 
AIDA::IHistogram1D * histo1D (const HistoID &ID) const
 access the EXISTING 1D histogram by ID return the pointer to existing 1D histogram or NULL More...
 
AIDA::IHistogram1D * histo (const HistoID &ID) const
 access the EXISTING 1D histogram by ID More...
 
AIDA::IHistogram2D * histo2D (const HistoID &ID) const
 access the EXISTING 2D histogram by ID return the pointer to existing 2D histogram or NULL More...
 
AIDA::IHistogram3D * histo3D (const HistoID &ID) const
 access the EXISTING 3D histogram by ID return the pointer to existing 3D histogram or NULL More...
 
AIDA::IProfile1D * profile1D (const HistoID &ID) const
 access the EXISTING 1D profile histogram by ID return the pointer to existing 1D profile histogram or NULL More...
 
AIDA::IProfile2D * profile2D (const HistoID &ID) const
 access the EXISTING 2D profile histogram by ID return the pointer to existing 2D profile histogram or NULL More...
 
bool histoExists (const std::string &title) const
 check the existence AND validity of the histogram with given title More...
 
bool histoExists (const HistoID &ID) const
 check the existence AND validity of the histogram with given title More...
 
unsigned int totalNumberOfHistos () const
 Returns the total number of histograms (of all types) currently booked. More...
 
bool produceHistos () const
 get the flag for histogram production (property "HistoProduce") More...
 
bool fullDetail () const
 get flag to control output level of histograms More...
 
bool checkForNaN () const
 get the flag for NaN checks (property "HistoCheckForNan") More...
 
bool splitHistoDir () const
 get the flag for histogram path split (property "HistoSplitDir") More...
 
HistoID::NumericID histoOffSet () const
 get the value for histogram offset (property "HistoOffSet") More...
 
const std::stringhistoTopDir () const
 get top-level histogram directory (property "HistoTopDir") More...
 
const std::stringhistoDir () const
 get histogram directory (property "HistoDir") More...
 
std::string histoPath () const
 get the constructed histogram path More...
 
bool histosPrint () const
 print histograms at finalization ? More...
 
bool histoCountersPrint () const
 print histogram counters at finalization ? More...
 
bool useNumericAutoIDs () const
 Use old style sequencial numerical automatically assigned IDs ? More...
 
int printHistos (const MSG::Level level=MSG::ALWAYS) const
 perform the actual printout of histograms More...
 
const Histo1DMapTitlehisto1DMapTitle () const
 get access to the map of all 1D histograms indexed via their title More...
 
const Histo1DMapIDhisto1DMapID () const
 get access to the map of all 1D histograms index via ID More...
 
const Histo2DMapTitlehisto2DMapTitle () const
 get access to the map of all 2D histograms indexed via their title More...
 
const Histo2DMapIDhisto2DMapID () const
 get access to the map of 2D histograms index via ID More...
 
const Histo3DMapTitlehisto3DMapTitle () const
 get access to the map of all 3D histograms indexed via their title More...
 
const Histo3DMapIDhisto3DMapID () const
 get access to the map of all 3D histograms index via a ID More...
 
const Profile1DMapTitleprofile1DMapTitle () const
 get access to the map of all 1D profile histograms indexed via their title More...
 
const Profile1DMapIDprofile1DMapID () const
 get access to the map of 1D profile histograms index via a ID More...
 
const Profile2DMapTitleprofile2DMapTitle () const
 get access to the map of all 2D profile histograms indexed via their title More...
 
const Profile2DMapIDprofile2DMapID () const
 get access to the map of 2D profile histograms index via a ID More...
 
void setProduceHistos (const bool val)
 set the flag for histogram production (property "HistoProduce") More...
 
void setFullDetail (const bool val)
 set flag to control output level of histograms More...
 
void setCheckForNaN (const bool val)
 set the flag for NaN checks (property "HistoCheckForNan") More...
 
void setSplitHistoDir (const bool val)
 set the flag for histogram path split (property "HistoSplitDir") More...
 
void setHistoOffSet (const HistoID::NumericID val)
 set a value for histogram offset (property "HistoOffSet" More...
 
void setHistoTopDir (const std::string &val)
 set top-level histogram directory (property "HistoTopDir") More...
 
void setHistoDir (const std::string &val)
 set histogram directory (property "HistoDir") More...
 
template<typename U = PBASE, typename = std::enable_if_t<std::is_base_of_v<Gaudi::Algorithm, PBASE>, U>>
 GaudiHistos (const std::string &name, ISvcLocator *pSvcLocator)
 Algorithm constructor - the SFINAE constraint below ensures that this is constructor is only defined if PBASE derives from GaudiAlgorithm. More...
 
template<typename U = PBASE, typename = std::enable_if_t<std::is_base_of_v<GaudiTool, PBASE>, U>>
 GaudiHistos (const std::string &type, const std::string &name, const IInterface *parent)
 Tool constructor - SFINAE-ed to insure this constructor is only defined if PBASE derives from GaudiTool. More...
 

Protected Member Functions

StatusCode initialize () override
 standard initialization method More...
 
StatusCode finalize () override
 standard finalization method More...
 
std::string convertTitleToID (std::string title) const
 Create an ID string from a title string. More...
 

Private Member Functions

bool noHistos () const
 Check if all histogram maps are empty. More...
 
void monitorHisto (const AIDA::IBaseHistogram *hist, const HistoID &ID) const
 Declare a histogram to the monitor service. More...
 
void newHistoID (const std::string &title, HistoID &ID) const
 Create a new histogram ID using the given title. More...
 

Private Attributes

Gaudi::Property< bool > m_produceHistos { this, "HistoProduce", true, "Switch on/off the production of histograms" }
 
Gaudi::Property< bool > m_histosPrint
 
Gaudi::Property< bool > m_histoCountersPrint
 
Gaudi::Property< bool > m_checkForNaN
 
Gaudi::Property< bool > m_splitHistoDir
 
Gaudi::Property< HistoID::NumericIDm_histoOffSet
 
Gaudi::Property< std::stringm_histoTopDir
 
Gaudi::Property< std::stringm_histoDir
 
Gaudi::Property< bool > m_fullDetail { this, "FullDetail", false }
 
Gaudi::Property< bool > m_declareMoniHists { this, "MonitorHistograms", true }
 
Gaudi::Property< std::stringm_histo1DTableFormat
 
Gaudi::Property< std::stringm_histo1DTableFormatShort
 
Gaudi::Property< std::stringm_histo1DTableHeader
 
Gaudi::Property< bool > m_useNumericAutoIDs
 
Gaudi::Property< std::map< std::string, std::string > > m_idReplaceInfo
 
Histo1DMapTitle m_histo1DMapTitle
 the actual storage/access of 1D histograms by unique title More...
 
Histo1DMapID m_histo1DMapID
 the actual storage/access of 1D histograms by unique ID More...
 
Histo2DMapTitle m_histo2DMapTitle
 the actual storage/access of 2D histograms by unique title More...
 
Histo2DMapID m_histo2DMapID
 the actual storage/access of 2D histograms by unique ID More...
 
Histo3DMapTitle m_histo3DMapTitle
 the actual storage/access of 3D histograms by unique title More...
 
Histo3DMapID m_histo3DMapID
 the actual storage/access of 3D histograms by unique ID More...
 
Profile1DMapTitle m_profile1DMapTitle
 the actual storage/access of 1D profile histograms by unique title More...
 
Profile1DMapID m_profile1DMapID
 the actual storage/access of 1D profile histograms by unique ID More...
 
Profile2DMapTitle m_profile2DMapTitle
 the actual storage/access of 2D profile histograms by unique title More...
 
Profile2DMapID m_profile2DMapID
 the actual storage/access of 2D profile histograms by unique ID More...
 

Detailed Description

template<class PBASE>
class GaudiHistos< PBASE >

Templated base class providing common histogramming methods for GaudiAlgorithm and GaudiTool like classes.

Author
Chris Jones Chris.nosp@m.toph.nosp@m.er.Ro.nosp@m.b.Jo.nosp@m.nes@c.nosp@m.ern..nosp@m.ch
Vanya BELYAEV Ivan..nosp@m.Bely.nosp@m.aev@i.nosp@m.tep..nosp@m.ru
Date
2005-08-08

Definition at line 65 of file GaudiHistos.h.

Member Typedef Documentation

◆ Histo1DMapID

template<class PBASE >
typedef GaudiAlg::Histo1DMapID GaudiHistos< PBASE >::Histo1DMapID

the actual type for (ID)->(1D histogram) mapping

Definition at line 72 of file GaudiHistos.h.

◆ Histo1DMapTitle

template<class PBASE >
typedef GaudiAlg::Histo1DMapTitle GaudiHistos< PBASE >::Histo1DMapTitle

the actual type for title->(1D histogram) mapping

Definition at line 74 of file GaudiHistos.h.

◆ Histo2DMapID

template<class PBASE >
typedef GaudiAlg::Histo2DMapID GaudiHistos< PBASE >::Histo2DMapID

the actual type for (ID)->(2D histogram) mapping

Definition at line 77 of file GaudiHistos.h.

◆ Histo2DMapTitle

template<class PBASE >
typedef GaudiAlg::Histo2DMapTitle GaudiHistos< PBASE >::Histo2DMapTitle

the actual type for title->(2D histogram) mapping

Definition at line 79 of file GaudiHistos.h.

◆ Histo3DMapID

template<class PBASE >
typedef GaudiAlg::Histo3DMapID GaudiHistos< PBASE >::Histo3DMapID

the actual type for (ID)->(3D histogram) mapping

Definition at line 82 of file GaudiHistos.h.

◆ Histo3DMapTitle

template<class PBASE >
typedef GaudiAlg::Histo3DMapTitle GaudiHistos< PBASE >::Histo3DMapTitle

the actual type for title->(3D histogram) mapping

Definition at line 84 of file GaudiHistos.h.

◆ HistoBinEdges

template<class PBASE >
typedef GaudiAlg::HistoBinEdges GaudiHistos< PBASE >::HistoBinEdges

Edges for variable binning.

Definition at line 97 of file GaudiHistos.h.

◆ HistoID

template<class PBASE >
typedef GaudiAlg::HistoID GaudiHistos< PBASE >::HistoID

the actual type for histogram identifier

Definition at line 69 of file GaudiHistos.h.

◆ Profile1DMapID

template<class PBASE >
typedef GaudiAlg::Profile1DMapID GaudiHistos< PBASE >::Profile1DMapID

the actual type for (ID)->(1D profile histogram) mapping

Definition at line 87 of file GaudiHistos.h.

◆ Profile1DMapTitle

template<class PBASE >
typedef GaudiAlg::Profile1DMapTitle GaudiHistos< PBASE >::Profile1DMapTitle

the actual type for title->(1D profile histogram) mapping

Definition at line 89 of file GaudiHistos.h.

◆ Profile2DMapID

template<class PBASE >
typedef GaudiAlg::Profile2DMapID GaudiHistos< PBASE >::Profile2DMapID

the actual type for (ID)->(2D profile histogram) mapping

Definition at line 92 of file GaudiHistos.h.

◆ Profile2DMapTitle

template<class PBASE >
typedef GaudiAlg::Profile2DMapTitle GaudiHistos< PBASE >::Profile2DMapTitle

the actual type for title->(2D profile histogram) mapping

Definition at line 94 of file GaudiHistos.h.

Constructor & Destructor Documentation

◆ GaudiHistos() [1/2]

template<class PBASE >
template<typename U = PBASE, typename = std::enable_if_t<std::is_base_of_v<Gaudi::Algorithm, PBASE>, U>>
GaudiHistos< PBASE >::GaudiHistos ( const std::string name,
ISvcLocator pSvcLocator 
)
inline

Algorithm constructor - the SFINAE constraint below ensures that this is constructor is only defined if PBASE derives from GaudiAlgorithm.

Definition at line 2688 of file GaudiHistos.h.

2688 : PBASE( name, pSvcLocator ) {}

◆ GaudiHistos() [2/2]

template<class PBASE >
template<typename U = PBASE, typename = std::enable_if_t<std::is_base_of_v<GaudiTool, PBASE>, U>>
GaudiHistos< PBASE >::GaudiHistos ( const std::string type,
const std::string name,
const IInterface parent 
)
inline

Tool constructor - SFINAE-ed to insure this constructor is only defined if PBASE derives from GaudiTool.

Definition at line 2693 of file GaudiHistos.h.

2694  : PBASE( type, name, parent ) {}

Member Function Documentation

◆ book() [1/4]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::book ( const Gaudi::Histo1DDef hdef) const

book the 1D histogram

The histogram will be assigned a unique identifier

See also
AIDA::IHistogram1D
Parameters
hdefhistogram description/definition
Returns
pointer to AIDA 1D histogram

Definition at line 147 of file GaudiHistos_1DFixedBinning.icpp.

147  {
148  return book1D( hdef.title(), hdef.lowEdge(), hdef.highEdge(), hdef.bins() );
149 }

◆ book() [2/4]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::book ( const HistoID ID,
const Gaudi::Histo1DDef hdef 
) const
inline

book the 1D histogram with forced ID

See also
IHistogram1D
Parameters
IDunique histogram ID
hdefhistogram descriptor
Returns
pointer to AIDA histogram

Definition at line 154 of file GaudiHistos_1DFixedBinning.icpp.

154  {
155  return book1D( ID, hdef.title(), hdef.lowEdge(), hdef.highEdge(), hdef.bins() );
156 }

◆ book() [3/4]

template<class PBASE >
AIDA::IHistogram1D* GaudiHistos< PBASE >::book ( const HistoID ID,
const std::string title,
const double  low = 0,
const double  high = 100,
const unsigned long  bins = 100 
) const
inline

book the 1D histogram with forced ID

Wrapper method for the equivalent book1D method. Retained for backwards compatibility, please use book1D instead.

See also
IHistogram1D
Parameters
IDunique histogram ID
titlehistogram title (must be unique within the algorithm)
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins
Returns
pointer to AIDA histogram

Definition at line 1900 of file GaudiHistos.h.

1901  {
1902  return book1D( ID, title, low, high, bins );
1903  }

◆ book() [4/4]

template<class PBASE >
AIDA::IHistogram1D* GaudiHistos< PBASE >::book ( const std::string title,
const double  low = 0,
const double  high = 100,
const unsigned long  bins = 100 
) const
inline

book the 1D histogram

Wrapper method for the equivalent book1D method. Retained for backwards compatibility, please use book1D instead.

See also
IHistogram1D
Parameters
titlehistogram title (must be unique within the algorithm)
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins
Returns
pointer to AIDA 1D histogram

Definition at line 1859 of file GaudiHistos.h.

1860  {
1861  return book1D( title, low, high, bins );
1862  }

◆ book1D() [1/4]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::book1D ( const HistoID ID,
const std::string title,
const double  low = 0,
const double  high = 100,
const unsigned long  bins = 100 
) const

book the 1D histogram with forced ID

See also
IHistogram1D
Parameters
IDunique histogram ID
titlehistogram title (must be unique within the algorithm)
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins
Returns
pointer to AIDA histogram

Definition at line 38 of file GaudiHistos_1DFixedBinning.icpp.

39  {
40  //
41  if ( !produceHistos() ) { return nullptr; } // RETURN
42  //
43 
44  // Check ID
45  if ( ID.undefined() ) {
46  this->Error( "Undefined Histogram ID : Title='" + title + "'" ).ignore();
47  return nullptr;
48  }
49 
50  // exist?
51  auto* hist = histo1D( ID );
52  // histogram is already booked
53  if ( hist ) { return hist; } // RETURN !!
54 
55  // Histogram title
56  const std::string& htitle = ( title.empty() ? "Unnamed 1D Histogram ID=" + ID.idAsString() : title );
57 
58  // book the histogram
59  if ( ID.numeric() ) {
60  hist = this->histoSvc()->book( histoPath(), ID.numericID(), htitle, bins, low, high );
61  } else if ( ID.literal() ) {
62  hist = this->histoSvc()->book( histoPath() + "/" + ID.literalID(), htitle, bins, low, high );
63  }
64 
65  // check OK
66  if ( !hist ) {
67  this->Error( "IHistogram1D* points to NULL! ID='" + ID.idAsString() + "' title='" + htitle + "'" ).ignore();
68  return nullptr;
69  } // RETURN !!
70 
71  // add histogram into histogram storages
72  m_histo1DMapID[ID] = hist;
73  m_histo1DMapTitle[title] = hist;
74 
75  // Declare to monitoring service
77 
78  // Printout and return
79  if ( this->msgLevel( MSG::DEBUG ) ) {
80  this->debug() << "Booked 1D Histogram : ID='" << ID << "' Path=" << histoPath() << " Title='"
81  << Gaudi::Utils::Histos::htitle( hist ) << "'" << endmsg;
82  }
83  return hist;
84 }

◆ book1D() [2/4]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::book1D ( const HistoID ID,
const std::string title,
const HistoBinEdges edges 
) const

book the 1D variable binning histogram with given ID

See also
AIDA::IHistogram1D
Parameters
IDunique histogram ID
titlehistogram title (must be unique within the algorithm)
edgesThe histogram bin edges
Returns
pointer to AIDA 1D histogram

Definition at line 37 of file GaudiHistos_1DVariableBinning.icpp.

38  {
39  //
40  if ( !produceHistos() ) { return nullptr; } // RETURN
41  //
42  // Check ID
43  if ( ID.undefined() ) {
44  this->Error( "Undefined Histogram ID : Title='" + title + "'" ).ignore();
45  return nullptr;
46  }
47 
48  // exist?
49  auto hist = histo1D( ID );
50  // histogram is already booked
51  if ( hist ) { return hist; } // RETURN !!
52 
53  // Histogram title
54  const std::string& htitle = ( title.empty() ? "Unnamed 1D Histogram ID=" + ID.idAsString() : title );
55 
56  // book the histogram
57  if ( ID.numeric() ) {
58  hist = this->histoSvc()->book( histoPath(), ID.numericID(), htitle, edges );
59  } else if ( ID.literal() ) {
60  hist = this->histoSvc()->book( histoPath() + "/" + ID.literalID(), htitle, edges );
61  }
62 
63  // check OK
64  if ( !hist ) {
65  this->Error( "IHistogram1D* points to NULL! ID='" + ID.idAsString() + "' title='" + htitle + "'" ).ignore();
66  return nullptr;
67  } // RETURN !!
68 
69  // add histogram into histogram storages
70  m_histo1DMapID[ID] = hist;
71  m_histo1DMapTitle[title] = hist;
72 
73  // Declare to monitoring service
75 
76  // Printout and return
77  if ( this->msgLevel( MSG::DEBUG ) ) {
78  this->debug() << "Booked 1D Histogram : ID='" << ID << "' Path=" << histoPath() << " Title='"
79  << Gaudi::Utils::Histos::htitle( hist ) << "'" << endmsg;
80  }
81  return hist;
82 }

◆ book1D() [3/4]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::book1D ( const std::string title,
const double  low = 0,
const double  high = 100,
const unsigned long  bins = 100 
) const

book the 1D histogram

The histogram will be assigned a unique identifier

See also
AIDA::IHistogram1D
Parameters
titlehistogram title (must be unique within the algorithm)
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins
Returns
pointer to AIDA 1D histogram

Definition at line 17 of file GaudiHistos_1DFixedBinning.icpp.

18  {
19  //
20  if ( !produceHistos() ) { return nullptr; } // RETURN
21  //
22  // exist?
23  auto hist = histo1D( title );
24  // histogram is already booked
25  if ( hist ) { return hist; } // RETURN !!
26 
27  // propose the histogram ID
28  HistoID ID;
29  newHistoID( title, ID );
30 
31  // Create a new histogram and return
32  return this->book1D( ID, title, low, high, bins );
33 }

◆ book1D() [4/4]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::book1D ( const std::string title,
const HistoBinEdges edges 
) const

book the 1D variable binning histogram

The histogram will be assigned a unique identifier

See also
AIDA::IHistogram1D
Parameters
titlehistogram title (must be unique within the algorithm)
edgesThe histogram bin edges
Returns
pointer to AIDA 1D histogram

Definition at line 17 of file GaudiHistos_1DVariableBinning.icpp.

17  {
18  //
19  if ( !produceHistos() ) { return nullptr; } // RETURN
20  //
21  // exist?
22  auto hist = histo1D( title );
23  // histogram is already booked
24  if ( hist ) { return hist; } // RETURN !!
25 
26  // propose the histogram ID
27  HistoID ID;
28  newHistoID( title, ID );
29 
30  // Create a new histogram and return
31  return this->book1D( ID, title, edges );
32 }

◆ book2D() [1/4]

template<class PBASE >
AIDA::IHistogram2D * GaudiHistos< PBASE >::book2D ( const HistoID ID,
const std::string title,
const double  lowX = 0,
const double  highX = 100,
const unsigned long  binsX = 50,
const double  lowY = 0,
const double  highY = 100,
const unsigned long  binsY = 50 
) const

book the 2D histogram with forced ID

See also
IHistogram2D
Parameters
IDunique histogram ID
titlehistogram title (must be unique within the algorithm)
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins
Returns
pointer to AIDA histogram

Definition at line 39 of file GaudiHistos_2DFixedBinning.icpp.

41  {
42  //
43  if ( !produceHistos() ) { return nullptr; } // RETURN
44  //
45  // Check ID
46  if ( ID.undefined() ) {
47  this->Error( "Undefined Histogram ID : Title='" + title + "'" ).ignore();
48  return nullptr;
49  }
50 
51  // exist?
52  auto hist = histo2D( ID );
53  // histogram is already booked
54  if ( hist ) { return hist; } // RETURN !!
55 
56  // Histogram title
57  const std::string& htitle = ( title.empty() ? "Unnamed 2D Histogram ID=" + ID.idAsString() : title );
58 
59  // book the histogram
60  if ( ID.numeric() ) {
61  hist = this->histoSvc()->book( histoPath(), ID.numericID(), htitle, binsX, lowX, highX, binsY, lowY, highY );
62  } else if ( ID.literal() ) {
63  hist = this->histoSvc()->book( histoPath() + "/" + ID.literalID(), htitle, binsX, lowX, highX, binsY, lowY, highY );
64  }
65 
66  // Check OK
67  if ( !hist ) {
68  this->Error( "IHistogram2D* points to NULL! ID='" + ID.idAsString() + "' title='" + htitle + "'" ).ignore();
69  return nullptr;
70  } // RETURN !!
71 
72  // add histogram into histogram storages
73  m_histo2DMapID[ID] = hist;
74  m_histo2DMapTitle[title] = hist;
75 
76  // Declare to monitoring service
78 
79  // Printout and return
80  if ( this->msgLevel( MSG::DEBUG ) ) {
81  this->debug() << "Booked 2D Histogram : ID='" << ID << "' Path=" << histoPath() << " Title='"
82  << Gaudi::Utils::Histos::htitle( hist ) << "'" << endmsg;
83  }
84  // return
85  return hist;
86 }

◆ book2D() [2/4]

template<class PBASE >
AIDA::IHistogram2D * GaudiHistos< PBASE >::book2D ( const HistoID ID,
const std::string title,
const HistoBinEdges edgesX,
const HistoBinEdges edgesY 
) const

book the 2D variable binning histogram with given ID

See also
AIDA::IHistogram2D
Parameters
IDunique histogram ID
titlehistogram title (must be unique within the algorithm)
edgesXThe histogram x bin edges
edgesYThe histogram y bin edges
Returns
pointer to AIDA 2D histogram

Definition at line 38 of file GaudiHistos_2DVariableBinning.icpp.

39  {
40  //
41  if ( !produceHistos() ) { return nullptr; } // RETURN
42  //
43  // Check ID
44  if ( ID.undefined() ) {
45  this->Error( "Undefined Histogram ID : Title='" + title + "'" ).ignore();
46  return nullptr;
47  }
48 
49  // exist?
50  auto hist = histo2D( ID );
51  // histogram is already booked
52  if ( hist ) { return hist; } // RETURN !!
53 
54  // Histogram title
55  const std::string& htitle = ( title.empty() ? "Unnamed 2D Histogram ID=" + ID.idAsString() : title );
56 
57  // book the histogram
58  if ( ID.numeric() ) {
59  hist = this->histoSvc()->book( histoPath(), ID.numericID(), htitle, edgesX, edgesY );
60  } else if ( ID.literal() ) {
61  hist = this->histoSvc()->book( histoPath() + "/" + ID.literalID(), htitle, edgesX, edgesY );
62  }
63 
64  // check OK
65  if ( !hist ) {
66  this->Error( "IHistogram2D* points to NULL! ID='" + ID.idAsString() + "' title='" + htitle + "'" ).ignore();
67  return nullptr;
68  } // RETURN !!
69 
70  // add histogram into histogram storages
71  m_histo2DMapID[ID] = hist;
72  m_histo2DMapTitle[title] = hist;
73 
74  // Declare to monitoring service
76 
77  // Printout and return
78  if ( this->msgLevel( MSG::DEBUG ) ) {
79  this->debug() << "Booked 2D Histogram : ID='" << ID << "' Path=" << histoPath() << " Title='"
80  << Gaudi::Utils::Histos::htitle( hist ) << "'" << endmsg;
81  }
82  return hist;
83 }

◆ book2D() [3/4]

template<class PBASE >
AIDA::IHistogram2D * GaudiHistos< PBASE >::book2D ( const std::string title,
const double  lowX = 0,
const double  highX = 100,
const unsigned long  binsX = 50,
const double  lowY = 0,
const double  highY = 100,
const unsigned long  binsY = 50 
) const

book the 2D histogram

The histogram will be assigned a unique identifier

See also
IHistogram2D
Parameters
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
binsXnumber of bins in x
lowYlow y limit for histogram
highYhigh y limit for histogram
binsYnumber of bins in y
Returns
pointer to AIDA 2D histogram

Definition at line 17 of file GaudiHistos_2DFixedBinning.icpp.

19  {
20  //
21  if ( !produceHistos() ) { return nullptr; } // RETURN
22  //
23  // exist?
24  auto hist = histo2D( title );
25  // histogram is already booked
26  if ( hist ) { return hist; } // RETURN !!
27 
28  // propose the histogram ID
29  HistoID ID;
30  newHistoID( title, ID );
31 
32  // Create a new histogram and return
33  return this->book2D( ID, title, lowX, highX, binsX, lowY, highY, binsY );
34 }

◆ book2D() [4/4]

template<class PBASE >
AIDA::IHistogram2D * GaudiHistos< PBASE >::book2D ( const std::string title,
const HistoBinEdges edgesX,
const HistoBinEdges edgesY 
) const

book the 2D variable binning histogram

The histogram will be assigned a unique identifier

See also
AIDA::IHistogram2D
Parameters
titlehistogram title (must be unique within the algorithm)
edgesXThe histogram x bin edges
edgesYThe histogram y bin edges
Returns
pointer to AIDA 2D histogram

Definition at line 17 of file GaudiHistos_2DVariableBinning.icpp.

18  {
19  //
20  if ( !produceHistos() ) { return nullptr; } // RETURN
21  //
22  // exist?
23  auto hist = histo2D( title );
24  // histogram is already booked
25  if ( hist ) { return hist; } // RETURN !!
26 
27  // propose the histogram ID
28  HistoID ID;
29  newHistoID( title, ID );
30 
31  // Create a new histogram and return
32  return this->book2D( ID, title, edgesX, edgesY );
33 }

◆ book3D() [1/4]

template<class PBASE >
AIDA::IHistogram3D * GaudiHistos< PBASE >::book3D ( const HistoID ID,
const std::string title,
const double  lowX = 0,
const double  highX = 100,
const unsigned long  binsX = 10,
const double  lowY = 0,
const double  highY = 100,
const unsigned long  binsY = 10,
const double  lowZ = 0,
const double  highZ = 100,
const unsigned long  binsZ = 10 
) const

book the 3D histogram with forced ID

See also
IHistogram3D
Parameters
IDunique histogram ID
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
binsXnumber of bins in x
lowYlow y limit for histogram
highYhigh y limit for histogram
binsYnumber of bins in y
lowZlow y limit for histogram
highZhigh y limit for histogram
binsZnumber of bins in y
Returns
pointer to AIDA 3D histogram

Definition at line 40 of file GaudiHistos_3DFixedBinning.icpp.

43  {
44  //
45  if ( !produceHistos() ) { return nullptr; } // RETURN
46  //
47  // Check ID
48  if ( ID.undefined() ) {
49  this->Error( "Undefined Histogram ID : Title='" + title + "'" ).ignore();
50  return nullptr;
51  }
52 
53  // exist?
54  auto hist = histo3D( ID );
55  // histogram is already booked
56  if ( hist ) { return hist; } // RETURN !!
57 
58  // Histogram title
59  const std::string& htitle = ( title.empty() ? "Unnamed 3D Histogram ID=" + ID.idAsString() : title );
60 
61  // book the histogram
62  if ( ID.numeric() ) {
63  hist = this->histoSvc()->book( histoPath(), ID.numericID(), htitle, binsX, lowX, highX, binsY, lowY, highY, binsZ,
64  lowZ, highZ );
65  } else if ( ID.literal() ) {
66  hist = this->histoSvc()->book( histoPath() + "/" + ID.literalID(), htitle, binsX, lowX, highX, binsY, lowY, highY,
67  binsZ, lowZ, highZ );
68  }
69 
70  // Check OK
71  if ( !hist ) {
72  this->Error( "IHistogram3D* points to NULL! ID='" + ID.idAsString() + "' title='" + htitle + "'" ).ignore();
73  return nullptr;
74  } // RETURN !!
75 
76  // add histogram into histogram storages
77  m_histo3DMapID[ID] = hist;
78  m_histo3DMapTitle[title] = hist;
79 
80  // Declare to monitoring service
82 
83  // Printout and return
84  if ( this->msgLevel( MSG::DEBUG ) ) {
85  this->debug() << "Booked 3D Histogram : ID='" << ID << "' Path=" << histoPath() << " Title='"
86  << Gaudi::Utils::Histos::htitle( hist ) << "'" << endmsg;
87  }
88  return hist;
89 }

◆ book3D() [2/4]

template<class PBASE >
AIDA::IHistogram3D * GaudiHistos< PBASE >::book3D ( const HistoID ID,
const std::string title,
const HistoBinEdges edgesX,
const HistoBinEdges edgesY,
const HistoBinEdges edgesZ 
) const

book the 3D variable binning histogram with given ID

See also
AIDA::IHistogram3D
Parameters
IDunique histogram ID
titlehistogram title (must be unique within the algorithm)
edgesXThe histogram x bin edges
edgesYThe histogram y bin edges
edgesZThe histogram z bin edges
Returns
pointer to AIDA 3D histogram

Definition at line 38 of file GaudiHistos_3DVariableBinning.icpp.

40  {
41  //
42  if ( !produceHistos() ) { return nullptr; } // RETURN
43  //
44  // Check ID
45  if ( ID.undefined() ) {
46  this->Error( "Undefined Histogram ID : Title='" + title + "'" ).ignore();
47  return nullptr;
48  }
49 
50  // exist?
51  auto hist = histo3D( ID );
52  // histogram is already booked
53  if ( hist ) { return hist; } // RETURN !!
54 
55  // Histogram title
56  const std::string& htitle = ( title.empty() ? "Unnamed 3D Histogram ID=" + ID.idAsString() : title );
57 
58  // book the histogram
59  if ( ID.numeric() ) {
60  hist = this->histoSvc()->book( histoPath(), ID.numericID(), htitle, edgesX, edgesY, edgesZ );
61  } else if ( ID.literal() ) {
62  hist = this->histoSvc()->book( histoPath() + "/" + ID.literalID(), htitle, edgesX, edgesY, edgesZ );
63  }
64 
65  // check OK
66  if ( !hist ) {
67  this->Error( "IHistogram3D* points to NULL! ID='" + ID.idAsString() + "' title='" + htitle + "'" ).ignore();
68  return nullptr;
69  } // RETURN !!
70 
71  // add histogram into histogram storages
72  m_histo3DMapID[ID] = hist;
73  m_histo3DMapTitle[title] = hist;
74 
75  // Declare to monitoring service
77 
78  // Printout and return
79  if ( this->msgLevel( MSG::DEBUG ) ) {
80  this->debug() << "Booked 3D Histogram : ID='" << ID << "' Path=" << histoPath() << " Title='"
81  << Gaudi::Utils::Histos::htitle( hist ) << "'" << endmsg;
82  }
83  return hist;
84 }

◆ book3D() [3/4]

template<class PBASE >
AIDA::IHistogram3D * GaudiHistos< PBASE >::book3D ( const std::string title,
const double  lowX = 0,
const double  highX = 100,
const unsigned long  binsX = 10,
const double  lowY = 0,
const double  highY = 100,
const unsigned long  binsY = 10,
const double  lowZ = 0,
const double  highZ = 100,
const unsigned long  binsZ = 10 
) const

book the 3D histogram

The histogram will be assigned a unique identifier

See also
IHistogram3D
Parameters
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
binsXnumber of bins in x
lowYlow y limit for histogram
highYhigh y limit for histogram
binsYnumber of bins in y
lowZlow y limit for histogram
highZhigh y limit for histogram
binsZnumber of bins in y
Returns
pointer to AIDA 3D histogram

Definition at line 17 of file GaudiHistos_3DFixedBinning.icpp.

20  {
21  //
22  if ( !produceHistos() ) { return nullptr; } // RETURN
23  //
24  // exist?
25  auto hist = histo3D( title );
26  // histogram is already booked
27  if ( hist ) { return hist; } // RETURN !!
28 
29  // propose the histogram ID
30  HistoID ID;
31  newHistoID( title, ID );
32 
33  // Create a new histogram and return
34  return this->book3D( ID, title, lowX, highX, binsX, lowY, highY, binsY, lowZ, highZ, binsZ );
35 }

◆ book3D() [4/4]

template<class PBASE >
AIDA::IHistogram3D * GaudiHistos< PBASE >::book3D ( const std::string title,
const HistoBinEdges edgesX,
const HistoBinEdges edgesY,
const HistoBinEdges edgesZ 
) const

book the 3D variable binning histogram

The histogram will be assigned a unique identifier

See also
AIDA::IHistogram3D
Parameters
titlehistogram title (must be unique within the algorithm)
edgesXThe histogram x bin edges
edgesYThe histogram y bin edges
edgesZThe histogram z bin edges
Returns
pointer to AIDA 3D histogram

Definition at line 17 of file GaudiHistos_3DVariableBinning.icpp.

18  {
19  //
20  if ( !produceHistos() ) { return nullptr; } // RETURN
21  //
22  // exist?
23  auto hist = histo3D( title );
24  // histogram is already booked
25  if ( hist ) { return hist; } // RETURN !!
26 
27  // propose the histogram ID
28  HistoID ID;
29  newHistoID( title, ID );
30 
31  // Create a new histogram and return
32  return this->book3D( ID, title, edgesX, edgesY, edgesZ );
33 }

◆ bookProfile1D() [1/4]

template<class PBASE >
AIDA::IProfile1D * GaudiHistos< PBASE >::bookProfile1D ( const HistoID ID,
const std::string title,
const double  low = 0,
const double  high = 100,
const unsigned long  bins = 100,
const std::string opt = "",
const double  lowY = -std::numeric_limits<double>::max(),
const double  highY = std::numeric_limits<double>::max() 
) const

book the 1D profile histogram

The histogram will be assigned a unique identifier

See also
IHistogram1D
Parameters
titlehistogram title (must be unique within the algorithm)
edgesThe histogram bin edges
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins
optthe options, used for evaluation of errors
lowYthe min cut-off for y-values
highYthe max cut-off for y-values
Returns
pointer to AIDA 1D profile histogram

Definition at line 37 of file GaudiHistos_1DProfFixedBinning.icpp.

40  {
41  //
42  if ( !produceHistos() ) { return nullptr; } // RETURN
43  //
44  // Check ID
45  if ( ID.undefined() ) {
46  this->Error( "Undefined Histogram ID : Title='" + title + "'" ).ignore();
47  return nullptr;
48  }
49 
50  // exist?
51  auto hist = profile1D( ID );
52  // histogram is already booked
53  if ( hist ) { return hist; } // RETURN !!
54 
55  // Histogram title
56  const std::string& htitle = ( title.empty() ? "Unnamed 1D Profile Histogram ID=" + ID.idAsString() : title );
57 
58  // book the histogram
59  if ( ID.numeric() ) {
60  hist = this->histoSvc()->bookProf( histoPath(), ID.numericID(), htitle, bins, low, high, lowY, highY, opt );
61  } else if ( ID.literal() ) {
62  hist = this->histoSvc()->bookProf( histoPath() + "/" + ID.literalID(), htitle, bins, low, high, lowY, highY, opt );
63  }
64 
65  // test ok
66  if ( !hist ) {
67  this->Error( "IProfile1D* points to NULL! ID='" + ID.idAsString() + "' title='" + htitle + "'" ).ignore();
68  return nullptr;
69  } // RETURN !!
70 
71  // add histogram into histogram storages
72  m_profile1DMapID[ID] = hist;
73  m_profile1DMapTitle[title] = hist;
74 
75  // Declare to monitoring service
77 
78  // printout and return
79  if ( this->msgLevel( MSG::DEBUG ) ) {
80  this->debug() << "Booked 1D Profile Histogram : ID='" << ID << "' Path=" << histoPath() << " Title='"
81  << Gaudi::Utils::Histos::htitle( hist ) << "'" << endmsg;
82  }
83  return hist;
84 }

◆ bookProfile1D() [2/4]

template<class PBASE >
AIDA::IProfile1D * GaudiHistos< PBASE >::bookProfile1D ( const HistoID ID,
const std::string title,
const HistoBinEdges edges 
) const

book the 1D profile histogram

The histogram will be assigned a unique identifier

See also
IHistogram1D
Parameters
titlehistogram title (must be unique within the algorithm)
edgesThe histogram bin edges
Returns
pointer to AIDA 1D profile histogram

Definition at line 35 of file GaudiHistos_1DProfVariableBinning.icpp.

36  {
37  //
38  if ( !produceHistos() ) { return nullptr; } // RETURN
39  //
40  // Check ID
41  if ( ID.undefined() ) {
42  this->Error( "Undefined Histogram ID : Title='" + title + "'" ).ignore();
43  return nullptr;
44  }
45 
46  // exist?
47  auto hist = profile1D( ID );
48  // histogram is already booked
49  if ( hist ) { return hist; } // RETURN !!
50 
51  // Histogram title
52  const std::string& htitle = ( title.empty() ? "Unnamed 1D Profile Histogram ID=" + ID.idAsString() : title );
53 
54  // book the histogram
55  if ( ID.numeric() ) {
56  hist = this->histoSvc()->bookProf( histoPath(), ID.numericID(), htitle, edges );
57  } else if ( ID.literal() ) {
58  hist = this->histoSvc()->bookProf( histoPath() + "/" + ID.literalID(), htitle, edges );
59  }
60 
61  // test ok
62  if ( !hist ) {
63  this->Error( "IProfile1D* points to NULL! ID='" + ID.idAsString() + "' title='" + htitle + "'" ).ignore();
64  return nullptr;
65  } // RETURN !!
66 
67  // add histogram into histogram storages
68  m_profile1DMapID[ID] = hist;
69  m_profile1DMapTitle[title] = hist;
70 
71  // Declare to monitoring service
73 
74  // printout and return
75  if ( this->msgLevel( MSG::DEBUG ) ) {
76  this->debug() << "Booked 1D Profile Histogram : ID='" << ID << "' Path=" << histoPath() << " Title='"
77  << Gaudi::Utils::Histos::htitle( hist ) << "'" << endmsg;
78  }
79  return hist;
80 }

◆ bookProfile1D() [3/4]

template<class PBASE >
AIDA::IProfile1D * GaudiHistos< PBASE >::bookProfile1D ( const std::string title,
const double  low = 0,
const double  high = 100,
const unsigned long  bins = 100,
const std::string opt = "",
const double  lowY = -std::numeric_limits<double>::max(),
const double  highY = std::numeric_limits<double>::max() 
) const

book the 1D profile histogram

The histogram will be assigned a unique identifier

See also
IHistogram1D
Parameters
titlehistogram title (must be unique within the algorithm)
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins
optthe options, used for evaluation of errors
lowYthe min cut-off for y-values
highYthe max cut-off for y-values
Returns
pointer to AIDA 1D profile histogram

Definition at line 15 of file GaudiHistos_1DProfFixedBinning.icpp.

17  {
18  //
19  if ( !produceHistos() ) { return nullptr; } // RETURN
20  //
21  // exist?
22  auto hist = profile1D( title );
23  // histogram is already booked
24  if ( hist ) { return hist; } // RETURN !!
25 
26  // propose the histogram ID
27  HistoID ID;
28  newHistoID( title, ID );
29 
30  // Book the histo and return
31  return this->bookProfile1D( ID, title, low, high, bins, opt, lowY, highY );
32 }

◆ bookProfile1D() [4/4]

template<class PBASE >
AIDA::IProfile1D * GaudiHistos< PBASE >::bookProfile1D ( const std::string title,
const HistoBinEdges edges 
) const

book the 1D profile histogram

The histogram will be assigned a unique identifier

See also
IHistogram1D
Parameters
titlehistogram title (must be unique within the algorithm)
edgesThe histogram bin edges
Returns
pointer to AIDA 1D profile histogram

Definition at line 15 of file GaudiHistos_1DProfVariableBinning.icpp.

15  {
16  //
17  if ( !produceHistos() ) { return nullptr; } // RETURN
18  //
19  // exist?
20  auto hist = profile1D( title );
21  // histogram is already booked
22  if ( hist ) { return hist; } // RETURN !!
23 
24  // propose the histogram ID
25  HistoID ID;
26  newHistoID( title, ID );
27 
28  // Book the histo and return
29  return this->bookProfile1D( ID, title, edges );
30 }

◆ bookProfile2D() [1/4]

template<class PBASE >
AIDA::IProfile2D * GaudiHistos< PBASE >::bookProfile2D ( const HistoID ID,
const std::string title,
const double  lowX = 0,
const double  highX = 100,
const unsigned long  binsX = 50,
const double  lowY = 0,
const double  highY = 100,
const unsigned long  binsY = 50 
) const

book the 2D profile histogram with forced ID

See also
AIDA::IProfile2D
Parameters
IDunique histogram ID
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
binsXnumber of bins in x
lowYlow y limit for histogram
highYhigh y limit for histogram
binsYnumber of bins in y
Returns
pointer to AIDA histogram

Definition at line 37 of file GaudiHistos_2DProfFixedBinning.icpp.

39  {
40  //
41  if ( !produceHistos() ) { return 0; } // RETURN
42  //
43  // Check ID
44  if ( ID.undefined() ) {
45  this->Error( "Undefined Histogram ID : Title='" + title + "'" ).ignore();
46  return nullptr;
47  }
48  // exist?
49  auto hist = profile2D( ID );
50  // histogram is already booked
51  if ( 0 != hist ) { return hist; } // RETURN !!
52 
53  // Histogram title
54  const std::string& htitle = ( title.empty() ? "Unnamed 2D Profile Histogram ID=" + ID.idAsString() : title );
55 
56  // book the histogram
57  if ( ID.numeric() ) {
58  hist = this->histoSvc()->bookProf( histoPath(), ID.numericID(), htitle, binsX, lowX, highX, binsY, lowY, highY );
59  } else if ( ID.literal() ) {
60  hist = this->histoSvc()->bookProf( histoPath() + "/" + ID.literalID(), htitle, binsX, lowX, highX, binsY, lowY,
61  highY );
62  }
63 
64  // test OK
65  if ( 0 == hist ) {
66  this->Error( "IProfile2D* points to NULL! ID='" + ID.idAsString() + "' title='" + htitle + "'" ).ignore();
67  return 0;
68  } // RETURN !!
69 
70  // add histogram into histogram storages
71  m_profile2DMapID[ID] = hist;
72  m_profile2DMapTitle[title] = hist;
73 
74  // Declare to monitoring service
76 
77  // printout and return
78  if ( this->msgLevel( MSG::DEBUG ) ) {
79  this->debug() << "Booked 2D Profile Histogram : ID='" << ID << "' Path=" << histoPath() << " Title='"
80  << Gaudi::Utils::Histos::htitle( hist ) << "'" << endmsg;
81  }
82  return hist;
83 }

◆ bookProfile2D() [2/4]

template<class PBASE >
AIDA::IProfile2D * GaudiHistos< PBASE >::bookProfile2D ( const HistoID ID,
const std::string title,
const HistoBinEdges edgesX,
const HistoBinEdges edgesY 
) const

book the 2D profile histogram with forced ID

See also
AIDA::IProfile2D
Parameters
IDunique histogram ID
titlehistogram title (must be unique within the algorithm)
edgesXx bin edges
edgesYy bin edges
Returns
pointer to AIDA histogram

Definition at line 36 of file GaudiHistos_2DProfVariableBinning.icpp.

37  {
38  //
39  if ( !produceHistos() ) { return 0; } // RETURN
40  //
41  // Check ID
42  if ( ID.undefined() ) {
43  this->Error( "Undefined Histogram ID : Title='" + title + "'" ).ignore();
44  return nullptr;
45  }
46  // exist?
47  auto hist = profile2D( ID );
48  // histogram is already booked
49  if ( hist ) { return hist; } // RETURN !!
50 
51  // Histogram title
52  const std::string& htitle = ( title.empty() ? "Unnamed 2D Profile Histogram ID=" + ID.idAsString() : title );
53 
54  // book the histogram
55  if ( ID.numeric() ) {
56  hist = this->histoSvc()->bookProf( histoPath(), ID.numericID(), htitle, edgesX, edgesY );
57  } else if ( ID.literal() ) {
58  hist = this->histoSvc()->bookProf( histoPath() + "/" + ID.literalID(), htitle, edgesX, edgesY );
59  }
60 
61  // test OK
62  if ( !hist ) {
63  this->Error( "IProfile2D* points to NULL! ID='" + ID.idAsString() + "' title='" + htitle + "'" ).ignore();
64  return nullptr;
65  } // RETURN !!
66 
67  // add histogram into histogram storages
68  m_profile2DMapID[ID] = hist;
69  m_profile2DMapTitle[title] = hist;
70 
71  // Declare to monitoring service
73 
74  // printout and return
75  if ( this->msgLevel( MSG::DEBUG ) ) {
76  this->debug() << "Booked 2D Profile Histogram : ID='" << ID << "' Path=" << histoPath() << " Title='"
77  << Gaudi::Utils::Histos::htitle( hist ) << "'" << endmsg;
78  }
79  return hist;
80 }

◆ bookProfile2D() [3/4]

template<class PBASE >
AIDA::IProfile2D * GaudiHistos< PBASE >::bookProfile2D ( const std::string title,
const double  lowX = 0,
const double  highX = 100,
const unsigned long  binsX = 50,
const double  lowY = 0,
const double  highY = 100,
const unsigned long  binsY = 50 
) const

book the 2D profile histogram

The histogram will be assigned a unique identifier

See also
AIDA::IProfile2D
Parameters
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
binsXnumber of bins in x
lowYlow y limit for histogram
highYhigh y limit for histogram
binsYnumber of bins in y
Returns
pointer to AIDA 2D histogram

Definition at line 15 of file GaudiHistos_2DProfFixedBinning.icpp.

17  {
18  //
19  if ( !produceHistos() ) { return 0; } // RETURN
20  //
21  // exist?
22  auto hist = profile2D( title );
23  // histogram is already booked
24  if ( 0 != hist ) { return hist; } // RETURN !!
25 
26  // propose the histogram ID
27  HistoID ID;
28  newHistoID( title, ID );
29 
30  // book histogram and return
31  return this->bookProfile2D( ID, title, lowX, highX, binsX, lowY, highY, binsY );
32 }

◆ bookProfile2D() [4/4]

template<class PBASE >
AIDA::IProfile2D * GaudiHistos< PBASE >::bookProfile2D ( const std::string title,
const HistoBinEdges edgesX,
const HistoBinEdges edgesY 
) const

book the 2D profile histogram

The histogram will be assigned a unique identifier

See also
AIDA::IProfile2D
Parameters
titlehistogram title (must be unique within the algorithm)
edgesXx bin edges
edgesYy bin edges
Returns
pointer to AIDA 2D histogram

Definition at line 15 of file GaudiHistos_2DProfVariableBinning.icpp.

16  {
17  //
18  if ( !produceHistos() ) { return 0; } // RETURN
19  //
20  // exist?
21  auto hist = profile2D( title );
22  // histogram is already booked
23  if ( hist ) { return hist; } // RETURN !!
24 
25  // propose the histogram ID
26  HistoID ID;
27  newHistoID( title, ID );
28 
29  // book histogram and return
30  return this->bookProfile2D( ID, title, edgesX, edgesY );
31 }

◆ checkForNaN()

template<class PBASE >
bool GaudiHistos< PBASE >::checkForNaN ( ) const
inline

get the flag for NaN checks (property "HistoCheckForNan")

Definition at line 2385 of file GaudiHistos.h.

2385 { return m_checkForNaN; }

◆ convertTitleToID()

template<class PBASE >
std::string GaudiHistos< PBASE >::convertTitleToID ( std::string  title) const
protected

Create an ID string from a title string.

Definition at line 360 of file GaudiHistos.icpp.

360  {
361  // clean up the ID string for all unwanted characters
362  for ( const auto& i : m_idReplaceInfo ) { stringSearchReplace( title, i.first, i.second ); }
363  return title;
364 }

◆ fill() [1/5]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::fill ( AIDA::IHistogram1D *  histo,
const double  value,
const double  weight,
const std::string title = "" 
) const

fill the 1D histogram with the value and weight

Parameters
histo1D histogram to be filled
valuevalue to be put into the histogram
weightweight to be used
titlehistogram title (to be used for error report)
Returns
pointer to AIDA 1D histogram

Definition at line 89 of file GaudiHistos_1DFixedBinning.icpp.

90  {
91  if ( !histo ) { return nullptr; } // RETURN
92  //
93  if ( !checkForNaN() ) {
94  Gaudi::Utils::Histos::fill( histo, value, weight );
95  } else if ( std::isfinite( value ) && std::isfinite( weight ) ) {
96  Gaudi::Utils::Histos::fill( histo, value, weight );
97  } else if ( std::isnan( value ) || std::isnan( weight ) ) {
98  this->Warning( "fill():: 'NaN' value is skipped from the histogram '" +
99  Gaudi::Utils::Histos::htitle( histo, title ) + "'" )
100  .ignore();
101  } else {
102  this->Warning( "fill():: 'Infinite' value is skipped from the histogram '" +
103  Gaudi::Utils::Histos::htitle( histo, title ) + "'" )
104  .ignore();
105  }
106  // return
107  return histo;
108 }

◆ fill() [2/5]

template<class PBASE >
AIDA::IHistogram2D * GaudiHistos< PBASE >::fill ( AIDA::IHistogram2D *  histo,
const double  valueX,
const double  valueY,
const double  weight,
const std::string title = "" 
) const

fill the 2D histogram with the value and weight

Parameters
histo2D histogram to be filled
valueXx value to be put into the histogram
valueYy value to be put into the histogram
weightweight to be used
titlehistogram title (to be used for error report)
Returns
pointer to AIDA 2D histogram

Definition at line 91 of file GaudiHistos_2DFixedBinning.icpp.

92  {
93  //
94  if ( !histo ) { return nullptr; } // RETURN
95  //
96  if ( !checkForNaN() ) {
97  Gaudi::Utils::Histos::fill( histo, valueX, valueY, weight );
98  } else if ( std::isfinite( valueX ) && std::isfinite( valueY ) && std::isfinite( weight ) ) {
99  Gaudi::Utils::Histos::fill( histo, valueX, valueY, weight );
100  } else if ( std::isnan( valueX ) || std::isnan( valueY ) || std::isnan( weight ) ) {
101  this->Warning( "fill():: 'NaN' value is skipped from the histogram '" +
102  Gaudi::Utils::Histos::htitle( histo, title ) + "'" )
103  .ignore();
104  } else {
105  this->Warning( "fill():: 'Infinite' value is skipped from the histogram '" +
106  Gaudi::Utils::Histos::htitle( histo, title ) + "'" )
107  .ignore();
108  }
109  // return
110  return histo;
111 }

◆ fill() [3/5]

template<class PBASE >
AIDA::IHistogram3D * GaudiHistos< PBASE >::fill ( AIDA::IHistogram3D *  histo,
const double  valueX,
const double  valueY,
const double  valueZ,
const double  weight,
const std::string title = "" 
) const

fill the 3D histogram with the value and weight

Parameters
histo3D histogram to be filled
valueXx value to be put into the histogram
valueYy value to be put into the histogram
valueZz value to be put into the histogram
weightweight to be used
titlehistogram title (to be used for error report)
Returns
pointer to AIDA 3D histogram

Definition at line 94 of file GaudiHistos_3DFixedBinning.icpp.

96  {
97  if ( !histo ) { return nullptr; } // RETURN
98  //
99  if ( !checkForNaN() ) {
100  Gaudi::Utils::Histos::fill( histo, valueX, valueY, valueZ, weight );
101  } else if ( std::isfinite( valueX ) && std::isfinite( valueY ) && std::isfinite( valueZ ) &&
102  std::isfinite( weight ) ) {
103  Gaudi::Utils::Histos::fill( histo, valueX, valueY, valueZ, weight );
104  } else if ( std::isnan( valueX ) || std::isnan( valueY ) || std::isnan( valueZ ) || std::isnan( weight ) ) {
105  this->Warning( "fill():: 'NaN' value is skipped from the histogram '" +
106  Gaudi::Utils::Histos::htitle( histo, title ) + "'" )
107  .ignore();
108  } else {
109  this->Warning( "fill():: 'Infinite' value is skipped from the histogram '" +
110  Gaudi::Utils::Histos::htitle( histo, title ) + "'" )
111  .ignore();
112  }
113  // return
114  return histo;
115 }

◆ fill() [4/5]

template<class PBASE >
AIDA::IProfile1D * GaudiHistos< PBASE >::fill ( AIDA::IProfile1D *  histo,
const double  valueX,
const double  valueY,
const double  weight,
const std::string title = "" 
) const

fill the 1D profile histogram with the values and weight

Parameters
histo1D profile histogram to be filled
valueXx value to be put into the histogram
valueYy value to be put into the histogram
weightweight to be used
titlehistogram title (to be used for error report)
Returns
pointer to AIDA 1D histogram

Definition at line 89 of file GaudiHistos_1DProfFixedBinning.icpp.

90  {
91  //
92  if ( !histo ) { return nullptr; } // RETURN
93  //
94  if ( !checkForNaN() ) {
95  Gaudi::Utils::Histos::fill( histo, valueX, valueY, weight );
96  } else if ( std::isfinite( valueX ) && std::isfinite( valueY ) && std::isfinite( weight ) ) {
97  Gaudi::Utils::Histos::fill( histo, valueX, valueY, weight );
98  } else if ( std::isnan( valueX ) || std::isnan( valueY ) || std::isnan( weight ) ) {
99  this->Warning( "fill():: 'NaN' value is skipped from the histogram '" +
100  Gaudi::Utils::Histos::htitle( histo, title ) + "'" )
101  .ignore();
102  } else {
103  this->Warning( "fill():: 'Infinite' value is skipped from the histogram '" +
104  Gaudi::Utils::Histos::htitle( histo, title ) + "'" )
105  .ignore();
106  }
107  // return
108  return histo;
109 }

◆ fill() [5/5]

template<class PBASE >
AIDA::IProfile2D * GaudiHistos< PBASE >::fill ( AIDA::IProfile2D *  histo,
const double  valueX,
const double  valueY,
const double  valueZ,
const double  weight,
const std::string title = "" 
) const

fill the 2D profile histogram with the values and weight

Parameters
histo2D profile histogram to be filled
valueXx value to be put into the histogram
valueYy value to be put into the histogram
valueZz value to be put into the histogram
weightweight to be used
titlehistogram title (to be used for error report)
Returns
pointer to AIDA 1D histogram

Definition at line 88 of file GaudiHistos_2DProfFixedBinning.icpp.

89  {
90  if ( 0 == histo ) { return 0; } // RETURN
91  //
92  if ( !checkForNaN() ) {
93  Gaudi::Utils::Histos::fill( histo, valueX, valueY, valueZ, weight );
94  } else if ( std::isfinite( valueX ) && std::isfinite( valueY ) && std::isfinite( valueZ ) &&
95  std::isfinite( weight ) ) {
96  Gaudi::Utils::Histos::fill( histo, valueX, valueY, valueZ, weight );
97  } else if ( std::isnan( valueX ) || std::isnan( valueY ) || std::isnan( valueZ ) || std::isnan( weight ) ) {
98  this->Warning( "fill():: 'NaN' value is skipped from the histogram '" +
99  Gaudi::Utils::Histos::htitle( histo, title ) + "'" )
100  .ignore();
101  } else {
102  this->Warning( "fill():: 'Infinite' value is skipped from the histogram '" +
103  Gaudi::Utils::Histos::htitle( histo, title ) + "'" )
104  .ignore();
105  }
106  // return
107  return histo;
108 }

◆ finalize()

template<class PBASE >
StatusCode GaudiHistos< PBASE >::finalize
overrideprotected

standard finalization method

Returns
status code

Definition at line 122 of file GaudiHistos.icpp.

128  {
129 
130  if ( produceHistos() ) {
131 
132  // Count how many histos of each type
133  if ( ( !noHistos() ) && histoCountersPrint() ) {
134  const unsigned int n1D = histo1DMapID().size();
135  const unsigned int n2D = histo2DMapID().size();
136  const unsigned int n3D = histo3DMapID().size();
137  const unsigned int n1DP = profile1DMapID().size();
138  const unsigned int n2DP = profile2DMapID().size();
139  const unsigned int total = n1D + n2D + n3D + n1DP + n2DP;
140  if ( total > 0 ) {
141  this->always() << "Booked " << total << " Histogram(s) : ";
142  if ( n1D > 0 ) this->always() << "1D=" << n1D << " ";
143  if ( n2D > 0 ) this->always() << "2D=" << n2D << " ";
144  if ( n3D > 0 ) this->always() << "3D=" << n3D << " ";
145  if ( n1DP > 0 ) this->always() << "1DProf=" << n1DP << " ";
146  if ( n2DP > 0 ) this->always() << "2DProf=" << n2DP << " ";
147  this->always() << endmsg;
148  }
149  }
150 
151  // detailed printing
152  if ( histosPrint() ) { printHistos(); }
153  }
154 
155  // clear all maps
166 
167  // finalize base class
168  return PBASE::finalize();
169 }

◆ fullDetail()

template<class PBASE >
bool GaudiHistos< PBASE >::fullDetail ( ) const
inline

get flag to control output level of histograms

Definition at line 2383 of file GaudiHistos.h.

2383 { return m_fullDetail; }

◆ histo() [1/2]

template<class PBASE >
AIDA::IHistogram1D* GaudiHistos< PBASE >::histo ( const HistoID ID) const
inline

access the EXISTING 1D histogram by ID

Wrapper method for the equivalent histo1D method. Retained for backwards compatibility, please use histo1D instead.

return the pointer to existing 1D histogram or NULL

Definition at line 2340 of file GaudiHistos.h.

2340 { return histo1D( ID ); }

◆ histo() [2/2]

template<class PBASE >
AIDA::IHistogram1D* GaudiHistos< PBASE >::histo ( const std::string title) const
inline

access the EXISTING 1D histogram by title

Wrapper method for the equivalent histo1D method. Retained for backwards compatibility, please use histo1D instead.

return the pointer to existing 1D histogram or NULL

Definition at line 2292 of file GaudiHistos.h.

2292 { return histo1D( title ); }

◆ histo1D() [1/2]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::histo1D ( const HistoID ID) const

access the EXISTING 1D histogram by ID return the pointer to existing 1D histogram or NULL

Definition at line 294 of file GaudiHistos.icpp.

294  {
295  return lookup_( histo1DMapID(), ID );
296 }

◆ histo1D() [2/2]

template<class PBASE >
AIDA::IHistogram1D* GaudiHistos< PBASE >::histo1D ( const std::string title) const
inline

access the EXISTING 1D histogram by title return the pointer to existing 1D histogram or NULL

Definition at line 2280 of file GaudiHistos.h.

2280  {
2281  auto found = histo1DMapTitle().find( title );
2282  return found != histo1DMapTitle().end() ? found->second : nullptr;
2283  }

◆ histo1DMapID()

template<class PBASE >
const Histo1DMapID& GaudiHistos< PBASE >::histo1DMapID ( ) const
inline

get access to the map of all 1D histograms index via ID

// iterate over the map!
for ( const auto& entry : histo1DMapID() )
{
// histogram ID
const HistoID ID = entry.first ;
// histogram itself
AIDA::IHistogram1D* h = entry.second ;
if ( 0 == h ) { continue ;}
std::cout << " Histogram ID " << ID
<< " Histogram title " << h->title() << std::endl ;
}

Definition at line 2458 of file GaudiHistos.h.

2458 { return m_histo1DMapID; }

◆ histo1DMapTitle()

template<class PBASE >
const Histo1DMapTitle& GaudiHistos< PBASE >::histo1DMapTitle ( ) const
inline

get access to the map of all 1D histograms indexed via their title

Using this method one can inspect e.g. a list of active histograms

// iterate over the map!
for ( const auto& entry :histo1DMapTitle() )
{
// histogram title
const std::string& title = entry.first ;
// histogram itself
AIDA::IHistogram1D* hist = entry.second ;
if( !hist ) { continue ; } // ATTENTION!
std::cout << " Histogram title " << title << std::endl ;
}
Attention
The map COULD contains NULL pointers, the check before use is mandatory!

Definition at line 2434 of file GaudiHistos.h.

2434 { return m_histo1DMapTitle; }

◆ histo2D() [1/2]

template<class PBASE >
AIDA::IHistogram2D * GaudiHistos< PBASE >::histo2D ( const HistoID ID) const

access the EXISTING 2D histogram by ID return the pointer to existing 2D histogram or NULL

Definition at line 301 of file GaudiHistos.icpp.

301  {
302  return lookup_( histo2DMapID(), ID );
303 }

◆ histo2D() [2/2]

template<class PBASE >
AIDA::IHistogram2D* GaudiHistos< PBASE >::histo2D ( const std::string title) const
inline

access the EXISTING 2D histogram by title return the pointer to existing 2D histogram or NULL

Definition at line 2297 of file GaudiHistos.h.

2297  {
2298  auto found = histo2DMapTitle().find( title );
2299  return histo2DMapTitle().end() != found ? found->second : nullptr;
2300  }

◆ histo2DMapID()

template<class PBASE >
const Histo2DMapID& GaudiHistos< PBASE >::histo2DMapID ( ) const
inline

get access to the map of 2D histograms index via ID

// iterate over the map!
for ( const auto& entry : histo2DMapID() )
{
// histogram ID
const HistoID ID = entry.first ;
// histogram itself
AIDA::IHistogram2D* h = entry.second ;
if ( 0 == h ) { continue ;}
std::cout << " Histogram ID " << ID
<< " Histogram title " << h->title() << std::endl ;
}

Definition at line 2508 of file GaudiHistos.h.

2508 { return m_histo2DMapID; }

◆ histo2DMapTitle()

template<class PBASE >
const Histo2DMapTitle& GaudiHistos< PBASE >::histo2DMapTitle ( ) const
inline

get access to the map of all 2D histograms indexed via their title

Using this method one can inspect e.g. a list of active histograms

// iterate over the map!
for ( const auto& entry : histo2DMapTitle() )
{
// histogram title
const std::string& title = entry.first ;
// histogram itself
AIDA::IHistogram2D* hist = entry.second ;
if( 0 == hist ) { continue ; } // ATTENTION!
std::cout << " Histogram title " << title << std::endl ;
}
Attention
The map COULD contains NULL pointers, the check before use is mandatory!

Definition at line 2485 of file GaudiHistos.h.

2485 { return m_histo2DMapTitle; }

◆ histo3D() [1/2]

template<class PBASE >
AIDA::IHistogram3D * GaudiHistos< PBASE >::histo3D ( const HistoID ID) const

access the EXISTING 3D histogram by ID return the pointer to existing 3D histogram or NULL

Definition at line 308 of file GaudiHistos.icpp.

308  {
309  return lookup_( histo3DMapID(), ID );
310 }

◆ histo3D() [2/2]

template<class PBASE >
AIDA::IHistogram3D* GaudiHistos< PBASE >::histo3D ( const std::string title) const
inline

access the EXISTING 3D histogram by title return the pointer to existing 3D histogram or NULL

Definition at line 2305 of file GaudiHistos.h.

2305  {
2306  auto found = histo3DMapTitle().find( title );
2307  return histo3DMapTitle().end() != found ? found->second : nullptr;
2308  }

◆ histo3DMapID()

template<class PBASE >
const Histo3DMapID& GaudiHistos< PBASE >::histo3DMapID ( ) const
inline

get access to the map of all 3D histograms index via a ID

// iterate over the map!
for ( const auto& entry : histo3DMapID() )
{
// histogram ID
const HistoID ID = entry.first ;
// histogram itself
AIDA::IHistogram3D* h = entry.second ;
if ( 0 == h ) { continue ;}
std::cout << " Histogram ID " << ID
<< " Histogram title " << h->title() << std::endl ;
}

Definition at line 2558 of file GaudiHistos.h.

2558 { return m_histo3DMapID; }

◆ histo3DMapTitle()

template<class PBASE >
const Histo3DMapTitle& GaudiHistos< PBASE >::histo3DMapTitle ( ) const
inline

get access to the map of all 3D histograms indexed via their title

Using this method one can inspect e.g. a list of active histograms

// iterate over the map!
for ( const auto& entry : histo3DMapTitle() )
{
// histogram title
const std::string& title = entry.first ;
// histogram itself
AIDA::IHistogram3D* hist = entry.second ;
if( 0 == hist ) { continue ; } // ATTENTION!
std::cout << " Histogram title " << title << std::endl ;
}
Attention
The map COULD contains NULL pointers, the check before use is mandatory!

Definition at line 2535 of file GaudiHistos.h.

2535 { return m_histo3DMapTitle; }

◆ histoCountersPrint()

template<class PBASE >
bool GaudiHistos< PBASE >::histoCountersPrint ( ) const
inline

print histogram counters at finalization ?

Definition at line 2399 of file GaudiHistos.h.

2399 { return m_histoCountersPrint; }

◆ histoDir()

template<class PBASE >
const std::string& GaudiHistos< PBASE >::histoDir ( ) const
inline

get histogram directory (property "HistoDir")

Definition at line 2393 of file GaudiHistos.h.

2393 { return m_histoDir; }

◆ histoExists() [1/2]

template<class PBASE >
bool GaudiHistos< PBASE >::histoExists ( const HistoID ID) const
inline

check the existence AND validity of the histogram with given title

Definition at line 2371 of file GaudiHistos.h.

2371  {
2372  return ( 0 != histo( ID ) || 0 != histo2D( ID ) || 0 != histo3D( ID ) || 0 != profile1D( ID ) ||
2373  0 != profile2D( ID ) );
2374  }

◆ histoExists() [2/2]

template<class PBASE >
bool GaudiHistos< PBASE >::histoExists ( const std::string title) const
inline

check the existence AND validity of the histogram with given title

Definition at line 2365 of file GaudiHistos.h.

2365  {
2366  return ( 0 != histo( title ) || 0 != histo2D( title ) || 0 != histo3D( title ) || 0 != profile1D( title ) ||
2367  0 != profile2D( title ) );
2368  }

◆ histoOffSet()

template<class PBASE >
HistoID::NumericID GaudiHistos< PBASE >::histoOffSet ( ) const
inline

get the value for histogram offset (property "HistoOffSet")

Definition at line 2389 of file GaudiHistos.h.

2389 { return m_histoOffSet; }

◆ histoPath()

template<class PBASE >
std::string GaudiHistos< PBASE >::histoPath

get the constructed histogram path

Definition at line 368 of file GaudiHistos.icpp.

368  {
370  return splitHistoDir() ? dirHbookName( path ) : path;
371 }

◆ histosPrint()

template<class PBASE >
bool GaudiHistos< PBASE >::histosPrint ( ) const
inline

print histograms at finalization ?

Definition at line 2397 of file GaudiHistos.h.

2397 { return m_histosPrint; }

◆ histoTopDir()

template<class PBASE >
const std::string& GaudiHistos< PBASE >::histoTopDir ( ) const
inline

get top-level histogram directory (property "HistoTopDir")

Definition at line 2391 of file GaudiHistos.h.

2391 { return m_histoTopDir; }

◆ initialize()

template<class PBASE >
StatusCode GaudiHistos< PBASE >::initialize
overrideprotected

standard initialization method

Returns
status code

Definition at line 85 of file GaudiHistos.icpp.

91  {
92  // initialize base class
93  const StatusCode sc = PBASE::initialize();
94  if ( sc.isFailure() ) return sc;
95 
96  // produce histograms?
97  if ( !produceHistos() ) {
98  this->debug() << "Histogram production is switched OFF" << endmsg;
99  return sc;
100  }
101 
102  // check the validity of histogram service
103  if ( !this->histoSvc() ) { return this->Error( "initialize():: IHistogramSvc* is invalid" ); }
104 
105  // Warn if the user has decided to use numerical automatic IDs
106  if ( useNumericAutoIDs() ) {
107  this->Warning(
108  "Using numerical automatic IDs. These are not guaranteed to be totally deterministic. Use with care...",
110  .ignore();
111  }
112 
113  // Finally, print the location histogram will be written to
114  this->Print( "The histogram path is set to be '" + histoPath() + "'", StatusCode::SUCCESS, MSG::DEBUG ).ignore();
115 
116  return sc;
117 }

◆ monitorHisto()

template<class PBASE >
void GaudiHistos< PBASE >::monitorHisto ( const AIDA::IBaseHistogram *  hist,
const HistoID ID 
) const
private

Declare a histogram to the monitor service.

Uses the histogram ID as the 'name' sent to the monitor service and the histogram title as the long description

Definition at line 281 of file GaudiHistos.icpp.

281  {
282  if ( hist && m_declareMoniHists ) {
283  if ( this->msgLevel( MSG::DEBUG ) ) {
284  this->debug() << "Monitoring histogram '" << ID.idAsString() << "' desc = '"
285  << Gaudi::Utils::Histos::htitle( hist ) << "'" << endmsg;
286  }
287  this->declareInfo( histoPath() + "/" + ID.idAsString(), hist, Gaudi::Utils::Histos::htitle( hist ) );
288  }
289 }

◆ newHistoID()

template<class PBASE >
void GaudiHistos< PBASE >::newHistoID ( const std::string title,
HistoID ID 
) const
private

Create a new histogram ID using the given title.

Parameters
[in]titleHistogram title
[out]IDThe ID to use for the new histogram

Definition at line 337 of file GaudiHistos.icpp.

337  {
338  if ( useNumericAutoIDs() || title.empty() ) {
339  if ( !useNumericAutoIDs() ) {
340  this->Warning(
341  "Cannot generate automatic literal ID from an empty title ! Using numeric ID instead for histogram ID",
343  .ignore();
344  }
345  // propose the histogram ID (always numeric)
346  ID = HistoID( totalNumberOfHistos() + 1 + histoOffSet() );
347  // adjust the proposed ID
348  while ( histoExists( ID ) ) { ID = HistoID( ID.numeric() + 1 ); }
349  } else {
350  // use the title to create a unique literal ID
351  ID = HistoID( this->convertTitleToID( title ) );
352  // Just in case ...
353  while ( histoExists( ID ) ) { ID = HistoID( ID.idAsString() + "_" ); }
354  }
355 }

◆ noHistos()

template<class PBASE >
bool GaudiHistos< PBASE >::noHistos
private

Check if all histogram maps are empty.

Definition at line 272 of file GaudiHistos.icpp.

272  {
273  return ( histo1DMapTitle().empty() && histo2DMapTitle().empty() && histo3DMapTitle().empty() &&
274  profile1DMapTitle().empty() && profile2DMapTitle().empty() && histo1DMapID().empty() &&
275  histo2DMapID().empty() && histo3DMapID().empty() && profile1DMapID().empty() && profile2DMapID().empty() );
276 }

◆ plot() [1/8]

template<class PBASE >
AIDA::IHistogram1D* GaudiHistos< PBASE >::plot ( const double  value,
const Gaudi::Histo1DDef hdef,
const double  weight = 1.0 
) const
inline

fill the 1D histogram (book on demand)

Wrapper method for the equivalent plot1D method. Retained for backwards compatibility, please use plot1D instead.

Parameters
valuevalue to be filled
hdefhistogram descriptor
weightweight
Returns
pointer to AIDA 1D histogram

Definition at line 203 of file GaudiHistos.h.

204  {
205  return plot1D( value, hdef, weight );
206  }

◆ plot() [2/8]

template<class PBASE >
AIDA::IHistogram1D* GaudiHistos< PBASE >::plot ( const double  value,
const HistoID ID,
const Gaudi::Histo1DDef hdef,
const double  weight = 1.0 
) const
inline

fill the 1D histogram (book on demand)

Wrapper method for the equivalent plot1D method. Retained for backwards compatibility, please use plot1D instead.

Parameters
valuevalue to be filled
IDhistogram identifier
hdefhistogram descriptor
weightweight
Returns
pointer to AIDA 1D histogram

Definition at line 335 of file GaudiHistos.h.

336  {
337  return plot1D( value, ID, hdef, weight );
338  }

◆ plot() [3/8]

template<class PBASE >
AIDA::IHistogram1D* GaudiHistos< PBASE >::plot ( const double  value,
const HistoID ID,
const std::string title,
const double  low,
const double  high,
const unsigned long  bins = 100,
const double  weight = 1.0 
) const
inline

fill the 1D histogram with forced ID assignment (book on demand)

Wrapper method for the equivalent plot1D method. Retained for backwards compatibility, please use plot1D instead.

Parameters
valuevalue to be filled
IDhistogram identifier
titlehistogram title (must be unique within the algorithm)
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins
weightweight
Returns
pointer to AIDA 1D histogram

Definition at line 290 of file GaudiHistos.h.

292  {
293  return plot1D( value, ID, title, low, high, bins, weight );
294  }

◆ plot() [4/8]

template<class PBASE >
AIDA::IHistogram1D* GaudiHistos< PBASE >::plot ( const double  value,
const std::string title,
const double  low,
const double  high,
const unsigned long  bins = 100,
const double  weight = 1.0 
) const
inline

fill the 1D histogram (book on demand)

Wrapper method for the equivalent plot1D method. Retained for backwards compatibility, please use plot1D instead.

Parameters
valuevalue to be filled
titlehistogram title (must be unique within the algorithm)
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins
weightweight
Returns
pointer to AIDA 1D histogram

Definition at line 162 of file GaudiHistos.h.

163  {
164  return plot1D( value, title, low, high, bins, weight );
165  }

◆ plot() [5/8]

template<class PBASE >
template<class FUNCTION , class OBJECT , class WEIGHT >
AIDA::IHistogram1D* GaudiHistos< PBASE >::plot ( const FUNCTION &  func,
OBJECT  first,
OBJECT  last,
const HistoID ID,
const std::string title,
const double  low,
const double  high,
const unsigned long  bins,
const WEIGHT &  weight 
) const
inline

book and fill the 1D histogram with forced ID and information from [first,last) sequence with given weight

// example with numerical ID
plot( sin , // function
v.begin() , v.end() , // sequence
100 , " bla-bla " , // ID and title
-1. , 1.0 , // low and high limits
100 , // number of bins
sinh ); // weight function
// example with literal ID
plot( sin , // function
v.begin() , v.end() , // sequence
"sin" , " bla-bla " , // ID and title
-1. , 1.0 , // low and high limits
100 , // number of bins
sinh ); // weight function
Attention
no checks for NaN or Finite are performed!

Sequence, objects and function can be non-trivial:

Particles* p = ... ;
plot( PT , // function
p->begin() , p->end() , // sequence
100 , " bla-bla " , // ID and title
-1. , 1.0 , // low and high limits
100 , // number of bins
MASS ) ; // weight function

where PT and MASS can be any function or function object for which the expressions PT(p) and MASS with p of type Particle* have some sense and can be evaluated to the values, which is convertible to double

Attention
These plot methods using iterator ranges are more efficient than the simplier "value" only methods, since the associated histogram only requires locating from internal storage once per loop, as opposed to once per fill for the simplier functions. It is recommended to use these whenever possible.
See also
AIDA::IHistogram1D
Parameters
firstbegin of the sequence
lastend of the sequence
IDhistogram identifier
titlehistogram title
funcfunction to be plotted
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins for histogram
weightweight function

Definition at line 645 of file GaudiHistos.h.

647  {
648  AIDA::IHistogram1D* h = nullptr;
649  if ( produceHistos() ) {
650  // retrieve or book the histogram
651  h = histo1D( ID );
652  if ( !h ) { h = book1D( ID, title, low, high, bins ); }
653  // fill histogram
654  while ( first != last && h ) {
655  h = fill( h, func( *first ), weight( *first ), title );
656  ++first;
657  }
658  }
659  return h;
660  }

◆ plot() [6/8]

template<class PBASE >
template<class FUNCTION , class OBJECT >
AIDA::IHistogram1D* GaudiHistos< PBASE >::plot ( const FUNCTION &  func,
OBJECT  first,
OBJECT  last,
const HistoID ID,
const std::string title,
const double  low,
const double  high,
const unsigned long  bins = 100 
) const
inline

fill the 1D histogram with forced ID and information from [first,last) sequence

// Example with numeric ID
plot( sin , // function
v.begin() , v.end() , // sequence
100 , " bla-bla " , // ID and title
-1. , 1.0 , // low and high limits
100 ); // number of bins
// Example with literal ID
plot( sin , // function
v.begin() , v.end() , // sequence
"sin" , " bla-bla " , // ID and title
-1. , 1.0 , // low and high limits
100 ); // number of bins

Sequence, objects and function can be non-trivial:

Particles* p = ... ;
plot( PT , // function
p->begin() , p->end() , // sequence
100 , " bla-bla " , // ID and title
-1. , 1.0 , // low and high limits
100 ) ; // number of bins
Attention
These plot methods using iterator ranges are more efficient than the simplier "value" only methods, since the associated histogram only requires locating from internal storage once per loop, as opposed to once per fill for the simplier functions. It is recommended to use these whenever possible.
See also
AIDA::IHistogram1D
Parameters
funcfunction to be plotted
firstbegin of the sequence
lastend of the sequence
IDhistogram identifier
titlehistogram title
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins for histogram

Definition at line 475 of file GaudiHistos.h.

477  {
478  AIDA::IHistogram1D* h( 0 );
479  if ( produceHistos() ) {
480  // retrieve or book the histogram
481  h = histo1D( ID );
482  if ( !h ) { h = book1D( ID, title, low, high, bins ); }
483  // fill histogram
484  while ( first != last && h ) {
485  h = fill( h, func( *first ), 1.0, title );
486  ++first;
487  }
488  }
489  return h;
490  }

◆ plot() [7/8]

template<class PBASE >
template<class FUNCTION , class OBJECT , class WEIGHT >
AIDA::IHistogram1D* GaudiHistos< PBASE >::plot ( const FUNCTION &  func,
OBJECT  first,
OBJECT  last,
const std::string title,
const double  low,
const double  high,
const unsigned long  bins,
const WEIGHT &  weight 
) const
inline

book and fill the 1D histogram with information from [first,last) sequence with given weight

plot( sin , // function
v.begin() , v.end() , // sequence
" bla-bla " , // title
-1. , 1.0 , // low and high limits
100 , // number of bins
tanh ); // weight function
Attention
The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title. An option exists to instead use numerical IDs. In this case the first histogram booked will be ID=1 the next ID=2 and so on. Note though this scheme is not recommended as it does NOT guarantee predictability of the ID a given histogram will be given when filled under conditional statements, since in these circumstances the order in which the histograms are first filled, and thus booked, will depend on the nature of the first few events read. This is particularly problematic when users submit many parallel 'sub-jobs' and then attempt to merge the final output ROOT (or HBOOK) files, since a given histogram could have different IDs in each of the sub-jobs. Consequently it is strongly recommended that users do not use numerical automatic IDs unless they are sure they understand what they are doing.

Sequence, objects and function can be non-trivial:

Particles* p = ... ;
plot( PT , // function
p->begin() , p->end() , // sequence
" bla-bla " , // title
-1. , 1.0 , // low and high limits
100 , // number of bins
MASS ) ; // weight function

where PT and MASS can be any function or function object for which the expressions PT(p) and MASS with p of type Particle* have some sense and can be evaluated to the values, which is convertible to double

Attention
These plot methods using iterator ranges are more efficient than the simplier "value" only methods, since the associated histogram only requires locating from internal storage once per loop, as opposed to once per fill for the simplier functions. It is recommended to use these whenever possible.
See also
AIDA::IHistogram1D
Parameters
firstbegin of the sequence
lastend of the sequence
titlehistogram title
funcfunction to be plotted
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins for histogram
weightweight function

Definition at line 561 of file GaudiHistos.h.

563  {
564  AIDA::IHistogram1D* h = nullptr;
565  if ( produceHistos() ) {
566  // retrieve or book the histogram
567  h = histo1D( title );
568  if ( !h ) { h = book1D( title, low, high, bins ); }
569  // fill histogram
570  while ( first != last && h ) {
571  h = fill( h, func( *first ), weight( *first ), title );
572  ++first;
573  }
574  }
575  return h;
576  }

◆ plot() [8/8]

template<class PBASE >
template<class FUNCTION , class OBJECT >
AIDA::IHistogram1D* GaudiHistos< PBASE >::plot ( const FUNCTION &  func,
OBJECT  first,
OBJECT  last,
const std::string title,
const double  low,
const double  high,
const unsigned long  bins = 100 
) const
inline

fill the 1D histogram with information from [first,last) sequence

plot( sin , // function
v.begin() , v.end() , // sequence
" bla-bla " , // title
-1. , 1.0 , // low and high limits
100 ) // number of bins
Attention
The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title. An option exists to instead use numerical IDs. In this case the first histogram booked will be ID=1 the next ID=2 and so on. Note though this scheme is not recommended as it does NOT guarantee predictability of the ID a given histogram will be given when filled under conditional statements, since in these circumstances the order in which the histograms are first filled, and thus booked, will depend on the nature of the first few events read. This is particularly problematic when users submit many parallel 'sub-jobs' and then attempt to merge the final output ROOT (or HBOOK) files, since a given histogram could have different IDs in each of the sub-jobs. Consequently it is strongly recommended that users do not use numerical automatic IDs unless they are sure they understand what they are doing.

Sequence, objects and function can be non-trivial:

Particles* p = ... ;
plot( PT , // function
p->begin() , p->end() , // sequence
" bla-bla " , // title
-1. , 1.0 , // low and high limits
100 ) ; // number of bins

where PT can be any function or function object for which the expression PT(p) , with p of type Particle* have some sense and can be evaluated to the values, which is convertible to double

Attention
These plot methods using iterator ranges are more efficient than the simplier "value" only methods, since the associated histogram only requires locating from internal storage once per loop, as opposed to once per fill for the simplier functions. It is recommended to use these whenever possible.
See also
AIDA::IHistogram1D
Parameters
funcfunction to be plotted
firstbegin of the sequence
lastend of the sequence
titlehistogram title
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins for histogram

Definition at line 403 of file GaudiHistos.h.

404  {
405  AIDA::IHistogram1D* h = nullptr;
406  if ( produceHistos() ) {
407  // retrieve or book the histogram
408  h = histo1D( title );
409  if ( !h ) { h = book1D( title, low, high, bins ); }
410  // fill histogram
411  while ( first != last && h ) {
412  h = fill( h, func( *first ), 1.0, title );
413  ++first;
414  }
415  }
416  return h;
417  }

◆ plot1D() [1/6]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::plot1D ( const double  value,
const Gaudi::Histo1DDef hdef,
const double  weight = 1.0 
) const

fill the 1D histogram (book on demand)

const Gaudi::Histo1DDef& hdef = ... ;
const double mass = ... ;
plot1D ( mass , hdef ) ;

The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title.

The histogram descriptor comes e.g. from the component properties.

See also
AIDA::IHistogram1D
Parameters
valuevalue to be filled
hdefhistogram descriptor
weightweight
Returns
pointer to AIDA 1D histogram

Definition at line 161 of file GaudiHistos_1DFixedBinning.icpp.

162  {
163  return plot1D( value, hdef.title(), hdef.lowEdge(), hdef.highEdge(), hdef.bins(), weight );
164 }

◆ plot1D() [2/6]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::plot1D ( const double  value,
const HistoID ID,
const Gaudi::Histo1DDef hdef,
const double  weight = 1.0 
) const

fill the 1D histogram with forced ID assignment (book on demand)

// get the histogram descriptor
const Gaudi::Histo1DDef& hdef = ... ;
// get the histogram ID
const HistoID ID = ... ;
const double mass = ... ;
plot1D ( mass , ID , hdef )
See also
AIDA::IHistogram1D

The histogram descriptor comes e.g. from component properties

Parameters
valuevalue to be filled
IDhistogram identifier
hdefhistogram descriptor
weightweight
Returns
pointer to AIDA 1D histogram

Definition at line 169 of file GaudiHistos_1DFixedBinning.icpp.

170  {
171  return plot1D( value, ID, hdef.title(), hdef.lowEdge(), hdef.highEdge(), hdef.bins(), weight );
172 }

◆ plot1D() [3/6]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::plot1D ( const double  value,
const HistoID ID,
const std::string title,
const double  low,
const double  high,
const unsigned long  bins = 100,
const double  weight = 1.0 
) const

fill the 1D histogram with forced ID assignment (book on demand)

const double mass = ... ;
plot1D( mass , 15 , "Invariant Mass" , 2.5 , 3.5 , 100 )

This example illustrates the filling of the 1D histogram ID=15 titled "Invariant Mass" with value mass .

If the histogram with given ID does not exist yet it will be automatically booked with parameters low equal to 2.5, parameters high equal to 3.5 and bins equal to 100.

It is also possible to use literal IDs. For example :-

const double mass = ... ;
plot1D( mass , "mass" , "Invariant Mass" , 2.5 , 3.5 , 100 )

Will book the same histogram, using the id "mass".

It is also possible using literal IDs, to place histograms in sub-directories from the main histogram directory, using for example :-

const double mass = ... ;
plot1D( mass , "subdir/mass" , "Invariant Mass" , 2.5 , 3.5 , 100 )

Which will create the histogram "mass" in the sub-directory "subdir". Histograms can also be created in sub-directories with numeric IDs if IDs such as "subdir/1" are used.

Attention
If the histogram with given ID is already booked through automatic assignment of histogram ID, the error will not be detected. Therefore it is recommended to use non-trivial histogram ID offset (property "HistoOffSet") if one need to combine these techniques together. It is still desirable to use the unique histogram title to avoid a bad interference.
See also
AIDA::IHistogram1D
Parameters
valuevalue to be filled
IDhistogram identifier
titlehistogram title (must be unique within the algorithm)
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins
weightweight
Returns
pointer to AIDA 1D histogram

Definition at line 130 of file GaudiHistos_1DFixedBinning.icpp.

132  {
133  AIDA::IHistogram1D* h( nullptr );
134  if ( produceHistos() ) {
135  // retrieve or book the histogram
136  h = histo1D( ID );
137  if ( !h ) { h = book1D( ID, title, low, high, bins ); }
138  // fill
139  h = fill( h, value, weight, title );
140  }
141  return h;
142 }

◆ plot1D() [4/6]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::plot1D ( const double  value,
const HistoID ID,
const std::string title,
const HistoBinEdges edges,
const double  weight = 1.0 
) const

fill the 1D variable binning histogram with forced ID assignment (book on demand)

const GaudiAlg::HistoBinEdges edges = ...;
const double mass = ... ;
plot1D( mass , 15 , "Invariant Mass" , edges )

This example illustrates the filling of the 1D histogram ID=15 titled "Invariant Mass" with value mass.

If the histogram with given ID does not exist yet it will be automatically booked with the given histogram bin edges.

It is also possible to use literal IDs. For example :-

const GaudiAlg::HistoBinEdges edges = ...;
const double mass = ... ;
plot1D( mass , "mass" , "Invariant Mass" , edges )

Will book the same histogram, using the id "mass".

It is also possible using literal IDs, to place histograms in sub-directories from the main histogram directory, using for example :-

const GaudiAlg::HistoBinEdges edges = ...;
const double mass = ... ;
plot1D( mass , "subdir/mass" , "Invariant Mass" , edges )

Which will create the histogram "mass" in the sub-directory "subdir". Histograms can also be created in sub-directories with numeric IDs if IDs such as "subdir/1" are used.

Attention
If the histogram with given ID is already booked through automatic assignment of histogram ID, the error will not be detected. Therefore it is recommended to use non-trivial histogram ID offset (property "HistoOffSet") if one need to combine these techniques together. It is still desirable to use the unique histogram title to avoid a bad interference.
See also
AIDA::IHistogram1D
Parameters
valuevalue to be filled
IDhistogram identifier
titlehistogram title (must be unique within the algorithm)
edgesThe histogram bin edges
weightweight
Returns
pointer to AIDA 1D histogram

Definition at line 103 of file GaudiHistos_1DVariableBinning.icpp.

104  {
105  AIDA::IHistogram1D* h( nullptr );
106  if ( produceHistos() ) {
107  // retrieve or book the histogram
108  h = histo1D( ID );
109  if ( !h ) { h = book1D( ID, title, edges ); }
110  // fill
111  h = fill( h, value, weight, title );
112  }
113  return h;
114 }

◆ plot1D() [5/6]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::plot1D ( const double  value,
const std::string title,
const double  low,
const double  high,
const unsigned long  bins = 100,
const double  weight = 1.0 
) const

fill the 1D histogram (book on demand)

const double mass = ... ;
plot1D( mass , "Invariant Mass" , 2.5 , 3.5 , 100 )

This example illustrates the filling of the histogram titled "InvariantMass" with value mass .

If the histogram with given title does not exist yet it will be automatically booked with parameters low equal to 2.5, parameters high equal to 3.5 and bins equal to 100.

Attention
The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title. An option exists to instead use numerical IDs. In this case the first histogram booked will be ID=1 the next ID=2 and so on. Note though this scheme is not recommended as it does NOT guarantee predictability of the ID a given histogram will be given when filled under conditional statements, since in these circumstances the order in which the histograms are first filled, and thus booked, will depend on the nature of the first few events read. This is particularly problematic when users submit many parallel 'sub-jobs' and then attempt to merge the final output ROOT (or HBOOK) files, since a given histogram could have different IDs in each of the sub-jobs. Consequently it is strongly recommended that users do not use numerical automatic IDs unless they are sure they understand what they are doing.
See also
AIDA::IHistogram1D
Parameters
valuevalue to be filled
titlehistogram title (must be unique within the algorithm)
lowlow limit for histogram
highhigh limit for histogram
binsnumber of bins
weightweight
Returns
pointer to AIDA 1D histogram

Definition at line 113 of file GaudiHistos_1DFixedBinning.icpp.

115  {
116  AIDA::IHistogram1D* h( nullptr );
117  if ( produceHistos() ) {
118  // retrieve or book the histogram
119  h = histo1D( title );
120  if ( !h ) { h = book1D( title, low, high, bins ); }
121  // fill the histogram
122  h = fill( h, value, weight, title );
123  }
124  return h;
125 }

◆ plot1D() [6/6]

template<class PBASE >
AIDA::IHistogram1D * GaudiHistos< PBASE >::plot1D ( const double  value,
const std::string title,
const HistoBinEdges edges,
const double  weight = 1.0 
) const

Fill the 1D variable binning histogram (book on demand)

const GaudiAlg::HistoBinEdges edges = ...;
const double mass = ... ;
plot1D( mass , "Invariant Mass" , edges )

This example illustrates the filling of the histogram titled "InvariantMass" with value mass.

If the histogram with given title does not exist yet it will be automatically booked with the given histogram bin edges.

Attention
The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title. An option exists to instead use numerical IDs. In this case the first histogram booked will be ID=1 the next ID=2 and so on. Note though this scheme is not recommended as it does NOT guarantee predictability of the ID a given histogram will be given when filled under conditional statements, since in these circumstances the order in which the histograms are first filled, and thus booked, will depend on the nature of the first few events read. This is particularly problematic when users submit many parallel 'sub-jobs' and then attempt to merge the final output ROOT (or HBOOK) files, since a given histogram could have different IDs in each of the sub-jobs. Consequently it is strongly recommended that users do not use numerical automatic IDs unless they are sure they understand what they are doing.
See also
AIDA::IHistogram1D
Parameters
valuevalue to be filled
titlehistogram title (must be unique within the algorithm)
edgesThe histogram bin edges
weightweight
Returns
pointer to AIDA 1D histogram

Definition at line 87 of file GaudiHistos_1DVariableBinning.icpp.

88  {
89  AIDA::IHistogram1D* h( nullptr );
90  if ( produceHistos() ) {
91  // retrieve or book the histogram
92  h = histo1D( title );
93  if ( !h ) { h = book1D( title, edges ); }
94  // fill the histogram
95  h = fill( h, value, weight, title );
96  }
97  return h;
98 }

◆ plot2D() [1/4]

template<class PBASE >
AIDA::IHistogram2D * GaudiHistos< PBASE >::plot2D ( const double  valueX,
const double  valueY,
const HistoID ID,
const std::string title,
const double  lowX,
const double  highX,
const double  lowY,
const double  highY,
const unsigned long  binsX = 50,
const unsigned long  binsY = 50,
const double  weight = 1.0 
) const

fill the 2D histogram with forced ID assignment (book on demand)

const double mass1 = ... ;
const double mass2 = ... ;
plot2D( mass1, mass2, 15,
"Invariant Mass2 versus Mass1" ,2.5 ,3.5, 4.5, 5.5, 100, 200 );

This example illustrates the filling of the 2D histogram ID=15 titled "Invariant Mass2 versus Mass1" with values mass1 and mass2 .

If the histogram with given title does not exist yet it will be automatically booked with parameters lowX equal to 2.5, highX equal to 3.5, lowY equal to 4.5, highY equal to 5.5, binsX equal to 100 and binsY equal to 200.

It is also possible to use literal IDs. For example :-

const double mass1 = ... ;
const double mass2 = ... ;
plot2D( mass1, mass2, "mass",
"Invariant Mass2 versus Mass1" ,2.5 ,3.5, 4.5, 5.5, 100, 200 );

Will book the same histogram, using the id "mass".

It is also possible using literal IDs, to place histograms in sub-directories from the main histogram directory, using for example :-

const double mass1 = ... ;
const double mass2 = ... ;
plot2D( mass1, mass2, "subdir/mass",
"Invariant Mass2 versus Mass1" ,2.5 ,3.5, 4.5, 5.5, 100, 200 );

Which will create the histogram "mass" in the sub-directory "subdir". Histograms can also be created in sub-directories with numeric IDs if IDs such as "subdir/1" are used.

Attention
If the histogram with given ID is already booked through automatic assignment of histogram ID, the error will not be detected. Therefore it is recommended to use non-trivial histogram ID offset (property "HistoOffSet") if one need to combine these techniques together It is still desirable to use the unique histogram title to avoid a bad interference
See also
AIDA::IHistogram2D
Parameters
valueXx value to be filled
valueYy value to be filled
IDHistogram ID to use
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
lowYlow y limit for histogram
highYhigh y limit for histogram
binsXnumber of bins in x
binsYnumber of bins in y
weightweight
Returns
pointer to AIDA 2D histogram

Definition at line 134 of file GaudiHistos_2DFixedBinning.icpp.

137  {
138  AIDA::IHistogram2D* h( nullptr );
139  // produce histograms ?
140  if ( produceHistos() ) {
141  // retrieve or book the histogram
142  h = histo2D( ID );
143  if ( !h ) { h = book2D( ID, title, lowX, highX, binsX, lowY, highY, binsY ); }
144  // fill the histogram
145  h = fill( h, valueX, valueY, weight, title );
146  }
147  return h;
148 }

◆ plot2D() [2/4]

template<class PBASE >
AIDA::IHistogram2D * GaudiHistos< PBASE >::plot2D ( const double  valueX,
const double  valueY,
const HistoID ID,
const std::string title,
const HistoBinEdges edgesX,
const HistoBinEdges edgesY,
const double  weight = 1.0 
) const

fill the 2D variable histogram with forced ID assignment (book on demand)

const GaudiAlg::HistoBinEdges edgesX = ...;
const GaudiAlg::HistoBinEdges edgesY = ...;
const double mass1 = ... ;
const double mass2 = ... ;
plot2D( mass1, mass2, 15,
"Invariant Mass2 versus Mass1", edgesX, edgesY );

This example illustrates the filling of the 2D histogram ID=15 titled "Invariant Mass2 versus Mass1" with values mass1 and mass2 .

If the histogram with given title does not exist yet it will be automatically booked with the given histogram bin edges.

It is also possible to use literal IDs. For example :-

const GaudiAlg::HistoBinEdges edgesX = ...;
const GaudiAlg::HistoBinEdges edgesY = ...;
const double mass1 = ... ;
const double mass2 = ... ;
plot2D( mass1, mass2, "mass",
"Invariant Mass2 versus Mass1", edgesX, edgesY );

Will book the same histogram, using the id "mass".

It is also possible using literal IDs, to place histograms in sub-directories from the main histogram directory, using for example :-

const GaudiAlg::HistoBinEdges edgesX = ...;
const GaudiAlg::HistoBinEdges edgesY = ...;
const double mass1 = ... ;
const double mass2 = ... ;
plot2D( mass1, mass2, "subdir/mass",
"Invariant Mass2 versus Mass1", edgesX, edgesY );

Which will create the histogram "mass" in the sub-directory "subdir". Histograms can also be created in sub-directories with numeric IDs if IDs such as "subdir/1" are used.

Attention
If the histogram with given ID is already booked through automatic assignment of histogram ID, the error will not be detected. Therefore it is recommended to use non-trivial histogram ID offset (property "HistoOffSet") if one need to combine these techniques together It is still desirable to use the unique histogram title to avoid a bad interference
See also
AIDA::IHistogram2D
Parameters
valueXx value to be filled
valueYy value to be filled
IDHistogram ID to use
titlehistogram title (must be unique within the algorithm)
edgesXThe histogram x bin edges
edgesYThe histogram y bin edges
weightweight
Returns
pointer to AIDA 2D histogram

Definition at line 105 of file GaudiHistos_2DVariableBinning.icpp.

107  {
108  AIDA::IHistogram2D* h( nullptr );
109  if ( produceHistos() ) {
110  // retrieve or book the histogram
111  h = histo2D( ID );
112  if ( !h ) { h = book2D( ID, title, edgesX, edgesY ); }
113  // fill
114  h = fill( h, valueX, valueY, weight, title );
115  }
116  return h;
117 }

◆ plot2D() [3/4]

template<class PBASE >
AIDA::IHistogram2D * GaudiHistos< PBASE >::plot2D ( const double  valueX,
const double  valueY,
const std::string title,
const double  lowX,
const double  highX,
const double  lowY,
const double  highY,
const unsigned long  binsX = 50,
const unsigned long  binsY = 50,
const double  weight = 1.0 
) const

fill the 2D histogram (book on demand)

const double mass1 = ... ;
const double mass2 = ... ;
plot2D( mass1, mass2,
"Invariant Mass2 versus Mass1" ,2.5 ,3.5, 4.5, 5.5, 100, 200 );

This example illustrates the filling of the 2D histogram titled "Invariant Mass2 versus Mass1" with values mass1 and mass2 .

If the histogram with given title does not exist yet it will be automatically booked with parameters lowX equal to 2.5, highX equal to 3.5, lowY equal to 4.5, highY equal to 5.5, binsX equal to 100 and binsY equal to 200.

Attention
The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title. An option exists to instead use numerical IDs. In this case the first histogram booked will be ID=1 the next ID=2 and so on. Note though this scheme is not recommended as it does NOT guarantee predictability of the ID a given histogram will be given when filled under conditional statements, since in these circumstances the order in which the histograms are first filled, and thus booked, will depend on the nature of the first few events read. This is particularly problematic when users submit many parallel 'sub-jobs' and then attempt to merge the final output ROOT (or HBOOK) files, since a given histogram could have different IDs in each of the sub-jobs. Consequently it is strongly recommended that users do not use numerical automatic IDs unless they are sure they understand what they are doing.
See also
AIDA::IHistogram2D
Parameters
valueXx value to be filled
valueYy value to be filled
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
lowYlow y limit for histogram
highYhigh y limit for histogram
binsXnumber of bins in x
binsYnumber of bins in y
weightweight
Returns
pointer to AIDA 2D histogram

Definition at line 116 of file GaudiHistos_2DFixedBinning.icpp.

119  {
120  AIDA::IHistogram2D* h( nullptr );
121  if ( produceHistos() ) {
122  // retrieve or book the histogram
123  h = histo2D( title );
124  if ( !h ) { h = book2D( title, lowX, highX, binsX, lowY, highY, binsY ); }
125  // fill the histogram
126  h = fill( h, valueX, valueY, weight, title );
127  }
128  return h;
129 }

◆ plot2D() [4/4]

template<class PBASE >
AIDA::IHistogram2D * GaudiHistos< PBASE >::plot2D ( const double  valueX,
const double  valueY,
const std::string title,
const HistoBinEdges edgesX,
const HistoBinEdges edgesY,
const double  weight = 1.0 
) const

Fill the 2D variable binning histogram (book on demand)

const GaudiAlg::HistoBinEdges edgesX = ...;
const GaudiAlg::HistoBinEdges edgesY = ...;
const double mass1 = ... ;
const double mass2 = ... ;
plot2D( mass1, mass2,
"Invariant Mass2 versus Mass1" , edgesX, edgesY );

This example illustrates the filling of the 2D histogram titled "Invariant Mass2 versus Mass1" with values mass1 and mass2 .

If the histogram with given title does not exist yet it will be automatically booked with the given histogram bin edges.

Attention
The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title. An option exists to instead use numerical IDs. In this case the first histogram booked will be ID=1 the next ID=2 and so on. Note though this scheme is not recommended as it does NOT guarantee predictability of the ID a given histogram will be given when filled under conditional statements, since in these circumstances the order in which the histograms are first filled, and thus booked, will depend on the nature of the first few events read. This is particularly problematic when users submit many parallel 'sub-jobs' and then attempt to merge the final output ROOT (or HBOOK) files, since a given histogram could have different IDs in each of the sub-jobs. Consequently it is strongly recommended that users do not use numerical automatic IDs unless they are sure they understand what they are doing.
See also
AIDA::IHistogram2D
Parameters
valueXx value to be filled
valueYy value to be filled
titlehistogram title (must be unique within the algorithm)
edgesXThe histogram x bin edges
edgesYThe histogram y bin edges
weightweight
Returns
pointer to AIDA 2D histogram

Definition at line 88 of file GaudiHistos_2DVariableBinning.icpp.

90  {
91  AIDA::IHistogram2D* h( nullptr );
92  if ( produceHistos() ) {
93  // retrieve or book the histogram
94  h = histo2D( title );
95  if ( !h ) { h = book2D( title, edgesX, edgesY ); }
96  // fill the histogram
97  h = fill( h, valueX, valueY, weight, title );
98  }
99  return h;
100 }

◆ plot3D() [1/4]

template<class PBASE >
AIDA::IHistogram3D * GaudiHistos< PBASE >::plot3D ( const double  valueX,
const double  valueY,
const double  valueZ,
const HistoID ID,
const std::string title,
const double  lowX,
const double  highX,
const double  lowY,
const double  highY,
const double  lowZ,
const double  highZ,
const unsigned long  binsX = 10,
const unsigned long  binsY = 10,
const unsigned long  binsZ = 10,
const double  weight = 1.0 
) const

fill the 3D histogram with forced ID assignment (book on demand)

const double X = ... ;
const double Y = ... ;
const double Z = ... ;
plot3D( X, Y, Z,
15 , "Space Points" ,
2.5 ,3.5, 4.5, 5.5, 6.5, 7.5, 10, 20, 30 );

This example illustrates the filling of the 3D histogram ID=15 titled "Space Points" with values X, Y and Z.

If the histogram with given title does not exist yet it will be automatically booked with parameters lowX equal to 2.5, highX equal to 3.5, lowY equal to 4.5, highY equal to 5.5, lowZ equal to 6.5, highZ equal to 7.5, binsX equal to 10, binsY equal to 20 and binsZ equal to 30.

It is also possible to use literal IDs. For example :-

const double X = ... ;
const double Y = ... ;
const double Z = ... ;
plot3D( X, Y, Z,
"space", "Space Points" ,
2.5 ,3.5, 4.5, 5.5, 6.5, 7.5, 10, 20, 30 );

Will book the same histogram, using the id "space".

It is also possible using literal IDs, to place histograms in sub-directories from the main histogram directory, using for example :-

const double X = ... ;
const double Y = ... ;
const double Z = ... ;
plot3D( X, Y, Z,
"subdir/space", "Space Points" ,
2.5 ,3.5, 4.5, 5.5, 6.5, 7.5, 10, 20, 30 );

Which will create the histogram "space" in the sub-directory "subdir". Histograms can also be created in sub-directories with numeric IDs if IDs such as "subdir/1" are used.

Attention
If the histogram with given ID is already booked through automatic assignment of histogram ID, the error will not be detected. Therefore it is recommended to use non-trivial histogram ID offset (property "HistoOffSet") if one need to combine these techniques together It is still desirable to use the unique histogram title to avoid a bad interference
See also
AIDA::IHistogram3D
Parameters
valueXx value to be filled
valueYy value to be filled
valueZz value to be filled
IDHistogram ID to use
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
lowYlow y limit for histogram
highYhigh y limit for histogram
lowZlow z limit for histogram
highZhigh z limit for histogram
binsXnumber of bins in x
binsYnumber of bins in y
binsZnumber of bins in z
weightweight
Returns
pointer to AIDA 3D histogram

Definition at line 140 of file GaudiHistos_3DFixedBinning.icpp.

143  {
144  AIDA::IHistogram3D* h( nullptr );
145  if ( produceHistos() ) {
146  // retrieve or book the histogram
147  h = histo3D( ID );
148  if ( !h ) { h = book3D( ID, title, lowX, highX, binsX, lowY, highY, binsY, lowZ, highZ, binsZ ); }
149  // fill the histogram
150  h = fill( h, valueX, valueY, valueZ, weight, title );
151  }
152  return h;
153 }

◆ plot3D() [2/4]

template<class PBASE >
AIDA::IHistogram3D * GaudiHistos< PBASE >::plot3D ( const double  valueX,
const double  valueY,
const double  valueZ,
const HistoID ID,
const std::string title,
const HistoBinEdges edgesX,
const HistoBinEdges edgesY,
const HistoBinEdges edgesZ,
const double  weight = 1.0 
) const

fill the 3D histogram with forced ID assignment (book on demand)

const GaudiAlg::HistoBinEdges edgesX = ...;
const GaudiAlg::HistoBinEdges edgesY = ...;
const GaudiAlg::HistoBinEdges edgesZ = ...;
const double X = ... ;
const double Y = ... ;
const double Z = ... ;
plot3D( X, Y, Z, "Space Points", edgesX, edgesY, edgesZ );

This example illustrates the filling of the 3D histogram ID=15 titled "Space Points" with values X, Y and Z.

If the histogram with given title does not exist yet it will be automatically booked with the given histogram bin edges and histogram ID.

It is also possible to use literal IDs. For example :-

const GaudiAlg::HistoBinEdges edgesX = ...;
const GaudiAlg::HistoBinEdges edgesY = ...;
const GaudiAlg::HistoBinEdges edgesZ = ...;
const double X = ... ;
const double Y = ... ;
const double Z = ... ;
plot3D( X, Y, Z,
"space", "Space Points" ,
edgesX, edgesY, edgesZ );

Will book the same histogram, using the id "space".

It is also possible using literal IDs, to place histograms in sub-directories from the main histogram directory, using for example :-

const GaudiAlg::HistoBinEdges edgesX = ...;
const GaudiAlg::HistoBinEdges edgesY = ...;
const GaudiAlg::HistoBinEdges edgesZ = ...;
const double X = ... ;
const double Y = ... ;
const double Z = ... ;
plot3D( X, Y, Z,
"subdir/space", "Space Points" ,
edgesX, edgesY, edgesZ );

Which will create the histogram "space" in the sub-directory "subdir". Histograms can also be created in sub-directories with numeric IDs if IDs such as "subdir/1" are used.

Attention
If the histogram with given ID is already booked through automatic assignment of histogram ID, the error will not be detected. Therefore it is recommended to use non-trivial histogram ID offset (property "HistoOffSet") if one need to combine these techniques together It is still desirable to use the unique histogram title to avoid a bad interference
See also
AIDA::IHistogram3D
Parameters
valueXx value to be filled
valueYy value to be filled
valueZz value to be filled
IDHistogram ID to use
titlehistogram title (must be unique within the algorithm)
edgesXThe histogram x bin edges
edgesYThe histogram y bin edges
edgesZThe histogram z bin edges
weightweight
Returns
pointer to AIDA 3D histogram

Definition at line 107 of file GaudiHistos_3DVariableBinning.icpp.

110  {
111  AIDA::IHistogram3D* h( nullptr );
112  if ( produceHistos() ) {
113  // retrieve or book the histogram
114  h = histo3D( ID );
115  if ( !h ) { h = book3D( ID, title, edgesX, edgesY, edgesZ ); }
116  // fill
117  h = fill( h, valueX, valueY, valueZ, weight, title );
118  }
119  return h;
120 }

◆ plot3D() [3/4]

template<class PBASE >
AIDA::IHistogram3D * GaudiHistos< PBASE >::plot3D ( const double  valueX,
const double  valueY,
const double  valueZ,
const std::string title,
const double  lowX,
const double  highX,
const double  lowY,
const double  highY,
const double  lowZ,
const double  highZ,
const unsigned long  binsX = 10,
const unsigned long  binsY = 10,
const unsigned long  binsZ = 10,
const double  weight = 1.0 
) const

fill the 3D histogram (book on demand)

const double X = ... ;
const double Y = ... ;
const double Z = ... ;
plot3D( X, Y, Z, "Space Points" ,
2.5 , 3.5 ,
4.5 , 5.5 ,
6.5 , 7.5 ,
10, 20, 30 );

This example illustrates the filling of the 3D histogram titled "Space Points" with values X, Y and Z.

If the histogram with given title does not exist yet it will be automatically booked with parameters lowX equal to 2.5, highX equal to 3.5, lowY equal to 4.5, highY equal to 5.5, lowZ equal to 6.5, highZ equal to 7.5, binsX equal to 10, binsY equal to 20 and binsZ equal to 30.

Attention
The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title. An option exists to instead use numerical IDs. In this case the first histogram booked will be ID=1 the next ID=2 and so on. Note though this scheme is not recommended as it does NOT guarantee predictability of the ID a given histogram will be given when filled under conditional statements, since in these circumstances the order in which the histograms are first filled, and thus booked, will depend on the nature of the first few events read. This is particularly problematic when users submit many parallel 'sub-jobs' and then attempt to merge the final output ROOT (or HBOOK) files, since a given histogram could have different IDs in each of the sub-jobs. Consequently it is strongly recommended that users do not use numerical automatic IDs unless they are sure they understand what they are doing.
See also
AIDA::IHistogram3D
Parameters
valueXx value to be filled
valueYy value to be filled
valueZz value to be filled
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
lowYlow y limit for histogram
highYhigh y limit for histogram
lowZlow z limit for histogram
highZhigh z limit for histogram
binsXnumber of bins in x
binsYnumber of bins in y
binsZnumber of bins in z
weightweight
Returns
pointer to AIDA 3D histogram

Definition at line 121 of file GaudiHistos_3DFixedBinning.icpp.

124  {
125  AIDA::IHistogram3D* h( nullptr );
126  if ( produceHistos() ) {
127  // retrieve or book the histogram
128  h = histo3D( title );
129  if ( !h ) { h = book3D( title, lowX, highX, binsX, lowY, highY, binsY, lowZ, highZ, binsZ ); }
130  // fill the histogram
131  h = fill( h, valueX, valueY, valueZ, weight, title );
132  }
133  return h;
134 }

◆ plot3D() [4/4]

template<class PBASE >
AIDA::IHistogram3D * GaudiHistos< PBASE >::plot3D ( const double  valueX,
const double  valueY,
const double  valueZ,
const std::string title,
const HistoBinEdges edgesX,
const HistoBinEdges edgesY,
const HistoBinEdges edgesZ,
const double  weight = 1.0 
) const

Fill the 3D variable binning histogram (book on demand)

const GaudiAlg::HistoBinEdges edgesX = ...;
const GaudiAlg::HistoBinEdges edgesY = ...;
const GaudiAlg::HistoBinEdges edgesZ = ...;
const double X = ... ;
const double Y = ... ;
const double Z = ... ;
plot3D( X, Y, Z, "Space Points", edgesX, edgesY, edgesZ );

This example illustrates the filling of the 3D histogram titled "Space Points" with values X, Y and Z.

If the histogram with given title does not exist yet it will be automatically booked with the given histogram bin edges.

Attention
The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title. An option exists to instead use numerical IDs. In this case the first histogram booked will be ID=1 the next ID=2 and so on. Note though this scheme is not recommended as it does NOT guarantee predictability of the ID a given histogram will be given when filled under conditional statements, since in these circumstances the order in which the histograms are first filled, and thus booked, will depend on the nature of the first few events read. This is particularly problematic when users submit many parallel 'sub-jobs' and then attempt to merge the final output ROOT (or HBOOK) files, since a given histogram could have different IDs in each of the sub-jobs. Consequently it is strongly recommended that users do not use numerical automatic IDs unless they are sure they understand what they are doing.
See also
AIDA::IHistogram3D
Parameters
valueXx value to be filled
valueYy value to be filled
valueZz value to be filled
titlehistogram title (must be unique within the algorithm)
edgesXThe histogram x bin edges
edgesYThe histogram y bin edges
edgesZThe histogram z bin edges
weightweight
Returns
pointer to AIDA 3D histogram

Definition at line 89 of file GaudiHistos_3DVariableBinning.icpp.

92  {
93  AIDA::IHistogram3D* h( nullptr );
94  if ( produceHistos() ) {
95  // retrieve or book the histogram
96  h = histo3D( title );
97  if ( !h ) { h = book3D( title, edgesX, edgesY, edgesZ ); }
98  // fill the histogram
99  h = fill( h, valueX, valueY, valueZ, weight, title );
100  }
101  return h;
102 }

◆ printHistos()

template<class PBASE >
int GaudiHistos< PBASE >::printHistos ( const MSG::Level  level = MSG::ALWAYS) const

perform the actual printout of histograms

Parameters
levelThe message level to print at
Returns
number of active histograms

Definition at line 174 of file GaudiHistos.icpp.

174  {
175  using namespace Gaudi::Utils::Histos;
176 
177  if ( noHistos() ) {
178  if ( this->msgLevel( MSG::DEBUG ) ) { this->msgStream( level ) << "No histograms are booked" << endmsg; }
179  return 0; // RETURN
180  }
181 
182  MsgStream& msg = this->msgStream( level );
183 
184  // Printout all histograms
185 
186  if ( !histo1DMapID().empty() ) {
187  msg << "1D histograms in directory "
188  << "\"" << histoPath() << "\" : " << histo1DMapID().size();
190  if ( !table.header().empty() ) {
192  }
193  for ( const auto& entry : ordered( histo1DMapID() ) ) {
194  const auto* aida = entry.second;
195  if ( !aida ) {
196  this->error() << "IHistogram1D points to NULL" << endmsg;
197  continue;
198  }
199  // format and print the row
200  msg << std::endl << table.toString( aida, HistoID( entry.first ), m_histo1DTableFormatShort );
201  }
202  msg << endmsg;
203  }
204  // ==========================================================================
205  if ( !histo2DMapID().empty() ) {
206  msg << "2D histograms in directory "
207  << "\"" << histoPath() << "\" : " << histo2DMapID().size();
208 
209  for ( const auto& entry : ordered( histo2DMapID() ) ) {
210  const auto* aida = entry.second;
211  if ( !aida ) {
212  this->error() << "IHistogram2D points to NULL" << endmsg;
213  continue;
214  }
215  msg << std::endl << GaudiAlg::Print2D::toString( aida, entry.first );
216  }
217  msg << endmsg;
218  }
219  // ==========================================================================
220  if ( !histo3DMapID().empty() ) {
221  msg << "3D histograms in directory "
222  << "\"" << histoPath() << "\" : " << histo3DMapID().size();
223  for ( const auto& entry : ordered( histo3DMapID() ) ) {
224  const auto* aida = entry.second;
225  if ( !aida ) {
226  this->error() << "IHistogram3D points to NULL" << endmsg;
227  continue;
228  }
229  msg << std::endl << GaudiAlg::Print3D::toString( aida, entry.first );
230  }
231  msg << endmsg;
232  }
233  // ==========================================================================
234  if ( !profile1DMapID().empty() ) {
235  msg << "1D profile histograms in directory "
236  << "\"" << histoPath() << "\" : " << profile1DMapID().size();
238  if ( !table.header().empty() ) {
240  }
241  for ( const auto& entry : ordered( profile1DMapID() ) ) {
242  const auto* aida = entry.second;
243  if ( !aida ) {
244  this->error() << "IProfile1D points to NULL" << endmsg;
245  continue;
246  }
247  msg << std::endl << table.toString( aida, HistoID( entry.first ), m_histo1DTableFormatShort );
248  }
249  msg << endmsg;
250  }
251  // ==========================================================================
252  if ( !profile2DMapID().empty() ) {
253  msg << "2D profile histograms in directory "
254  << "\"" << histoPath() << "\" : " << profile2DMapID().size();
255  for ( const auto& entry : ordered( profile2DMapID() ) ) {
256  const auto* aida = entry.second;
257  if ( !aida ) {
258  this->error() << "IProfile2D points to NULL" << endmsg;
259  continue;
260  }
261  msg << std::endl << GaudiAlg::Print2DProf::toString( aida, entry.first );
262  }
263  msg << endmsg;
264  }
265  //
266  return this->totalNumberOfHistos();
267 }

◆ produceHistos()

template<class PBASE >
bool GaudiHistos< PBASE >::produceHistos ( ) const
inline

get the flag for histogram production (property "HistoProduce")

Definition at line 2381 of file GaudiHistos.h.

2381 { return m_produceHistos; }

◆ profile1D() [1/6]

template<class PBASE >
AIDA::IProfile1D * GaudiHistos< PBASE >::profile1D ( const double  valueX,
const double  valueY,
const HistoID ID,
const std::string title,
const double  lowX,
const double  highX,
const unsigned long  binsX = 100,
const std::string opt = "",
const double  lowY = -std::numeric_limits<double>::max(),
const double  highY = std::numeric_limits<double>::max(),
const double  weight = 1.0 
) const

fill the 1D profile histogram with forced ID assignment (book on demand)

const double mass1 = ... ;
const double mass2 = ... ;
profile1D( mass1, mass2,
15, "Invariant Mass2 versus Mass1" ,2.5 ,3.5, 100 );

This example illustrates the filling of the 1D profile histogram with ID=15 titled "Invariant Mass2 versus Mass1" with values mass1 and mass2 .

If the histogram with given title does not exist yet it will be automatically booked with parameters lowX equal to 2.5, highX equal to 3.5, binsX equal to 100

It is also possible to use literal IDs. For example :-

const double mass1 = ... ;
const double mass2 = ... ;
profile1D( mass1, mass2,
"mass", "Invariant Mass2 versus Mass1" ,2.5 ,3.5, 100 );

Will book the same histogram, using the id "mass".

It is also possible using literal IDs, to place histograms in sub-directories from the main histogram directory, using for example :-

const double mass1 = ... ;
const double mass2 = ... ;
profile1D( mass1, mass2,
"subdir/mass", "Invariant Mass2 versus Mass1" ,2.5 ,3.5, 100 );

Which will create the histogram "mass" in the sub-directory "subdir". Histograms can also be created in sub-directories with numeric IDs if IDs such as "subdir/1" are used.

See also
AIDA::IProfile1D
Parameters
valueXx value to be filled
valueYy value to be filled
IDhistogram identifier
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
binsXnumber of bins in x
optthe options, used for evaluation of errors
lowYthe min cut-off for y-values
highYthe max cut-off for y-values
weightweight
Returns
pointer to AIDA 1D profile histogram

Definition at line 132 of file GaudiHistos_1DProfFixedBinning.icpp.

135  {
136  AIDA::IProfile1D* h = nullptr;
137  if ( produceHistos() ) {
138  // retrieve or book the histogram
139  h = profile1D( ID );
140  if ( !h ) { h = bookProfile1D( ID, title, lowX, highX, binsX, opt, lowY, highY ); }
141  // fill the histogram
142  h = fill( h, valueX, valueY, weight, title );
143  }
144  return h;
145 }

◆ profile1D() [2/6]

template<class PBASE >
AIDA::IProfile1D * GaudiHistos< PBASE >::profile1D ( const double  valueX,
const double  valueY,
const HistoID ID,
const std::string title,
const HistoBinEdges edges,
const double  weight = 1.0 
) const

fill the 1D variable binning profile histogram with forced ID assignment (book on demand)

const GaudiAlg::HistoBinEdges edges = ...;
const double mass1 = ... ;
const double mass2 = ... ;
profile1D( mass1, mass2,
15, "Invariant Mass2 versus Mass1", edges );

This example illustrates the filling of the 1D profile histogram with ID=15 titled "Invariant Mass2 versus Mass1" with values mass1 and mass2 .

If the histogram with given ID does not exist yet it will be automatically booked with the given histogram bin edges.

It is also possible to use literal IDs. For example :-

const GaudiAlg::HistoBinEdges edges = ...;
const double mass1 = ... ;
const double mass2 = ... ;
profile1D( mass1, mass2,
"mass", "Invariant Mass2 versus Mass1", edges );

Will book the same histogram, using the id "mass".

It is also possible using literal IDs, to place histograms in sub-directories from the main histogram directory, using for example :-

const GaudiAlg::HistoBinEdges edges = ...;
const double mass1 = ... ;
const double mass2 = ... ;
profile1D( mass1, mass2,
"subdir/mass", "Invariant Mass2 versus Mass1", edges );

Which will create the histogram "mass" in the sub-directory "subdir". Histograms can also be created in sub-directories with numeric IDs if IDs such as "subdir/1" are used.

See also
AIDA::IProfile1D
Parameters
valueXx value to be filled
valueYy value to be filled
IDhistogram identifier
titlehistogram title (must be unique within the algorithm)
edgesThe histogram bin edges
weightweight
Returns
pointer to AIDA 1D profile histogram

Definition at line 101 of file GaudiHistos_1DProfVariableBinning.icpp.

103  {
104  AIDA::IProfile1D* h( nullptr );
105  if ( produceHistos() ) {
106  // retrieve or book the histogram
107  h = profile1D( ID );
108  if ( !h ) { h = bookProfile1D( ID, title, edges ); }
109  // fill the histogram
110  h = fill( h, valueX, valueY, weight, title );
111  }
112  return h;
113 }

◆ profile1D() [3/6]

template<class PBASE >
AIDA::IProfile1D * GaudiHistos< PBASE >::profile1D ( const double  valueX,
const double  valueY,
const std::string title,
const double  lowX,
const double  highX,
const unsigned long  binsX = 100,
const std::string opt = "",
const double  lowY = -std::numeric_limits<double>::max(),
const double  highY = std::numeric_limits<double>::max(),
const double  weight = 1.0 
) const

fill the 1D profile histogram (book on demand)

const double mass1 = ... ;
const double mass2 = ... ;
profile1D( mass1, mass2, "Invariant Mass2 versus Mass1" ,2.5 ,3.5, 100 );

This example illustrates the filling of the 1D profile histogram titled "Invariant Mass2 versus Mass1" with values mass1 and mass2 .

If the histogram with given title does not exist yet it will be automatically booked with parameters lowX equal to 2.5, highX equal to 3.5, binsX equal to 100

Attention
The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title. An option exists to instead use numerical IDs. In this case the first histogram booked will be ID=1 the next ID=2 and so on. Note though this scheme is not recommended as it does NOT guarantee predictability of the ID a given histogram will be given when filled under conditional statements, since in these circumstances the order in which the histograms are first filled, and thus booked, will depend on the nature of the first few events read. This is particularly problematic when users submit many parallel 'sub-jobs' and then attempt to merge the final output ROOT (or HBOOK) files, since a given histogram could have different IDs in each of the sub-jobs. Consequently it is strongly recommended that users do not use numerical automatic IDs unless they are sure they understand what they are doing.
See also
AIDA::IProfile1D
Parameters
valueXx value to be filled
valueYy value to be filled
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
binsXnumber of bins in x
optthe options, used for evaluation of errors
lowYthe min cut-off for y-values
highYthe max cut-off for y-values
weightweight
Returns
pointer to AIDA 1D profile histogram

Definition at line 114 of file GaudiHistos_1DProfFixedBinning.icpp.

117  {
118  AIDA::IProfile1D* h = nullptr;
119  if ( produceHistos() ) {
120  // retrieve or book the histogram
121  h = profile1D( title );
122  if ( !h ) { h = bookProfile1D( title, lowX, highX, binsX, opt, lowY, highY ); }
123  // fill the histogram
124  h = fill( h, valueX, valueY, weight, title );
125  }
126  return h;
127 }

◆ profile1D() [4/6]

template<class PBASE >
AIDA::IProfile1D * GaudiHistos< PBASE >::profile1D ( const double  valueX,
const double  valueY,
const std::string title,
const HistoBinEdges edges,
const double  weight = 1.0 
) const

fill the 1D variable binning profile histogram (book on demand)

const GaudiAlg::HistoBinEdges edges = ...;
const double mass1 = ... ;
const double mass2 = ... ;
profile1D( mass1, mass2, "Invariant Mass2 versus Mass1", edges );

This example illustrates the filling of the 1D profile histogram titled "Invariant Mass2 versus Mass1" with values mass1 and mass2 .

If the histogram with given title does not exist yet it will be automatically booked with the given histogram bin edges.

Attention
The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title. An option exists to instead use numerical IDs. In this case the first histogram booked will be ID=1 the next ID=2 and so on. Note though this scheme is not recommended as it does NOT guarantee predictability of the ID a given histogram will be given when filled under conditional statements, since in these circumstances the order in which the histograms are first filled, and thus booked, will depend on the nature of the first few events read. This is particularly problematic when users submit many parallel 'sub-jobs' and then attempt to merge the final output ROOT (or HBOOK) files, since a given histogram could have different IDs in each of the sub-jobs. Consequently it is strongly recommended that users do not use numerical automatic IDs unless they are sure they understand what they are doing.
See also
AIDA::IProfile1D
Parameters
valueXx value to be filled
valueYy value to be filled
titlehistogram title (must be unique within the algorithm)
edgesThe histogram bin edges
weightweight
Returns
pointer to AIDA 1D profile histogram

Definition at line 85 of file GaudiHistos_1DProfVariableBinning.icpp.

86  {
87  AIDA::IProfile1D* h( nullptr );
88  if ( produceHistos() ) {
89  // retrieve or book the histogram
90  h = profile1D( title );
91  if ( !h ) { h = bookProfile1D( title, edges ); }
92  // fill the histogram
93  h = fill( h, valueX, valueY, weight, title );
94  }
95  return h;
96 }

◆ profile1D() [5/6]

template<class PBASE >
AIDA::IProfile1D * GaudiHistos< PBASE >::profile1D ( const HistoID ID) const

access the EXISTING 1D profile histogram by ID return the pointer to existing 1D profile histogram or NULL

Definition at line 315 of file GaudiHistos.icpp.

315  {
316  return lookup_( profile1DMapID(), ID );
317 }

◆ profile1D() [6/6]

template<class PBASE >
AIDA::IProfile1D* GaudiHistos< PBASE >::profile1D ( const std::string title) const
inline

access the EXISTING 1D profile histogram by title return the pointer to existing 1D profile histogram or NULL

Definition at line 2313 of file GaudiHistos.h.

2313  {
2314  auto found = profile1DMapTitle().find( title );
2315  return profile1DMapTitle().end() != found ? found->second : nullptr;
2316  }

◆ profile1DMapID()

template<class PBASE >
const Profile1DMapID& GaudiHistos< PBASE >::profile1DMapID ( ) const
inline

get access to the map of 1D profile histograms index via a ID

// iterate over the map!
for ( const auto& entry : profile1DMapID() )
{
// histogram ID
const HistoID ID = entry.first ;
// histogram itself
AIDA::IProfile1D* h = entry.second ;
if ( 0 == h ) { continue ;}
std::cout << " Histogram ID " << ID
<< " Histogram title " << h->title() << std::endl ;
}

Definition at line 2610 of file GaudiHistos.h.

2610 { return m_profile1DMapID; }

◆ profile1DMapTitle()

template<class PBASE >
const Profile1DMapTitle& GaudiHistos< PBASE >::profile1DMapTitle ( ) const
inline

get access to the map of all 1D profile histograms indexed via their title

Using this method one can inspect e.g. a list of active histograms

// iterate over the map!
histos.end() != entry ; ++entry )
{
// histogram title
const std::string& title = entry->first ;
// histogram itself
AIDA::IProfile1D* hist = entry->second ;
if( 0 == hist ) { continue ; } // ATTENTION!
std::cout << " Histogram title " << title << std::endl ;
}
Attention
The map COULD contains NULL pointers, the check before use is mandatory!

Definition at line 2587 of file GaudiHistos.h.

2587 { return m_profile1DMapTitle; }

◆ profile2D() [1/6]

template<class PBASE >
AIDA::IProfile2D * GaudiHistos< PBASE >::profile2D ( const double  valueX,
const double  valueY,
const double  valueZ,
const HistoID ID,
const std::string title,
const double  lowX,
const double  highX,
const double  lowY,
const double  highY,
const unsigned long  binsX = 50,
const unsigned long  binsY = 50,
const double  weight = 1.0 
) const

fill the 2D profile histogram with forced ID assignment (book on demand)

const double X = ... ;
const double Y = ... ;
const double Z = ... ;
profile2D( X, Y, Z, 15, "Space Points" ,2.5 ,3.5, 4.5, 5.5, 10, 20 );

This example illustrates the filling of the 2D profile histogram with ID=15 titled "Space Points" with values X, Y and Z.

If the histogram with given title does not exist yet it will be automatically booked with parameters lowX equal to 2.5, highX equal to 3.5, lowY equal to 4.5, highY equal to 5.5, binsX equal to 10, binsY equal to 20.

It is also possible to use literal IDs. For example :-

const double X = ... ;
const double Y = ... ;
const double Z = ... ;
profile2D( X, Y, Z, "space", "Space Points" ,2.5 ,3.5, 4.5, 5.5, 10, 20 );

Will book the same histogram, using the id "space".

It is also possible using literal IDs, to place histograms in sub-directories from the main histogram directory, using for example :-

const double X = ... ;
const double Y = ... ;
const double Z = ... ;
profile2D( X, Y, Z,
"subdir/space", "Space Points" ,2.5 ,3.5, 4.5, 5.5, 10, 20 );

Which will create the histogram "space" in the sub-directory "subdir". Histograms can also be created in sub-directories with numeric IDs if IDs such as "subdir/1" are used.

See also
AIDA::IProfile2D
Parameters
valueXx value to be filled
valueYy value to be filled
valueZz value to be filled
IDhistogram identifier
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
lowYlow y limit for histogram
highYhigh y limit for histogram
binsXnumber of bins in x
binsYnumber of bins in y
weightweight
Returns
pointer to AIDA 2D profile histogram

Definition at line 131 of file GaudiHistos_2DProfFixedBinning.icpp.

135  {
136  AIDA::IProfile2D* h = nullptr;
137  if ( produceHistos() ) {
138  // retrieve or book the histogram
139  h = profile2D( ID );
140  if ( 0 == h ) { h = bookProfile2D( ID, title, lowX, highX, binsX, lowY, highY, binsY ); }
141  // fill the histogram
142  h = fill( h, valueX, valueY, valueZ, weight, title );
143  }
144  return h;
145 }

◆ profile2D() [2/6]

template<class PBASE >
AIDA::IProfile2D * GaudiHistos< PBASE >::profile2D ( const double  valueX,
const double  valueY,
const double  valueZ,
const HistoID ID,
const std::string title,
const HistoBinEdges edgesX,
const HistoBinEdges edgesY,
const double  weight = 1.0 
) const

fill the 2D variable binning profile histogram with forced ID assignment (book on demand)

const GaudiAlg::HistoBinEdges edgesX = ...;
const GaudiAlg::HistoBinEdges edgesY = ...;
const double X = ... ;
const double Y = ... ;
const double Z = ... ;
profile2( X, Y, Z, "Space Points", edgesX, edgesY );

This example illustrates the filling of the 2D profile histogram titled "Space Points" with values X, Y and Z.

If the histogram with given ID does not exist yet it will be automatically booked with the given histogram bin edges.

It is also possible to use literal IDs. For example :-

const double X = ... ;
const double Y = ... ;
const double Z = ... ;
profile2D( X, Y, Z, "space", "Space Points", edgesX, edgesY );

Will book the same histogram, using the id "mass".

It is also possible using literal IDs, to place histograms in sub-directories from the main histogram directory, using for example :-

const double X = ... ;
const double Y = ... ;
const double Z = ... ;
profile2D( X, Y, Z,
"subdir/space", "Space Points", edgesX, edgesY );

Which will create the histogram "mass" in the sub-directory "subdir". Histograms can also be created in sub-directories with numeric IDs if IDs such as "subdir/1" are used.

See also
AIDA::IProfile2D
Parameters
valueXx value to be filled
valueYy value to be filled
valueZz value to be filled
IDhistogram identifier
titlehistogram title (must be unique within the algorithm)
edgesXThe histogram x bin edges
edgesYThe histogram y bin edges
weightweight
Returns
pointer to AIDA 1D profile histogram

Definition at line 102 of file GaudiHistos_2DProfVariableBinning.icpp.

105  {
106  AIDA::IProfile2D* h( nullptr );
107  if ( produceHistos() ) {
108  // retrieve or book the histogram
109  h = profile2D( ID );
110  if ( !h ) { h = bookProfile2D( ID, title, edgesX, edgesY ); }
111 
112  // fill the histogram
113  h = fill( h, valueX, valueY, valueZ, weight, title );
114  }
115  return h;
116 }

◆ profile2D() [3/6]

template<class PBASE >
AIDA::IProfile2D * GaudiHistos< PBASE >::profile2D ( const double  valueX,
const double  valueY,
const double  valueZ,
const std::string title,
const double  lowX,
const double  highX,
const double  lowY,
const double  highY,
const unsigned long  binsX = 50,
const unsigned long  binsY = 50,
const double  weight = 1.0 
) const

fill the 2D profile histogram (book on demand)

const double X = ... ;
const double Y = ... ;
const double Z = ... ;
profile2( X, Y, Z, "Space Points" ,2.5 ,3.5, 4.5, 5.5, 10, 20 );

This example illustrates the filling of the 2D profile histogram titled "Space Points" with values X, Y and Z.

If the histogram with given title does not exist yet it will be automatically booked with parameters lowX equal to 2.5, highX equal to 3.5, lowY equal to 4.5, highY equal to 5.5, binsX equal to 10, binsY equal to 20.

Attention
The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title. An option exists to instead use numerical IDs. In this case the first histogram booked will be ID=1 the next ID=2 and so on. Note though this scheme is not recommended as it does NOT guarantee predictability of the ID a given histogram will be given when filled under conditional statements, since in these circumstances the order in which the histograms are first filled, and thus booked, will depend on the nature of the first few events read. This is particularly problematic when users submit many parallel 'sub-jobs' and then attempt to merge the final output ROOT (or HBOOK) files, since a given histogram could have different IDs in each of the sub-jobs. Consequently it is strongly recommended that users do not use numerical automatic IDs unless they are sure they understand what they are doing.
See also
AIDA::IProfile2D
Parameters
valueXx value to be filled
valueYy value to be filled
valueZz value to be filled
titlehistogram title (must be unique within the algorithm)
lowXlow x limit for histogram
highXhigh x limit for histogram
lowYlow y limit for histogram
highYhigh y limit for histogram
binsXnumber of bins in x
binsYnumber of bins in y
weightweight
Returns
pointer to AIDA 2D profile histogram

Definition at line 113 of file GaudiHistos_2DProfFixedBinning.icpp.

116  {
117  AIDA::IProfile2D* h = nullptr;
118  if ( produceHistos() ) {
119  // retrieve or book the histogram
120  h = profile2D( title );
121  if ( 0 == h ) { h = bookProfile2D( title, lowX, highX, binsX, lowY, highY, binsY ); }
122  // fill the histogram
123  h = fill( h, valueX, valueY, valueZ, weight, title );
124  }
125  return h;
126 }

◆ profile2D() [4/6]

template<class PBASE >
AIDA::IProfile2D * GaudiHistos< PBASE >::profile2D ( const double  valueX,
const double  valueY,
const double  valueZ,
const std::string title,
const HistoBinEdges edgesX,
const HistoBinEdges edgesY,
const double  weight = 1.0 
) const

fill the 2D variable binning profile histogram (book on demand)

const GaudiAlg::HistoBinEdges edgesX = ...;
const GaudiAlg::HistoBinEdges edgesY = ...;
const double X = ... ;
const double Y = ... ;
const double Z = ... ;
profile2D( X, Y, Z, "Space Points", edgesX, edgesY );

This example illustrates the filling of the 2D profile histogram titled "Space Points" with values X, Y and Z.

If the histogram with given title does not exist yet it will be automatically booked with the given histogram bin edges.

Attention
The histogram will get a unique identifier automatically assigned which by default will be equal to the histogram title. An option exists to instead use numerical IDs. In this case the first histogram booked will be ID=1 the next ID=2 and so on. Note though this scheme is not recommended as it does NOT guarantee predictability of the ID a given histogram will be given when filled under conditional statements, since in these circumstances the order in which the histograms are first filled, and thus booked, will depend on the nature of the first few events read. This is particularly problematic when users submit many parallel 'sub-jobs' and then attempt to merge the final output ROOT (or HBOOK) files, since a given histogram could have different IDs in each of the sub-jobs. Consequently it is strongly recommended that users do not use numerical automatic IDs unless they are sure they understand what they are doing.
See also
AIDA::IProfile2D
Parameters
valueXx value to be filled
valueYy value to be filled
valueZz value to be filled
titlehistogram title (must be unique within the algorithm)
edgesXThe histogram x bin edges
edgesYThe histogram x bin edges
weightweight
Returns
pointer to AIDA 1D profile histogram

Definition at line 85 of file GaudiHistos_2DProfVariableBinning.icpp.

87  {
88  AIDA::IProfile2D* h( nullptr );
89  if ( produceHistos() ) {
90  // retrieve or book the histogram
91  h = profile2D( title );
92  if ( !h ) { h = bookProfile2D( title, edgesX, edgesY ); }
93  // fill the histogram
94  h = fill( h, valueX, valueY, valueZ, weight, title );
95  }
96  return h;
97 }

◆ profile2D() [5/6]

template<class PBASE >
AIDA::IProfile2D * GaudiHistos< PBASE >::profile2D ( const HistoID ID) const

access the EXISTING 2D profile histogram by ID return the pointer to existing 2D profile histogram or NULL

Definition at line 322 of file GaudiHistos.icpp.

322  {
323  return lookup_( profile2DMapID(), ID );
324 }

◆ profile2D() [6/6]

template<class PBASE >
AIDA::IProfile2D* GaudiHistos< PBASE >::profile2D ( const std::string title) const
inline

access the EXISTING 2D profile histogram by title return the pointer to existing 2D profile histogram or NULL

Definition at line 2321 of file GaudiHistos.h.

2321  {
2322  auto found = profile2DMapTitle().find( title );
2323  return profile2DMapTitle().end() != found ? found->second : nullptr;
2324  }

◆ profile2DMapID()

template<class PBASE >
const Profile2DMapID& GaudiHistos< PBASE >::profile2DMapID ( ) const
inline

get access to the map of 2D profile histograms index via a ID

// iterate over the map!
for ( const auto& entry : profile2DMapID() )
{
// histogram ID
const HistoID ID = entry.first ;
// histogram itself
AIDA::IProfile2D* h = entry.second ;
if ( 0 == h ) { continue ;}
std::cout << " Histogram ID " << ID
<< " Histogram title " << h->title() << std::endl ;
}

Definition at line 2660 of file GaudiHistos.h.

2660 { return m_profile2DMapID; }

◆ profile2DMapTitle()

template<class PBASE >
const Profile2DMapTitle& GaudiHistos< PBASE >::profile2DMapTitle ( ) const
inline

get access to the map of all 2D profile histograms indexed via their title

Using this method one can inspect e.g. a list of active histograms

// iterate over the map!
for ( const auto& entry : profile2DMapTitle() )
{
// histogram title
const std::string& title = entry.first ;
// histogram itself
AIDA::IProfile2D* hist = entry.second ;
if( 0 == hist ) { continue ; } // ATTENTION!
std::cout << " Histogram title " << title << std::endl ;
}
Attention
The map COULD contains NULL pointers, the check before use is mandatory!

Definition at line 2637 of file GaudiHistos.h.

2637 { return m_profile2DMapTitle; }

◆ setCheckForNaN()

template<class PBASE >
void GaudiHistos< PBASE >::setCheckForNaN ( const bool  val)
inline

set the flag for NaN checks (property "HistoCheckForNan")

Definition at line 2669 of file GaudiHistos.h.

2669 { m_checkForNaN = val; }

◆ setFullDetail()

template<class PBASE >
void GaudiHistos< PBASE >::setFullDetail ( const bool  val)
inline

set flag to control output level of histograms

Definition at line 2667 of file GaudiHistos.h.

2667 { m_fullDetail = val; }

◆ setHistoDir()

template<class PBASE >
void GaudiHistos< PBASE >::setHistoDir ( const std::string val)
inline

set histogram directory (property "HistoDir")

Definition at line 2679 of file GaudiHistos.h.

2679 { m_histoDir = val; }

◆ setHistoOffSet()

template<class PBASE >
void GaudiHistos< PBASE >::setHistoOffSet ( const HistoID::NumericID  val)
inline

set a value for histogram offset (property "HistoOffSet"

Definition at line 2673 of file GaudiHistos.h.

2673 { m_histoOffSet = val; }

◆ setHistoTopDir()

template<class PBASE >
void GaudiHistos< PBASE >::setHistoTopDir ( const std::string val)
inline

set top-level histogram directory (property "HistoTopDir")

Definition at line 2676 of file GaudiHistos.h.

2676 { m_histoTopDir = val; }

◆ setProduceHistos()

template<class PBASE >
void GaudiHistos< PBASE >::setProduceHistos ( const bool  val)
inline

set the flag for histogram production (property "HistoProduce")

Definition at line 2665 of file GaudiHistos.h.

2665 { m_produceHistos = val; }

◆ setSplitHistoDir()

template<class PBASE >
void GaudiHistos< PBASE >::setSplitHistoDir ( const bool  val)
inline

set the flag for histogram path split (property "HistoSplitDir")

Definition at line 2671 of file GaudiHistos.h.

2671 { m_splitHistoDir = val; }

◆ splitHistoDir()

template<class PBASE >
bool GaudiHistos< PBASE >::splitHistoDir ( ) const
inline

get the flag for histogram path split (property "HistoSplitDir")

Definition at line 2387 of file GaudiHistos.h.

2387 { return m_splitHistoDir; }

◆ totalNumberOfHistos()

template<class PBASE >
unsigned int GaudiHistos< PBASE >::totalNumberOfHistos

Returns the total number of histograms (of all types) currently booked.

Definition at line 329 of file GaudiHistos.icpp.

329  {
330  return histo1DMapID().size() + histo2DMapID().size() + histo3DMapID().size() + profile1DMapID().size() +
331  profile2DMapID().size();
332 }

◆ useNumericAutoIDs()

template<class PBASE >
bool GaudiHistos< PBASE >::useNumericAutoIDs ( ) const
inline

Use old style sequencial numerical automatically assigned IDs ?

Definition at line 2401 of file GaudiHistos.h.

2401 { return m_useNumericAutoIDs; }

Member Data Documentation

◆ m_checkForNaN

template<class PBASE >
Gaudi::Property<bool> GaudiHistos< PBASE >::m_checkForNaN
private
Initial value:
{ this, "HistoCheckForNaN", true,
"Switch on/off the checks for NaN and Infinity for histogram fill" }

Definition at line 2757 of file GaudiHistos.h.

◆ m_declareMoniHists

template<class PBASE >
Gaudi::Property<bool> GaudiHistos< PBASE >::m_declareMoniHists { this, "MonitorHistograms", true }
private

Definition at line 2768 of file GaudiHistos.h.

◆ m_fullDetail

template<class PBASE >
Gaudi::Property<bool> GaudiHistos< PBASE >::m_fullDetail { this, "FullDetail", false }
private

Definition at line 2767 of file GaudiHistos.h.

◆ m_histo1DMapID

template<class PBASE >
Histo1DMapID GaudiHistos< PBASE >::m_histo1DMapID
mutableprivate

the actual storage/access of 1D histograms by unique ID

Definition at line 2790 of file GaudiHistos.h.

◆ m_histo1DMapTitle

template<class PBASE >
Histo1DMapTitle GaudiHistos< PBASE >::m_histo1DMapTitle
mutableprivate

the actual storage/access of 1D histograms by unique title

Definition at line 2788 of file GaudiHistos.h.

◆ m_histo1DTableFormat

template<class PBASE >
Gaudi::Property<std::string> GaudiHistos< PBASE >::m_histo1DTableFormat
private
Initial value:
{ this, "FormatFor1DHistoTable",
"Format string for printout of 1D histograms" }

Definition at line 2769 of file GaudiHistos.h.

◆ m_histo1DTableFormatShort

template<class PBASE >
Gaudi::Property<std::string> GaudiHistos< PBASE >::m_histo1DTableFormatShort
private
Initial value:
{ this, "ShortFormatFor1DHistoTable", " | %1$-25.25s %2%",
"Format string for printout of 1D histograms" }

Definition at line 2772 of file GaudiHistos.h.

◆ m_histo1DTableHeader

template<class PBASE >
Gaudi::Property<std::string> GaudiHistos< PBASE >::m_histo1DTableHeader
private
Initial value:
{ this, "HeaderFor1DHistoTable",
"The table header for printout of 1D histograms " }

Definition at line 2774 of file GaudiHistos.h.

◆ m_histo2DMapID

template<class PBASE >
Histo2DMapID GaudiHistos< PBASE >::m_histo2DMapID
mutableprivate

the actual storage/access of 2D histograms by unique ID

Definition at line 2795 of file GaudiHistos.h.

◆ m_histo2DMapTitle

template<class PBASE >
Histo2DMapTitle GaudiHistos< PBASE >::m_histo2DMapTitle
mutableprivate

the actual storage/access of 2D histograms by unique title

Definition at line 2793 of file GaudiHistos.h.

◆ m_histo3DMapID

template<class PBASE >
Histo3DMapID GaudiHistos< PBASE >::m_histo3DMapID
mutableprivate

the actual storage/access of 3D histograms by unique ID

Definition at line 2800 of file GaudiHistos.h.

◆ m_histo3DMapTitle

template<class PBASE >
Histo3DMapTitle GaudiHistos< PBASE >::m_histo3DMapTitle
mutableprivate

the actual storage/access of 3D histograms by unique title

Definition at line 2798 of file GaudiHistos.h.

◆ m_histoCountersPrint

template<class PBASE >
Gaudi::Property<bool> GaudiHistos< PBASE >::m_histoCountersPrint
private
Initial value:
{ this, "HistoCountersPrint", true,
"Switch on/off the printout of histogram counters at finalization" }

Definition at line 2755 of file GaudiHistos.h.

◆ m_histoDir

template<class PBASE >
Gaudi::Property<std::string> GaudiHistos< PBASE >::m_histoDir
private
Initial value:
{
this, "HistoDir", boost::algorithm::replace_all_copy( this->name(), ":", "_" ), "Histogram Directory" }

Definition at line 2765 of file GaudiHistos.h.

◆ m_histoOffSet

template<class PBASE >
Gaudi::Property<HistoID::NumericID> GaudiHistos< PBASE >::m_histoOffSet
private
Initial value:
{
this, "HistoOffSet", 0, "OffSet for automatically assigned histogram numerical identifiers " }

Definition at line 2761 of file GaudiHistos.h.

◆ m_histosPrint

template<class PBASE >
Gaudi::Property<bool> GaudiHistos< PBASE >::m_histosPrint
private
Initial value:
{ this, "HistoPrint", false,
[this]( const auto& ) {
if ( this->FSMState() >= Gaudi::StateMachine::INITIALIZED &&
this->histosPrint() )
},
"Switch on/off the printout of histograms at finalization" }

Definition at line 2747 of file GaudiHistos.h.

◆ m_histoTopDir

template<class PBASE >
Gaudi::Property<std::string> GaudiHistos< PBASE >::m_histoTopDir
private
Initial value:
{ this, "HistoTopDir", "",
"Top level histogram directory (take care that it ends with '/')" }

Definition at line 2763 of file GaudiHistos.h.

◆ m_idReplaceInfo

template<class PBASE >
Gaudi::Property<std::map<std::string, std::string> > GaudiHistos< PBASE >::m_idReplaceInfo
private
Initial value:
{
this,
"AutoStringIDPurgeMap",
{ { "/", "=SLASH=" } },
"Map of strings to search and replace when using the title "
"as the basis of automatically generated literal IDs" }

Definition at line 2780 of file GaudiHistos.h.

◆ m_produceHistos

template<class PBASE >
Gaudi::Property<bool> GaudiHistos< PBASE >::m_produceHistos { this, "HistoProduce", true, "Switch on/off the production of histograms" }
private

Definition at line 2746 of file GaudiHistos.h.

◆ m_profile1DMapID

template<class PBASE >
Profile1DMapID GaudiHistos< PBASE >::m_profile1DMapID
mutableprivate

the actual storage/access of 1D profile histograms by unique ID

Definition at line 2805 of file GaudiHistos.h.

◆ m_profile1DMapTitle

template<class PBASE >
Profile1DMapTitle GaudiHistos< PBASE >::m_profile1DMapTitle
mutableprivate

the actual storage/access of 1D profile histograms by unique title

Definition at line 2803 of file GaudiHistos.h.

◆ m_profile2DMapID

template<class PBASE >
Profile2DMapID GaudiHistos< PBASE >::m_profile2DMapID
mutableprivate

the actual storage/access of 2D profile histograms by unique ID

Definition at line 2810 of file GaudiHistos.h.

◆ m_profile2DMapTitle

template<class PBASE >
Profile2DMapTitle GaudiHistos< PBASE >::m_profile2DMapTitle
mutableprivate

the actual storage/access of 2D profile histograms by unique title

Definition at line 2808 of file GaudiHistos.h.

◆ m_splitHistoDir

template<class PBASE >
Gaudi::Property<bool> GaudiHistos< PBASE >::m_splitHistoDir
private
Initial value:
{ this, "HistoSplitDir", false,
"Split long directory names into short pieces (suitable for HBOOK)" }

Definition at line 2759 of file GaudiHistos.h.

◆ m_useNumericAutoIDs

template<class PBASE >
Gaudi::Property<bool> GaudiHistos< PBASE >::m_useNumericAutoIDs
private
Initial value:
{
this, "UseSequencialNumericAutoIDs", false,
"Flag to allow users to switch back to the old style of creating numerical automatic IDs" }

Definition at line 2777 of file GaudiHistos.h.


The documentation for this class was generated from the following files:
GaudiHistos::histo1DMapTitle
const Histo1DMapTitle & histo1DMapTitle() const
get access to the map of all 1D histograms indexed via their title
Definition: GaudiHistos.h:2434
MSG::DEBUG
@ DEBUG
Definition: IMessageSvc.h:25
GaudiHistos::bookProfile2D
AIDA::IProfile2D * bookProfile2D(const std::string &title, const double lowX=0, const double highX=100, const unsigned long binsX=50, const double lowY=0, const double highY=100, const unsigned long binsY=50) const
book the 2D profile histogram
Definition: GaudiHistos_2DProfFixedBinning.icpp:15
GaudiHistos::m_declareMoniHists
Gaudi::Property< bool > m_declareMoniHists
Definition: GaudiHistos.h:2768
GaudiHistos::plot3D
AIDA::IHistogram3D * plot3D(const double valueX, const double valueY, const double valueZ, const std::string &title, const double lowX, const double highX, const double lowY, const double highY, const double lowZ, const double highZ, const unsigned long binsX=10, const unsigned long binsY=10, const unsigned long binsZ=10, const double weight=1.0) const
fill the 3D histogram (book on demand)
Definition: GaudiHistos_3DFixedBinning.icpp:121
GaudiHistos::plot1D
AIDA::IHistogram1D * plot1D(const double value, const std::string &title, const double low, const double high, const unsigned long bins=100, const double weight=1.0) const
fill the 1D histogram (book on demand)
Definition: GaudiHistos_1DFixedBinning.icpp:113
GaudiHistos::profile1DMapTitle
const Profile1DMapTitle & profile1DMapTitle() const
get access to the map of all 1D profile histograms indexed via their title
Definition: GaudiHistos.h:2587
std::string
STL class.
GaudiHistos::histo2D
AIDA::IHistogram2D * histo2D(const std::string &title) const
access the EXISTING 2D histogram by title return the pointer to existing 2D histogram or NULL
Definition: GaudiHistos.h:2297
GaudiHistos::histo3DMapID
const Histo3DMapID & histo3DMapID() const
get access to the map of all 3D histograms index via a ID
Definition: GaudiHistos.h:2558
GaudiUtils::Map::find
iterator find(const key_type &key)
Definition: Map.h:157
GaudiHistos::histoPath
std::string histoPath() const
get the constructed histogram path
Definition: GaudiHistos.icpp:368
GaudiHistos::convertTitleToID
std::string convertTitleToID(std::string title) const
Create an ID string from a title string.
Definition: GaudiHistos.icpp:360
GaudiHistos::m_histoDir
Gaudi::Property< std::string > m_histoDir
Definition: GaudiHistos.h:2765
std::vector< double >
GaudiHistos::histo3D
AIDA::IHistogram3D * histo3D(const std::string &title) const
access the EXISTING 3D histogram by title return the pointer to existing 3D histogram or NULL
Definition: GaudiHistos.h:2305
Gaudi::Utils::Histos::Formats::header
GAUDI_API std::string header(const int ID=Default)
get the recommended header by enum
Definition: HistoTableFormat.cpp:186
GaudiHistos::m_profile1DMapTitle
Profile1DMapTitle m_profile1DMapTitle
the actual storage/access of 1D profile histograms by unique title
Definition: GaudiHistos.h:2803
GaudiHistos::m_histo2DMapTitle
Histo2DMapTitle m_histo2DMapTitle
the actual storage/access of 2D histograms by unique title
Definition: GaudiHistos.h:2793
GaudiHistos::histoExists
bool histoExists(const std::string &title) const
check the existence AND validity of the histogram with given title
Definition: GaudiHistos.h:2365
GaudiMP.FdsRegistry.msg
msg
Definition: FdsRegistry.py:19
GaudiHistos::newHistoID
void newHistoID(const std::string &title, HistoID &ID) const
Create a new histogram ID using the given title.
Definition: GaudiHistos.icpp:337
GaudiHistos::monitorHisto
void monitorHisto(const AIDA::IBaseHistogram *hist, const HistoID &ID) const
Declare a histogram to the monitor service.
Definition: GaudiHistos.icpp:281
GaudiHistos::m_profile1DMapID
Profile1DMapID m_profile1DMapID
the actual storage/access of 1D profile histograms by unique ID
Definition: GaudiHistos.h:2805
GaudiHistos::m_splitHistoDir
Gaudi::Property< bool > m_splitHistoDir
Definition: GaudiHistos.h:2759
GaudiHistos::m_histo1DTableFormatShort
Gaudi::Property< std::string > m_histo1DTableFormatShort
Definition: GaudiHistos.h:2772
GaudiHistos::histo1DMapID
const Histo1DMapID & histo1DMapID() const
get access to the map of all 1D histograms index via ID
Definition: GaudiHistos.h:2458
GaudiHistos::produceHistos
bool produceHistos() const
get the flag for histogram production (property "HistoProduce")
Definition: GaudiHistos.h:2381
GaudiHistos::profile2DMapTitle
const Profile2DMapTitle & profile2DMapTitle() const
get access to the map of all 2D profile histograms indexed via their title
Definition: GaudiHistos.h:2637
GaudiHistos::histo3DMapTitle
const Histo3DMapTitle & histo3DMapTitle() const
get access to the map of all 3D histograms indexed via their title
Definition: GaudiHistos.h:2535
GaudiHistos::m_fullDetail
Gaudi::Property< bool > m_fullDetail
Definition: GaudiHistos.h:2767
GaudiHistos::m_histo3DMapID
Histo3DMapID m_histo3DMapID
the actual storage/access of 3D histograms by unique ID
Definition: GaudiHistos.h:2800
GaudiHistos::Profile1DMapTitle
GaudiAlg::Profile1DMapTitle Profile1DMapTitle
the actual type for title->(1D profile histogram) mapping
Definition: GaudiHistos.h:89
GaudiHistos::plot2D
AIDA::IHistogram2D * plot2D(const double valueX, const double valueY, const std::string &title, const double lowX, const double highX, const double lowY, const double highY, const unsigned long binsX=50, const unsigned long binsY=50, const double weight=1.0) const
fill the 2D histogram (book on demand)
Definition: GaudiHistos_2DFixedBinning.icpp:116
GaudiUtils::Map< K, T, std::unordered_map< K, T, Hash< K > > >::const_iterator
map_type::const_iterator const_iterator
Definition: Map.h:108
GaudiHistos::m_histo1DMapTitle
Histo1DMapTitle m_histo1DMapTitle
the actual storage/access of 1D histograms by unique title
Definition: GaudiHistos.h:2788
GaudiAlg::Print2DProf::toString
static std::string toString(const AIDA::IProfile2D *aida, const GaudiAlg::HistoID &ID)
Definition: Print.cpp:98
Gaudi::Histo1DDef
Definition: HistoDef.h:41
std::isnan
T isnan(T... args)
GaudiHistos::m_histoOffSet
Gaudi::Property< HistoID::NumericID > m_histoOffSet
Definition: GaudiHistos.h:2761
GaudiHistos::m_useNumericAutoIDs
Gaudi::Property< bool > m_useNumericAutoIDs
Definition: GaudiHistos.h:2777
GaudiUtils::Map::clear
void clear()
Definition: Map.h:195
std::isfinite
T isfinite(T... args)
GaudiAlg::Print3D::toString
static std::string toString(const AIDA::IHistogram3D *aida, const GaudiAlg::HistoID &ID)
Definition: Print.cpp:77
TimingHistograms.name
name
Definition: TimingHistograms.py:25
StatusCode
Definition: StatusCode.h:65
GaudiHistos::profile1DMapID
const Profile1DMapID & profile1DMapID() const
get access to the map of 1D profile histograms index via a ID
Definition: GaudiHistos.h:2610
Gaudi::Utils::Histos::toBase
GAUDI_API AIDA::IBaseHistogram * toBase(AIDA::IHistogram1D *histo)
Definition: Fill.cpp:165
std::cout
GaudiPluginService.cpluginsvc.func
func
Definition: cpluginsvc.py:236
GaudiHistos::histo2DMapID
const Histo2DMapID & histo2DMapID() const
get access to the map of 2D histograms index via ID
Definition: GaudiHistos.h:2508
GaudiHistos::m_histo1DTableHeader
Gaudi::Property< std::string > m_histo1DTableHeader
Definition: GaudiHistos.h:2774
AlgSequencer.h
h
Definition: AlgSequencer.py:32
GaudiHistos::totalNumberOfHistos
unsigned int totalNumberOfHistos() const
Returns the total number of histograms (of all types) currently booked.
Definition: GaudiHistos.icpp:329
GaudiHistos::HistoID
GaudiAlg::HistoID HistoID
the actual type for histogram identifier
Definition: GaudiHistos.h:69
GaudiHistos::m_histo3DMapTitle
Histo3DMapTitle m_histo3DMapTitle
the actual storage/access of 3D histograms by unique title
Definition: GaudiHistos.h:2798
GaudiPython.HistoUtils.path
path
Definition: HistoUtils.py:961
Gaudi::Utils::Histos::htitle
GAUDI_API std::string htitle(const AIDA::IBaseHistogram *histo, const std::string &title="")
get the title
Definition: Fill.cpp:119
Gaudi::Details::Property::ParsingErrorPolicy::Warning
@ Warning
GaudiHistos::m_histosPrint
Gaudi::Property< bool > m_histosPrint
Definition: GaudiHistos.h:2747
GaudiHistos::printHistos
int printHistos(const MSG::Level level=MSG::ALWAYS) const
perform the actual printout of histograms
Definition: GaudiHistos.icpp:174
endmsg
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:203
GaudiHistos::m_produceHistos
Gaudi::Property< bool > m_produceHistos
Definition: GaudiHistos.h:2746
GaudiHistos::m_idReplaceInfo
Gaudi::Property< std::map< std::string, std::string > > m_idReplaceInfo
Definition: GaudiHistos.h:2780
GaudiHistos::histo
AIDA::IHistogram1D * histo(const std::string &title) const
access the EXISTING 1D histogram by title
Definition: GaudiHistos.h:2292
GaudiHistos::noHistos
bool noHistos() const
Check if all histogram maps are empty.
Definition: GaudiHistos.icpp:272
gaudirun.level
level
Definition: gaudirun.py:364
MsgStream
Definition: MsgStream.h:34
GaudiHistos::bookProfile1D
AIDA::IProfile1D * bookProfile1D(const std::string &title, const double low=0, const double high=100, const unsigned long bins=100, const std::string &opt="", const double lowY=-std::numeric_limits< double >::max(), const double highY=std::numeric_limits< double >::max()) const
book the 1D profile histogram
Definition: GaudiHistos_1DProfFixedBinning.icpp:15
GaudiHistos::histoDir
const std::string & histoDir() const
get histogram directory (property "HistoDir")
Definition: GaudiHistos.h:2393
Gaudi::Utils::Histos::Table
Definition: HistoTableFormat.h:437
GaudiUtils::Map::end
iterator end()
Definition: Map.h:140
GaudiHistos::profile1D
AIDA::IProfile1D * profile1D(const double valueX, const double valueY, const std::string &title, const double lowX, const double highX, const unsigned long binsX=100, const std::string &opt="", const double lowY=-std::numeric_limits< double >::max(), const double highY=std::numeric_limits< double >::max(), const double weight=1.0) const
fill the 1D profile histogram (book on demand)
Definition: GaudiHistos_1DProfFixedBinning.icpp:114
Gaudi::Histo1DDef::highEdge
double highEdge() const
get the high edge
Definition: HistoDef.h:65
HistoDumpEx.v
v
Definition: HistoDumpEx.py:27
GaudiHistos::m_histoTopDir
Gaudi::Property< std::string > m_histoTopDir
Definition: GaudiHistos.h:2763
Gaudi::Utils::Histos::Formats::format
GAUDI_API std::string format(const int ID=Default)
get the format by enum
Definition: HistoTableFormat.cpp:153
GaudiAlg::Print2D::toString
static std::string toString(const AIDA::IHistogram2D *aida, const GaudiAlg::HistoID &ID)
Definition: Print.cpp:66
GaudiHistos::book2D
AIDA::IHistogram2D * book2D(const std::string &title, const double lowX=0, const double highX=100, const unsigned long binsX=50, const double lowY=0, const double highY=100, const unsigned long binsY=50) const
book the 2D histogram
Definition: GaudiHistos_2DFixedBinning.icpp:17
GaudiHistos::m_histoCountersPrint
Gaudi::Property< bool > m_histoCountersPrint
Definition: GaudiHistos.h:2755
StatusCode::isFailure
bool isFailure() const
Definition: StatusCode.h:129
gaudirun.type
type
Definition: gaudirun.py:160
GaudiHistos::histoOffSet
HistoID::NumericID histoOffSet() const
get the value for histogram offset (property "HistoOffSet")
Definition: GaudiHistos.h:2389
StatusCode::SUCCESS
constexpr static const auto SUCCESS
Definition: StatusCode.h:100
std::endl
T endl(T... args)
GaudiHistos::m_profile2DMapID
Profile2DMapID m_profile2DMapID
the actual storage/access of 2D profile histograms by unique ID
Definition: GaudiHistos.h:2810
GaudiUtils::Map::size
size_type size() const
Definition: Map.h:199
MSG::ALWAYS
@ ALWAYS
Definition: IMessageSvc.h:25
GaudiHistos::m_histo1DMapID
Histo1DMapID m_histo1DMapID
the actual storage/access of 1D histograms by unique ID
Definition: GaudiHistos.h:2790
HistoEx.histos
histos
Definition: HistoEx.py:103
GaudiHistos::plot
AIDA::IHistogram1D * plot(const double value, const std::string &title, const double low, const double high, const unsigned long bins=100, const double weight=1.0) const
fill the 1D histogram (book on demand)
Definition: GaudiHistos.h:162
Gaudi::StateMachine::INITIALIZED
@ INITIALIZED
Definition: StateMachine.h:25
GaudiHistos::m_histo1DTableFormat
Gaudi::Property< std::string > m_histo1DTableFormat
Definition: GaudiHistos.h:2769
GaudiHistos::splitHistoDir
bool splitHistoDir() const
get the flag for histogram path split (property "HistoSplitDir")
Definition: GaudiHistos.h:2387
GaudiHistos::checkForNaN
bool checkForNaN() const
get the flag for NaN checks (property "HistoCheckForNan")
Definition: GaudiHistos.h:2385
GaudiHistos::profile2DMapID
const Profile2DMapID & profile2DMapID() const
get access to the map of 2D profile histograms index via a ID
Definition: GaudiHistos.h:2660
GaudiHistos::histo1D
AIDA::IHistogram1D * histo1D(const std::string &title) const
access the EXISTING 1D histogram by title return the pointer to existing 1D histogram or NULL
Definition: GaudiHistos.h:2280
GaudiHistos::useNumericAutoIDs
bool useNumericAutoIDs() const
Use old style sequencial numerical automatically assigned IDs ?
Definition: GaudiHistos.h:2401
Gaudi::Histo1DDef::lowEdge
double lowEdge() const
get the low edge
Definition: HistoDef.h:63
GaudiHistos::book3D
AIDA::IHistogram3D * book3D(const std::string &title, const double lowX=0, const double highX=100, const unsigned long binsX=10, const double lowY=0, const double highY=100, const unsigned long binsY=10, const double lowZ=0, const double highZ=100, const unsigned long binsZ=10) const
book the 3D histogram
Definition: GaudiHistos_3DFixedBinning.icpp:17
std::string::empty
T empty(T... args)
GaudiHistos::m_checkForNaN
Gaudi::Property< bool > m_checkForNaN
Definition: GaudiHistos.h:2757
GaudiHistos::profile2D
AIDA::IProfile2D * profile2D(const double valueX, const double valueY, const double valueZ, const std::string &title, const double lowX, const double highX, const double lowY, const double highY, const unsigned long binsX=50, const unsigned long binsY=50, const double weight=1.0) const
fill the 2D profile histogram (book on demand)
Definition: GaudiHistos_2DProfFixedBinning.icpp:113
Gaudi::Histo1DDef::bins
int bins() const
get the number of bins
Definition: HistoDef.h:67
Gaudi::Histo1DDef::title
const std::string & title() const
get the title
Definition: HistoDef.h:69
Gaudi::Utils::Histos::fill
GAUDI_API void fill(AIDA::IHistogram1D *histo, const double value, const double weight=1.0)
simple function to fill AIDA::IHistogram1D objects
Definition: Fill.cpp:45
GaudiHistos::m_histo2DMapID
Histo2DMapID m_histo2DMapID
the actual storage/access of 2D histograms by unique ID
Definition: GaudiHistos.h:2795
GaudiHistos::histoCountersPrint
bool histoCountersPrint() const
print histogram counters at finalization ?
Definition: GaudiHistos.h:2399
GaudiHistos::histosPrint
bool histosPrint() const
print histograms at finalization ?
Definition: GaudiHistos.h:2397
Gaudi::Utils::Histos
Definition: Fill.h:36
GaudiHistos::book1D
AIDA::IHistogram1D * book1D(const std::string &title, const double low=0, const double high=100, const unsigned long bins=100) const
book the 1D histogram
Definition: GaudiHistos_1DFixedBinning.icpp:17
GaudiHistos::histo2DMapTitle
const Histo2DMapTitle & histo2DMapTitle() const
get access to the map of all 2D histograms indexed via their title
Definition: GaudiHistos.h:2485
GaudiHistos::histoTopDir
const std::string & histoTopDir() const
get top-level histogram directory (property "HistoTopDir")
Definition: GaudiHistos.h:2391
Gaudi::Utils::Histos::format
GAUDI_API std::string format(const AIDA::IHistogram1D *histo, const std::string &fmt)
Make the string representation of the histogram according to the specified format.
Definition: HistoTableFormat.cpp:233
GaudiHistos::fill
AIDA::IHistogram1D * fill(AIDA::IHistogram1D *histo, const double value, const double weight, const std::string &title="") const
fill the 1D histogram with the value and weight
Definition: GaudiHistos_1DFixedBinning.icpp:89
GaudiHistos::m_profile2DMapTitle
Profile2DMapTitle m_profile2DMapTitle
the actual storage/access of 2D profile histograms by unique title
Definition: GaudiHistos.h:2808