166 TUnfoldDensity::~TUnfoldDensity(
void)
169 if(fOwnedOutputBins)
delete fOwnedOutputBins;
170 if(fOwnedInputBins)
delete fOwnedInputBins;
171 if(fRegularisationConditions)
delete fRegularisationConditions;
183 fRegularisationConditions=0;
220 const TUnfoldBinning *inputBins,
const char *regularisationDistribution,
221 const char *regularisationAxisSteering) :
222 TUnfoldSys(hist_A,histmap,kRegModeNone,constraint)
224 fRegularisationConditions=0;
226 fConstOutputBins = outputBins;
227 fOwnedOutputBins = 0;
228 TAxis const *genAxis,*detAxis;
229 if(histmap==kHistMapOutputHoriz) {
236 if(!fConstOutputBins) {
241 fConstOutputBins = fOwnedOutputBins;
244 if(fConstOutputBins->GetParentNode()) {
245 Error(
"TUnfoldDensity",
246 "Invalid output binning scheme (node is not the root node)");
248 fConstInputBins = inputBins;
250 if(!fConstInputBins) {
255 fConstInputBins = fOwnedInputBins;
257 if(fConstInputBins->GetParentNode()) {
258 Error(
"TUnfoldDensity",
259 "Invalid input binning scheme (node is not the root node)");
267 if((nOutMappedT!= nOut)&&(nOutMappedF!=nOut)) {
268 Error(
"TUnfoldDensity",
269 "Output binning incompatible number of bins: axis %d binning scheme %d (%d)",
270 nOut,nOutMappedT,nOutMappedF);
277 if((nInputMappedT!= nInput)&&(nInputMappedF!= nInput)) {
278 Error(
"TUnfoldDensity",
279 "Input binning incompatible number of bins:axis %d binning scheme %d (%d) ",
280 nInput,nInputMappedT,nInputMappedF);
284 for (
Int_t ix = 0; ix <= nOut+1; ix++) {
286 Info(
"TUnfold",
"*NOT* unfolding bin %s",(
char const *)GetOutputBinName(ix));
291 if(regmode !=kRegModeNone) {
292 RegularizeDistribution
293 (regmode,densityMode,regularisationDistribution,
294 regularisationAxisSteering);
309 else return fConstOutputBins->GetBinName(iBinX);
336 if((densityMode == kDensityModeBinWidth)||
337 (densityMode == kDensityModeBinWidthAndUser)) {
338 Double_t binSize=fConstOutputBins->GetBinSize(iBin);
339 if(binSize>0.0) factor /= binSize;
342 if((densityMode == kDensityModeUser)||
343 (densityMode == kDensityModeBinWidthAndUser)) {
344 factor *= fConstOutputBins->GetBinFactor(iBin);
385 const char *axisSteering)
388 RegularizeDistributionRecursive(GetOutputBinning(),regmode,densityMode,
389 distribution,axisSteering);
403 EDensityMode densityMode,
const char *distribution,
const char *axisSteering) {
404 if((!distribution)|| !TString(distribution).CompareTo(binning->
GetName())) {
405 RegularizeOneDistribution(binning,regmode,densityMode,axisSteering);
409 RegularizeDistributionRecursive(child,regmode,densityMode,distribution,
427 cout<<
"TUnfoldDensity::RegularizeOneDistribution node=" 428 <<binning->
GetName()<<
" "<<regmode<<
" "<<densityMode
429 <<
" "<<(axisSteering ? axisSteering :
"")<<
"\n";
431 if(!fRegularisationConditions)
438 Int_t isOptionGiven[8];
441 isOptionGiven[0] |= isOptionGiven[1];
443 isOptionGiven[2] |= isOptionGiven[3];
445 isOptionGiven[4] |= isOptionGiven[5];
447 for(
Int_t i=0;i<7;i++) {
448 isOptionGiven[7] &= ~isOptionGiven[i];
451 if(isOptionGiven[6] & (isOptionGiven[0]|isOptionGiven[2]) ) {
452 Error(
"RegularizeOneDistribution",
453 "axis steering %s is not valid",axisSteering);
456 cout<<
" "<<isOptionGiven[0]
457 <<
" "<<isOptionGiven[1]
458 <<
" "<<isOptionGiven[2]
459 <<
" "<<isOptionGiven[3]
460 <<
" "<<isOptionGiven[4]
461 <<
" "<<isOptionGiven[5]
462 <<
" "<<isOptionGiven[6]
463 <<
" "<<isOptionGiven[7]
466 Info(
"RegularizeOneDistribution",
"regularizing %s regMode=%d" 467 " densityMode=%d axisSteering=%s",
469 axisSteering ? axisSteering :
"");
472 std::vector<Double_t> factor(endBin-startBin);
474 for(
Int_t bin=startBin;bin<endBin;bin++) {
475 factor[bin-startBin]=GetDensityFactor(densityMode,bin);
476 if(factor[bin-startBin] !=0.0) nbin++;
479 cout<<
"initial number of bins "<<nbin<<
"\n";
485 for(
Int_t bin=startBin;bin<endBin;bin++) {
486 Int_t uStatus,oStatus;
488 if(uStatus & isOptionGiven[1]) factor[bin-startBin]=0.;
489 if(oStatus & isOptionGiven[3]) factor[bin-startBin]=0.;
490 if(factor[bin-startBin] !=0.0) nbin++;
493 cout<<
"after underflow/overflow bin removal "<<nbin<<
"\n";
495 if(regmode==kRegModeSize) {
499 for(
Int_t bin=startBin;bin<endBin;bin++) {
500 if(factor[bin-startBin]==0.0)
continue;
501 if(AddRegularisationCondition(bin,factor[bin-startBin])) {
506 thisRegularisationBinning->
AddBinning(
"size",nRegBins);
508 }
else if((regmode==kRegModeDerivative)||(regmode==kRegModeCurvature)) {
509 for(
Int_t direction=0;direction<dimension;direction++) {
512 Int_t directionMask=(1<<direction);
513 if(isOptionGiven[7] & directionMask) {
515 cout<<
"skip direction "<<direction<<
"\n";
520 (isOptionGiven[5] & directionMask) ?
522 (direction,isOptionGiven[0] & directionMask,
523 isOptionGiven[2] & directionMask) : 1.0;
524 for(
Int_t bin=startBin;bin<endBin;bin++) {
526 if(factor[bin-startBin]==0.0)
continue;
531 (bin,direction,&iPrev,&distPrev,&iNext,&distNext,
532 isOptionGiven[6] & directionMask);
534 Error(
"RegularizeOneDistribution",
535 "invalid option %s (isPeriodic) for axis %s" 536 " (has underflow or overflow)",axisSteering,
539 if((regmode==kRegModeDerivative)&&(iNext>=0)) {
540 Double_t f0 = -factor[bin-startBin];
542 if(isOptionGiven[4] & directionMask) {
544 f0 *= binDistanceNormalisation/distNext;
545 f1 *= binDistanceNormalisation/distNext;
551 if((f0==0.0)||(f1==0.0))
continue;
552 if(AddRegularisationCondition(bin,f0,iNext,f1)) {
555 std::cout<<
"Added Reg: bin "<<bin<<
" "<<f0
556 <<
" next: "<<iNext<<
" "<<f1<<
"\n";
559 }
else if((regmode==kRegModeCurvature)&&(iPrev>=0)&&(iNext>=0)) {
560 Double_t f0 = factor[iPrev-startBin];
563 if(isOptionGiven[4] & directionMask) {
564 if((distPrev<0.)&&(distNext>0.)) {
569 f1 *= f*(1./distPrev+1./distNext);
577 if((f0==0.0)||(f1==0.0)||(f2==0.0))
continue;
578 if(AddRegularisationCondition(iPrev,f0,bin,f1,iNext,f2)) {
581 std::cout<<
"Added Reg: prev "<<iPrev<<
" "<<f0
582 <<
" bin: "<<bin<<
" "<<f1
583 <<
" next: "<<iNext<<
" "<<f2<<
"\n";
590 if(regmode==kRegModeDerivative) {
592 }
else if(regmode==kRegModeCurvature) {
596 thisRegularisationBinning->
AddBinning(name,nRegBins);
651 (
const char *histogramName,
const char *histogramTitle,
652 const char *distributionName,
const char *axisSteering,
653 Bool_t useAxisBinning)
const 658 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
683 (
const char *histogramName,
const char *histogramTitle,
684 const char *distributionName,
const char *axisSteering,
685 Bool_t useAxisBinning)
const 690 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
694 if(binMap)
delete [] binMap;
715 (
const char *histogramName,
const char *histogramTitle,
716 const char *distributionName,
const char *axisSteering,
722 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
729 if(binMap)
delete [] binMap;
751 (
const char *histogramName,
const char *bgrSource,
const char *histogramTitle,
752 const char *distributionName,
const char *axisSteering,
Bool_t useAxisBinning,
753 Int_t includeError)
const 758 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
762 if(binMap)
delete [] binMap;
781 (
const char *histogramName,
const char *histogramTitle,
782 const char *distributionName,
const char *axisSteering,
783 Bool_t useAxisBinning)
const 788 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
792 if(binMap)
delete [] binMap;
814 (
const char *histogramName,
const char *histogramTitle,
815 const char *distributionName,
const char *axisSteering,
820 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
825 TString ematName(histogramName);
826 ematName +=
"_inverseEMAT";
829 (ematName,useAxisBinning,&binMap2D,histogramTitle,
831 if(binMap2D)
delete [] binMap2D;
833 Error(
"GetRhoItotal",
834 "can not return inverse of error matrix for this binning");
842 if(binMap)
delete [] binMap;
865 (
const char *histogramName,
const char *histogramTitle,
866 const char *distributionName,
const char *axisSteering,
871 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
876 TString ematName(histogramName);
877 ematName +=
"_inverseEMAT";
880 (ematName,useAxisBinning,&binMap2D,histogramTitle,
882 if(binMap2D)
delete [] binMap2D;
884 Error(
"GetRhoItotal",
885 "can not return inverse of error matrix for this binning");
893 if(binMap)
delete [] binMap;
913 (
const char *source,
const char *histogramName,
914 const char *histogramTitle,
const char *distributionName,
915 const char *axisSteering,
Bool_t useAxisBinning) {
919 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
926 if(binMap)
delete [] binMap;
947 (
const char *bgrSource,
const char *histogramName,
948 const char *histogramTitle,
const char *distributionName,
949 const char *axisSteering,
Bool_t useAxisBinning) {
953 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
960 if(binMap)
delete [] binMap;
980 (
const char *histogramName,
const char *histogramTitle,
981 const char *distributionName,
const char *axisSteering,
Bool_t useAxisBinning)
986 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
993 if(binMap)
delete [] binMap;
1012 (
const char *histogramName,
const char *histogramTitle,
1013 const char *distributionName,
const char *axisSteering,
1016 TH2 *
r=GetEmatrixTotal
1017 (histogramName,histogramTitle,distributionName,
1018 axisSteering,useAxisBinning);
1030 if((e_i>0.0)&&(e_j>0.0)) {
1064 (
const char *histogramName,
const char *histogramTitle,
1065 const char *distributionName,
const char *axisSteering,
1071 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
1075 if(binMap)
delete [] binMap;
1095 (
const char *bgrSource,
const char *histogramName,
1096 const char *histogramTitle,
const char *distributionName,
1097 const char *axisSteering,
Bool_t useAxisBinning)
1102 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
1106 if(binMap)
delete [] binMap;
1126 (
const char *histogramName,
const char *histogramTitle,
1127 const char *distributionName,
const char *axisSteering,
1133 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
1137 if(binMap)
delete [] binMap;
1153 (
const char *histogramName,
const char *histogramTitle,
1154 Bool_t useAxisBinning)
const 1157 (fConstOutputBins,fConstInputBins,histogramName,
1158 useAxisBinning,useAxisBinning,histogramTitle);
1178 (
const char *histogramName,
const char *histogramTitle,
1179 const char *distributionName,
const char *axisSteering,
1185 (histogramName,useAxisBinning,&binMap,histogramTitle,axisSteering);
1189 if(binMap)
delete [] binMap;
1205 (
const char *histogramName,
const char *histogramTitle,
Bool_t useAxisBinning)
1207 if(fRegularisationConditions &&
1208 (fRegularisationConditions->GetEndBin()-
1209 fRegularisationConditions->GetStartBin()!= fL->GetNrows())) {
1211 "remove invalid scheme of regularisation conditions %d %d",
1212 fRegularisationConditions->GetEndBin(),fL->GetNrows());
1213 delete fRegularisationConditions;
1214 fRegularisationConditions=0;
1216 if(!fRegularisationConditions) {
1217 fRegularisationConditions=
new TUnfoldBinning(
"regularisation",fL->GetNrows());
1218 Warning(
"GetL",
"create flat regularisation conditions scheme");
1221 (fConstOutputBins,fRegularisationConditions,histogramName,
1222 useAxisBinning,useAxisBinning,histogramTitle);
1243 (
const char *histogramName,
const char *histogramTitle)
1247 if(fRegularisationConditions &&
1248 (fRegularisationConditions->GetEndBin()-
1249 fRegularisationConditions->GetStartBin()!= fL->GetNrows())) {
1251 "remove invalid scheme of regularisation conditions %d %d",
1252 fRegularisationConditions->GetEndBin(),fL->GetNrows());
1253 delete fRegularisationConditions;
1254 fRegularisationConditions=0;
1256 if(!fRegularisationConditions) {
1257 fRegularisationConditions=
new TUnfoldBinning(
"regularisation",fL->GetNrows());
1258 Warning(
"GetLxMinusBias",
"create flat regularisation conditions scheme");
1260 TH1 *
r=fRegularisationConditions->CreateHistogram
1261 (histogramName,
kFALSE,0,histogramTitle);
1265 if(Ldx_rows[row]<Ldx_rows[row+1]) {
1282 (
const char *distributionName)
const 1286 return fConstInputBins->
FindNode(distributionName);
1298 (
const char *distributionName)
const 1302 return fConstOutputBins->
FindNode(distributionName);
1345 Int_t mode,
const char *distribution,
const char *axisSteering,
1348 typedef std::map<Double_t,Double_t> TauScan_t;
1349 typedef std::map<Double_t,std::pair<Double_t,Double_t> > LCurve_t;
1374 if((tauMin<=0)||(tauMax<=0.0)||(tauMin>=tauMax)) {
1384 Error(
"ScanTau",
"too few input bins, NDF<=0 %d",GetNdf());
1388 Double_t y0=GetScanVariable(mode,distribution,axisSteering);
1389 Info(
"ScanTau",
"logtau=-Infinity y=%lf X=%lf Y=%lf",y0,X0,Y0);
1397 Fatal(
"ScanTau",
"problem (missing regularisation?) X=%f Y=%f",
1398 GetLcurveX(),GetLcurveY());
1400 Double_t y=GetScanVariable(mode,distribution,axisSteering);
1402 lcurve[logTau]=std::make_pair(GetLcurveX(),GetLcurveY());
1403 Info(
"ScanTau",
"logtau=%lf y=%lf X=%lf Y=%lf",logTau,y,
1404 GetLcurveX(),GetLcurveY());
1409 while(((
int)curve.size()<nPoint-1)&&
1414 Double_t y=GetScanVariable(mode,distribution,axisSteering);
1416 lcurve[logTau]=std::make_pair(GetLcurveX(),GetLcurveY());
1417 Info(
"ScanTay",
"logtau=%lf y=%lf X=%lf Y=%lf",logTau,y,
1418 GetLcurveX(),GetLcurveY());
1426 Double_t y=GetScanVariable(mode,distribution,axisSteering);
1428 lcurve[logTauMax]=std::make_pair(GetLcurveX(),GetLcurveY());
1429 Info(
"ScanTau",
"logtau=%lf y=%lf X=%lf Y=%lf",logTauMax,y,
1430 GetLcurveX(),GetLcurveY());
1434 Double_t y=GetScanVariable(mode,distribution,axisSteering);
1436 lcurve[logTauMin]=std::make_pair(GetLcurveX(),GetLcurveY());
1437 Info(
"ScanTau",
"logtau=%lf y=%lf X=%lf Y=%lf",logTauMin,y,
1438 GetLcurveX(),GetLcurveY());
1444 while((
int)curve.size()<nPoint-1) {
1450 TauScan_t::const_iterator i0,i1;
1455 for(;i0!=curve.end();i0++) {
1456 if((*i0).second<yMin) {
1458 logTauYMin=(*i0).first;
1467 for(i1++;i1!=curve.end();i1++) {
1472 +0.25*
TMath::Power(0.5*((*i0).first+(*i1).first)-logTauYMin,2.)/
1473 ((*curve.rbegin()).
first-(*curve.begin()).
first)/nPoint;
1474 if((dist<=0.0)||(dist>distMax)) {
1476 logTau=0.5*((*i0).first+(*i1).first);
1481 Double_t y=GetScanVariable(mode,distribution,axisSteering);
1483 lcurve[logTau]=std::make_pair(GetLcurveX(),GetLcurveY());
1484 Info(
"ScanTau",
"logtau=%lf y=%lf X=%lf Y=%lf",logTau,y,
1485 GetLcurveX(),GetLcurveY());
1499 for(TauScan_t::const_iterator i=curve.begin();i!=curve.end();i++) {
1516 for(
Int_t i=iskip;i<n-1-iskip;i++) {
1539 xx = m_p_half + discr;
1541 xx = m_p_half - discr;
1545 if((xx>0.0)&&(xx<dx)) {
1546 y=splineC->
Eval(x+xx);
1559 if((xx>0.0)&&(xx<dx)) {
1560 y=splineC->
Eval(x+xx);
1580 Double_t y=GetScanVariable(mode,distribution,axisSteering);
1582 lcurve[logTauFin]=std::make_pair(GetLcurveX(),GetLcurveY());
1583 Info(
"ScanTau",
"Result logtau=%lf y=%lf X=%lf Y=%lf",logTauFin,y,
1584 GetLcurveX(),GetLcurveY());
1590 Int_t bestChoice=-1;
1591 if(curve.size()>0) {
1595 for( TauScan_t::const_iterator i=curve.begin();i!=curve.end();i++) {
1596 if(logTauFin==(*i).first) {
1606 if(distribution) name+= distribution;
1608 if(axisSteering) name += axisSteering;
1610 (*scanResult)=
new TSpline3(name+
"%log(tau)",logT,y,n);
1620 for(LCurve_t::const_iterator i=lcurve.begin();i!=lcurve.end();i++) {
1622 x[
n]=(*i).second.first;
1623 y[
n]=(*i).second.second;
1628 *lCurvePlot=
new TGraph(n,x,y);
1629 (*lCurvePlot)->SetTitle(
"L curve");
1632 *logTauXPlot=
new TSpline3(
"log(chi**2)%log(tau)",logT,x,n);
1634 *logTauYPlot=
new TSpline3(
"log(reg.cond)%log(tau)",logT,y,n);
1668 (
Int_t mode,
const char *distribution,
const char *axisSteering)
1671 TString
name(
"GetScanVariable(");
1673 if(distribution) name += distribution;
1675 if(axisSteering) name += axisSteering;
1678 if((mode==kEScanTauRhoAvg)||(mode==kEScanTauRhoMax)||
1679 (mode==kEScanTauRhoSquareAvg)) {
1680 rhoi=GetRhoIstatbgr(name,0,distribution,axisSteering,
kFALSE);
1681 }
else if((mode==kEScanTauRhoAvgSys)||(mode==kEScanTauRhoMaxSys)||
1682 (mode==kEScanTauRhoSquareAvgSys)) {
1683 rhoi=GetRhoItotal(name,0,distribution,axisSteering,
kFALSE);
1693 if(c>rhoMax) rhoMax=c;
1699 if((mode==kEScanTauRhoAvg)||(mode==kEScanTauRhoAvgSys)) {
1701 }
else if((mode==kEScanTauRhoSquareAvg)||
1702 (mode==kEScanTauRhoSquareAvgSys)) {
1710 Fatal(
"GetScanVariable",
"mode %d not implemented",mode);
virtual const char * GetName() const
Returns name of object.
virtual const Element * GetMatrixArray() const
TUnfoldBinning const * GetChildNode(void) const
first daughter node
double dist(Rotation3D const &r1, Rotation3D const &r2)
static long int sum(long int i)
TH1 * CreateHistogram(const char *histogramName, Bool_t originalAxisBinning=kFALSE, Int_t **binMap=0, const char *histogramTitle=0, const char *axisSteering=0) const
Create a THxx histogram capable to hold the bins of this binning node and its children.
An algorithm to unfold distributions from detector to truth level.
TH2D * CreateErrorMatrixHistogram(const char *histogramName, Bool_t originalAxisBinning, Int_t **binMap=0, const char *histogramTitle=0, const char *axisSteering=0) const
Create a TH2D histogram capable to hold a covariance matrix.
virtual const Int_t * GetRowIndexArray() const
void Fatal(const char *location, const char *msgfmt,...)
void GetEmatrixInput(TH2 *ematrix, const Int_t *binMap=0, Bool_t clearEmat=kTRUE)
Covariance matrix contribution from input measurement uncertainties.
virtual Double_t GetDistributionAverageBinSize(Int_t axis, Bool_t includeUnderflow, Bool_t includeOverflow) const
Get average bin size on the specified axis.
virtual Int_t ScanTau(Int_t nPoint, Double_t tauMin, Double_t tauMax, TSpline **scanResult, Int_t mode=kEScanTauRhoAvg, const char *distribution=0, const char *projectionMode=0, TGraph **lCurvePlot=0, TSpline **logTauXPlot=0, TSpline **logTauYPlot=0)
Scan a function wrt tau and determine the minimum.
Bool_t GetDeltaSysSource(TH1 *hist_delta, const char *source, const Int_t *binMap=0)
Correlated one-sigma shifts correspinding to a given systematic uncertainty.
TH1 * GetBias(const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE) const
Retrieve bias vector as a new histogram.
Base class for spline implementation containing the Draw/Paint methods.
virtual Double_t GetBinContent(Int_t bin) const
Return content of bin number bin.
An algorithm to unfold distributions from detector to truth level, with background subtraction and pr...
void GetBinUnderflowOverflowStatus(Int_t iBin, Int_t *uStatus, Int_t *oStatus) const
Return bit maps indicating underflow and overflow status.
TH2 * GetEmatrixSysUncorr(const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE)
Retrieve covariance contribution from uncorrelated (statistical) uncertainties of the response matrix...
TH1 * GetFoldedOutput(const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE, Bool_t addBgr=kFALSE) const
Retrieve unfolding result folded back as a new histogram.
void GetEmatrixSysBackgroundUncorr(TH2 *ematrix, const char *source, const Int_t *binMap=0, Bool_t clearEmat=kTRUE)
Covariance contribution from background uncorrelated uncertainty.
TUnfoldDensity(void)
Only for use by root streamer or derived classes.
EDensityMode
choice of regularisation scale factors to cinstruct the matrix L
TH2 * GetL(const char *histogramName, const char *histogramTitle=0, Bool_t useAxisBinning=kTRUE)
Access matrix of regularisation conditions in a new histogram.
void RegularizeDistribution(ERegMode regmode, EDensityMode densityMode, const char *distribution, const char *axisSteering)
Set up regularisation conditions.
LongDouble_t Power(LongDouble_t x, LongDouble_t y)
TUnfoldBinning const * GetNextNode(void) const
next sister node
Class to create third splines to interpolate knots Arbitrary conditions can be introduced for first a...
Double_t GetRhoI(TH1 *rhoi, const Int_t *binMap=0, TH2 *invEmat=0) const
Get global correlation coefficients, possibly cumulated over several bins.
TH2 * GetEmatrixSysBackgroundUncorr(const char *bgrSource, const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE)
Retrieve covariance contribution from uncorrelated background uncertainties.
virtual Int_t GetDimension() const
TH1 * GetLxMinusBias(const char *histogramName, const char *histogramTitle=0)
Get regularisation conditions multiplied by result vector minus bias L(x-biasScale*biasVector).
TH2 * GetEmatrixTotal(const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE)
Get covariance matrix including all contributions.
const TUnfoldBinning * GetOutputBinning(const char *distributionName=0) const
Locate a binning node for the unfolded (truth level) quantities.
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString...
void GetEmatrixSysUncorr(TH2 *ematrix, const Int_t *binMap=0, Bool_t clearEmat=kTRUE)
Covariance contribution from uncorrelated uncertainties of the response matrix.
TH1 * GetBackground(const char *histogramName, const char *bgrSource=0, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE, Int_t includeError=3) const
Retrieve a background source in a new histogram.
EHistMap
arrangement of axes for the response matrix (TH2 histogram)
EConstraint
type of extra constraint
Double_t Log10(Double_t x)
void RegularizeOneDistribution(const TUnfoldBinning *binning, ERegMode regmode, EDensityMode densityMode, const char *axisSteering)
Regularize the distribution of the given node.
void Info(const char *location, const char *msgfmt,...)
Int_t GetBinNeighbours(Int_t globalBin, Int_t axis, Int_t *prev, Double_t *distPrev, Int_t *next, Double_t *distNext, Bool_t isPeriodic=kFALSE) const
Get neighbour bins along the specified axis.
Int_t GetStartBin(void) const
first bin of this node
void Error(const char *location, const char *msgfmt,...)
ERegMode
choice of regularisation scheme
Int_t GetDistributionDimension(void) const
query dimension of this node's distribution
void GetBias(TH1 *bias, const Int_t *binMap=0) const
Get bias vector including bias scale.
void DecodeAxisSteering(const char *axisSteering, const char *options, Int_t *isOptionGiven) const
Decode axis steering.
virtual TString GetOutputBinName(Int_t iBinX) const
Get bin name of an output bin.
Service class for 2-Dim histogram classes.
Class to manage histogram axis.
TH2 * GetRhoIJtotal(const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE)
Retrieve correlation coefficients, including all uncertainties.
void GetEmatrixTotal(TH2 *ematrix, const Int_t *binMap=0)
Get total error matrix, summing up all contributions.
virtual void SetBinContent(Int_t bin, Double_t content)
Set bin content see convention for numbering bins in TH1::GetBin In case the bin number is greater th...
TH1 * GetInput(const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE) const
Retrieve input distribution in a new histogram.
const TUnfoldBinning * GetInputBinning(const char *distributionName=0) const
Locate a binning node for the input (measured) quantities.
Bool_t GetDeltaSysTau(TH1 *delta, const Int_t *binMap=0)
Correlated one-sigma shifts from shifting tau.
TH1 * GetDeltaSysTau(const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE)
Retrieve 1-sigma shift corresponding to the previously specified uncertainty on tau.
void Warning(const char *location, const char *msgfmt,...)
void GetBackground(TH1 *bgr, const char *bgrSource=0, const Int_t *binMap=0, Int_t includeError=3, Bool_t clearHist=kTRUE) const
Get background into a histogram.
static TH2D * CreateHistogramOfMigrations(TUnfoldBinning const *xAxis, TUnfoldBinning const *yAxis, char const *histogramName, Bool_t originalXAxisBinning=kFALSE, Bool_t originalYAxisBinning=kFALSE, char const *histogramTitle=0)
Create a TH2D histogram capable to hold the bins of the two input binning schemes on the x and y axes...
TH1 * GetRhoIstatbgr(const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE, TH2 **ematInv=0)
Retrieve global correlation coefficients including input (statistical) and background uncertainties...
Binning schemes for use with the unfolding algorithm TUnfoldDensity.
TH1 * GetDeltaSysSource(const char *source, const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE)
Retrieve a correlated systematic 1-sigma shift.
TString GetDistributionAxisLabel(Int_t axis) const
get name of an axis
virtual TString GetOutputBinName(Int_t iBinX) const
Get bin name of an output bin.
TH1 * GetOutput(const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE) const
retrieve unfolding result as a new histogram
void GetProbabilityMatrix(TH2 *A, EHistMap histmap) const
Get matrix of probabilities.
void GetFoldedOutput(TH1 *folded, const Int_t *binMap=0) const
Get unfolding result on detector level.
void GetInput(TH1 *inputData, const Int_t *binMap=0) const
Input vector of measurements.
Int_t GetDistributionNumberOfBins(void) const
number of bins in the distribution possibly including under/overflow
void GetCoeff(Int_t i, Double_t &x, Double_t &y, Double_t &b, Double_t &c, Double_t &d)
TH1 * GetDeltaSysBackgroundScale(const char *bgrSource, const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE)
Retrieve systematic 1-sigma shift corresponding to a background scale uncertainty.
double f2(const double *x)
void GetOutput(TH1 *output, const Int_t *binMap=0) const
Get output distribution, possibly cumulated over several bins.
A Graph is a graphics object made of two arrays X and Y with npoints each.
you should not use this method at all Int_t Int_t Double_t Double_t Double_t Int_t Double_t Double_t Double_t Double_t b
virtual Double_t GetBinContent(Int_t bin) const
Return content of bin number bin.
virtual Double_t GetScanVariable(Int_t mode, const char *distribution, const char *projectionMode)
Calculate the function for ScanTau().
Double_t GetDensityFactor(EDensityMode densityMode, Int_t iBin) const
Density correction factor for a given bin.
TH2 * GetEmatrixInput(const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE)
Get covariance contribution from the input uncertainties (data statistical uncertainties).
virtual void SetBinContent(Int_t bin, Double_t content)
Set bin content.
TH1 * GetRhoItotal(const char *histogramName, const char *histogramTitle=0, const char *distributionName=0, const char *projectionMode=0, Bool_t useAxisBinning=kTRUE, TH2 **ematInv=0)
Retrieve global correlation coefficients including all uncertainty sources.
void GetL(TH2 *l) const
Get matrix of regularisation conditions.
virtual Int_t GetNbinsX() const
Double_t Sqrt(Double_t x)
void GetRhoItotal(TH1 *rhoi, const Int_t *binMap=0, TH2 *invEmat=0)
Get global correlatiocn coefficients, summing up all contributions.
Double_t Eval(Double_t x) const
Eval this spline at x.
TUnfoldBinning * AddBinning(TUnfoldBinning *binning)
Add a TUnfoldBinning as the last child of this node.
TUnfoldBinning const * FindNode(char const *name) const
Traverse the tree and return the first node which matches the given name.
TH2 * GetProbabilityMatrix(const char *histogramName, const char *histogramTitle=0, Bool_t useAxisBinning=kTRUE) const
Get matrix of probabilities in a new histogram.
Bool_t GetDeltaSysBackgroundScale(TH1 *delta, const char *source, const Int_t *binMap=0)
Correlated one-sigma shifts from background normalisation uncertainty.
virtual Int_t GetNbinsY() const
void RegularizeDistributionRecursive(const TUnfoldBinning *binning, ERegMode regmode, EDensityMode densityMode, const char *distribution, const char *axisSteering)
Recursively add regularisation conditions for this node and its children.