35 #include <sys/types.h> 107 using namespace std ;
152 Double_t inMaxVal,
const char *unit) :
196 return (
getVal()==value) ;
216 if (!assumeSameType) {
232 if(appendUnit && 0 != strlen(
getUnit())) {
299 <<
"): validation failed: " << value << endl ;
319 const RooArgSet* ,
const char* rangeName)
const 350 if (code==0)
return getVal(normSet) ;
364 coutF(
Eval) <<
"RooAbsReal::analyticalIntegral(" <<
GetName() <<
") code " << code <<
" not implemented" << endl ;
425 os << indent <<
"--- RooAbsReal ---" << endl;
427 if(!unit.IsNull()) unit.Prepend(
' ');
429 os << endl << indent <<
" Plot label is \"" <<
getPlotLabel() <<
"\"" << endl;
514 pc.
process(arg1,arg2,arg3,arg4,arg5,arg6,arg7,arg8) ;
545 if (!rangeName || strchr(rangeName,
',')==0) {
553 TObjArray* oa = TString(rangeName).Tokenize(
",");
559 components.
add(*compIntegral) ;
564 title.Prepend(
"Integral of ") ;
593 title.Prepend(
"Integral of ") ;
617 TString title(integrand->
GetTitle()) ;
618 title.Prepend(
"Integral of ") ;
627 if (integrand !=
this) {
635 if (integrand ==
this && iset.
getSize()>0) {
636 coutI(
Integration) <<
GetName() <<
" : multidimensional integration over observables with parameterized ranges in terms of other integrated observables detected, using recursive integration strategy to construct final integral" << endl ;
640 integrand = integral ;
648 coutE(
Integration) <<
GetName() <<
" : ERROR while defining recursive integral over observables with parameterized integration ranges, please check that integration rangs specify uniquely defined integral " << endl;
657 if (cacheParamsStr && strlen(cacheParamsStr)) {
665 if (cacheParams->
getSize()>0) {
667 <<
"-dim value cache for integral over " << iset2 <<
" as a function of " << *cacheParams <<
" in range " << (rangeName?rangeName:
"<none>") << endl ;
671 cachedIntegral->addOwnedComponents(*integral) ;
672 cachedIntegral->setCacheSource(
kTRUE) ;
674 cachedIntegral->setOperMode(
ADirty) ;
677 integral = cachedIntegral ;
723 obsWithParamRange.
add(*aarg) ;
724 obsWithFixedRange.
remove(*aarg) ;
725 obsServingAsRangeParams.
add(*loBoundObs,
kFALSE) ;
726 obsServingAsRangeParams.
add(*hiBoundObs,
kFALSE) ;
736 RooArgSet obsWithFixedRangeNP(obsWithFixedRange) ;
737 obsWithFixedRangeNP.
remove(obsServingAsRangeParams) ;
740 RooArgSet obsWithParamRangeNP(obsWithParamRange) ;
741 obsWithParamRangeNP.
remove(obsServingAsRangeParams) ;
745 innerObs.
add(obsWithFixedRangeNP) ;
746 innerObs.
add(obsWithParamRangeNP) ;
763 name.Append(
"_Int[") ;
778 name.Append(rangeName) ;
781 }
else if (!omitEmpty) {
782 name.Append(
"_Int[]") ;
785 if (nset && nset->
getSize()>0 ) {
790 name.Append(
"_Norm[") ;
872 assert(0 != dependentIterator);
877 <<
"\" of wrong type: " << arg->
ClassName() << endl;
878 delete dependentIterator;
885 <<
"\" is not a dependent and will be ignored." << endl;
890 leafNodes.
replace(*found,*arg);
892 leafNodes.
add(*arg) ;
902 leafNodes.
add(*lvs) ;
911 if(0 != projectedVars && projectedVars->
find(arg->
GetName())) {
913 <<
"\" cannot be both a dependent and a projected variable." << endl;
914 delete dependentIterator;
920 if(0 != projectedVars) leafNodes.
remove(*projectedVars,
kTRUE);
925 coutE(
Plotting) <<
"RooAbsPdf::createPlotProjection(" <<
GetName() <<
") Couldn't deep-clone PDF, abort," << endl ;
938 delete plotLeafNodes ;
942 if(0 != projectedVars) normSet.
add(*projectedVars);
951 if(0 == projectedVars) projectedVars= ∅
957 title.Prepend(
"Projection of ");
962 if(0 == projected || !projected->
isValid()) {
966 if(0 != projected)
delete projected;
967 delete dependentIterator;
971 projected->
SetName(name.Data()) ;
978 delete dependentIterator;
1014 if(hdim != plotVars.
getSize()) {
1023 for(
Int_t index= 0; index < plotVars.
getSize(); index++) {
1028 <<
"\" of type " << var->
ClassName() << endl;
1033 <<
":fillHistogram: WARNING: variable is not an explicit dependent: " << realVar->
GetName() << endl;
1049 if (projectedVars) {
1050 allDeps.
add(*projectedVars) ;
1064 Int_t xbins(0),ybins(1),zbins(1);
1076 assert(0 != zvar && 0 != zaxis);
1077 if (scaleForDensity) {
1085 assert(0 != yvar && 0 != yaxis);
1086 if (scaleForDensity) {
1094 assert(0 != xvar && 0 != xaxis);
1095 if (scaleForDensity) {
1101 << hdim <<
" dimensions" << endl;
1108 Int_t xbin(0),ybin(0),zbin(0);
1109 Int_t bins= xbins*ybins*zbins;
1110 for(
Int_t bin= 0; bin < bins; bin++) {
1113 if(bin % (xbins*ybins) == 0) {
1119 if(bin % xbins == 0) {
1120 ybin= (ybin%ybins) + 1;
1125 xbin= (xbin%xbins) + 1;
1135 coutW(
Plotting) <<
"WARNING: Function evaluation error(s) at coordinates [x]=" << xvar->
getVal() ;
1208 if (showProgress && (i%onePct==0)) {
1212 Double_t binVal = theClone->
getVal(normSet?normSet:obs)*scaleFactor ;
1213 if (correctForBinSize) {
1240 strlcpy(buf,varNameList,1024) ;
1241 char* varName = strtok(buf,
",:") ;
1246 varName = strtok(0,
",") ;
1248 varName = strtok(0,
",") ;
1337 pc.
defineInt(
"intBinning",
"IntrinsicBinning",0,2) ;
1338 pc.
defineInt(
"extended",
"Extended",0,2) ;
1342 pc.
defineSet(
"projObs",
"ProjectedObservables",0,0) ;
1345 pc.
defineMutex(
"SelectCompSet",
"SelectCompSpec") ;
1347 pc.
defineMutex(
"IntrinsicBinning",
"BinningName") ;
1348 pc.
defineMutex(
"IntrinsicBinning",
"BinningSpec") ;
1376 if (!pdfSelf && doExtended>0) {
1377 coutW(
InputArguments) <<
"RooAbsReal::createHistogram(" <<
GetName() <<
") WARNING extended mode requested for a non-pdf object, ignored" << endl ;
1381 coutW(
InputArguments) <<
"RooAbsReal::createHistogram(" <<
GetName() <<
") WARNING extended mode requested for a non-extendable pdf, ignored" << endl ;
1384 if (pdfSelf && doExtended==2) {
1388 const char* compSpec = pc.
getString(
"compSpec") ;
1390 Bool_t haveCompSel = ( (compSpec && strlen(compSpec)>0) || compSet) ;
1393 if (doIntBinning>0) {
1398 if (doIntBinning==1) {
1400 <<
") WARNING, intrinsic model binning requested for histogram, but model does not define bin boundaries, reverting to default binning"<< endl ;
1403 if (doIntBinning==2) {
1405 <<
") INFO: Model has intrinsic binning definition, selecting that binning for the histogram"<< endl ;
1408 for (list<double>::iterator it=bl->begin() ; it!=bl->end() ; ++it) { ba[i++] = *it ; }
1409 intBinning =
new RooBinning(bl->size()-1,ba) ;
1415 pc.
stripCmdList(argListCreate,
"Scaling,ProjectedObservables,IntrinsicBinning,SelectCompSet,SelectCompSpec,Extended") ;
1420 argListCreate.
Add(&tmp) ;
1438 if (!dynamic_cast<RooAbsReal*>(arg)) {
1439 branchNodeSet.
remove(*arg) ;
1450 if (dirSelNodes->
getSize()>0) {
1451 coutI(
Plotting) <<
"RooAbsPdf::createHistogram(" <<
GetName() <<
") directly selected PDF components: " << *dirSelNodes << endl ;
1457 coutE(
Plotting) <<
"RooAbsPdf::createHistogram(" <<
GetName() <<
") ERROR: component selection set " << *compSet <<
" does not match any components of p.d.f." << endl ;
1459 coutE(
Plotting) <<
"RooAbsPdf::createHistogram(" <<
GetName() <<
") ERROR: component selection expression '" << compSpec <<
"' does not select any components of p.d.f." << endl ;
1463 delete dirSelNodes ;
1501 if (!dynamic_cast<RooAbsReal*>(arg)) {
1502 branchNodeSet.
remove(*arg) ;
1543 selNodes->
add(tmp) ;
1544 coutI(
Plotting) <<
"RooAbsPdf::plotOn(" <<
GetName() <<
") indirectly selected PDF components: " << tmp << endl ;
1703 if (rcmd && TString(rcmd->
getString(0)).Contains(
",")) {
1707 argList.
Add(&rnorm) ;
1709 list<string> rlist ;
1714 char* oneRange = strtok(buf,
",") ;
1716 rlist.push_back(oneRange) ;
1717 oneRange = strtok(0,
",") ;
1720 for (list<string>::iterator riter=rlist.begin() ; riter!=rlist.end() ; ++riter) {
1733 pc.
defineString(
"curveNameSuffix",
"CurveNameSuffix",0,
"") ;
1742 pc.
defineInt(
"doEvalError",
"EvalErrorValue",0,0) ;
1743 pc.
defineInt(
"shiftToZero",
"ShiftToZero",0,0) ;
1748 pc.
defineSet(
"errorPars",
"VisualizeError",0) ;
1749 pc.
defineInt(
"linearMethod",
"VisualizeError",0,0) ;
1750 pc.
defineInt(
"binProjData",
"ProjData",0,0) ;
1753 pc.
defineInt(
"numee",
"PrintEvalErrors",0,10) ;
1754 pc.
defineInt(
"rangeAdjustNorm",
"Range",0,0) ;
1755 pc.
defineInt(
"rangeWNAdjustNorm",
"RangeWithName",0,0) ;
1759 pc.
defineInt(
"lineColor",
"LineColor",0,-999) ;
1760 pc.
defineInt(
"lineStyle",
"LineStyle",0,-999) ;
1761 pc.
defineInt(
"lineWidth",
"LineWidth",0,-999) ;
1762 pc.
defineInt(
"fillColor",
"FillColor",0,-999) ;
1763 pc.
defineInt(
"fillStyle",
"FillStyle",0,-999) ;
1765 pc.
defineInt(
"curveInvisible",
"Invisible",0,0) ;
1766 pc.
defineInt(
"showProg",
"ShowProgress",0,0) ;
1768 pc.
defineInt(
"interleave",
"NumCPU",1,0) ;
1772 pc.
defineInt(
"moveToBack",
"MoveToBack",0,0) ;
1776 pc.
defineMutex(
"VisualizeError",
"VisualizeErrorData") ;
1814 const char* sliceCatState = pc.
getString(
"sliceCatState",0,
kTRUE) ;
1816 if (sliceCatState) {
1825 strlcpy(buf,sliceCatState,1024) ;
1826 const char* slabel = strtok(buf,
",") ;
1838 slabel = strtok(0,
",") ;
1850 if (vlines==2) vlines=0 ;
1856 if (vlines==2) vlines=0 ;
1882 cxcoutD(
Plotting) <<
"RooAbsReal::plotOn(" <<
GetName() <<
") Preprocessing: have slice " << *sliceSet << endl ;
1889 while((sliceArg=(
RooAbsArg*)iter->Next())) {
1892 projectedVars.
remove(*arg) ;
1895 << sliceArg->
GetName() <<
" was not projected anyway" << endl ;
1899 }
else if (projSet) {
1900 cxcoutD(
Plotting) <<
"RooAbsReal::plotOn(" <<
GetName() <<
") Preprocessing: have projSet " << *projSet << endl ;
1903 cxcoutD(
Plotting) <<
"RooAbsReal::plotOn(" <<
GetName() <<
") Preprocessing: have neither sliceSet nor projSet " << endl ;
1908 cxcoutD(
Plotting) <<
"RooAbsReal::plotOn(" <<
GetName() <<
") Preprocessing: projectedVars = " << projectedVars << endl ;
1974 projDataVars.
add(*tmp) ;
1997 cxcoutD(
Plotting) <<
"RooAbsReal::plotOn(" <<
GetName() <<
") frame->getNormVars() that are also observables = " << *sliceSetTmp << endl ;
2010 << frame->
getPlotVar()->
GetName() <<
" represents a slice in " << *sliceSetTmp << endl ;
2012 sliceSet.
add(*sliceSetTmp) ;
2013 delete sliceSetTmp ;
2019 cxcoutD(
Plotting) <<
"RooAbsReal::plotOn(" <<
GetName() <<
") projectedVars = " << projectedVars <<
" sliceSet = " << sliceSet << endl ;
2032 if (!plotCloneSet) {
2033 coutE(
Plotting) <<
"RooAbsReal::plotOn(" <<
GetName() <<
") Couldn't deep-clone self, abort," << endl ;
2039 if (projectedVars.
getSize()) {
2041 <<
" integrates over variables " << projectedVars
2044 if (projDataNeededVars && projDataNeededVars->
getSize()>0) {
2046 <<
" averages using data variables " << *projDataNeededVars << endl ;
2054 if (projDataNeededVars) {
2058 deps->
add(*plotVar) ;
2064 coutE(
Plotting) <<
"RooAbsReal::plotOn(" <<
GetName() <<
") error in checkObservables, abort" << endl ;
2066 delete plotCloneSet ;
2067 if (projDataNeededVars)
delete projDataNeededVars ;
2082 fullNormSet.
add(projectedVars) ;
2083 if (projDataNeededVars && projDataNeededVars->
getSize()>0) {
2084 fullNormSet.
add(*projDataNeededVars) ;
2100 if (o.
projData && projDataNeededVars && projDataNeededVars->
getSize()>0) {
2110 if (sliceDataSet->
getSize()>0) {
2116 cutString.Append(
"&&") ;
2123 if ((real = dynamic_cast<RooAbsRealLValue*>(sliceVar))) {
2125 }
else if ((cat = dynamic_cast<RooAbsCategoryLValue*>(sliceVar))) {
2131 delete sliceDataSet ;
2133 if (!cutString.IsNull()) {
2135 coutI(
Plotting) <<
"RooAbsReal::plotOn(" <<
GetName() <<
") reducing given projection dataset to entries with " << cutString << endl ;
2140 <<
") only the following components of the projection data will be used: " << *projDataNeededVars << endl ;
2144 if (!o.
binProjData && dynamic_cast<RooDataSet*>(projDataSel)!=0) {
2151 if (!dynamic_cast<RooCategory*>(arg2)) allCat =
kFALSE ;
2156 coutI(
Plotting) <<
"RooAbsReal::plotOn(" <<
GetName() <<
") unbinned projection dataset consist only of discrete variables," 2157 <<
" performing projection with binned copy for optimization." << endl ;
2165 if (projDataSel!=o.
projData)
delete projDataSel ;
2172 projection->
getVal(projDataSel->
get()) ;
2192 TString curveName(projection->
GetName()) ;
2209 curve->
SetName(curveName.Data()) ;
2230 if (projDataSel!=o.
projData)
delete projDataSel ;
2270 TString curveName(projection->
GetName()) ;
2278 curve->
SetName(curveName.Data()) ;
2299 if (projDataNeededVars)
delete projDataNeededVars ;
2301 delete projectionCompList ;
2302 delete plotCloneSet ;
2321 while((sliceArg=(
RooAbsArg*)iter->Next())) {
2324 projectedVars.
remove(*arg) ;
2327 << sliceArg->
GetName() <<
" was not projected anyway" << endl ;
2370 projDataVars.
add(*tmp) ;
2380 <<
") function doesn't depend on asymmetry category " << asymCat.
GetName() << endl ;
2387 <<
") asymmetry category must have 2 or 3 states with index values -1,0,1" << endl ;
2411 << frame->
getPlotVar()->
GetName() <<
" represents a slice in " << *sliceSetTmp << endl ;
2413 sliceSet.
add(*sliceSetTmp) ;
2414 delete sliceSetTmp ;
2438 if (projectedVars.
getSize()) {
2440 <<
" projects variables " << projectedVars << endl ;
2442 if (projDataNeededVars && projDataNeededVars->getSize()>0) {
2444 <<
" averages using data variables "<< *projDataNeededVars << endl ;
2463 RooArgSet *posProjCompList, *negProjCompList ;
2469 depPos.
add(projDataVars) ;
2470 depNeg.
add(projDataVars) ;
2474 if (!posProj || !negProj) {
2475 coutE(
Plotting) <<
"RooAbsReal::plotAsymOn(" <<
GetName() <<
") Unable to create projections, abort" << endl ;
2481 asymName.Append(
"_Asym[") ;
2482 asymName.Append(asymCat.
GetName()) ;
2483 asymName.Append(
"]") ;
2484 TString asymTitle(asymCat.
GetName()) ;
2485 asymTitle.Append(
" Asymmetry of ") ;
2493 if (projDataNeededVars && projDataNeededVars->getSize()<o.
projData->
get()->
getSize()) {
2498 if (sliceDataSet->
getSize()>0) {
2504 cutString.Append(
"&&") ;
2511 if ((real = dynamic_cast<RooAbsRealLValue*>(sliceVar))) {
2513 }
else if ((cat = dynamic_cast<RooAbsCategoryLValue*>(sliceVar))) {
2519 delete sliceDataSet ;
2521 if (!cutString.IsNull()) {
2524 <<
") reducing given projection dataset to entries with " << cutString << endl ;
2529 <<
") only the following components of the projection data will be used: " << *projDataNeededVars << endl ;
2539 ((
RooAbsReal*)posProj)->attachDataSet(*projDataSel) ;
2540 ((
RooAbsReal*)negProj)->attachDataSet(*projDataSel) ;
2551 TString curveName(funcAsym->
GetName()) ;
2574 if (projDataSel!=o.
projData)
delete projDataSel ;
2593 TString curveName(funcAsym->
GetName()) ;
2601 curve->
SetName(curveName.Data()) ;
2613 delete posProjCompList ;
2614 delete negProjCompList ;
2647 vector<int> fpf_idx ;
2651 paramList.
add(*par) ;
2652 fpf_idx.push_back(i) ;
2656 vector<Double_t> plusVar, minusVar ;
2663 for (
Int_t ivar=0 ; ivar<paramList.
getSize() ; ivar++) {
2671 ((
RooRealVar*)paramList.
at(ivar))->setVal(cenVal+errVal) ;
2672 plusVar.push_back(cloneFunc->
getVal(nset)) ;
2675 ((
RooRealVar*)paramList.
at(ivar))->setVal(cenVal-errVal) ;
2676 minusVar.push_back(cloneFunc->
getVal(nset)) ;
2682 vector<double> errVec(paramList.
getSize()) ;
2683 for (
int i=0 ; i<paramList.
getSize() ; i++) {
2684 errVec[i] =
sqrt(V(i,i)) ;
2685 for (
int j=i ; j<paramList.
getSize() ; j++) {
2686 C(i,j) = V(i,j)/
sqrt(V(i,i)*V(j,j)) ;
2693 for (
unsigned int j=0 ; j<plusVar.size() ; j++) {
2694 F[j] = (plusVar[j]-minusVar[j])/2 ;
2701 delete errorParams ;
2743 pc.
stripCmdList(plotArgListTmp,
"VisualizeError,MoveToBack") ;
2750 if (std::string(
"Normalization")==cmd->
GetName()) {
2753 plotArgList.
Add(cmd) ;
2756 plotArgList.
Add(cmd) ;
2783 coutI(
Plotting) <<
"RooAbsReal::plotOn(" <<
GetName() <<
") INFO: visualizing " << Z <<
"-sigma uncertainties in parameters " 2784 << *errorParams <<
" from fit result " << fr.
GetName() <<
" using " << n <<
" samplings." << endl ;
2789 RooDataSet* d = paramPdf->generate(*errorParams,n) ;
2790 vector<RooCurve*> cvec ;
2792 *cloneParams = (*d->
get(i)) ;
2794 cloneFunc->
plotOn(frame,tmp2) ;
2795 cvec.push_back(frame->
getCurve()) ;
2808 for (vector<RooCurve*>::iterator i=cvec.begin() ; i!=cvec.end() ; i++) {
2833 vector<int> fpf_idx ;
2837 paramList.add(*par) ;
2838 fpf_idx.push_back(i) ;
2842 vector<RooCurve*> plusVar, minusVar ;
2851 for (
Int_t ivar=0 ; ivar<paramList.getSize() ; ivar++) {
2859 ((
RooRealVar*)paramList.at(ivar))->setVal(cenVal+Z*errVal) ;
2863 cloneFunc->
plotOn(frame,tmp2) ;
2864 plusVar.push_back(frame->
getCurve()) ;
2869 ((
RooRealVar*)paramList.at(ivar))->setVal(cenVal-Z*errVal) ;
2871 cloneFunc->
plotOn(frame,tmp3) ;
2872 minusVar.push_back(frame->
getCurve()) ;
2875 ((
RooRealVar*)paramList.at(ivar))->setVal(cenVal) ;
2879 vector<double> errVec(paramList.getSize()) ;
2880 for (
int i=0 ; i<paramList.getSize() ; i++) {
2881 errVec[i] =
sqrt(V(i,i)) ;
2882 for (
int j=i ; j<paramList.getSize() ; j++) {
2883 C(i,j) = V(i,j)/
sqrt(V(i,i)*V(j,j)) ;
2893 for (vector<RooCurve*>::iterator i=plusVar.begin() ; i!=plusVar.end() ; i++) {
2896 for (vector<RooCurve*>::iterator i=minusVar.begin() ; i!=minusVar.end() ; i++) {
2903 if (!band)
return frame ;
2907 pc.
defineString(
"curveNameSuffix",
"CurveNameSuffix",0,
"") ;
2908 pc.
defineInt(
"lineColor",
"LineColor",0,-999) ;
2909 pc.
defineInt(
"lineStyle",
"LineStyle",0,-999) ;
2910 pc.
defineInt(
"lineWidth",
"LineWidth",0,-999) ;
2911 pc.
defineInt(
"fillColor",
"FillColor",0,-999) ;
2912 pc.
defineInt(
"fillStyle",
"FillStyle",0,-999) ;
2914 pc.
defineInt(
"curveInvisible",
"Invisible",0,0) ;
2915 pc.
defineInt(
"moveToBack",
"MoveToBack",0,0) ;
2976 <<
":plotOn: frame does not specify a plot variable" << endl;
2981 if(!dynamic_cast<RooAbsRealLValue*>(var)) {
3011 <<
" allVars = " << (allVars?(*allVars):
RooArgSet()) << endl ;
3014 if (!allVars) return ;
3017 projectedVars.
add(*allVars) ;
3022 projectedVars.
remove(*found);
3032 <<
" from projection set because it a server of " << plotVar->
GetName() << endl ;
3033 projectedVars.
remove(*tmp) ;
3037 delete plotServers ;
3041 <<
") WARNING: cannot project out frame variable (" 3042 << found->
GetName() <<
"), ignoring" << endl ;
3054 <<
") function doesn't depend on projection variable " 3055 << arg->
GetName() <<
", ignoring" << endl ;
3094 if(binding && !binding->
isValid()) {
3118 }
else if (source->
getAttribute(
"INTEGER_TREE_BRANCH")) {
3124 }
else if (source->
getAttribute(
"SIGNEDBYTE_TREE_BRANCH")) {
3126 }
else if (source->
getAttribute(
"UNSIGNED_INTEGER_TREE_BRANCH")) {
3164 TBranch* branch = t.GetBranch(cleanName) ;
3175 <<
" is an array and cannot be attached to a RooAbsReal" << endl ;
3181 if (!typeName.CompareTo(
"Float_t")) {
3183 <<
" will be converted to double precision" << endl ;
3187 }
else if (!typeName.CompareTo(
"Int_t")) {
3189 <<
" will be converted to double precision" << endl ;
3192 t.SetBranchAddress(cleanName,&
_intValue) ;
3193 }
else if (!typeName.CompareTo(
"UChar_t")) {
3195 <<
" will be converted to double precision" << endl ;
3199 }
else if (!typeName.CompareTo(
"Bool_t")) {
3201 <<
" will be converted to double precision" << endl ;
3205 }
else if (!typeName.CompareTo(
"Char_t")) {
3207 <<
" will be converted to double precision" << endl ;
3211 }
else if (!typeName.CompareTo(
"UInt_t")) {
3213 <<
" will be converted to double precision" << endl ;
3217 }
else if (!typeName.CompareTo(
"Double_t")) {
3218 t.SetBranchAddress(cleanName,&
_value) ;
3220 coutE(
InputArguments) <<
"RooAbsReal::attachToTree(" <<
GetName() <<
") data type " << typeName <<
" is not supported" << endl ;
3232 TString
format(cleanName);
3233 format.Append(
"/D");
3234 branch = t.Branch(cleanName, &
_value, (
const Text_t*)format, bufSize);
3392 const TList &nameList)
const 3401 matched.
add(*found);
3415 if(isMatched) matchedArgs.
add(matched);
3464 if (config)
return config ;
3477 if (config)
return config ;
3589 if (inLogEvalError) {
3592 inLogEvalError =
kTRUE ;
3597 if (serverValueString) {
3602 oocoutE((
TObject*)0,
Eval) <<
"RooAbsReal::logEvalError(" <<
"<STATIC>" <<
") evaluation error, " << endl
3603 <<
" origin : " << origName << endl
3604 <<
" message : " << ee.
_msg << endl
3605 <<
" server values: " << ee.
_srvval << endl ;
3612 inLogEvalError =
kFALSE ;
3644 if (inLogEvalError) {
3647 inLogEvalError =
kTRUE ;
3652 if (serverValueString) {
3672 ostringstream oss2 ;
3676 coutE(
Eval) <<
"RooAbsReal::logEvalError(" <<
GetName() <<
") evaluation error, " << endl
3677 <<
" origin : " << oss2.str() << endl
3678 <<
" message : " << ee.
_msg << endl
3679 <<
" server values: " << ee.
_srvval << endl ;
3688 <<
") delayed evaluation error, " << endl
3689 <<
" origin : " << oss2.str() << endl
3690 <<
" message : " << oee.
_msg << endl
3691 <<
" server values: " << oee.
_srvval << endl ;
3698 inLogEvalError =
kFALSE ;
3734 if (maxPerNode<0) return ;
3736 map<const RooAbsArg*,pair<string,list<EvalError> > >::iterator iter =
_evalErrorList.begin() ;
3739 if (maxPerNode==0) {
3742 os << iter->second.first ;
3744 os <<
" has " << iter->second.second.size() <<
" errors" << endl ;
3749 os << iter->second.first << endl ;
3753 std::list<EvalError>::iterator iter2 = iter->second.second.begin() ;
3754 for(;iter2!=iter->second.second.end() ; ++iter2, i++) {
3755 os <<
" " << iter2->_msg <<
" @ " << iter2->_srvval << endl ;
3757 os <<
" ... (remaining " << iter->second.second.size() - maxPerNode <<
" messages suppressed)" << endl ;
3777 map<const RooAbsArg*,pair<string,list<EvalError> > >::iterator iter =
_evalErrorList.begin() ;
3779 ntot += iter->second.second.size() ;
3854 orderedObs.
add(obs) ;
3914 pc.
defineInt(
"numScanBins",
"ScanParameters",0,1000) ;
3915 pc.
defineInt(
"intOrder",
"ScanParameters",1,2) ;
3916 pc.
defineInt(
"doScanNum",
"ScanNum",0,1) ;
3917 pc.
defineInt(
"doScanAll",
"ScanAll",0,0) ;
3918 pc.
defineInt(
"doScanNon",
"ScanNone",0,0) ;
3922 pc.
process(arg1,arg2,arg3,arg4,arg5,arg6,arg7,arg8) ;
3952 coutI(
NumIntegration) <<
"RooAbsPdf::createRunningIntegral(" <<
GetName() <<
") integration over observable(s) " << iset <<
" involves numeric integration," << endl
3953 <<
" constructing cdf though numeric integration of sampled pdf in " << numScanBins <<
" bins and applying order " 3954 << intOrder <<
" interpolation on integrated histogram." << endl
3955 <<
" To override this choice of technique use argument ScanNone(), to change scan parameters use ScanParameters(nbins,order) argument" << endl ;
3973 ivar->
setBins(numScanBins,
"numcdf") ;
3993 if (dynamic_cast<RooRealVar*>(arg)) {
4017 cloneList.
add(*cloneArg) ;
4023 loList.
add(*cloneLo) ;
4056 coutE(
InputArguments) <<
"RooAbsReal::functor(" <<
GetName() <<
") ERROR: one or more specified observables are not variables of this p.d.f" << endl ;
4062 coutE(
InputArguments) <<
"RooAbsReal::functor(" <<
GetName() <<
") ERROR: one or more specified parameters are not variables of this p.d.f" << endl ;
4083 coutE(
InputArguments) <<
"RooAbsReal::functor(" <<
GetName() <<
") ERROR: one or more specified observables are not variables of this p.d.f" << endl ;
4089 coutE(
InputArguments) <<
"RooAbsReal::functor(" <<
GetName() <<
") ERROR: one or more specified parameters are not variables of this p.d.f" << endl ;
4097 for (
int i=0 ; i<obs.
getSize() ; i++) {
4098 if (dynamic_cast<RooRealVar*>(obs.
at(i))==0) {
4103 for (
int i=0 ; i<pars.
getSize() ; i++) {
4104 if (dynamic_cast<RooRealVar*>(pars.
at(i))==0) {
4137 <<
" observables specified, but a ROOT TFx can only have 1,2 or 3 observables" << endl ;
4142 for (
int i=0 ; i<pars.
getSize() ; i++) {
4160 return new RooDerivative(name.c_str(),title.c_str(),*
this,obs,order,eps) ;
4172 return new RooDerivative(name.c_str(),title.c_str(),*
this,obs,normSet,order,eps) ;
4184 string title=
Form(
"%sMoment of order %d of %s w.r.t %s ",(central?
"Central ":
""),order,
GetName(),obs.
GetName()) ;
4185 if (order==1)
return new RooFirstMoment(name.c_str(),title.c_str(),*
this,obs) ;
4186 if (order==2)
return new RooSecondMoment(name.c_str(),title.c_str(),*
this,obs,central,takeRoot) ;
4187 return new RooMoment(name.c_str(),title.c_str(),*
this,obs,order,central,takeRoot) ;
4199 string title=
Form(
"%sMoment of order %d of %s w.r.t %s ",(central?
"Central ":
""),order,
GetName(),obs.
GetName()) ;
4201 if (order==1)
return new RooFirstMoment(name.c_str(),title.c_str(),*
this,obs,normObs,intNormObs) ;
4202 if (order==2)
return new RooSecondMoment(name.c_str(),title.c_str(),*
this,obs,normObs,central,takeRoot,intNormObs) ;
4203 return new RooMoment(name.c_str(),title.c_str(),*
this,obs,normObs,order,central,takeRoot,intNormObs) ;
4335 return new RooChi2Var(name.c_str(),name.c_str(),*
this,
data,arg1,arg2,arg3,arg4,arg5,arg6,arg7,arg8) ;
4359 return createChi2(data,*cmds[0],*cmds[1],*cmds[2],*cmds[3],*cmds[4],*cmds[5],*cmds[6],*cmds[7]) ;
4478 pc.
defineInt(
"integrate",
"Integrate",0,0) ;
4494 return new RooXYChi2Var(name.c_str(),name.c_str(),*
this,
data,*yvar,integrate) ;
4515 pc.
defineInt(
"optConst",
"Optimize",0,1) ;
4519 pc.
defineInt(
"plevel",
"PrintLevel",0,1) ;
4521 pc.
defineInt(
"initHesse",
"InitialHesse",0,0) ;
4525 pc.
defineInt(
"numee",
"PrintEvalErrors",0,10) ;
4547 #ifdef __ROOFIT_NOROOMINIMIZER 4548 const char* minType =0 ;
4550 const char* minType = pc.
getString(
"mintype",
"Minuit") ;
4551 const char* minAlg = pc.
getString(
"minalg",
"minuit") ;
4568 #ifdef __ROOFIT_NOROOMINIMIZER 4571 if (
"OldMinuit" ==
string(minType)) {
4593 ret = m.
fit(fitOpt) ;
4627 m.
minos(*minosSet) ;
4636 string title =
Form(
"Result of fit of %s ",
GetName()) ;
4637 ret = m.
save(name.c_str(),title.c_str()) ;
4642 #ifndef __ROOFIT_NOROOMINIMIZER 4664 ret = m.
fit(fitOpt) ;
4698 m.
minos(*minosSet) ;
4707 string title =
Form(
"Result of fit of %s ",
GetName()) ;
4708 ret = m.
save(name.c_str(),title.c_str()) ;
4750 while((arg=iter.
next())) {
4753 <<
") function does not depend on listed parameter " << arg->
GetName() <<
", ignoring" << endl ;
4756 if (plist.size()>0) plist +=
":" ;
virtual Double_t getMin(const char *name=0) const
void setAttribute(const Text_t *name, Bool_t value=kTRUE)
Set (default) or clear a named boolean attribute of this object.
RooArgSet * getVariables(Bool_t stripDisconnected=kTRUE) const
Return RooArgSet with all variables (tree leaf nodes of expresssion tree)
static RooNumIntConfig & defaultConfig()
Return reference to instance of default numeric integrator configuration object.
virtual const char * GetName() const
Returns name of object.
A TLeaf describes individual elements of a TBranch See TBranch structure in TTree.
virtual void SetLineWidth(Width_t lwidth)
Set the line width.
virtual RooAbsArg * cloneTree(const char *newname=0) const
Clone tree expression of objects.
void setInterpolationOrder(Int_t order)
Set interpolation order of RooHistFunct representing cache histogram.
TIterator * createIterator(Bool_t dir=kIterForward) const
Bool_t postRangeFracScale
const char * getString(Int_t idx) const
static long int sum(long int i)
static void globalSelectComp(Bool_t flag)
Global switch controlling the activation of the selectComp() functionality.
virtual void printStream(std::ostream &os, Int_t contents, StyleOption style, TString indent="") const
Print description of object on ostream, printing contents set by contents integer, which is interpreted as an OR of 'enum ContentsOptions' values and in the style given by 'enum StyleOption'.
virtual Bool_t add(const RooAbsArg &var, Bool_t silent=kFALSE)
Add the specified argument to list.
void treeNodeServerList(RooAbsCollection *list, const RooAbsArg *arg=0, Bool_t doBranch=kTRUE, Bool_t doLeaf=kTRUE, Bool_t valueOnly=kFALSE, Bool_t recurseNonDerived=kFALSE) const
Fill supplied list with nodes of the arg tree, following all server links, starting with ourself as t...
virtual RooPlot * plotOn(RooPlot *frame, const RooCmdArg &arg1=RooCmdArg(), const RooCmdArg &arg2=RooCmdArg(), const RooCmdArg &arg3=RooCmdArg(), const RooCmdArg &arg4=RooCmdArg(), const RooCmdArg &arg5=RooCmdArg(), const RooCmdArg &arg6=RooCmdArg(), const RooCmdArg &arg7=RooCmdArg(), const RooCmdArg &arg8=RooCmdArg(), const RooCmdArg &arg9=RooCmdArg(), const RooCmdArg &arg10=RooCmdArg()) const
Plot (project) PDF on specified frame.
TObject * FindObject(const char *name) const
Return pointer to obejct with given name.
virtual void Delete(Option_t *option="")
Remove all objects from the list AND delete all heap based objects.
void setServerValues(const char *tmp)
void setPrintEvalErrors(Int_t numEvalErrors)
A RooCurve is a one-dimensional graphical representation of a real-valued function.
static EvalErrorIter evalErrorIter()
Bool_t _boolValue
Transient cache for integer values from tree branches.
const RooArgList & floatParsFinal() const
RooNumIntConfig holds the configuration parameters of the various numeric integrators used by RooReal...
virtual Double_t getMax(const char *name=0) const
virtual Bool_t add(const RooAbsCollection &col, Bool_t silent=kFALSE)
Add a collection of arguments to this collection by calling add() for each element in the source coll...
virtual const RooArgSet * get() const
void setVerbose(Bool_t flag=kTRUE)
TMatrixDSym reducedCovarianceMatrix(const RooArgList ¶ms) const
Return a reduced covariance matrix (Note that Vred is a simple sub-matrix of V, row/columns are order...
void optimizeConst(Int_t flag)
If flag is true, perform constant term optimization on function being minimized.
virtual TObject * clone(const char *newname) const
const char * addToCurveName
Bool_t dependsOn(const RooAbsCollection &serverList, const RooAbsArg *ignoreArg=0, Bool_t valueOnly=kFALSE) const
Test whether we depend on (ie, are served by) any object in the specified collection.
virtual void SetParName(Int_t ipar, const char *name)
Set name of parameter number ipar.
void sort(Bool_t ascend=kTRUE)
const Text_t * getUnit() const
void plotOnCompSelect(RooArgSet *selNodes) const
Helper function for plotting of composite p.d.fs.
static RooNumIntConfig * defaultIntegratorConfig()
Returns the default numeric integration configuration for all RooAbsReals.
Class RooProfileLL implements the profile likelihood estimator for a given likelihood and set of para...
Bool_t defineDouble(const char *name, const char *argName, Int_t doubleNum, Double_t defValue=0.)
Define Double_t property name 'name' mapped to Double_t in slot 'doubleNum' in RooCmdArg with name ar...
RooArgSet * getObservables(const RooArgSet &set, Bool_t valueOnly=kTRUE) const
Collectable string class.
virtual const RooArgSet * get() const
void setPlotLabel(const char *label)
Set the label associated with this variable.
RooCmdArg ZVar(const RooAbsRealLValue &var, const RooCmdArg &arg=RooCmdArg::none())
Int_t GetCompressionLevel() const
void leafNodeServerList(RooAbsCollection *list, const RooAbsArg *arg=0, Bool_t recurseNonDerived=kFALSE) const
Fill supplied list with all leaf nodes of the arg tree, starting with ourself as top node...
virtual Double_t evaluate() const =0
RooAbsCollection * selectCommon(const RooAbsCollection &refColl) const
Create a subset of the current collection, consisting only of those elements that are contained as we...
virtual Bool_t isValidReal(Double_t value, Bool_t printError=kFALSE) const
Interface function to check if given value is a valid value for this object.
Bool_t matchArgs(const RooArgSet &allDeps, RooArgSet &numDeps, const RooArgProxy &a) const
Utility function for use in getAnalyticalIntegral().
virtual TObject * Clone(const char *newName=0) const
Make a clone of an object using the Streamer facility.
Int_t hesse()
Execute HESSE.
const char * getString(const char *name, const char *defaultValue="", Bool_t convEmptyToNull=kFALSE)
Return string property registered with name 'name'.
virtual Bool_t isParameterized() const
virtual Bool_t replace(const RooAbsArg &var1, const RooAbsArg &var2)
Replace var1 with var2 and return kTRUE for success.
Double_t getVal(const RooArgSet *set=0) const
Bool_t matchArgsByName(const RooArgSet &allArgs, RooArgSet &matchedArgs, const TList &nameList) const
Check if allArgs contains matching elements for each name in nameList.
void setString(Int_t idx, const char *value)
const TMatrixDSym & covarianceMatrix() const
Return covariance matrix.
virtual void SetName(const char *name)
Set the name of the TNamed.
virtual Int_t getAnalyticalIntegral(RooArgSet &allVars, RooArgSet &analVars, const char *rangeName=0) const
Interface function getAnalyticalIntergral advertises the analytical integrals that are supported...
Lightweight interface adaptor that exports a RooAbsReal as a ROOT::Math::IMultiGenFunction.
RooFirstMoment represents the first, second, or third order derivative of any RooAbsReal as calculate...
virtual const char * GetTypeName() const
RooAbsMoment * moment(RooRealVar &obs, Int_t order, Bool_t central, Bool_t takeRoot)
Return function representing moment of function of given order.
virtual TLeaf * GetLeafCounter(Int_t &countval) const
Return a pointer to the counter of this leaf.
Class RooNumRunningInt is an implementation of RooAbsCachedReal that represents a running integral t...
void setBuffer(RooAbsReal *real, Double_t *newBuf)
RooAbsArg * createFundamental(const char *newname=0) const
Create a RooRealVar fundamental object with our properties.
void set(Double_t weight, Double_t wgtErr=-1)
Increment the weight of the bin enclosing the coordinates given by 'row' by the specified amount...
void addPlotable(RooPlotable *plotable, Option_t *drawOptions="", Bool_t invisible=kFALSE, Bool_t refreshNorm=kFALSE)
Add the specified plotable object to our plot.
virtual std::list< Double_t > * binBoundaries(RooAbsRealLValue &, Double_t, Double_t) const
Double_t traceEval(const RooArgSet *set) const
Calculate current value of object, with error tracing wrapper.
void SetCompressionLevel(Int_t level=1)
Set compression level.
static std::map< const RooAbsArg *, std::pair< std::string, std::list< EvalError > > > _evalErrorList
Int_t minos()
Execute MINOS.
virtual Int_t GetNbinsZ() const
Bool_t defineSet(const char *name, const char *argName, Int_t setNum, const RooArgSet *set=0)
Define TObject property name 'name' mapped to object in slot 'setNum' in RooCmdArg with name argName ...
TString getTitle(Bool_t appendUnit=kFALSE) const
Return this variable's title string.
virtual void printMultiline(std::ostream &os, Int_t contents, Bool_t verbose=kFALSE, TString indent="") const
Structure printing.
friend class RooRealIntegral
static void clearEvalErrorLog()
Clear the stack of evaluation error messages.
virtual RooAbsReal * createChi2(RooDataHist &data, const RooLinkedList &cmdList)
Internal back-end function to create a chi2.
void setNameList(const char *givenList)
virtual void selectNormalization(const RooArgSet *depSet=0, Bool_t force=kFALSE)
Interface function to force use of a given set of observables to interpret function value...
static Int_t numEvalErrorItems()
RooFIter fwdIterator() const
void constOptimizeTestStatistic(ConstOpCode opcode, Bool_t doAlsoTrackingOpt=kTRUE)
Driver function to propagate constant term optimizations in test statistic.
RooAbsData * reduce(const RooCmdArg &arg1, const RooCmdArg &arg2=RooCmdArg(), const RooCmdArg &arg3=RooCmdArg(), const RooCmdArg &arg4=RooCmdArg(), const RooCmdArg &arg5=RooCmdArg(), const RooCmdArg &arg6=RooCmdArg(), const RooCmdArg &arg7=RooCmdArg(), const RooCmdArg &arg8=RooCmdArg())
Create a reduced copy of this dataset.
TAttFill * getAttFill(const char *name=0) const
Return a pointer to the fill attributes of the named object in this plot, or zero if the named object...
virtual TObject * Clone(const char *newname=0) const
Make a clone of an object using the Streamer facility.
virtual void SetFillStyle(Style_t fstyle)
Set the fill area style.
virtual void fixAddCoefRange(const char *rangeName=0, Bool_t force=kTRUE)
Fix the interpretation of the coefficient of any RooAddPdf component in the expression tree headed by...
void allowUndefined(Bool_t flag=kTRUE)
RooAbsReal * createScanRI(const RooArgSet &iset, const RooArgSet &nset, Int_t numScanBins, Int_t intOrder)
Utility function for createRunningIntegral that construct an object implementing the numeric scanning...
virtual Int_t getIndex() const
Return index number of current state.
Bool_t isValueDirtyAndClear() const
Bool_t addOwnedComponents(const RooArgSet &comps)
Take ownership of the contents of 'comps'.
Int_t migrad()
Execute MIGRAD.
void setStrategy(Int_t strat)
Change MINUIT strategy to istrat.
static std::string format(double x, double y, int digits, int width)
TObject * At(Int_t idx) const
RooAbsMoment represents the first, second, or third order derivative of any RooAbsReal as calculated ...
TObject * getObject(const char *name, TObject *obj=0)
Return TObject property registered with name 'name'.
RooCmdArg SupNormSet(const RooArgSet &nset)
static void setHideOffset(Bool_t flag)
void attachDataSet(const RooAbsData &set)
Replace server nodes with names matching the dataset variable names with those data set variables...
virtual void copyCache(const RooAbsArg *source, Bool_t valueOnly=kFALSE, Bool_t setValDirty=kTRUE)
Copy the cached value of another RooAbsArg to our cache.
virtual RooPlot * plotAsymOn(RooPlot *frame, const RooAbsCategoryLValue &asymCat, PlotOpt o) const
Iterator abstract base class.
virtual ~RooAbsReal()
Destructor.
void setMinimizerType(const char *type)
Choose the minimzer algorithm.
Double_t findRoot(RooRealVar &x, Double_t xmin, Double_t xmax, Double_t yval)
Return value of x (in range xmin,xmax) at which function equals yval.
RooAbsReal * createRunningIntegral(const RooArgSet &iset, const RooArgSet &nset=RooArgSet())
Create a running integral over this function, i.e.
void setStrategy(Int_t strat)
Change MINUIT strategy to istrat.
virtual Bool_t setLabel(const char *label, Bool_t printError=kTRUE)
Set value by specifying the name of the desired state If printError is set, a message will be printed...
virtual Bool_t isValid() const
Check if current value is valid.
const char * curveNameSuffix
void setValueDirty() const
RooDataHist * fillDataHist(RooDataHist *hist, const RooArgSet *nset, Double_t scaleFactor, Bool_t correctForBinVolume=kFALSE, Bool_t showProgress=kFALSE) const
Fill a RooDataHist with values sampled from this function at the bin centers.
Bool_t process(const RooCmdArg &arg)
Process given RooCmdArg.
static const RooCmdArg & none()
Return reference to null argument.
void setStringAttribute(const Text_t *key, const Text_t *value)
Associate string 'value' to this object under key 'key'.
RooAbsReal * createIntRI(const RooArgSet &iset, const RooArgSet &nset=RooArgSet())
Utility function for createRunningIntegral that construct an object implementing the standard (analyt...
const char * normRange() const
virtual Int_t GetDimension() const
friend class RooRealBinding
void setVerbose(Bool_t flag=kTRUE)
virtual void SetMinimum(Double_t minimum=-1111)
Set minimum value of Y axis.
void setBinning(const RooAbsBinning &binning, const char *name=0)
Add given binning under name 'name' with this variable.
virtual const char * ClassName() const
Returns name of class to which the object belongs.
static void setEvalErrorLoggingMode(ErrorLoggingMode m)
Set evaluation error logging mode.
const char * normRangeName
RooDataSet is a container class to hold N-dimensional binned data.
RooRealIntegral performs hybrid numerical/analytical integrals of RooAbsReal objects The class perfor...
virtual Bool_t readFromStream(std::istream &is, Bool_t compact, Bool_t verbose=kFALSE)
Read object contents from stream (dummy for now)
RooAbsPdf * createHessePdf(const RooArgSet ¶ms) const
Return a p.d.f that represents the fit result as a multi-variate probability densisty function on the...
void findInnerMostIntegration(const RooArgSet &allObs, RooArgSet &innerObs, const char *rangeName) const
Utility function for createIntObj() that aids in the construct of recursive integrals over functions ...
virtual Double_t getValV(const RooArgSet *set=0) const
Return value of object.
virtual TObject * Clone(const char *newname=0) const
Make a clone of an object using the Streamer facility.
TH1 * createHistogram(const char *name, const RooCmdArg &arg1=RooCmdArg::none(), const RooCmdArg &arg2=RooCmdArg::none(), const RooCmdArg &arg3=RooCmdArg::none(), const RooCmdArg &arg4=RooCmdArg::none(), const RooCmdArg &arg5=RooCmdArg::none(), const RooCmdArg &arg6=RooCmdArg::none(), const RooCmdArg &arg7=RooCmdArg::none(), const RooCmdArg &arg8=RooCmdArg::none()) const
virtual void removeAll()
Remove all arguments from our set, deleting them if we own them.
Int_t _intValue
Transient cache for floating point values from tree branches.
void removeRange(const char *name=0)
TH1 * createHistogram(const char *varNameList, Int_t xbins=0, Int_t ybins=0, Int_t zbins=0) const
Create and fill a ROOT histogram TH1,TH2 or TH3 with the values of this function for the variables wi...
double cdf(double *x, double *p)
RooVectorDataStore is the abstract base class for data collection that use a TTree as internal storag...
Int_t setPrintLevel(Int_t newLevel)
Change the MINUIT internal printing level.
std::map< const RooAbsArg *, std::pair< std::string, std::list< E