The Gaudi Framework  master (37c0b60a)
H3D.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 #pragma once
12 
13 #include "Generic3D.h"
14 #include <AIDA/IHistogram3D.h>
16 #include <GaudiKernel/DataObject.h>
17 #include <TH3D.h>
18 
19 #include <nlohmann/json.hpp>
20 
21 namespace Gaudi {
22 
29  class GAUDI_API Histogram3D : public DataObject, public Generic3D<AIDA::IHistogram3D, TH3D> {
30  public:
32  Histogram3D();
34  Histogram3D( TH3D* rep );
35 
37  bool fill( double x, double y, double z, double weight ) override;
39  virtual bool setBinContents( int i, int j, int k, int entries, double height, double error, double centreX,
40  double centreY, double centreZ );
42  virtual bool setRms( double rmsX, double rmsY, double rmsZ );
43  // overwrite reset
44  bool reset() override;
45  // free function reset
46  friend void reset( Histogram3D& h ) { h.reset(); }
48  friend void to_json( nlohmann::json& j, Histogram3D const& h ) { j = *h.m_rep.get(); }
50  void* cast( const std::string& className ) const override;
52  void copyFromAida( const AIDA::IHistogram3D& h );
54  const CLID& clID() const override { return classID(); }
55  static const CLID& classID() { return CLID_H3D; }
56 
57  protected:
58  // cache sumwx and sumwy when setting contents since I don't have bin mean
59  double m_sumwx = 0;
60  double m_sumwy = 0;
61  double m_sumwz = 0;
62 
63  private:
65  };
66 } // namespace Gaudi
std::string
STL class.
jsonFromLHCbLog.json
json
Definition: jsonFromLHCbLog.py:86
Gaudi::Histogram3D::classID
static const CLID & classID()
Definition: H3D.h:55
Utils.h
Gaudi::Histogram3D::clID
const CLID & clID() const override
Retrieve reference to class defininition identifier.
Definition: H3D.h:54
Gaudi::Histogram3D::m_fillSerialization
std::mutex m_fillSerialization
Definition: H3D.h:64
ProduceConsume.j
j
Definition: ProduceConsume.py:104
AlgSequencer.h
h
Definition: AlgSequencer.py:31
Gaudi::Histogram3D::reset
friend void reset(Histogram3D &h)
Definition: H3D.h:46
CLID
unsigned int CLID
Class ID definition.
Definition: ClassID.h:18
Gaudi::Histogram3D
Definition: H3D.h:29
Gaudi
This file provides a Grammar for the type Gaudi::Accumulators::Axis It allows to use that type from p...
Definition: __init__.py:1
Gaudi::Histogram3D::to_json
friend void to_json(nlohmann::json &j, Histogram3D const &h)
conversion to json via nlohmann library
Definition: H3D.h:48
DataObject.h
DataObject
Definition: DataObject.h:36
Generic3D.h
std::mutex
STL class.
Gaudi::Generic3D
Definition: Generic3D.h:46
GAUDI_API
#define GAUDI_API
Definition: Kernel.h:81