34 testInvariant ()
const
67 for (std::size_t form = 0, end = m_formulas.size(); form != end; ++ form)
81 : m_hist (0), m_type (-1), m_valnum (1), m_cut (
false), m_hist2 (0)
89 AlgHist (TH1 *val_hist_swallow,
90 const std::string& val_value0,
91 const std::string& val_value1,
92 const std::string& val_value2,
93 const std::string& val_value3)
94 : m_hist (0), m_type (-1), m_valnum (1), m_cut (
false), m_hist2 (0)
96 std::unique_ptr<TH1> hist (val_hist_swallow);
101 m_formulas.push_back (val_value0);
102 if (!val_value1.empty())
103 m_formulas.push_back (val_value1);
104 if (!val_value2.empty())
105 m_formulas.push_back (val_value2);
106 if (!val_value3.empty())
107 m_formulas.push_back (val_value3);
109 m_hist = hist.release();
110 m_hist->SetDirectory (0);
111 if (
dynamic_cast<TProfile*
>(m_hist) != 0)
115 }
else if (
dynamic_cast<TH2*
>(m_hist) != 0)
119 }
else if (
dynamic_cast<TH3*
>(m_hist) != 0)
128 m_values.resize (m_valnum + 1, 1);
129 if (m_valnum == m_formulas.size())
131 else if (m_valnum+1 == m_formulas.size())
143 if (m_hist !=
nullptr) {
155 return EL::StatusCode::SUCCESS;
168 for (std::size_t form = 0, end = m_formulas.size(); form != end; ++ form)
169 m_index.push_back (m_formSvc->addForm (m_formulas[form]));
170 m_hist2 =
dynamic_cast<TH1*
>(m_hist->Clone ());
172 wk()->addOutput (m_hist2);
178 return EL::StatusCode::SUCCESS;
188 RCU_ASSERT (m_formulas.size() == m_index.size());
189 RCU_ASSERT (m_formulas.size() <= m_values.size());
191 if (m_cut && m_index.back()->ndim() == 0 &&
192 (m_values.back() = m_index.back()->value (0)) == 0)
193 return EL::StatusCode::SUCCESS;
196 std::size_t
size = std::size_t (-1);
197 for (std::size_t form = 0; form != m_valnum; ++ form)
199 switch (m_index[form]->ndim())
205 if (m_index[form]->ndata() > 0)
206 m_values[form] = m_index[form]->value (0);
212 if (
size > m_index[form]->ndata())
213 size = m_index[form]->ndata();
216 RCU_THROW_MSG (
"unknown formula dimension: " + m_formulas[form]);
220 if (ndim == 0 &&
size > 1)
222 for (std::size_t iter = 0; iter !=
size; ++ iter)
226 if (m_cut && m_index.back()->ndim() == 1 &&
227 (m_values.back() = m_index.back()->value (iter)) == 0)
230 for (std::size_t form = 0; form != m_valnum; ++ form)
232 if (m_index[form]->ndim() == 1)
233 m_values[form] = m_index[form]->value (iter);
240 m_hist2->Fill (m_values[0], m_values[1]);
243 static_cast<TProfile*
>(m_hist2)->Fill (m_values[0], m_values[1], m_values[2]);
246 static_cast<TH2*
>(m_hist2)->Fill (m_values[0], m_values[1], m_values[2]);
249 static_cast<TH3*
>(m_hist2)->Fill (m_values[0], m_values[1], m_values[2], m_values[3]);
255 return EL::StatusCode::SUCCESS;