42 #include "TDirectory.h"
71 TNamed(name,title), _constPars(0), _initPars(0), _finalPars(0), _globalCorr(0), _randomPars(0), _Lt(0),
72 _CM(0), _VM(0), _GC(0)
85 _status(other._status),
86 _covQual(other._covQual),
87 _numBadNLL(other._numBadNLL),
88 _minNLL(other._minNLL),
124 if (_VM)
delete _VM ;
125 if (_GC)
delete _GC ;
201 <<
" ERROR request for status history slot "
202 << icycle <<
" exceeds history count of " <<
_statusHistory.size() << endl ;
215 <<
" ERROR request for status history slot "
216 << icycle <<
" exceeds history count of " <<
_statusHistory.size() << endl ;
249 const char *options)
const
254 coutE(
InputArguments) <<
"RooFitResult::correlationPlot: parameter not floated in fit: " << parName1 << endl;
259 coutE(
InputArguments) <<
"RooFitResult::correlationPlot: parameter not floated in fit: " << parName2 << endl;
309 TGaxis *axis=
new TGaxis(x1-s1,x2-s2,x1+s1,x2-s2,-1.,+1.,502,
"-=");
322 TGaxis *axis=
new TGaxis(x1-s1,x2-s2,x1-s1,x2+s2,-1.,+1.,502,
"-=");
356 for(
Int_t iPar= 0; iPar < nPar; iPar++) {
359 for(
Int_t k= 0; k < iPar; k++) {
361 L(iPar,iPar)-= tmp*tmp;
363 L(iPar,iPar)=
sqrt(
L(iPar,iPar));
365 for(
Int_t jPar= iPar+1; jPar < nPar; jPar++) {
367 for(
Int_t k= 0; k < iPar; k++) {
368 L(iPar,jPar)-=
L(k,iPar)*
L(k,jPar);
370 L(iPar,jPar)/=
L(iPar,iPar);
404 Int_t idx1 = _finalPars->index(parname1) ;
405 Int_t idx2 = _finalPars->index(parname2) ;
407 coutE(
InputArguments) <<
"RooFitResult::correlation(" <<
GetName() <<
") parameter " << parname1 <<
" is not a floating fit parameter" << endl ;
411 coutE(
InputArguments) <<
"RooFitResult::correlation(" <<
GetName() <<
") parameter " << parname2 <<
" is not a floating fit parameter" << endl ;
425 if (_globalCorr==0) {
429 RooAbsArg* arg = _initPars->find(parname) ;
431 coutE(
InputArguments) <<
"RooFitResult::correlation: variable " << parname <<
" not a floating parameter in fit" << endl ;
444 if (_globalCorr==0) {
448 RooAbsArg* arg = _initPars->find(parname) ;
450 coutE(
InputArguments) <<
"RooFitResult::globalCorr: variable " << parname <<
" not a floating parameter in fit" << endl ;
455 return ((
RooAbsReal*)_globalCorr->at(_initPars->index(arg)))->getVal() ;
468 if (_globalCorr==0) {
482 return (*
_CM)(row,col) ;
491 return (*_VM)(row,col) ;
505 << indent <<
" RooFitResult: minimized FCN value: " << _minNLL <<
", estimated distance to minimum: " << _edm << endl
506 << indent <<
" covariance matrix quality: " ;
508 case -1 : os <<
"Unknown, matrix was externally provided" ; break ;
509 case 0 : os <<
"Not calculated at all" ; break ;
510 case 1 : os <<
"Approximation only, not accurate" ; break ;
511 case 2 : os <<
"Full matrix, but forced positive-definite" ; break ;
512 case 3 : os <<
"Full, accurate covariance matrix" ; break ;
515 os << indent <<
" Status : " ;
517 os <<
iter->first <<
"=" <<
iter->second <<
" " ;
519 os << endl << endl ;;
523 if (_constPars->getSize()>0) {
524 os << indent <<
" Constant Parameter Value " << endl
525 << indent <<
" -------------------- ------------" << endl ;
527 for (i=0 ; i<_constPars->getSize() ; i++) {
528 os << indent <<
" " << setw(20) << ((
RooAbsArg*)_constPars->at(i))->
GetName()
529 <<
" " << setw(12) <<
Form(
"%12.4e",((
RooRealVar*)_constPars->at(i))->getVal())
538 for (i=0 ; i<_finalPars->getSize() ; i++) {
539 if (((
RooRealVar*)_finalPars->at(i))->hasAsymError()) {
546 os << indent <<
" Floating Parameter InitialValue FinalValue (+HiError,-LoError) GblCorr." << endl
547 << indent <<
" -------------------- ------------ ---------------------------------- --------" << endl ;
549 os << indent <<
" Floating Parameter InitialValue FinalValue +/- Error GblCorr." << endl
550 << indent <<
" -------------------- ------------ -------------------------- --------" << endl ;
553 for (i=0 ; i<_finalPars->getSize() ; i++) {
554 os << indent <<
" " << setw(20) << ((
RooAbsArg*)_finalPars->at(i))->
GetName() ;
555 os << indent <<
" " << setw(12) <<
Form(
"%12.4e",((
RooRealVar*)_initPars->at(i))->getVal())
556 << indent <<
" " << setw(12) <<
Form(
"%12.4e",((
RooRealVar*)_finalPars->at(i))->getVal()) ;
558 if (((
RooRealVar*)_finalPars->at(i))->hasAsymError()) {
559 os << setw(21) <<
Form(
" (+%8.2e,-%8.2e)",((
RooRealVar*)_finalPars->at(i))->getAsymErrorHi(),
560 -1*((
RooRealVar*)_finalPars->at(i))->getAsymErrorLo()) ;
563 os << (doAsymErr?
" ":
"") <<
" +/- " << setw(9) <<
Form(
"%9.2e",err) ;
567 os <<
" " << setw(8) <<
Form(
"%8.6f" ,((
RooRealVar*)_globalCorr->at(i))->getVal()) ;
576 os << indent <<
" Floating Parameter FinalValue +/- Error " << endl
577 << indent <<
" -------------------- --------------------------" << endl ;
579 for (i=0 ; i<_finalPars->getSize() ; i++) {
581 os << indent <<
" " << setw(20) << ((
RooAbsArg*)_finalPars->at(i))->
GetName()
582 <<
" " << setw(12) <<
Form(
"%12.4e",((
RooRealVar*)_finalPars->at(i))->getVal())
583 <<
" +/- " << setw(9) <<
Form(
"%9.2e",err)
600 coutI(
Minimization) <<
"RooFitResult::fillCorrMatrix: number of floating parameters is zero, correlation matrix not filled" << endl ;
605 coutE(
Minimization) <<
"RooFitResult::fillCorrMatrix: ERROR: list of initial parameters must be filled first" << endl ;
611 if (_VM)
delete _VM ;
612 if (_GC)
delete _GC ;
619 (*_GC)[i] = globalCC[i] ;
640 _globalCorr =
new RooArgList(
"globalCorrelations") ;
642 TIterator* vIter = _initPars->createIterator() ;
651 gcTitle.
Append(
" Global Correlation") ;
652 _globalCorr->addOwned(*(
new RooRealVar(gcName.
Data(),gcTitle.Data(),0.))) ;
660 TIterator* vIter2 = _initPars->createIterator() ;
669 TString cTitle(
"Correlation between ") ;
680 TIterator *gcIter = _globalCorr->createIterator() ;
681 TIterator *parIter = _finalPars->createIterator() ;
683 for (
unsigned int i = 0; i < (
unsigned int)
_CM->
GetNcols() ; ++i) {
687 gcVal->
setVal((*_GC)(i)) ;
691 for (
unsigned int it = 0; it < (
unsigned int)
_CM->
GetNcols() ; ++it) {
693 double value = (*_CM)(i,it) ;
695 (*_CM)(i,it) = value;
718 coutI(
Minimization) <<
"RooFitResult::fillCorrMatrix: number of floating parameters is zero, correlation matrix not filled" << endl ;
723 coutE(
Minimization) <<
"RooFitResult::fillCorrMatrix: ERROR: list of initial parameters must be filled first" << endl ;
729 if (_VM)
delete _VM ;
730 if (_GC)
delete _GC ;
735 _GC =
new TVectorD(_initPars->getSize()) ;
748 ndex = m*(m-1) / 2 + n;
761 for (
int ii=0 ; ii<_finalPars->getSize() ; ii++) {
762 for (
int jj=0 ; jj<_finalPars->getSize() ; jj++) {
763 (*_VM)(ii,jj) = (*
_CM)(ii,jj) * ((
RooRealVar*)_finalPars->at(ii))->getError() * ((
RooRealVar*)_finalPars->at(jj))->getError() ;
779 cout <<
"RooFitResult::isIdentical: minimized value of -log(L) is different " << _minNLL <<
" vs. " << other.
_minNLL << endl ;
783 for (
Int_t i=0 ; i<_constPars->getSize() ; i++) {
786 cout <<
"RooFitResult::isIdentical: cannot find constant parameter " << _constPars->at(i)->
GetName() <<
" in reference" << endl ;
789 if (ov &&
fabs(static_cast<RooAbsReal*>(_constPars->at(i))->getVal()-ov->
getVal())>=tol) {
790 cout <<
"RooFitResult::isIdentical: constant parameter " << _constPars->at(i)->GetName()
791 <<
" differs in value: " <<
static_cast<RooAbsReal*
>(_constPars->at(i))->getVal() <<
" vs. " << ov->
getVal() << endl ;
796 for (
Int_t i=0 ; i<_initPars->getSize() ; i++) {
799 cout <<
"RooFitResult::isIdentical: cannot find initial parameter " << _initPars->at(i)->
GetName() <<
" in reference" << endl ;
802 if (ov &&
fabs(static_cast<RooAbsReal*>(_initPars->at(i))->getVal()-ov->
getVal())>=tol) {
803 cout <<
"RooFitResult::isIdentical: initial parameter " << _initPars->at(i)->GetName()
804 <<
" differs in value: " <<
static_cast<RooAbsReal*
>(_initPars->at(i))->getVal() <<
" vs. " << ov->
getVal() << endl ;
809 for (
Int_t i=0 ; i<_finalPars->getSize() ; i++) {
812 cout <<
"RooFitResult::isIdentical: cannot find final parameter " << _finalPars->at(i)->
GetName() <<
" in reference" << endl ;
815 if (ov &&
fabs(static_cast<RooAbsReal*>(_finalPars->at(i))->getVal()-ov->
getVal())>=tol) {
816 cout <<
"RooFitResult::isIdentical: final parameter " << _finalPars->at(i)->GetName()
817 <<
" differs in value: " <<
static_cast<RooAbsReal*
>(_finalPars->at(i))->getVal() <<
" vs. " << ov->
getVal() << endl ;
823 if (_finalPars->getSize()>1) {
828 for (
Int_t i=0 ; i<_globalCorr->getSize() ; i++) {
831 cout <<
"RooFitResult::isIdentical: cannot find global correlation coefficient " << _globalCorr->at(i)->
GetName() <<
" in reference" << endl ;
834 if (ov &&
fabs(static_cast<RooAbsReal*>(_globalCorr->at(i))->getVal()-ov->
getVal())>=tolCorr) {
835 cout <<
"RooFitResult::isIdentical: global correlation coefficient " << _globalCorr->at(i)->GetName()
836 <<
" differs in value: " <<
static_cast<RooAbsReal*
>(_globalCorr->at(i))->getVal() <<
" vs. " << ov->
getVal() << endl ;
847 cout <<
"RooFitResult::isIdentical: cannot find correlation coefficient " << row->
at(i)->
GetName() <<
" in reference" << endl ;
850 if (ov &&
fabs(static_cast<RooAbsReal*>(row->
at(i))->getVal()-ov->
getVal())>=tolCorr) {
851 cout <<
"RooFitResult::isIdentical: correlation coefficient " << row->
at(i)->
GetName()
852 <<
" differs in value: " <<
static_cast<RooAbsReal*
>(row->
at(i))->getVal() <<
" vs. " << ov->
getVal() << endl ;
873 <<
" or match the number of variables of the last fit (" <<
gMinuit->
fNu <<
")" << endl ;
881 if (!dynamic_cast<RooRealVar*>(arg)) {
910 if ((xlo<xhi) && !isConst) {
911 var =
new RooRealVar(varName,varName,xval,xlo,xhi) ;
925 oocoutI((
TObject*)0,
Eval) <<
"RooFitResult::lastMinuitFit: fit parameter '" << varName
926 <<
"' stored in variable '" << var->
GetName() <<
"'" << endl ;
939 Int_t icode,npari,nparx ;
998 TH2D* hh =
new TH2D(name,name,n,0,n,n,0,n) ;
1000 for (
Int_t i = 0 ; i<
n ; i++) {
1001 for (
Int_t j = 0 ; j<
n; j++) {
1002 hh->
Fill(i+0.5,n-j-0.5,(*
_CM)(i,j)) ;
1047 if (_finalPars->find(arg->
GetName())) {
1051 << arg->
GetName() <<
" was not a floating parameters in fit result and is ignored" << endl ;
1058 iter = _finalPars->createIterator() ;
1067 vector<int> map1, map2 ;
1068 for (
int i=0 ; i<_finalPars->getSize() ; i++) {
1069 if (params3.
find(_finalPars->at(i)->GetName())) {
1108 coutE(
Eval) <<
"RooFitResult::conditionalCovarianceMatrix(" <<
GetName() <<
") ERROR: covariance matrix is not positive definite (|V|="
1109 << det <<
") cannot reduce it" << endl ;
1110 throw string(
"RooFitResult::conditionalCovarianceMatrix() ERROR, input covariance matrix is not positive definite") ;
1118 if (_finalPars->find(arg->
GetName())) {
1122 << arg->
GetName() <<
" was not a floating parameters in fit result and is ignored" << endl ;
1129 iter = _finalPars->createIterator() ;
1138 vector<int> map1, map2 ;
1139 for (
int i=0 ; i<_finalPars->getSize() ; i++) {
1140 if (params3.
find(_finalPars->at(i)->GetName())) {
1158 TMatrixD S22bar = S11 - S12 * (S22Inv * S21) ;
1162 for (
int i=0 ; i<Vred.GetNcols() ; i++) {
1163 for (
int j=i ; j<Vred.GetNcols() ; j++) {
1164 Vred(i,j) = (S22bar(i,j) + S22bar(j,i))/2 ;
1165 Vred(j,i) = Vred(i,j) ;
1194 coutE(
Eval) <<
"RooFitResult::createHessePdf(" <<
GetName() <<
") ERROR: covariance matrix is not positive definite (|V|="
1195 << det <<
") cannot construct p.d.f" << endl ;
1204 if (_finalPars->find(arg->
GetName())) {
1208 << arg->
GetName() <<
" was not a floating parameters in fit result and is ignored" << endl ;
1215 iter = _finalPars->createIterator() ;
1225 if (params3.
getSize()==_finalPars->getSize()) {
1228 for (
Int_t i=0 ; i<_finalPars->getSize() ; i++) {
1247 vector<int> map1, map2 ;
1248 for (
int i=0 ; i<_finalPars->getSize() ; i++) {
1249 if (params3.
find(_finalPars->at(i)->GetName())) {
1264 for (
UInt_t i=0 ; i<map1.size() ; i++) {
1267 mu1.
add(*parclone) ;
1275 TMatrixD S22bar = S11 - S12 * (S22Inv * S21) ;
1279 for (
int i=0 ; i<Vred.GetNcols() ; i++) {
1280 for (
int j=i ; j<Vred.GetNcols() ; j++) {
1281 Vred(i,j) = (S22bar(i,j) + S22bar(j,i))/2 ;
1282 Vred(j,i) = Vred(i,j) ;
1350 os <<
"[constPars=" << *_constPars <<
",floatPars=" << *_finalPars <<
"]" ;
1360 os <<
"(status=" << _status <<
",FCNmin=" << _minNLL <<
",EDM=" << _edm <<
",covQual=" << _covQual <<
")" ;
1378 if (!opt || strlen(opt)==0) {
1388 void RooFitResult::Streamer(
TBuffer &R__b)
1399 TNamed::Streamer(R__b);
1400 RooPrintable::Streamer(R__b);
1401 RooDirItem::Streamer(R__b);
1420 TIterator *gcIter = _globalCorr->createIterator() ;
1421 TIterator *parIter = _finalPars->createIterator() ;
1423 for (
unsigned int i = 0; i < (
unsigned int)
_CM->
GetNcols() ; ++i) {
1427 (*_GC)(i) = gcVal->
getVal() ;
1431 for (
unsigned int it = 0; it < (
unsigned int)
_CM->
GetNcols() ; ++it) {
1433 double value = cVal->
getVal() ;
1434 (*_CM)(it,i) = value ;
1435 (*_CM)(i,it) = value;
1437 (*_VM)(i,it) = (*_VM)(it,i) ;
virtual void printArgs(std::ostream &os) const
Print arguments of fit result, i.e. the parameters of the fit.
virtual const char * GetTitle() const
Returns title of object.
virtual void SetLineWidth(Width_t lwidth)
virtual void mnstat(Double_t &fmin, Double_t &fedm, Double_t &errdef, Int_t &npari, Int_t &nparx, Int_t &istat)
*-*-*-*-*Returns concerning the current status of the minimization*-*-*-*-* *-* =====================...
Double_t covariance(Int_t row, Int_t col) const
Return the covariance matrix element addressed with numeric indices.
RooPlot * plotOn(RooPlot *frame, const RooAbsArg &par1, const RooAbsArg &par2, const char *options="ME") const
virtual Bool_t add(const RooAbsArg &var, Bool_t silent=kFALSE)
Add the specified argument to list.
virtual Int_t WriteClassBuffer(const TClass *cl, void *pointer)=0
virtual void Delete(Option_t *option="")
Remove all objects from the list AND delete all heap based objects.
RooAbsCollection * snapshot(Bool_t deepCopy=kTRUE) const
Take a snap shot of current collection contents: An owning collection is returned containing clones o...
virtual void SetMaximum(Double_t maximum=-1111)
const RooArgList & floatParsFinal() const
const RooArgList & constPars() const
static Double_t gaussian(TRandom *generator=randomGenerator())
Return a Gaussian random variable with mean 0 and variance 1.
static void blockDecompose(const TMatrixD &input, const std::vector< int > &map1, const std::vector< int > &map2, TMatrixDSym &S11, TMatrixD &S12, TMatrixD &S21, TMatrixDSym &S22)
Block decomposition of covI according to given maps of observables.
static void ioStreamerPass2Finalize()
Method called by workspace container to finalize schema evolution issues that cannot be handled in a ...
RooArgList L(const RooAbsArg &v1)
void addObject(TObject *obj, Option_t *drawOptions="", Bool_t invisible=kFALSE)
Add a generic object to this plot.
virtual Bool_t addOwned(RooAbsArg &var, Bool_t silent=kFALSE)
Add the specified argument to list.
virtual void SetName(const char *name)
Change (i.e.
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
virtual TList * GetList() const
virtual void printTitle(std::ostream &os) const
Print title of fit result.
void SetNameTitle(const char *name, const char *title)
Change name and title of RooFitResult object.
void addPlotable(RooPlotable *plotable, Option_t *drawOptions="", Bool_t invisible=kFALSE, Bool_t refreshNorm=kFALSE)
Add the specified plotable object to our plot.
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 ToUpper()
Change string to upper case.
Buffer base class used for serializing objects.
void setStatus(Int_t val)
Int_t GetNoElements() const
TMatrixDSym conditionalCovarianceMatrix(const RooArgList ¶ms) const
Return a reduced covariance matrix, which is calculated as ___ -1 Vred = V22 = V11 - V12 * V22 * V21...
virtual void SetMinimum(Double_t minimum=-1111)
virtual Int_t CheckByteCount(UInt_t startpos, UInt_t bcnt, const TClass *clss)=0
TH2 * correlationHist(const char *name="correlation_matrix") const
Return TH2D of correlation matrix.
Short_t Min(Short_t a, Short_t b)
virtual void SetFillStyle(Style_t fstyle)
Bool_t addOwnedComponents(const RooArgSet &comps)
Take ownership of the contents of 'comps'.
void box(Int_t pat, Double_t x1, Double_t y1, Double_t x2, Double_t y2)
void setInitParList(const RooArgList &list)
Fill the list of initial values of the floating parameters.
virtual StyleOption defaultPrintStyle(Option_t *opt) const
virtual void SetNameTitle(const char *name, const char *title)
Change (i.e. set) all the TNamed parameters (name and title).
virtual TObject * At(Int_t idx) const
Returns the object at position idx. Returns 0 if idx is out of range.
Iterator abstract base class.
void setEDM(Double_t val)
const char * Data() const
void appendToDir(TObject *obj, Bool_t forceMemoryResident=kFALSE)
Append object to directory.
virtual TObject * Clone(const char *newname="") const
Make a clone of an object using the Streamer facility.
static const double x2[5]
R__EXTERN TMinuit * gMinuit
virtual void printValue(std::ostream &os) const
Print the value of the fit result, i.e.g the status, minimized FCN, edm and covariance quality code...
virtual Double_t Determinant() const
The TNamed class is the base class for all named ROOT classes.
void deleteSharedProperties()
std::map< std::string, std::string >::const_iterator iter
TIterator * createIterator(Bool_t dir=kIterForward) const
virtual void SetMarkerColor(Color_t mcolor=1)
TString & Append(const char *cs)
Double_t getVal(const RooArgSet *set=0) const
const RooArgList & randomizePars() const
Return a list of floating parameter values that are perturbed from the final fit values by random amo...
Bool_t isIdentical(const RooFitResult &other, Double_t tol=5e-5, Double_t tolCorr=1e-4, Bool_t verbose=kTRUE) const
Return true if this fit result is identical to other within tolerance 'tol' on fitted values and tole...
void printMultiline(std::ostream &os, Int_t contents, Bool_t verbose=kFALSE, TString indent="") const
Print fit result to stream 'os'.
TVectorT< Double_t > TVectorD
Double_t correlation(const RooAbsArg &par1, const RooAbsArg &par2) const
void setMinNLL(Double_t val)
TList _corrMatrix
List of global correlation coefficients.
virtual void setVal(Double_t value)
Set value of variable to 'value'.
virtual void SetLineColor(Color_t lcolor)
TMatrixDSym * _CM
triangular matrix used for generate random perturbations
VecExpr< UnaryOp< Fabs< T >, VecExpr< A, T, D >, T >, T, D > fabs(const VecExpr< A, T, D > &rhs)
Int_t statusCodeHistory(UInt_t icycle) const
Service class for 2-Dim histogram classes.
TString * fCpnam
Character to be plotted at the X,Y contour positions.
RooAbsArg * find(const char *name) const
Find object with given name in list.
void setConstant(Bool_t value=kTRUE)
static RooFitResult * lastMinuitFit(const RooArgList &varList=RooArgList())
Import the results of the last fit performed by gMinuit, interpreting the fit parameters as the given...
virtual TObject * Remove(TObject *obj)
Remove object from the list.
char * Form(const char *fmt,...)
virtual ~RooFitResult()
Destructor.
void setFinalParList(const RooArgList &list)
Fill the list of final values of the floating parameters.
const TMatrixDSym & covarianceMatrix() const
Return covariance matrix.
virtual const char * GetName() const
Returns name of object.
RooFitResult(const char *name=0, const char *title=0)
Constructor with name and title coverity[UNINIT_CTOR].
static void indent(ostringstream &buf, int indent_level)
void removeFromDir(TObject *obj)
Remove object from directory it was added to.
TMatrixF * _Lt
List of floating parameters with most recent random perturbation applied.
void SetName(const char *name)
Change name of RooFitResult object.
virtual Int_t ReadClassBuffer(const TClass *cl, void *pointer, const TClass *onfile_class=0)=0
RooArgList * _randomPars
Correlation matrix (list of RooArgLists)
void setConstParList(const RooArgList &list)
Fill the list of constant parameters.
virtual Int_t GetSize() const
static const double x1[5]
RooAbsArg * at(Int_t idx) const
RooAbsReal is the common abstract base class for objects that represent a real value and implements f...
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...
virtual TObject * Clone(const char *newname=0) const
Make a clone of an object using the Streamer facility.
TMatrixTSym< Double_t > TMatrixDSym
virtual void printName(std::ostream &os) const
Print name of fit result.
const char * statusLabelHistory(UInt_t icycle) const
virtual StyleOption defaultPrintStyle(Option_t *opt) const
Configure mapping of Print() arguments to RooPrintable print styles.
virtual void SetBinLabel(Int_t bin, const char *label)
Set label for bin.
TMatrixT< Float_t > TMatrix
virtual void SetLineStyle(Style_t lstyle)
void setRange(const char *name, Double_t min, Double_t max)
Set range named 'name to [min,max].
Mother of all ROOT objects.
RooAbsPdf is the abstract interface for all probability density functions The class provides hybrid a...
virtual void Add(TObject *obj)
virtual void RemoveAll(TCollection *col)
Remove all objects in collection col from this collection.
Short_t Max(Short_t a, Short_t b)
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
virtual TObject * Next()=0
const RooArgList * globalCorr()
Return the list of all global correlations.
void setCovQual(Int_t val)
Double_t Sqrt(Double_t x)
RooAbsArg is the common abstract base class for objects that represent a value (of arbitrary type) an...
const TMatrixDSym & correlationMatrix() const
Return correlation matrix ;.
void fillCorrMatrix()
Internal utility method to extract the correlation matrix and the global correlation coefficients fro...
virtual void printClassName(std::ostream &os) const
Print class name of fit result.
Int_t Fill(Double_t)
Invalid Fill method.
virtual Int_t defaultPrintContents(Option_t *opt) const
Configure default contents to be printed.
void setCovarianceMatrix(TMatrixDSym &V)
Store externally provided correlation matrix in this RooFitResult ;.
int CompareTo(const char *cs, ECaseCompare cmp=kExact) const
Compare a string to char *cs2.
virtual Version_t ReadVersion(UInt_t *start=0, UInt_t *bcnt=0, const TClass *cl=0)=0
void fillLegacyCorrMatrix() const
Sanity check.
std::vector< std::pair< std::string, int > > _statusHistory
void setError(Double_t value)
2-D histogram with a double per channel (see TH1 documentation)}
Double_t getError() const