Filler for plain 1D histograms.
More...
#include <HistogramFiller1D.h>
Filler for plain 1D histograms.
Definition at line 21 of file HistogramFiller1D.h.
◆ HistogramFiller1D()
◆ fill() [1/2]
Method that actually fills the ROOT object.
- Returns
- number of fills performed
Implements Monitored::HistogramFiller.
Reimplemented in Monitored::CumulativeHistogramFiller1D, and Monitored::VecHistogramFiller1D.
Definition at line 27 of file HistogramFiller1D.h.
28 std::function<
bool(
size_t)> cutMaskAccessor;
32 if (cutMaskValuePair.first == 0) {
return 0; }
33 if (
ATH_UNLIKELY(cutMaskValuePair.first > 1 && cutMaskValuePair.first != vars.var[0]->size())) {
35 log << MSG::ERROR <<
"CutMask does not match the size of plotted variable: "
36 << cutMaskValuePair.first <<
" " << vars.var[0]->size() <<
endmsg;
38 cutMaskAccessor = cutMaskValuePair.second;
42 auto weightAccessor = [&](
size_t i){
return vars.weight->get(
i); };
44 if (
ATH_UNLIKELY(vars.weight->size() != vars.var[0]->size())) {
46 log << MSG::ERROR <<
"Weight does not match the size of plotted variable: "
47 << vars.weight->size() <<
" " << vars.var[0]->size() <<
endmsg;
50 if (not vars.cut)
return HistogramFiller::fill<TH1>(weightAccessor,
detail::noCut, *vars.var[0]);
51 else return HistogramFiller::fill<TH1>(weightAccessor, cutMaskAccessor, *vars.var[0]);
55 else return HistogramFiller::fill<TH1>(
detail::noWeight, cutMaskAccessor, *vars.var[0]);
◆ fill() [2/2]
template<class H , typename W , typename C , typename ... Ms>
unsigned Monitored::HistogramFiller::fill |
( |
W |
weight, |
|
|
C |
cut, |
|
|
const Ms &... |
m |
|
) |
| const |
|
inlineprotectedinherited |
Fill histogram from IMonitoredVariable.
Supports arbitrary dimensions and double/string representation.
- Template Parameters
-
H | histogram type (TH1, TH2, ...) |
- Parameters
-
Definition at line 184 of file HistogramFiller.h.
185 auto hist = this->histogram<H>();
◆ getCutMaskFunc()
Definition at line 155 of file HistogramFiller.h.
156 std::function<
bool(
size_t)> cutMaskValue = [] (size_t){
return true; };
158 if (
mask !=
nullptr ) {
163 return std::make_pair(0, [](
size_t){
return false; });
167 return std::make_pair(
maskSize, [
mask](
size_t i){
return static_cast<bool>(
mask->get(
i)); });
170 return std::make_pair(
maskSize, cutMaskValue);
◆ getLock()
const std::unique_lock<std::mutex> Monitored::HistogramFiller::getLock |
( |
| ) |
const |
|
inlineinherited |
◆ histogram()
template<class H >
H* Monitored::HistogramFiller::histogram |
( |
| ) |
const |
|
inlineprotectedinherited |
◆ histogramCutMaskName()
const std::string& Monitored::HistogramFiller::histogramCutMaskName |
( |
| ) |
const |
|
inlineinherited |
◆ histogramVariablesNames()
const std::vector<std::string>& Monitored::HistogramFiller::histogramVariablesNames |
( |
| ) |
const |
|
inlineinherited |
◆ histogramWeightName()
const std::string& Monitored::HistogramFiller::histogramWeightName |
( |
| ) |
const |
|
inlineinherited |
◆ touch()
void Monitored::HistogramFiller::touch |
( |
| ) |
const |
|
inlineinherited |
◆ m_histDef
std::shared_ptr<HistogramDef> Monitored::HistogramFiller::m_histDef |
|
protectedinherited |
◆ m_histogramProvider
◆ m_lock
std::mutex Monitored::HistogramFiller::m_lock |
|
mutableprotectedinherited |
The documentation for this class was generated from the following file:
void doFill(H *hist, W weight, size_t i, const M &m1, const Ms &... m)
Perform (arbitrary dimension) histogram fill with weight.