Go to the documentation of this file. 1 #ifndef DD4hep_XHistogram_h
2 #define DD4hep_XHistogram_h
17 typedef std::pair<double, double>
Range;
48 size_t size,
size_t bins_x,
size_t bins_y,
Range x,
Range y,
size_t zones,
const std::vector<double>&
max)
68 Histogram(
nullptr,
nullptr, 0, 0., 0., 0, 0., 0.);
72 void fill(
double x,
double y,
const std::vector<double>&
weight,
double norm);
75 void fill(
double x,
double y,
const std::vector<double>&
weight,
double norm,
unsigned int colour);
81 void fill(
const Range&
x,
const Range&
y,
const std::vector<double>&
weight,
double norm,
unsigned int colour);
112 position(
const double& f_,
const double& x_,
const double& y_) :
f(f_),
x(x_),
y(y_) {}
124 throw std::invalid_argument(
"weight: wrong number of elements");
128 #endif // DD4hep_XHistogram_h
std::shared_ptr< ColorMap > m_colormap
void check_weight(const std::vector< double > &weight) noexcept(false)
check the weights passed as an std::vector have the correct size
FWCore Framework interface EventSetupRecordImplementation h
Helper function to determine trigger accepts.
std::vector< std::shared_ptr< Histogram > > m_histograms
std::pair< double, double > Range
Histogram * get(size_t h=0) const
access one of the histograms
bool operator<(const position &other) const
void fill(double x, double y, const std::vector< double > &weight, double norm)
fill one point
std::shared_ptr< Histogram > m_normalization
ColorMap * colormap(void) const
access the colormap
Histogram * normalization(void) const
access the normalization
std::shared_ptr< Histogram > m_dummy
DD4hep_XHistogram(size_t size, size_t bins_x, size_t bins_y, Range x, Range y, size_t zones, const std::vector< double > &max)
std::vector< position > splitSegment(Range x, Range y) const
split a segment into a vector of points
void normalize(void)
normalize the histograms
DD4hep_XHistogram(void)
default CTOR
position(const double &f_, const double &x_, const double &y_)