38{
39 void AlgCFlow ::
40 testInvariant () const
41 {
43 if (m_hist != 0)
44 {
47 RCU_INVARIANT (m_formulas.size() == std::size_t (m_hist->GetNbinsX()));
51 }
52 if (m_hist2)
53 {
56 } else
58 }
59
60
61
62 AlgCFlow ::
63 AlgCFlow ()
64 : m_hist (0), m_hist2 (0), m_formSvc (0)
65 {
67 }
68
69
70
71 AlgCFlow ::
72 AlgCFlow (TH1 *val_hist_swallow)
73 : m_hist (0), m_hist2 (0)
74 {
75 std::unique_ptr<TH1>
hist (val_hist_swallow);
76
79
80 for (std::size_t form = 0, end =
hist->GetNbinsX();
81 form != end; ++ form)
82 {
83 const std::string
label =
hist->GetXaxis()->GetBinLabel(form+1);
85
86 m_axis.push_back (
hist->GetXaxis()->GetBinCenter (form+1));
87 if (
split == std::string::npos)
88 {
89 m_formulas.push_back (
label);
90 m_back.push_back (form - 1);
91 } else
92 {
93 m_formulas.push_back (
label.substr (0,
split));
94 const std::string back =
label.substr (
split+1);
95 m_back.push_back (form);
96
97 if (!back.empty())
98 {
99 for (std::size_t form2 = 0; form2 != form; ++ form2)
100 {
101 if (m_formulas[form2] == back)
102 m_back.back() = form2;
103 }
104 if (m_back.back() == form)
106 }
107 }
108 }
109
110 m_hist =
hist.release();
111 m_hist->SetDirectory (0);
112
113 m_values.resize (m_formulas.size());
114
116 }
117
118
119
122 {
125 return EL::StatusCode::SUCCESS;
126 }
127
128
129
131 initialize ()
132 {
134
135 try
136 {
138 for (std::size_t form = 0, end = m_formulas.size(); form != end; ++ form)
139 {
140 if (!m_formulas[form].
empty())
141 m_index.push_back (m_formSvc->addForm (m_formulas[form]));
142 else
143 m_index.push_back (0);
144 }
145 m_hist2 = dynamic_cast<TH1*>(m_hist->Clone ());
147 wk()->addOutput (m_hist2);
148 } catch (...)
149 {
150 m_index.clear ();
151 throw;
152 }
153 return EL::StatusCode::SUCCESS;
154 }
155
156
157
159 execute ()
160 {
162
164
165 int ndim = 0;
166 std::size_t size = std::size_t (-1);
167 for (std::size_t form = 0; form != m_formulas.size(); ++ form)
168 {
169 if (m_index[form]) switch (m_index[form]->ndim())
170 {
171 case -1:
173 break;
174 case 0:
175 if (m_index[form]->ndata() > 0)
176 m_values[form] = m_index[form]->value (0);
177 else
178 size = 0;
179 break;
180 case 1:
181 ndim = 1;
182 if (size > m_index[form]->ndata())
183 size = m_index[form]->ndata();
184 break;
185 default:
186 RCU_THROW_MSG (
"unknown formula dimension: " + m_formulas[form]);
187 }
188 }
189
190 if (ndim == 0 && size > 1)
191 size = 1;
192 for (std::size_t iter = 0;
iter != size; ++
iter)
193 {
194 for (std::size_t form = 0, end = m_formulas.size(); form != end; ++ form)
195 {
197
198 if (m_back[form] < form)
199 weight = m_values[m_back[form]];
200
201 if (weight != 0 && !m_formulas[form].
empty())
202 {
203 if (m_index[form]->ndim() == 1)
204 weight *= m_index[form]->value (iter);
205 else
206 weight *= m_index[form]->value (0);
207 }
208
210 m_hist2->Fill (m_axis[form], m_values[form]);
211 }
212 }
213 return EL::StatusCode::SUCCESS;
214 }
215}
#define RCU_CHANGE_INVARIANT(x)
#define RCU_NEW_INVARIANT(x)
#define RCU_REQUIRE_SOFT(x)
#define RCU_THROW_MSG(message)
static const Attributes_t empty
std::vector< std::string > split(const std::string &s, const std::string &t=":")
std::string label(const std::string &format, int i)
::StatusCode StatusCode
StatusCode definition for legacy code.
FormulaSvc * formulas(EL::IWorker *worker)
returns: the formula service for this worker guarantee: strong failures: formula service not configur...
void useFormulas(EL::Job &job)
effects: register the formula service for this job guarantee: strong failures: out of memory I