The Gaudi Framework  v36r10 (fc05264c)
H1D.h
Go to the documentation of this file.
1 /***********************************************************************************\
2 * (c) Copyright 1998-2019 CERN for the benefit of the LHCb and ATLAS collaborations *
3 * *
4 * This software is distributed under the terms of the Apache version 2 licence, *
5 * copied verbatim in the file "LICENSE". *
6 * *
7 * In applying this licence, CERN does not waive the privileges and immunities *
8 * granted to it by virtue of its status as an Intergovernmental Organization *
9 * or submit itself to any jurisdiction. *
10 \***********************************************************************************/
11 #ifndef HISTOGRAMSVC_H1D_H
12 #define HISTOGRAMSVC_H1D_H 1
13 
14 #include "Generic1D.h"
15 #include <AIDA/IHistogram1D.h>
16 #include <GaudiKernel/DataObject.h>
17 #include <TH1D.h>
18 
19 #include <nlohmann/json.hpp>
20 
21 #include <mutex>
22 
23 namespace Gaudi {
24 
31  class GAUDI_API Histogram1D : public DataObject, public Gaudi::Generic1D<AIDA::IHistogram1D, TH1D> {
32  private:
33  void init( const std::string& title, bool initialize_axis = true );
34  void initSums();
35 
36  protected:
38  double m_sumwx = 0;
39 
40  public:
42  Histogram1D();
44  Histogram1D( TH1D* rep );
45 
47  void adoptRepresentation( TObject* rep ) override;
49  virtual bool setBinContents( int i, int entries, double height, double error, double centre );
51  bool reset() override;
53  nlohmann::json toJSON() const;
55  virtual bool setStatistics( int allEntries, double eqBinEntries, double mean, double rms );
57  bool fill( double x, double weight ) override;
59  bool setRms( double rms );
61  void copyFromAida( const AIDA::IHistogram1D& h );
63  const CLID& clID() const override { return classID(); }
64  static const CLID& classID() { return CLID_H1D; }
69  StreamBuffer& serialize( StreamBuffer& s );
70 
75  StreamBuffer& serialize( StreamBuffer& s ) const;
76 
77  private:
79 
80  }; // end class IHistogram1D
81 } // end namespace Gaudi
82 #endif // HISTOGRAMSVC_H1D_H
std::string
STL class.
gaudirun.s
string s
Definition: gaudirun.py:346
jsonFromLHCbLog.json
dictionary json
Definition: jsonFromLHCbLog.py:87
StreamBuffer
Definition: StreamBuffer.h:52
AlgSequencer.h
h
Definition: AlgSequencer.py:32
Generic1D.h
Gaudi::Histogram1D::classID
static const CLID & classID()
Definition: H1D.h:64
GaudiPython.HistoUtils.rms
rms
Definition: HistoUtils.py:908
CLID
unsigned int CLID
Class ID definition.
Definition: ClassID.h:18
Gaudi::Histogram1D
Definition: H1D.h:31
GaudiPython.HistoUtils.mean
mean
Definition: HistoUtils.py:904
Gaudi
Header file for std:chrono::duration-based Counters.
Definition: __init__.py:1
DataObject.h
DataObject
Definition: DataObject.h:40
Gaudi::Histogram1D::m_fillSerialization
std::mutex m_fillSerialization
Definition: H1D.h:78
std::mutex
STL class.
Gaudi::Generic1D
Definition: Generic1D.h:46
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
Gaudi::Histogram1D::clID
const CLID & clID() const override
Retrieve reference to class defininition identifier.
Definition: H1D.h:63
GAUDI_API
#define GAUDI_API
Definition: Kernel.h:81