17 #ifdef MARLIN_USE_ROOT
19 #include "analysis/OrcaKinFit/ParameterScanner.h"
21 #include "analysis/OrcaKinFit/BaseFitter.h"
22 #include "analysis/OrcaKinFit/NewFitterGSL.h"
23 #include "analysis/OrcaKinFit/BaseFitObject.h"
24 #include "analysis/OrcaKinFit/BaseHardConstraint.h"
25 #include <framework/logging/Logger.h>
29 #include <TMultiGraph.h>
32 #include <gsl/gsl_vector.h>
46 namespace OrcaKinFit {
48 ParameterScanner::ParameterScanner(BaseFitter& fitter_)
52 void ParameterScanner::doScan(
int xglobal,
61 const char* titleprefix,
65 NewFitterGSL* newfitter =
dynamic_cast<NewFitterGSL*
>(&fitter);
67 FitObjectContainer* fitobjects = fitter.getFitObjects();
68 if (fitobjects == 0)
return;
69 ConstraintContainer* constraints = fitter.getConstraints();
70 if (constraints == 0)
return;
78 for (FitObjectIterator i = fitobjects->begin(); i != fitobjects->end(); ++i) {
79 BaseFitObject* fo = *i;
81 for (
int ilocal = 0; ilocal < fo->getNPar(); ++ilocal) {
82 int iglobal = fo->getGlobalParNum(ilocal);
83 if (iglobal >= idim) idim = iglobal + 1;
84 if (iglobal == xglobal) xname = fo->getParamName(ilocal);
85 if (iglobal == yglobal) yname = fo->getParamName(ilocal);
88 for (ConstraintIterator i = constraints->begin(); i != constraints->end(); ++i) {
89 BaseHardConstraint* c = *i;
91 int iglobal = c->getGlobalNum();
92 if (iglobal >= idim) idim = iglobal + 1;
95 if (xglobal >= idim)
return;
96 if (yglobal >= idim)
return;
98 double* parsave =
new double [idim];
99 double* par =
new double [idim];
102 for (FitObjectIterator i = fitobjects->begin(); i != fitobjects->end(); ++i) {
103 BaseFitObject* fo = *i;
105 for (
int ilocal = 0; ilocal < fo->getNPar(); ++ilocal) {
106 int iglobal = fo->getGlobalParNum(ilocal);
107 assert(iglobal >= 0 && iglobal < idim);
108 parsave[iglobal] = fo->getParam(ilocal);
114 TString idpostfix(
"");
115 idpostfix += xglobal;
117 idpostfix += yglobal;
119 TString titlepostfix(
" vs ");
120 titlepostfix += xname;
121 titlepostfix +=
" and ";
122 titlepostfix += yname;
124 titlepostfix += xname;
126 titlepostfix += yname;
130 TString id(idprefix);
134 TString title(titleprefix);
136 title += titlepostfix;
138 TH2F* hchi2 =
new TH2F(
id, title, nx, xstart, xstop, ny, ystart, ystop);
139 B2INFO(
"Booking Histo '" <<
id <<
"': '" << title <<
"'");
142 TH2F* hlog2alpha = 0;
153 title += titlepostfix;
155 halpha =
new TH2F(
id, title, nx, xstart, xstop, ny, ystart, ystop);
156 B2INFO(
"Booking Histo '" <<
id <<
"': '" << title <<
"'");
163 title +=
"log_{2} (#alpha) ";
164 title += titlepostfix;
166 hlog2alpha =
new TH2F(
id, title, nx, xstart, xstop, ny, ystart, ystop);
167 B2INFO(
"Booking Histo '" <<
id <<
"': '" << title <<
"'");
175 title += titlepostfix;
177 hmu =
new TH2F(
id, title, nx, xstart, xstop, ny, ystart, ystop);
178 B2INFO(
"Booking Histo '" <<
id <<
"': '" << title <<
"'");
185 title +=
"Merit function #phi_{1} ";
186 title += titlepostfix;
188 hphi1 =
new TH2F(
id, title, nx, xstart, xstop, ny, ystart, ystop);
189 B2INFO(
"Booking Histo '" <<
id <<
"': '" << title <<
"'");
194 TMultiGraph* mgstepsfull = 0;
195 TMultiGraph* mgsteps = 0;
205 title +=
"Full Steps ";
206 title += titlepostfix;
208 mgstepsfull =
new TMultiGraph(
id, title);
209 B2INFO(
"Booking Multigraph '" <<
id <<
"': '" << title <<
"'");
217 title += titlepostfix;
219 mgsteps =
new TMultiGraph(
id, title);
220 B2INFO(
"Booking Multigraph '" <<
id <<
"': '" << title <<
"'");
227 title +=
"Step Start Points ";
228 title += titlepostfix;
230 gstep0 =
new TGraph(nx * ny);
231 gstep0 ->SetName(
id);
232 gstep0 ->SetTitle(title);
233 gstep0->SetMarkerStyle(20);
234 gstep0->SetMarkerColor(kBlack);
235 gstep0->SetMarkerSize(0.5);
238 id +=
"stependfull_";
242 title +=
"Full Step End Points ";
243 title += titlepostfix;
245 gstep1 =
new TGraph(nx * ny);
246 gstep1 ->SetName(
id);
247 gstep1 ->SetTitle(title);
248 gstep1->SetMarkerStyle(20);
249 gstep1->SetMarkerColor(kRed);
250 gstep1->SetMarkerSize(0.5);
257 title +=
"Step End Points ";
258 title += titlepostfix;
260 gstep2 =
new TGraph(nx * ny);
261 gstep2 ->SetName(
id);
262 gstep2 ->SetTitle(title);
263 gstep2->SetMarkerStyle(21);
264 gstep2->SetMarkerColor(kGreen);
265 gstep2->SetMarkerSize(0.5);
270 unsigned int ncon = constraints->size();
271 if (ncon > NCONMAX) ncon = NCONMAX;
273 TH2F* hlambda[NCONMAX];
274 for (
unsigned int icon = 0; icon < ncon; ++icon) {
277 BaseConstraint* c = (*constraints)[icon];
286 title +=
"Constraint ";
289 title += c->getName();
290 title += titlepostfix;
292 hcon[icon] =
new TH2F(
id, title, nx, xstart, xstop, ny, ystart, ystop);
293 B2INFO(
"Booking Histo '" <<
id <<
"': '" << title <<
"'");
306 title += c->getName();
307 title += titlepostfix;
309 hlambda[icon] =
new TH2F(
id, title, nx, xstart, xstop, ny, ystart, ystop);
310 B2INFO(
"Booking Histo '" <<
id <<
"': '" << title <<
"'");
321 for (
int ix = 1; ix <= nx; ++ix) {
322 double x = (ix - 0.5) * (xstop - xstart) / nx + xstart;
323 for (
int iy = 1; iy <= ny; ++iy) {
324 double y = (iy - 0.5) * (ystop - ystart) / ny + ystart;
327 for (
int i = 0; i < idim; ++i) par[i] = parsave[i];
330 for (FitObjectIterator i = fitobjects->begin(); i != fitobjects->end(); ++i) {
331 BaseFitObject* fo = *i;
333 fo->updateParams(par, idim);
339 for (FitObjectIterator i = fitobjects->begin(); i != fitobjects->end(); ++i) {
340 BaseFitObject* fo = *i;
342 chi2 += fo->getChi2();
348 newfitter->fillx(newfitter->x);
349 newfitter->assembleConstDer(newfitter->M);
350 newfitter->determineLambdas(newfitter->x, newfitter->M, newfitter->x, newfitter->W, newfitter->v1);
354 hchi2->SetBinContent(ix, iy, chi2);
355 for (
unsigned int icon = 0; icon < ncon; ++icon) {
356 BaseHardConstraint* c = (*constraints)[icon];
357 TH2F* h = hcon[icon];
358 if (c && h) h->SetBinContent(ix, iy, c->getValue());
359 if (c) B2INFO(
"x=" << x <<
", y=" << y <<
": Constraint " << c->getName() <<
": " << c->getValue())
361 if (c && h && newfitter) {
362 int kglobal = c->getGlobalNum();
363 h->SetBinContent(ix, iy, gsl_vector_get(newfitter->x, kglobal));;
369 newfitter->setDebug((ix == 1) ? 4 : 0);
371 double xval[2], yval[2];
374 gstep0->SetPoint((ix - 1)*ny + (iy - 1), xval[0], yval[0]);
375 newfitter->fillx(newfitter->x);
376 newfitter->fillperr(newfitter->perr);
378 newfitter->assembleConstDer(newfitter->M);
379 newfitter->determineLambdas(newfitter->x, newfitter->M, newfitter->x, newfitter->W, newfitter->v1);
381 double phi1 = newfitter->meritFunction(mumerit, newfitter->x, newfitter->perr);
382 if (hphi1) hphi1->SetBinContent(ix, iy, phi1);
384 newfitter->calcNewtonDx(newfitter->dx, newfitter->dxscal, newfitter->x,
385 newfitter->perr, newfitter->M, newfitter->Mscal,
386 newfitter->y, newfitter->yscal, newfitter->W, newfitter->W2,
387 newfitter->permW, newfitter->v1);
388 newfitter->add(newfitter->xnew, newfitter->x, 1, newfitter->dx);
390 xval[1] = gsl_vector_get(newfitter->xnew, xglobal);
391 yval[1] = gsl_vector_get(newfitter->xnew, yglobal);
393 B2INFO(
"ParameterScanner::doScan: full step from (" << xval[0] <<
", " << yval[0]
394 <<
") -> (" << xval[1] <<
", " << yval[1] <<
")");
397 gstep1->SetPoint((ix - 1)*ny + (iy - 1), xval[1], yval[1]);
399 TGraph* g =
new TGraph(2, xval, yval);
400 g->SetLineColor(kRed);
402 if (xval[1] > xstart - 10 * (xstop - xstart) &&
403 xval[1] < xstop + 10 * (xstop - xstart) &&
404 yval[1] > ystart - 10 * (ystop - ystart) &&
405 yval[1] < ystop + 10 * (ystop - ystart)) {
407 mgstepsfull->Add(g,
"L");
408 B2INFO(
" -> added\n");
414 newfitter->calcLimitedDx(alpha, mu, newfitter->xnew, imode,
415 newfitter->x, newfitter->v2, newfitter->dx, newfitter->dxscal,
416 newfitter->perr, newfitter->M, newfitter->Mscal,
417 newfitter->W, newfitter->v1);
419 xval[1] = gsl_vector_get(newfitter->xnew, xglobal);
420 yval[1] = gsl_vector_get(newfitter->xnew, yglobal);
422 B2INFO(
" limited step from (" << xval[0] <<
", " << yval[0]
423 <<
") -> (" << xval[1] <<
", " << yval[1] <<
"), alpha=" << alpha);
425 gstep2->SetPoint((ix - 1)*ny + (iy - 1), xval[1], yval[1]);
427 g =
new TGraph(2, xval, yval);
428 g->SetLineColor(kGreen);
430 if (xval[1] > xstart - 10 * (xstop - xstart) &&
431 xval[1] < xstop + 10 * (xstop - xstart) &&
432 yval[1] > ystart - 10 * (ystop - ystart) &&
433 yval[1] < ystop + 10 * (ystop - ystart)) {
435 mgsteps->Add(g,
"L");
436 B2INFO(
" -> added\n");
438 if (halpha) halpha->SetBinContent(ix, iy, alpha);
439 if (hlog2alpha) hlog2alpha->SetBinContent(ix, iy, std::log(alpha) / std::log(2.));
440 if (hmu) hmu->SetBinContent(ix, iy, mu);
450 for (
unsigned int icon = 0; icon < ncon; ++icon) {
451 if (hcon[icon]) hcon[icon]->Write();
452 if (hlambda[icon]) hcon[icon]->Write();
455 for (FitObjectIterator i = fitobjects->begin(); i != fitobjects->end(); ++i) {
456 BaseFitObject* fo = *i;
458 fo->updateParams(parsave, idim);
461 if (mgstepsfull) mgstepsfull->Write();
462 if (mgsteps) mgsteps->Write();
463 if (gstep0) gstep0->Write();
464 if (gstep1) gstep1->Write();
465 if (gstep2) gstep2->Write();
466 if (halpha) halpha->Write();
467 if (hlog2alpha) hlog2alpha->Write();
468 if (hmu) hmu->Write();
469 if (hphi1) hphi1->Write();
Abstract base class for different kinds of events.