44xRooNLLVar::xRooHypoSpace::xRooHypoSpace(
const char *
name,
const char *title)
76 ssize /= (
v->getMax() -
v->getMin());
84 for (
auto &
p : *
this) {
85 for (
auto a : *
p.coords) {
86 if (!
fPars->find(
a->GetName()))
103 std::shared_ptr<xRooNode> out =
nullptr;
105 for (
auto &[_range, _pdf] : fPdfs) {
109 for (
auto &
_lhs : *_range) {
115 if (!(
v->getMin() <=
v2->getMax() &&
v2->getMin() <=
v->getMax())) {
120 if (!(
v->getMin() <=
c2->getVal() &&
c2->getVal() <=
v->getMax())) {
127 if (!(
c->getVal() <=
v2->getMax() &&
v2->getMin() <=
c->getVal())) {
132 if (!(
c->getVal() ==
c2->getVal())) {
141 throw std::runtime_error(
"Multiple pdf possibilities");
159 auto _idx = s.
Index(
'=');
165 if (
_val.IsFloat()) {
167 }
else if (
_val.BeginsWith(
'[')) {
168 _idx =
_val.Index(
',');
187 throw std::runtime_error(
"Unknown parameter");
188 _par->setAttribute(
"axis");
191 Warning(
"AddPoints",
"low edge of hypoSpace %g below lower bound of parameter: %g. Changing to lower bound", low,
193 low = _par->getMin();
195 if (high > _par->getMax()) {
196 Warning(
"AddPoints",
"high edge of hypoSpace %g above upper bound of parameter: %g. Changing to upper bound",
197 high, _par->getMax());
198 high = _par->getMax();
202 _par->setVal((high + low) * 0.5);
207 double step = (high - low) / (
nPoints - 1);
209 throw std::runtime_error(
"Invalid steps");
211 for (
size_t i = 0; i <
nPoints; i++) {
212 _par->setVal((i ==
nPoints - 1) ? high : (low + step * i));
220 if (axes().empty()) {
223 throw std::runtime_error(
"No POI to scan");
225 poi().first()->setAttribute(
"axis");
231 poi().setAttribAll(
"poi",
false);
232 axes().setAttribAll(
"poi");
244 if (
sType.Contains(
"cls") && !
sType.Contains(
"pcls"))
245 sType.ReplaceAll(
"cls",
"pcls");
246 if (!
sType.Contains(
"pcls") && !
sType.Contains(
"ts") && !
sType.Contains(
"pnull") && !
sType.Contains(
"plr")) {
247 throw std::runtime_error(
"scan type must be equal to one of: plr, cls, ts, pnull");
251 if (axes().empty()) {
254 throw std::runtime_error(
"No POI to scan");
256 poi().first()->setAttribute(
"axis");
261 poi().setAttribAll(
"poi",
false);
262 axes().setAttribAll(
"poi");
264 auto p =
dynamic_cast<RooRealVar *
>(axes().first());
266 throw std::runtime_error(
TString::Format(
"%s not scannable", axes().first()->GetName()));
269 if (
sType.Contains(
"cls")) {
270 if (empty() &&
relUncert == std::numeric_limits<double>::infinity()) {
272 ::Info(
"xRooHypoSpace::scan",
"Using default precision of 10%% for auto-scan");
275 for (
auto a : axes()) {
276 if (!
a->hasRange(
"physical")) {
277 ::Info(
"xRooHypoSpace::scan",
"No physical range set for %s, setting to [0,inf]",
p->GetName());
278 dynamic_cast<RooRealVar *
>(
a)->setRange(
"physical", 0, std::numeric_limits<double>::infinity());
280 if (!
a->getStringAttribute(
"altVal") || !
strlen(
p->getStringAttribute(
"altVal"))) {
281 ::Info(
"xRooHypoSpace::scan",
"No altVal set for %s, setting to 0",
a->GetName());
282 a->setStringAttribute(
"altVal",
"0");
288 ::Info(
"xRooHypoSpace::scan",
"range of POI does not straddle alt value, adjusting minimum to %g",
293 ::Info(
"xRooHypoSpace::scan",
"range of POI does not straddle alt value, adjusting maximum to %g",
297 for (
auto &[
pdf, nll] : fNlls) {
298 if (
auto _v =
dynamic_cast<RooRealVar *
>(nll->pars()->find(*
a))) {
299 _v->setRange(
v->getMin(),
v->getMax());
303 }
else if (
sType.Contains(
"plr")) {
306 sType.ReplaceAll(
"plr",
"ts");
312 for (
auto a : axes()) {
313 if (!
a->getStringAttribute(
"altVal") || !
strlen(
p->getStringAttribute(
"altVal"))) {
314 ::Info(
"xRooHypoSpace::scan",
"No altVal set for %s, setting to 1",
a->GetName());
315 a->setStringAttribute(
"altVal",
"1");
320 if ( (high == low &&
nPoints != 1)) {
323 low =
p->getMin(
"scan");
324 high =
p->getMax(
"scan");
326 if (!std::isnan(low) && !std::isnan(high) && !(std::isinf(low) && std::isinf(high))) {
327 p->setRange(
"scan", std::min(low, high), std::max(low, high));
341 relUncert = std::numeric_limits<double>::infinity();
350#if ROOT_VERSION_CODE >= ROOT_VERSION(6, 26, 00)
370 if (
auto myDb =
dynamic_cast<TMemFile *
>(fFitDb.get())) {
372 myDb->SetWritable(
true);
388 fFitDb = std::shared_ptr<TDirectory>(
400 if (!
gROOT->IsBatch() && !
sType.Contains(
"visualize"))
401 sType +=
" visualize";
405 if (
sType.Contains(
"cls")) {
406 if (
p->hasRange(
"scan")) {
407 ::Info(
"xRooHypoSpace::scan",
"Using %s scan range: %g - %g",
p->GetName(),
p->getMin(
"scan"),
420 if (std::isnan(res.first) || std::isnan(res.second)) {
422 }
else if (std::isinf(res.second)) {
426 }
else if (
sType.Contains(
"ts")) {
429 AddPoint(
TString::Format(
"%s=%g", poi().first()->GetName(), poi().getRealValue(poi().first()->GetName())));
431 if (back().status() != 0) {
435 low = std::max(low, back().mu_hat().getVal() - back().mu_hat().getError() * 3);
436 high = std::min(high, back().mu_hat().getVal() + back().mu_hat().getError() * 3);
438 double step = (high - low) / (
nPoints - 1);
439 for (
size_t i = 0; i <
nPoints; i++) {
440 AddPoint(
TString::Format(
"%s=%g", poi().first()->GetName(), low + step * i));
442 if (back().status() != 0)
447 throw std::runtime_error(
TString::Format(
"Automatic scanning not yet supported for %s",
type));
452 AddPoint(
TString::Format(
"%s=%g", poi().first()->GetName(), (high + low) / 2.));
454 if (back().status() != 0)
457 double step = (high - low) / (
nPoints - 1);
458 for (
size_t i = 0; i <
nPoints; i++) {
459 AddPoint(
TString::Format(
"%s=%g", poi().first()->GetName(), low + step * i));
461 if (back().status() != 0)
470 if (
auto myDb =
dynamic_cast<TMemFile *
>(fFitDb.get())) {
472 myDb->SetWritable(
false);
477std::map<std::string, xRooNLLVar::xValueWithError>
484 relUncert = std::numeric_limits<double>::infinity();
489 std::map<std::string, xRooNLLVar::xValueWithError> out;
511 auto _idx = s.
Index(
'=');
516 auto _v =
dynamic_cast<RooRealVar *
>(fPars->find(_name));
520 if (
_val.IsFloat()) {
529 throw std::runtime_error(
"no model at coordinates");
536 if (fNlls.find(_pdf) == fNlls.end()) {
537 fNlls[_pdf] = std::make_shared<xRooNLLVar>(_pdf->nll(
"" , {}));
543 out.
fData = fNlls[_pdf]->getData();
545 dynamic_cast<RooDataSet *
>(out.
fData.first.get())->weightVar()->getAttribute(
"expected");
548 out.
coords.reset(fPars->snapshot());
557 ->remove(*std::unique_ptr<RooAbsCollection>(out.
coords->selectByAttrib(
"Constant",
false)),
true,
true);
562 auto _type = fTestStatType;
577 for (
auto &
p : *
this) {
582 if (!
p.alt_poi().equals(out.
alt_poi()))
585 for (
auto c :
p.alt_poi()) {
599 if (!
p.coords->equals(*out.
coords))
601 for (
auto c : *
p.coords) {
602 if (
c->getAttribute(
"poi")) {
606 v && std::abs(
v->getVal() - out.
coords->getRealValue(
v->GetName())) > 1
e-12) {
620 if (
auto cfit =
p.cfit_alt(
true)) {
623 if (
p.asimov(
true) &&
p.asimov(
true)->fData.first && (!out.
asimov(
true) || !out.
asimov(
true)->fData.first)) {
624 out.
asimov()->fData =
p.asimov(
true)->fData;
626 if (!
p.poi().equals(out.
poi()))
628 for (
auto c :
p.poi()) {
642 for (
auto a : axes()) {
657 return emplace_back(out);
664 throw std::runtime_error(
"Not a pdf");
676 throw std::runtime_error(std::string(
"Clashing model: ") +
existing->GetName());
682 pars.remove(*fPars,
true,
true);
684 fPars->addClone(
pars);
686 fPdfs.insert(std::make_pair(
myPars, std::make_shared<xRooNode>(_pdf)));
697 out.
add(*std::unique_ptr<RooAbsCollection>(
698 fPars->selectByAttrib(
"axis",
true)));
704 std::set<std::vector<double>> coords;
705 for (
auto &
p : *
this) {
708 auto _v =
dynamic_cast<RooRealVar *
>(
p.coords->find(o->GetName()));
710 (
_v &&
_v->isConstant())
712 : std::numeric_limits<double>::infinity());
715 if (coords.find(
p_coords) != coords.end()) {
724 std::map<std::string, std::unordered_set<double>> values;
725 for (
auto &par : *
pars()) {
728 for (
auto p : *
this) {
729 auto _v =
dynamic_cast<RooRealVar *
>(
p.coords->find(par->GetName()));
730 values[par->GetName()].insert(
731 (
_v &&
_v->isConstant())
733 : std::numeric_limits<double>::infinity());
742 for (
auto &[k,
v] : values) {
745 isPOI =
pars()->find(k.c_str())->getAttribute(
"poi");
758 std::unique_ptr<RooAbsCollection> poi(out.
selectByAttrib(
"poi",
true));
769 out.
add(*std::unique_ptr<RooAbsCollection>(
pars()->selectByAttrib(
"poi",
true)));
780 for (
size_t i = 0; i <
size(); i++) {
781 std::cout << i <<
") ";
785 std::cout <<
a->GetName() <<
"="
786 << at(i).coords->getRealValue(
a->GetName(), std::numeric_limits<double>::quiet_NaN());
788 std::cout <<
" status=[ufit:";
793 std::cout << ufit->
status();
796 std::cout <<
",cfit_null:";
797 auto cfit =
const_cast<xRooHypoPoint &
>(at(i)).cfit_null(
true);
801 std::cout << cfit->
status();
804 std::cout <<
",cfit_alt:";
809 std::cout <<
afit->status();
813 std::cout <<
",asimov.ufit:";
821 std::cout <<
",asimov.cfit_null:";
829 auto cfit_lbound =
const_cast<xRooHypoPoint &
>(at(i)).cfit_lbound(
true);
832 std::cout <<
",cfit_lbound:" << cfit_lbound->
status();
837 auto sigma_mu =
const_cast<xRooHypoPoint &
>(at(i)).sigma_mu(
true);
838 if (!std::isnan(sigma_mu.first)) {
839 std::cout <<
" sigma_mu=" << sigma_mu.first;
841 std::cout <<
" +/- " << sigma_mu.second;
843 std::cout << std::endl;
845 std::cout <<
"--------------------------" << std::endl;
846 std::cout <<
"Number of bad fits: " <<
badFits << std::endl;
850 const char *opt )
const
861 (
sOpt.Contains(
"exp"))
865 : std::numeric_limits<double>::quiet_NaN();
870 if (
_axes.size() != 1)
873 auto out = std::make_shared<TGraphErrors>();
874 out->SetName(GetName());
875 out->SetEditable(
false);
876 const char *
sCL = (
doCLs) ?
"CLs" :
"null";
890 out->SetMarkerStyle(20);
891 out->SetMarkerSize(0.5);
892 if (
sOpt.Contains(
"ts")) {
894 (empty() ?
"" : front().tsTitle(
true).Data())));
898 out->SetMarkerStyle(0);
899 out->SetMarkerSize(0);
900 out->SetLineStyle(2 +
int(
nSigma));
904 out->SetLineStyle(0);
905 out->SetLineWidth(0);
906 auto x = out->Clone(
"up");
910 out->GetListOfFunctions()->Add(
x,
"F");
911 x = out->Clone(
"down");
915 out->GetListOfFunctions()->Add(
x,
"F");
917 if (
sOpt.Contains(
"ts")) {
924 auto badPoints2 =
dynamic_cast<TGraph *
>(out->GetListOfFunctions()->FindObject(
"badPoints"));
932 out->GetListOfFunctions()->Add(
badPoints2,
"P");
941 for (
auto &
p : *
this) {
945 auto gra = graph(
sOpt +
" readOnly");
948 gROOT->GetSelectedPad()->cd();
952#if ROOT_VERSION_CODE >= ROOT_VERSION(6, 30, 00)
953 if (
auto pad =
gROOT->GetSelectedPad()) {
954 pad->GetCanvas()->ResetUpdated();
960 ::Info(
"xRooHypoSpace::graph",
"Completed %d/%d points for %s",
int(
nDone),
int(
size()),
sOpt.Data());
966 double _x =
p.coords->getRealValue(
_axes.at(0)->GetName(), std::numeric_limits<double>::quiet_NaN());
970 if (std::isnan(
pval.first)) {
971 if (
p.status() != 0) {
975 out->InsertPointBefore(idx, _x,
pval.first);
976 out->SetPointError(idx, 0,
pval.second);
981 sOpt2.ReplaceAll(
"exp",
"exp-");
983 if (std::isnan(
pval.first)) {
984 if (
p.status() != 0) {
988 out->InsertPointBefore(idx + 1, _x,
pval.first);
989 out->SetPointError(idx + 1, 0,
pval.second);
991 if (out->GetPointY(idx) <
pval.first)
998 if (out->GetN() == 0)
1003 if (out->GetListOfFunctions()->FindObject(
"badPoints")) {
1005 for (
int i = 0; i <
badPoints()->GetN(); i++) {
1014 auto up =
dynamic_cast<TGraph *
>(out->GetListOfFunctions()->FindObject(
"up"));
1015 auto down =
dynamic_cast<TGraph *
>(out->GetListOfFunctions()->FindObject(
"down"));
1017 for (
int i = 0; i < out->GetN(); i++) {
1019 up->SetPoint(
up->GetN(), out->GetPointX(i), out->GetPointY(i) + out->GetErrorY(i) * (
above ? 1. : -1.));
1023 down->SetPoint(
down->GetN(), out->GetPointX(i), out->GetPointY(i) + out->GetErrorY(i) * (
above ? 1. : -1.));
1027 for (
int i = out->GetN()-1; i >= 0; i--) {
1029 up->SetPoint(
up->GetN(), out->GetPointX(i), out->GetPointY(i) - out->GetErrorY(i) * (
above ? 1. : -1.));
1033 down->SetPoint(
down->GetN(), out->GetPointX(i), out->GetPointY(i) - out->GetErrorY(i) * (
above ? 1. : -1.));
1041 gROOT->GetSelectedPad()->cd();
1045#if ROOT_VERSION_CODE >= ROOT_VERSION(6, 30, 00)
1046 if (
auto pad =
gROOT->GetSelectedPad()) {
1047 pad->GetCanvas()->ResetUpdated();
1060 std::shared_ptr<TMultiGraph> out;
1061 if (
sOpt.Contains(
"pcls") ||
sOpt.Contains(
"pnull") ||
sOpt.Contains(
"ts")) {
1064 sOpt.ReplaceAll(
"visualize",
"");
1066 auto exp2 = graph(
sOpt +
" exp2");
1068 auto exp = graph(
sOpt +
" exp");
1071 auto obs = (
doObs) ? graph(
sOpt) :
nullptr;
1073 out = std::make_shared<TMultiGraph>(GetName(), GetTitle());
1074 if (exp2 && exp2->GetN() > 1)
1075 out->Add(
static_cast<TGraph *
>(exp2->Clone()),
"FP");
1077 out->Add(
static_cast<TGraph *
>(
exp1->Clone()),
"FP");
1078 if (exp && exp->GetN() > 1)
1079 out->Add(
static_cast<TGraph *
>(exp->Clone()),
"LP");
1080 if (obs && obs->GetN() > 1)
1081 out->Add(
static_cast<TGraph *
>(obs->Clone()),
"LP");
1083 if (!out->GetListOfGraphs()) {
1088 if (
sOpt.Contains(
"pcls")) {
1090 line->SetName(
"alpha");
1092 line->SetEditable(
false);
1093 line->SetPoint(
line->GetN(), out->GetHistogram()->GetXaxis()->GetXmin() - 10, 0.05);
1100 for (
int i = 0; i < exp->GetN(); i++) {
1104 line->SetPoint(
line->GetN(), out->GetHistogram()->GetXaxis()->GetXmax() + 10, 0.05);
1106 out->GetListOfFunctions()->Add(
line,
"L");
1109 out->GetHistogram()->GetXaxis()->SetTitle(exp->GetHistogram()->GetXaxis()->GetTitle());
1110 out->GetHistogram()->GetYaxis()->SetTitle(exp->GetHistogram()->GetYaxis()->GetTitle());
1113 if (out->GetListOfGraphs()->GetEntries() > 1) {
1116 leg->SetName(
"legend");
1119 out->GetListOfFunctions()->Add(
leg);
1122 for (
auto g : *out->GetListOfGraphs()) {
1124 leg->AddEntry(
g,
"",
"F");
1126 leg->AddEntry(
g,
"",
"LPE");
1131 auto addToLegend = [](
TLegend *
l,
const char *label,
const std::pair<double, double> val) {
1134 TString::Format(
"%s%s: %g #pm %g%s", std::isfinite(val.second) ?
"" :
"#color[2]{", label,
1135 val.first, val.second, std::isfinite(val.second) ?
"" :
"}"),
1140 if (
sOpt.Contains(
"pcls")) {
1142 if (exp2 && exp2->GetN() > 1) {
1150 if (exp && exp->GetN() > 1) {
1158 if (exp2 && exp2->GetN() > 1) {
1162 if (obs && obs->GetN() > 1) {
1172 gROOT->GetSelectedPad()->cd();
1177 if (
sOpt.Contains(
"pcls") ||
sOpt.Contains(
"pnull")) {
1178 gra2->SetMinimum(1
e-6);
1179 gra2->SetMaximum(1);
1183 gPad->GetCanvas()->Paint();
1184 gPad->GetCanvas()->Update();
1185#if ROOT_VERSION_CODE >= ROOT_VERSION(6, 30, 00)
1186 gPad->GetCanvas()->ResetUpdated();
1199 if (std::isnan(
target)) {
1203 auto gr = std::make_shared<TGraph>(
pValues);
1224 return std::pair<double, double>(std::numeric_limits<double>::quiet_NaN(), 0);
1227 double alpha = log(
target);
1241 return std::pair(
lim, err);
1256 return std::pair(std::numeric_limits<double>::infinity(), std::numeric_limits<double>::infinity());
1257 return std::pair((alpha -
y1) /
m +
x1, std::numeric_limits<double>::infinity());
1264 return std::pair(-std::numeric_limits<double>::infinity(), -std::numeric_limits<double>::infinity());
1265 return std::pair((alpha -
y1) /
m +
x1, -std::numeric_limits<double>::infinity());
1272 if (std::isnan(
nSigma)) {
1277 return GetLimit(*graph(
sOpt +
" readonly"));
1285 sOpt.ReplaceAll(
"visualize",
"");
1286 std::shared_ptr<TGraphErrors>
gr = graph(
sOpt +
" readonly");
1288 auto gra = graphs(
sOpt.Contains(
"toys") ?
"pcls readonly toys" :
"pcls readonly");
1295 gra2->SetMinimum(1
e-9);
1296 gra2->SetMaximum(1);
1298 gPad->GetCanvas()->Paint();
1299 gPad->GetCanvas()->Update();
1300#if ROOT_VERSION_CODE >= ROOT_VERSION(6, 30, 00)
1301 gPad->GetCanvas()->ResetUpdated();
1308 for (
auto p : axes()) {
1309 for (
auto &[
pdf, nll] : fNlls) {
1310 if (
auto _v =
dynamic_cast<RooRealVar *
>(nll->pars()->find(*
p))) {
1317 auto v = (axes().empty()) ?
nullptr :
dynamic_cast<RooRealVar *
>(*axes().rbegin());
1319 return std::pair(std::numeric_limits<double>::quiet_NaN(), 0.);
1320 double muMax = std::min(std::min(
v->getMax(
"physical"),
v->getMax()),
v->getMax(
"scan"));
1321 double muMin = std::max(std::max(
v->getMin(
"physical"),
v->getMin()),
v->getMin(
"scan"));
1325 ::Error(
"findlimit",
"Problem evaluating First Point %s @ %s=%g",
sOpt.Data(),
v->GetName(),
muMin);
1326 return std::pair(std::numeric_limits<double>::quiet_NaN(), 0.);
1339 if (
sOpt.Contains(
"obs")) {
1341 sOpt2.ReplaceAll(
"obs",
"exp");
1342 auto expLim = findlimit(
sOpt2, std::numeric_limits<double>::infinity(), 0);
1348 (
sOpt.Contains(
"exp")) ? back().asimov() : std::shared_ptr<xRooHypoPoint>(&back(), [](
xRooHypoPoint *) {});
1350 if (point && point->ufit()) {
1361 ::Error(
"xRooHypoSpace::findlimit",
"Problem evaluating Second Point %s @ %s=%g",
sOpt.Data(),
v->GetName(),
1363 return std::pair(std::numeric_limits<double>::quiet_NaN(), 0.);
1369 auto lim = GetLimit(*
gr);
1371 if (std::isnan(
lim.first)) {
1375 auto v =
dynamic_cast<RooRealVar *
>(*axes().rbegin());
1376 double maxMu = std::min(std::min(
v->getMax(
"physical"),
v->getMax()),
v->getMax(
"scan"));
1377 double minMu = std::max(std::max(
v->getMin(
"physical"),
v->getMin()),
v->getMin(
"scan"));
1380 if (
lim.first > -std::numeric_limits<double>::infinity() &&
lim.first < std::numeric_limits<double>::infinity() &&
1386 if (
lim.second == std::numeric_limits<double>::infinity()) {
1396 (
sOpt.Contains(
"exp")) ? back().asimov() : std::shared_ptr<xRooHypoPoint>(&back(), [](
xRooHypoPoint *) {});
1398 if (point && point->ufit()) {
1410 }
else if (
lim.second == -std::numeric_limits<double>::infinity()) {
1425 ::Warning(
"xRooHypoSpace::findlimit",
"Reached max number of point evaluations");
1429 ::Info(
"xRooHypoSpace::findlimit",
"%s -- Testing new point @ %s=%g (delta=%g)",
sOpt.Data(),
v->GetName(),
1432 ::Error(
"xRooHypoSpace::findlimit",
"Problem evaluating %s @ %s=%g",
sOpt.Data(),
v->GetName(),
nextPoint);
1445 if ((
sOpt ==
"" ||
sOpt ==
"same") && !empty()) {
1448 for (
auto &
hp : *
this) {
1449 if (!
hp.nullToys.empty() || !
hp.altToys.empty()) {
1460 auto _axes = axes();
1464 if (
sOpt ==
"status") {
1466 if (
_axes.size() <= 2) {
1494 (
_axes.size() == 1) ?
"" :
_axes.at(1)->GetTitle()));
1495 for (
auto &
p : *
this) {
1496 bool _readOnly =
p.nllVar ?
p.nllVar->get()->getAttribute(
"readOnly") :
false;
1498 p.nllVar->get()->setAttribute(
"readOnly",
true);
1499 double x =
p.coords->getRealValue(
_axes.at(0)->GetName());
1500 double y =
_axes.size() == 1 ?
p.ts_asymp().first :
p.coords->getRealValue(
_axes.at(1)->GetName());
1502 if (!std::isnan(
p.ts_asymp().first)) {
1503 if (
_axes.size() == 1)
1506 }
else if (
p.fUfit && (std::isnan(
p.fUfit->minNll()) ||
1510 }
else if (
p.fNull_cfit && (std::isnan(
p.fNull_cfit->minNll()) ||
1515 if (!std::isnan(
p.ts_asymp(0).first)) {
1517 }
else if (
p.asimov() &&
p.asimov()->fUfit &&
1518 (std::isnan(
p.asimov()->fUfit->minNll()) ||
1522 }
else if (
p.asimov() &&
p.asimov()->fNull_cfit &&
1523 (std::isnan(
p.asimov()->fNull_cfit->minNll()) ||
1528 p.nllVar->get()->setAttribute(
"readOnly",
_readOnly);
1531 if (
_axes.size() == 1) {
1533 for (
int i = 0; i < out->
GetN(); i++) {
1538 for (
int i = 0; i <
g->GetN(); i++) {
1539 if (std::isnan(
g->GetPointY(i)))
1540 g->SetPointY(i, std::isnan(
tmp.Eval(
g->GetPointX(i))) ? 0. :
tmp.Eval(
g->GetPointX(i)));
1552 auto leg =
new TLegend(1. -
gPad->GetRightMargin() - 0.3, 1. -
gPad->GetTopMargin() - 0.35,
1553 1. -
gPad->GetRightMargin() - 0.05, 1. -
gPad->GetTopMargin() - 0.05);
1554 leg->SetName(
"legend");
1555 leg->AddEntry(out,
"Uncomputed",
"P");
1565 leg->AddEntry(
expAvail,
"Expected computed",
"P");
1585 if (
_axes.size() == 1)
1586 gPad->SetLogy(
false);
1594 if (
sOpt.Contains(
"pcls") ||
sOpt.Contains(
"pnull") ||
sOpt.Contains(
"ts")) {
1595 auto gra = graphs(
sOpt +
" readonly");
1597 gROOT->GetSelectedPad()->cd();
1598 if (!
sOpt.Contains(
"same") &&
gPad) {
1606 if (
sOpt.Contains(
"pcls") ||
sOpt.Contains(
"pnull")) {
1607 gra2->SetMinimum(1
e-6);
1608 gra2->SetMaximum(1);
1612 gPad->GetCanvas()->Paint();
1613 gPad->GetCanvas()->Update();
1614#if ROOT_VERSION_CODE >= ROOT_VERSION(6, 30, 00)
1615 gPad->GetCanvas()->ResetUpdated();
1620 if (!
sOpt.Contains(
"same") &&
gPad) {
1641 if (!empty() && axes().
size() == 1) {
1642 for (
auto &
p : *
this) {
1648 title += front().tsTitle(
true);
1652 *
dynamic_cast<TAttFill *
>(out) = *
this;
1653 *
dynamic_cast<TAttLine *
>(out) = *
this;
1660 if (!
sOpt.Contains(
"same"))
1664 if (
sOpt.Contains(
"fits")) {
1666 sOpt.ReplaceAll(
"fits",
"");
1676 gPad->SetBottomMargin(
gPad->GetBottomMargin() * 2.);
1686 std::pair<double, double>
minMax(std::numeric_limits<double>::infinity(), -std::numeric_limits<double>::infinity());
1687 for (
auto &
p : *
this) {
1690 auto val =
p.pll(
true).first;
1691 if (std::isnan(val))
1696 if (
minMax.first < std::numeric_limits<double>::infinity())
1698 if (
minMax.second > -std::numeric_limits<double>::infinity())
1705 std::shared_ptr<const RooFitResult>
ufr;
1706 for (
auto &
p : *
this) {
1709 auto val =
p.pll().first;
1712 if (out->
GetN() == 0 &&
ufr &&
ufr->status() == 0) {
1714 ufr->floatParsFinal().getRealValue(axes().first()->GetName(),
1715 ufr->constPars().getRealValue(axes().first()->GetName())),
1719 if (
auto fr =
p.fNull_cfit;
1724 new TPad(fr->GetName(),
TString::Format(
"%s = %g", poi().first()->GetTitle(),
p.fNullVal()), 0, 0, 1., 1);
1725 pad->SetNumber(out->
GetN() + 1);
1732 if (std::isnan(val) &&
p.status() != 0) {
1744 }
else if (!std::isnan(val)) {
1745 out->
SetPoint(out->
GetN(),
p.coords->getRealValue(axes().first()->GetName()),
p.pll().first);
1751 for (
int i = 0; i <
badPoints->GetN(); i++)
1758 basePad->GetCanvas()->Paint();
1759 basePad->GetCanvas()->Update();
1766 basePad->GetCanvas()->Paint();
1767 basePad->GetCanvas()->Update();
1768#if ROOT_VERSION_CODE >= ROOT_VERSION(6, 30, 00)
1769 basePad->GetCanvas()->ResetUpdated();
1776 auto pad =
new TPad(
ufr->GetName(),
"unconditional fit", 0, 0, 1., 1.);
1784 pad =
new TPad(
"selected",
"selected", 0, 0, 1, 1);
1787 basePad->GetPad(2)->GetPad(-1)->AppendPad();
1799 gPad->GetCanvas()->
Connect(
"Highlighted(TVirtualPad*,TObject*,Int_t,Int_t)",
"xRooNode::InteractiveObject",
1811 auto _axes = axes();
1818 for (
auto &
p : *
this) {
1819 double _x =
p.coords->getRealValue(
_axes.at(0)->GetName(), std::numeric_limits<double>::quiet_NaN());
1820 out->
Add(_x,
p.result());
size_t size(const MatrixT &matrix)
retrieve the size of a square matrix
const char Option_t
Option string (const char)
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
void Info(const char *location, const char *msgfmt,...)
Use this function for informational messages.
void Error(const char *location, const char *msgfmt,...)
Use this function in case an error occurred.
void Warning(const char *location, const char *msgfmt,...)
Use this function in warning situations.
winID h TVirtualViewer3D TVirtualGLPainter p
Option_t Option_t SetFillStyle
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h offset
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t target
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t result
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void value
Option_t Option_t TPoint TPoint const char x1
Option_t Option_t SetFillColor
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t type
Option_t Option_t TPoint TPoint const char y1
R__EXTERN TStyle * gStyle
R__EXTERN TSystem * gSystem
static std::pair< double, double > matchPrecision(const std::pair< double, double > &in)
std::pair< std::shared_ptr< RooAbsData >, std::shared_ptr< const RooAbsCollection > > fData
std::shared_ptr< const RooAbsCollection > coords
std::shared_ptr< xRooNLLVar > nllVar
xRooFit::Asymptotics::PLLType fPllType
std::shared_ptr< xRooHypoPoint > asimov(bool readOnly=false)
RooArgList alt_poi() const
std::shared_ptr< const RooFitResult > fAlt_cfit
static std::set< int > allowedStatusCodes
xValueWithError limit(const char *type="cls", double nSigma=std::numeric_limits< double >::quiet_NaN()) const
xRooHypoPoint & point(size_t i)
RooStats::HypoTestInverterResult * result()
static xValueWithError GetLimit(const TGraph &pValues, double target=std::numeric_limits< double >::quiet_NaN())
std::map< std::string, xValueWithError > limits(const char *opt="cls", const std::vector< double > &nSigmas={0, 1, 2, -1, -2, std::numeric_limits< double >::quiet_NaN()}, double relUncert=std::numeric_limits< double >::infinity())
bool AddModel(const xRooNode &pdf, const char *validity="")
std::shared_ptr< TMultiGraph > graphs(const char *opt)
static RooArgList toArgs(const char *str)
xValueWithError findlimit(const char *opt, double relUncert=std::numeric_limits< double >::infinity(), unsigned int maxTries=20)
int AddPoints(const char *parName, size_t nPoints, double low, double high)
std::shared_ptr< TGraphErrors > graph(const char *opt) const
std::shared_ptr< RooArgSet > fPars
void Print(Option_t *opt="") const override
Print TNamed name and title.
xRooHypoSpace(const char *name="", const char *title="")
xRooHypoPoint & AddPoint(double value)
int scan(const char *type, size_t nPoints, double low=std::numeric_limits< double >::quiet_NaN(), double high=std::numeric_limits< double >::quiet_NaN(), const std::vector< double > &nSigmas={0, 1, 2, -1, -2, std::numeric_limits< double >::quiet_NaN()}, double relUncert=0.1)
std::shared_ptr< xRooNode > pdf(const RooAbsCollection &parValues) const
void Draw(Option_t *opt="") override
Default Draw method for all objects.
std::shared_ptr< RooAbsPdf > pdf() const
std::shared_ptr< RooArgSet > pars(bool stripGlobalObs=true) const
The xRooNode class is designed to wrap over a TObject and provide functionality to aid with interacti...
void Draw(Option_t *opt="") override
Default Draw method for all objects.
RooArgList argList() const
static InteractiveObject * gIntObj
xRooNode pars() const
List of parameters (non-observables) of this node.
const_iterator end() const
A space to attach TBranches.
virtual value_type getCurrentIndex() const
Return index number of current state.
Abstract container object that can hold multiple RooAbsArg objects.
RooAbsCollection * selectByAttrib(const char *name, bool value) const
Create a subset of the current collection, consisting only of those elements with the specified attri...
double getRealValue(const char *name, double defVal=0.0, bool verbose=false) const
Get value of a RooAbsReal stored in set with given name.
Int_t getCatIndex(const char *name, Int_t defVal=0, bool verbose=false) const
Get index value of a RooAbsCategory stored in set with given name.
virtual bool remove(const RooAbsArg &var, bool silent=false, bool matchByNameOnly=false)
Remove the specified argument from our list.
virtual bool add(const RooAbsArg &var, bool silent=false)
Add the specified argument to list.
void setAttribAll(const Text_t *name, bool value=true)
Set given attribute in each element of the collection by calling each elements setAttribute() functio...
virtual RooAbsArg * addClone(const RooAbsArg &var, bool silent=false)
Add a clone of the specified argument to list.
void setName(const char *name)
RooAbsArg * find(const char *name) const
Find object with given name in list.
Abstract interface for all probability density functions.
Abstract base class for objects that represent a real value that may appear on the left hand side of ...
Abstract base class for objects that represent a real value and implements functionality common to al...
RooArgList is a container object that can hold multiple RooAbsArg objects.
RooArgSet is a container object that can hold multiple RooAbsArg objects.
Represents a constant real-valued object.
Container class to hold unbinned data.
Variable that can be changed from the outside.
HypoTestInverterResult class holds the array of hypothesis test results and compute a confidence inte...
HypoTestResult * GetResult(int index) const
return a pointer to the i^th result object
int ArraySize() const
number of entries in the results array
double GetXValue(int index) const
function to return the value of the parameter of interest for the i^th entry in the results
bool Add(const HypoTestInverterResult &otherResult)
merge with the content of another HypoTestInverterResult object
RooArgSet * GetParameters() const override
return a cloned list with the parameter of interest
Fill Area Attributes class.
virtual void SetLineStyle(Style_t lstyle)
Set the line style.
virtual Size_t GetMarkerSize() const
Return the marker size.
virtual void SetMarkerStyle(Style_t mstyle=1)
Set the marker style.
virtual void SetMarkerSize(Size_t msize=1)
Set the marker size.
static TCanvas * MakeDefCanvas()
Static function to build a default canvas.
Describe directory structure in memory.
virtual Int_t GetValue(const char *name, Int_t dflt) const
Returns the integer value for a resource.
A TGraphErrors is a TGraph with error bars.
virtual void SetPointError(Double_t ex, Double_t ey)
Set ex and ey values for point pointed by the mouse.
A TGraph is an object made of two arrays X and Y with npoints each.
virtual Double_t GetPointX(Int_t i) const
Get x value for point i.
virtual void SetPoint(Int_t i, Double_t x, Double_t y)
Set x and y values for point number i.
virtual void SetMaximum(Double_t maximum=-1111)
Set the maximum of the graph.
static Bool_t CompareX(const TGraph *gr, Int_t left, Int_t right)
Return kTRUE if fX[left] > fX[right]. Can be used by Sort.
virtual void Sort(Bool_t(*greater)(const TGraph *, Int_t, Int_t)=&TGraph::CompareX, Bool_t ascending=kTRUE, Int_t low=0, Int_t high=-1111)
Sorts the points of this TGraph using in-place quicksort (see e.g.
TList * GetListOfFunctions() const
virtual Double_t Eval(Double_t x, TSpline *spline=nullptr, Option_t *option="") const
Interpolate points in this graph at x using a TSpline.
virtual Int_t RemovePoint()
Delete point close to the mouse position Returns index of removed point (or -1 if nothing was changed...
void SetName(const char *name="") override
Set graph name.
void Draw(Option_t *chopt="") override
Draw this graph with its current attributes.
virtual Double_t GetPointY(Int_t i) const
Get y value for point i.
void SetTitle(const char *title="") override
Change (i.e.
virtual void SetPointY(Int_t i, Double_t y)
Set y value for point i.
virtual void SetEditable(Bool_t editable=kTRUE)
if editable=kFALSE, the graph cannot be modified with the mouse by default a TGraph is editable
virtual void SetMinimum(Double_t minimum=-1111)
Set the minimum of the graph.
This class displays a legend box (TPaveText) containing several legend entries.
TObject * FindObject(const char *name) const override
Find an object in this list using its name.
void Add(TObject *obj) override
A TMemFile is like a normal TFile except that it reads and writes only from memory.
A TMultiGraph is a collection of TGraph (or derived) objects.
The TNamed class is the base class for all named ROOT classes.
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
const char * GetName() const override
Returns name of object.
const char * GetTitle() const override
Returns title of object.
virtual void SetName(const char *name)
Set the name of the TNamed.
virtual void SetNameTitle(const char *name, const char *title)
Set all the TNamed parameters (name and title).
Mother of all ROOT objects.
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
The most important graphics class in the ROOT system.
Bool_t Connect(const char *signal, const char *receiver_class, void *receiver, const char *slot)
Non-static method is used to connect from the signal of this object to the receiver slot.
Double_t RealTime()
Stop the stopwatch (if it is running) and return the realtime (in seconds) passed between the start a...
void Start(Bool_t reset=kTRUE)
Start the stopwatch.
void Continue()
Resume a stopped stopwatch.
Provides iteration through tokens of a given string.
Bool_t NextToken()
Get the next token, it is stored in this TString.
Double_t Atof() const
Return floating-point value contained in string.
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString.
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
Float_t GetPadRightMargin() const
Float_t GetPadTopMargin() const
virtual Bool_t ProcessEvents()
Process pending events (GUI, timers, sockets).
This class defines a UUID (Universally Unique IDentifier), also known as GUIDs (Globally Unique IDent...
TVirtualPad is an abstract base class for the Pad and Canvas classes.
double gaussian_quantile(double z, double sigma)
Inverse ( ) of the cumulative distribution function of the lower tail of the normal (Gaussian) distri...
void writeStdoutLine(const char *msg)
bool isPythonInitialized()
#define BEGIN_XROOFIT_NAMESPACE
#define END_XROOFIT_NAMESPACE