The following types of functions can be created:
TF1 *fa1 = new TF1("fa1","sin(x)/x",0,10); fa1->Draw();
TF1 *fa2 = new TF1("fa2","TMath::DiLog(x)",0,10); fa2->Draw();
Double_t myFunc(x) { return x+sin(x); } TF1 *fa3 = new TF1("fa3","myFunc(x)",-3,5); fa3->Draw();
fa->SetParameter(0,value_first_parameter); fa->SetParameter(1,value_second_parameter);Parameters may be given a name:
fa->SetParName(0,"Constant");
// Macro myfunc.C Double_t myfunction(Double_t *x, Double_t *par) { Float_t xx =x[0]; Double_t f = TMath::Abs(par[0]*sin(par[1]*xx)/xx); return f; } void myfunc() { TF1 *f1 = new TF1("myfunc",myfunction,0,10,2); f1->SetParameters(2,1); f1->SetParNames("constant","coefficient"); f1->Draw(); } void myfit() { TH1F *h1=new TH1F("h1","test",100,0,10); h1->FillRandom("myfunc",20000); TF1 *f1=gROOT->GetFunction("myfunc"); f1->SetParameters(800,1); h1->Fit("myfunc"); }
In an interactive session you can do:
Root > .L myfunc.C Root > myfunc(); Root > myfit();
TF1 objects can reference other TF1 objects (thanks John Odonnell) of type A or B defined above. This excludes CINT interpreted functions and compiled functions. However, there is a restriction. A function cannot reference a basic function if the basic function is a polynomial polN.
Example:
{ TF1 *fcos = new TF1 ("fcos", "[0]*cos(x)", 0., 10.); fcos->SetParNames( "cos"); fcos->SetParameter( 0, 1.1); TF1 *fsin = new TF1 ("fsin", "[0]*sin(x)", 0., 10.); fsin->SetParNames( "sin"); fsin->SetParameter( 0, 2.1); TF1 *fsincos = new TF1 ("fsc", "fcos+fsin"); TF1 *fs2 = new TF1 ("fs2", "fsc+fsc"); }
Example:
class MyFunctionObject { public: // use constructor to customize your function object double operator() (double *x, double *p) { // function implementation using class data members } }; { .... MyFunctionObject * fobj = new MyFunctionObject(....); // create the function object TF1 * f = new TF1("f",fobj,0,1,npar,"MyFunctionObject"); // create TF1 class. ..... }
Example:
class MyFunction { public: ... double Evaluate() (double *x, double *p) { // function implementation } }; { .... MyFunction * fptr = new MyFunction(....); // create the user function class TF1 * f = new TF1("f",fptr,&MyFunction::Evaluate,0,1,npar,"MyFunction","Evaluate"); // create TF1 class. ..... }
virtual | ~TF1() |
void | TObject::AbstractMethod(const char* method) const |
static void | AbsValue(Bool_t reject = kTRUE) |
virtual void | AddParameter(const TString& name, Double_t value) |
virtual Bool_t | AddToGlobalList(Bool_t on = kTRUE) |
virtual void | TObject::AppendPad(Option_t* option = "") |
virtual void | Browse(TBrowser* b) |
static void | CalcGaussLegendreSamplingPoints(Int_t num, Double_t* x, Double_t* w, Double_t eps = 3.0E-11) |
virtual Double_t | CentralMoment(Double_t n, Double_t a, Double_t b, const Double_t* params = 0, Double_t epsilon = 9.9999999999999995E-7) |
static TClass* | Class() |
virtual const char* | TObject::ClassName() const |
virtual void | TNamed::Clear(Option_t* option = "") |
virtual TObject* | TNamed::Clone(const char* newname = "") const |
virtual Int_t | TNamed::Compare(const TObject* obj) const |
virtual void | Copy(TObject& f1) const |
virtual TH1* | CreateHistogram() |
virtual void | TObject::Delete(Option_t* option = "")MENU |
virtual Double_t | Derivative(Double_t x, Double_t* params = 0, Double_t epsilon = 0.001) const |
virtual Double_t | Derivative2(Double_t x, Double_t* params = 0, Double_t epsilon = 0.001) const |
virtual Double_t | Derivative3(Double_t x, Double_t* params = 0, Double_t epsilon = 0.001) const |
static Double_t | DerivativeError() |
Int_t | TAttLine::DistancetoLine(Int_t px, Int_t py, Double_t xp1, Double_t yp1, Double_t xp2, Double_t yp2) |
virtual Int_t | DistancetoPrimitive(Int_t px, Int_t py) |
virtual void | Draw(Option_t* option = "") |
virtual void | TObject::DrawClass() constMENU |
virtual TObject* | TObject::DrawClone(Option_t* option = "") constMENU |
virtual TF1* | DrawCopy(Option_t* option = "") const |
virtual TObject* | DrawDerivative(Option_t* option = "al")MENU |
virtual void | DrawF1(Double_t xmin, Double_t xmax, Option_t* option = "") |
virtual TObject* | DrawIntegral(Option_t* option = "al")MENU |
virtual void | TObject::Dump() constMENU |
virtual void | TObject::Error(const char* method, const char* msgfmt) const |
virtual Double_t | Eval(Double_t x, Double_t y = 0, Double_t z = 0, Double_t t = 0) const |
virtual Double_t | EvalPar(const Double_t* x, const Double_t* params = 0) |
virtual void | TObject::Execute(const char* method, const char* params, Int_t* error = 0) |
virtual void | TObject::Execute(TMethod* method, TObjArray* params, Int_t* error = 0) |
virtual void | ExecuteEvent(Int_t event, Int_t px, Int_t py) |
virtual void | TObject::Fatal(const char* method, const char* msgfmt) const |
virtual void | TNamed::FillBuffer(char*& buffer) |
virtual TObject* | TObject::FindObject(const char* name) const |
virtual TObject* | TObject::FindObject(const TObject* obj) const |
virtual void | FixParameter(Int_t ipar, Double_t value) |
Double_t | GetChisquare() const |
static TF1* | GetCurrent() |
virtual Option_t* | TObject::GetDrawOption() const |
static Long_t | TObject::GetDtorOnly() |
virtual TString | GetExpFormula(Option_t* option = "") const |
virtual Color_t | TAttFill::GetFillColor() const |
virtual Style_t | TAttFill::GetFillStyle() const |
virtual TFormula* | GetFormula() |
virtual const TFormula* | GetFormula() const |
virtual TH1* | GetHistogram() const |
virtual const char* | TObject::GetIconName() const |
virtual const TObject* | GetLinearPart(Int_t i) const |
virtual Color_t | TAttLine::GetLineColor() const |
virtual Style_t | TAttLine::GetLineStyle() const |
virtual Width_t | TAttLine::GetLineWidth() const |
virtual Color_t | TAttMarker::GetMarkerColor() const |
virtual Size_t | TAttMarker::GetMarkerSize() const |
virtual Style_t | TAttMarker::GetMarkerStyle() const |
virtual Double_t | GetMaximum(Double_t xmin = 0, Double_t xmax = 0, Double_t epsilon = 1.0E-10, Int_t maxiter = 100, Bool_t logx = false) const |
virtual Double_t | GetMaximumStored() const |
virtual Double_t | GetMaximumX(Double_t xmin = 0, Double_t xmax = 0, Double_t epsilon = 1.0E-10, Int_t maxiter = 100, Bool_t logx = false) const |
TMethodCall* | GetMethodCall() const |
virtual Double_t | GetMinimum(Double_t xmin = 0, Double_t xmax = 0, Double_t epsilon = 1.0E-10, Int_t maxiter = 100, Bool_t logx = false) const |
virtual Double_t | GetMinimumStored() const |
virtual Double_t | GetMinimumX(Double_t xmin = 0, Double_t xmax = 0, Double_t epsilon = 1.0E-10, Int_t maxiter = 100, Bool_t logx = false) const |
virtual const char* | TNamed::GetName() const |
virtual Int_t | GetNDF() const |
virtual Int_t | GetNdim() const |
virtual Int_t | GetNpar() const |
virtual Int_t | GetNpx() const |
virtual Int_t | GetNumber() const |
virtual Int_t | GetNumberFitPoints() const |
virtual Int_t | GetNumberFreeParameters() const |
virtual char* | GetObjectInfo(Int_t px, Int_t py) const |
static Bool_t | TObject::GetObjectStat() |
virtual Option_t* | TObject::GetOption() const |
virtual Double_t | GetParameter(Int_t ipar) const |
virtual Double_t | GetParameter(const TString& name) const |
virtual Double_t* | GetParameters() const |
virtual void | GetParameters(Double_t* params) |
TObject* | GetParent() const |
virtual Double_t | GetParError(Int_t ipar) const |
virtual const Double_t* | GetParErrors() const |
virtual void | GetParLimits(Int_t ipar, Double_t& parmin, Double_t& parmax) const |
virtual const char* | GetParName(Int_t ipar) const |
virtual Int_t | GetParNumber(const char* name) const |
virtual Double_t | GetProb() const |
virtual Int_t | GetQuantiles(Int_t nprobSum, Double_t* q, const Double_t* probSum) |
virtual Double_t | GetRandom() |
virtual Double_t | GetRandom(Double_t xmin, Double_t xmax) |
virtual void | GetRange(Double_t& xmin, Double_t& xmax) const |
virtual void | GetRange(Double_t& xmin, Double_t& ymin, Double_t& xmax, Double_t& ymax) const |
virtual void | GetRange(Double_t& xmin, Double_t& ymin, Double_t& zmin, Double_t& xmax, Double_t& ymax, Double_t& zmax) const |
virtual Double_t | GetSave(const Double_t* x) |
virtual const char* | TNamed::GetTitle() const |
virtual UInt_t | TObject::GetUniqueID() const |
virtual Double_t | GetVariable(const TString& name) |
virtual Double_t | GetX(Double_t y, Double_t xmin = 0, Double_t xmax = 0, Double_t epsilon = 1.0E-10, Int_t maxiter = 100, Bool_t logx = false) const |
TAxis* | GetXaxis() const |
virtual Double_t | GetXmax() const |
virtual Double_t | GetXmin() const |
TAxis* | GetYaxis() const |
TAxis* | GetZaxis() const |
virtual Double_t | GradientPar(Int_t ipar, const Double_t* x, Double_t eps = 0.01) |
virtual void | GradientPar(const Double_t* x, Double_t* grad, Double_t eps = 0.01) |
virtual Bool_t | TObject::HandleTimer(TTimer* timer) |
virtual ULong_t | TNamed::Hash() const |
virtual void | TObject::Info(const char* method, const char* msgfmt) const |
virtual Bool_t | TObject::InheritsFrom(const char* classname) const |
virtual Bool_t | TObject::InheritsFrom(const TClass* cl) const |
virtual void | InitArgs(const Double_t* x, const Double_t* params) |
static void | InitStandardFunctions() |
virtual void | TObject::Inspect() constMENU |
virtual Double_t | Integral(Double_t a, Double_t b, Double_t epsrel = 9.9999999999999998E-13) |
virtual Double_t | IntegralError(Double_t a, Double_t b, const Double_t* params = 0, const Double_t* covmat = 0, Double_t epsilon = 0.01) |
virtual Double_t | IntegralError(Int_t n, const Double_t* a, const Double_t* b, const Double_t* params = 0, const Double_t* covmat = 0, Double_t epsilon = 0.01) |
virtual Double_t | IntegralFast(Int_t num, Double_t* x, Double_t* w, Double_t a, Double_t b, Double_t* params = 0, Double_t epsilon = 9.9999999999999998E-13) |
virtual Double_t | IntegralMultiple(Int_t n, const Double_t* a, const Double_t* b, Double_t epsrel, Double_t& relerr) |
virtual Double_t | IntegralMultiple(Int_t n, const Double_t* a, const Double_t* b, Int_t maxpts, Double_t epsrel, Double_t epsabs, Double_t& relerr, Int_t& nfnevl, Int_t& ifail) |
virtual Double_t | IntegralMultiple(Int_t n, const Double_t* a, const Double_t* b, Int_t, Int_t maxpts, Double_t epsrel, Double_t& relerr, Int_t& nfnevl, Int_t& ifail) |
virtual Double_t | IntegralOneDim(Double_t a, Double_t b, Double_t epsrel, Double_t epsabs, Double_t& err) |
void | TObject::InvertBit(UInt_t f) |
virtual TClass* | IsA() const |
virtual Bool_t | TObject::IsEqual(const TObject* obj) const |
virtual Bool_t | IsEvalNormalized() const |
virtual Bool_t | TObject::IsFolder() const |
virtual Bool_t | IsInside(const Double_t* x) const |
virtual Bool_t | IsLinear() const |
Bool_t | TObject::IsOnHeap() const |
virtual Bool_t | TNamed::IsSortable() const |
virtual Bool_t | TAttFill::IsTransparent() const |
virtual Bool_t | IsValid() const |
Bool_t | TObject::IsZombie() const |
virtual void | TNamed::ls(Option_t* option = "") const |
void | TObject::MayNotUse(const char* method) const |
virtual Double_t | Mean(Double_t a, Double_t b, const Double_t* params = 0, Double_t epsilon = 9.9999999999999995E-7) |
virtual void | TAttLine::Modify() |
virtual Double_t | Moment(Double_t n, Double_t a, Double_t b, const Double_t* params = 0, Double_t epsilon = 9.9999999999999995E-7) |
virtual Bool_t | TObject::Notify() |
void | TObject::Obsolete(const char* method, const char* asOfVers, const char* removedFromVers) const |
void | TObject::operator delete(void* ptr) |
void | TObject::operator delete(void* ptr, void* vp) |
void | TObject::operator delete[](void* ptr) |
void | TObject::operator delete[](void* ptr, void* vp) |
void* | TObject::operator new(size_t sz) |
void* | TObject::operator new(size_t sz, void* vp) |
void* | TObject::operator new[](size_t sz) |
void* | TObject::operator new[](size_t sz, void* vp) |
virtual Double_t | operator()(const Double_t* x, const Double_t* params = 0) |
virtual Double_t | operator()(Double_t x, Double_t y = 0, Double_t z = 0, Double_t t = 0) const |
TF1& | operator=(const TF1& rhs) |
virtual void | Paint(Option_t* option = "") |
virtual void | TObject::Pop() |
virtual void | Print(Option_t* option = "") const |
virtual Int_t | TObject::Read(const char* name) |
virtual void | TObject::RecursiveRemove(TObject* obj) |
static Bool_t | RejectedPoint() |
static void | RejectPoint(Bool_t reject = kTRUE) |
virtual void | ReleaseParameter(Int_t ipar) |
virtual void | TAttFill::ResetAttFill(Option_t* option = "") |
virtual void | TAttLine::ResetAttLine(Option_t* option = "") |
virtual void | TAttMarker::ResetAttMarker(Option_t* toption = "") |
void | TObject::ResetBit(UInt_t f) |
virtual void | Save(Double_t xmin, Double_t xmax, Double_t ymin, Double_t ymax, Double_t zmin, Double_t zmax) |
virtual void | TObject::SaveAs(const char* filename = "", Option_t* option = "") constMENU |
virtual void | TAttFill::SaveFillAttributes(ostream& out, const char* name, Int_t coldef = 1, Int_t stydef = 1001) |
virtual void | TAttLine::SaveLineAttributes(ostream& out, const char* name, Int_t coldef = 1, Int_t stydef = 1, Int_t widdef = 1) |
virtual void | TAttMarker::SaveMarkerAttributes(ostream& out, const char* name, Int_t coldef = 1, Int_t stydef = 1, Int_t sizdef = 1) |
virtual void | SavePrimitive(ostream& out, Option_t* option = "") |
void | TObject::SetBit(UInt_t f) |
void | TObject::SetBit(UInt_t f, Bool_t set) |
virtual void | SetChisquare(Double_t chi2) |
static void | SetCurrent(TF1* f1) |
virtual void | TObject::SetDrawOption(Option_t* option = "")MENU |
static void | TObject::SetDtorOnly(void* obj) |
virtual void | TAttFill::SetFillAttributes()MENU |
virtual void | TAttFill::SetFillColor(Color_t fcolor) |
virtual void | TAttFill::SetFillColorAlpha(Color_t fcolor, Float_t falpha) |
virtual void | TAttFill::SetFillStyle(Style_t fstyle) |
virtual void | SetFitResult(const ROOT::Fit::FitResult& result, const Int_t* indpar = 0) |
virtual void | TAttLine::SetLineAttributes()MENU |
virtual void | TAttLine::SetLineColor(Color_t lcolor) |
virtual void | TAttLine::SetLineColorAlpha(Color_t lcolor, Float_t lalpha) |
virtual void | TAttLine::SetLineStyle(Style_t lstyle) |
virtual void | TAttLine::SetLineWidth(Width_t lwidth) |
virtual void | TAttMarker::SetMarkerAttributes()MENU |
virtual void | TAttMarker::SetMarkerColor(Color_t mcolor = 1) |
virtual void | TAttMarker::SetMarkerColorAlpha(Color_t mcolor, Float_t malpha) |
virtual void | TAttMarker::SetMarkerSize(Size_t msize = 1) |
virtual void | TAttMarker::SetMarkerStyle(Style_t mstyle = 1) |
virtual void | SetMaximum(Double_t maximum = -1111)MENU |
virtual void | SetMinimum(Double_t minimum = -1111)MENU |
virtual void | TNamed::SetName(const char* name)MENU |
virtual void | TNamed::SetNameTitle(const char* name, const char* title) |
virtual void | SetNDF(Int_t ndf) |
virtual void | SetNormalized(Bool_t flag) |
virtual void | SetNpx(Int_t npx = 100)MENU |
virtual void | SetNumberFitPoints(Int_t npfits) |
static void | TObject::SetObjectStat(Bool_t stat) |
virtual void | SetParameter(Int_t param, Double_t value) |
virtual void | SetParameter(const TString& name, Double_t value) |
virtual void | SetParameters(const Double_t* params) |
virtual void | SetParameters(Double_t p0, Double_t p1, Double_t p2 = 0, Double_t p3 = 0, Double_t p4 = 0, Double_t p5 = 0, Double_t p6 = 0, Double_t p7 = 0, Double_t p8 = 0, Double_t p9 = 0, Double_t p10 = 0)MENU |
virtual void | SetParent(TObject* p = 0) |
virtual void | SetParError(Int_t ipar, Double_t error) |
virtual void | SetParErrors(const Double_t* errors) |
virtual void | SetParLimits(Int_t ipar, Double_t parmin, Double_t parmax) |
virtual void | SetParName(Int_t ipar, const char* name) |
virtual void | SetParNames(const char* name0 = "p0", const char* name1 = "p1", const char* name2 = "p2", const char* name3 = "p3", const char* name4 = "p4", const char* name5 = "p5", const char* name6 = "p6", const char* name7 = "p7", const char* name8 = "p8", const char* name9 = "p9", const char* name10 = "p10")MENU |
virtual void | SetRange(Double_t xmin, Double_t xmax)MENU |
virtual void | SetRange(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax) |
virtual void | SetRange(Double_t xmin, Double_t ymin, Double_t zmin, Double_t xmax, Double_t ymax, Double_t zmax) |
virtual void | SetSavedPoint(Int_t point, Double_t value) |
virtual void | SetTitle(const char* title = "")MENU |
virtual void | TObject::SetUniqueID(UInt_t uid) |
virtual void | ShowMembers(TMemberInspector& insp) const |
virtual Int_t | TNamed::Sizeof() const |
virtual void | Streamer(TBuffer&) |
void | StreamerNVirtual(TBuffer& ClassDef_StreamerNVirtual_b) |
virtual void | TObject::SysError(const char* method, const char* msgfmt) const |
Bool_t | TObject::TestBit(UInt_t f) const |
Int_t | TObject::TestBits(UInt_t f) const |
TF1() | |
TF1(const TF1& f1) | |
TF1(const char* name, const char* formula, Double_t xmin = 0, Double_t xmax = 1) | |
TF1(const char* name, Double_t xmin, Double_t xmax, Int_t npar, Int_t ndim = 1) | |
TF1(const char* name, Double_t(*)(Double_t*,Double_t*) fcn, Double_t xmin = 0, Double_t xmax = 1, Int_t npar = 0, Int_t ndim = 1) | |
TF1(const char* name, Double_t(*)(const Double_t*,const Double_t*) fcn, Double_t xmin = 0, Double_t xmax = 1, Int_t npar = 0, Int_t ndim = 1) | |
TF1(const char* name, ROOT::Math::ParamFunctor f, Double_t xmin = 0, Double_t xmax = 1, Int_t npar = 0, Int_t ndim = 1) | |
virtual void | Update() |
virtual void | TObject::UseCurrentStyle() |
virtual Double_t | Variance(Double_t a, Double_t b, const Double_t* params = 0, Double_t epsilon = 9.9999999999999995E-7) |
virtual void | TObject::Warning(const char* method, const char* msgfmt) const |
virtual Int_t | TObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0) |
virtual Int_t | TObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0) const |
virtual TH1* | DoCreateHistogram(Double_t xmin, Double_t xmax, Bool_t recreate = kFALSE) |
virtual void | TObject::DoError(int level, const char* location, const char* fmt, va_list va) const |
void | DoInitialize() |
virtual Double_t | GetMinMaxNDim(Double_t* x, Bool_t findmax, Double_t epsilon = 0, Int_t maxiter = 0) const |
virtual void | GetRange(Double_t* xmin, Double_t* xmax) const |
void | IntegrateForNormalization() |
void | TObject::MakeZombie() |
static TObject::(anonymous) | TObject::kBitMask | |
static TObject::EStatusBits | TObject::kCanDelete | |
static TObject::EStatusBits | TObject::kCannotPick | |
static TObject::EStatusBits | TObject::kHasUUID | |
static TObject::EStatusBits | TObject::kInvalidObject | |
static TObject::(anonymous) | TObject::kIsOnHeap | |
static TObject::EStatusBits | TObject::kIsReferenced | |
static TObject::EStatusBits | TObject::kMustCleanup | |
static TObject::EStatusBits | TObject::kNoContextMenu | |
static TObject::(anonymous) | TObject::kNotDeleted | |
static TF1::(anonymous) | kNotDraw | |
static TObject::EStatusBits | TObject::kObjInCanvas | |
static TObject::(anonymous) | TObject::kOverwrite | |
static TObject::(anonymous) | TObject::kSingleKey | |
static TObject::(anonymous) | TObject::kWriteDelete | |
static TObject::(anonymous) | TObject::kZombie |
vector<Double_t> | fAlpha | !Array alpha. for each bin in x the deconvolution r of fIntegral |
vector<Double_t> | fBeta | !Array beta. is approximated by x = alpha +beta*r *gamma*r**2 |
Double_t | fChisquare | Function fit chisquare |
Color_t | TAttFill::fFillColor | fill area color |
Style_t | TAttFill::fFillStyle | fill area style |
TFormula* | fFormula | Pointer to TFormula in case when user define formula |
ROOT::Math::ParamFunctor | fFunctor | ! Functor object to wrap any C++ callable object |
vector<Double_t> | fGamma | !Array gamma. |
TH1* | fHistogram | !Pointer to histogram used for visualisation |
vector<Double_t> | fIntegral | !Integral of function binned on fNpx bins |
Color_t | TAttLine::fLineColor | line color |
Style_t | TAttLine::fLineStyle | line style |
Width_t | TAttLine::fLineWidth | line width |
Color_t | TAttMarker::fMarkerColor | Marker color index |
Size_t | TAttMarker::fMarkerSize | Marker size |
Style_t | TAttMarker::fMarkerStyle | Marker style |
Double_t | fMaximum | Maximum value for plotting |
TMethodCall* | fMethodCall | !Pointer to MethodCall in case of interpreted function |
Double_t | fMinimum | Minimum value for plotting |
Int_t | fNDF | Number of degrees of freedom in the fit |
TString | TNamed::fName | object identifier |
Int_t | fNdim | Function dimension |
Double_t | fNormIntegral | Integral of the function before being normalized |
Bool_t | fNormalized | Normalization option (false by default) |
Int_t | fNpar | Number of parameters |
Int_t | fNpfits | Number of points used in the fit |
Int_t | fNpx | Number of points used for the graphical representation |
vector<Double_t> | fParErrors | Array of errors of the fNpar parameters |
vector<Double_t> | fParMax | Array of upper limits of the fNpar parameters |
vector<Double_t> | fParMin | Array of lower limits of the fNpar parameters |
TF1Parameters* | fParams | Pointer to Function parameters object (exusts only for not-formula functions) |
TObject* | fParent | !Parent object hooking this function (if one) |
vector<Double_t> | fSave | Array of fNsave function values |
TString | TNamed::fTitle | object title |
Int_t | fType | (=0 for standard functions, 1 if pointer to function) |
Double_t | fXmax | Upper bounds for the range |
Double_t | fXmin | Lower bounds for the range |
static Bool_t | fgAbsValue | use absolute value of function when computing integral |
static Bool_t | fgAddToGlobList | True if we want to register the function in the global list |
static TF1* | fgCurrent | pointer to current function being processed |
static Bool_t | fgRejectPoint | True if point must be rejected in a fit |
static TF1::(anonymous) | kNotGlobal |
F1 constructor using a formula definition See TFormula constructor for explanation of the formula syntax. See tutorials: fillrandom, first, fit1, formula1, multifit for real examples. Creates a function of type A or B between xmin and xmax if formula has the form "fffffff;xxxx;yyyy", it is assumed that the formula string is "fffffff" and "xxxx" and "yyyy" are the titles for the X and Y axis respectively.
F1 constructor using name of an interpreted function. Creates a function of type C between xmin and xmax. name is the name of an interpreted CINT cunction. The function is defined with npar parameters fcn must be a function of type: Double_t fcn(Double_t *x, Double_t *params) This constructor is called for functions of type C by CINT. WARNING! A function created with this constructor cannot be Cloned.
F1 constructor using a pointer to a real function. npar is the number of free parameters used by the function This constructor creates a function of type C when invoked with the normal C++ compiler. see test program test/stress.cxx (function stress1) for an example. note the interface with an intermediate pointer. WARNING! A function created with this constructor cannot be Cloned.
F1 constructor using a pointer to real function. npar is the number of free parameters used by the function This constructor creates a function of type C when invoked with the normal C++ compiler. see test program test/stress.cxx (function stress1) for an example. note the interface with an intermediate pointer. WARNING! A function created with this constructor cannot be Cloned.
F1 constructor using the Functor class. xmin and xmax define the plotting range of the function npar is the number of free parameters used by the function This constructor can be used only in compiled code WARNING! A function created with this constructor cannot be Cloned.
Add to global list of functions (gROOT->GetListOfFunctions() ) return previous status (true of functions was already in the list false if not)
Static function: set the fgAbsValue flag. By default TF1::Integral uses the original function value to compute the integral However, TF1::Moment, CentralMoment require to compute the integral using the absolute value of the function.
Copy this F1 to a new F1. Note that the cached integral with its related arrays are not copied (they are also set as transient data members)
Returns the first derivative of the function at point x, computed by Richardson's extrapolation method (use 2 derivative estimates to compute a third, more accurate estimation) first, derivatives with steps h and h/2 are computed by central difference formulas the final estimate "Numerical Methods for Scientists and Engineers", H.M.Antia, 2nd edition" if the argument params is null, the current function parameters are used, otherwise the parameters in params are used. the argument eps may be specified to control the step size (precision). the step size is taken as eps*(xmax-xmin). the default value (0.001) should be good enough for the vast majority of functions. Give a smaller value if your function has many changes of the second derivative in the function range. Getting the error via TF1::DerivativeError: (total error = roundoff error + interpolation error) the estimate of the roundoff error is taken as follows: where k is the double precision, ai are coefficients used in central difference formulas interpolation error is decreased by making the step size h smaller. Author: Anna Kreshuk
Returns the second derivative of the function at point x, computed by Richardson's extrapolation method (use 2 derivative estimates to compute a third, more accurate estimation) first, derivatives with steps h and h/2 are computed by central difference formulas the final estimate "Numerical Methods for Scientists and Engineers", H.M.Antia, 2nd edition" if the argument params is null, the current function parameters are used, otherwise the parameters in params are used. the argument eps may be specified to control the step size (precision). the step size is taken as eps*(xmax-xmin). the default value (0.001) should be good enough for the vast majority of functions. Give a smaller value if your function has many changes of the second derivative in the function range. Getting the error via TF1::DerivativeError: (total error = roundoff error + interpolation error) the estimate of the roundoff error is taken as follows: where k is the double precision, ai are coefficients used in central difference formulas interpolation error is decreased by making the step size h smaller. Author: Anna Kreshuk
Returns the third derivative of the function at point x, computed by Richardson's extrapolation method (use 2 derivative estimates to compute a third, more accurate estimation) first, derivatives with steps h and h/2 are computed by central difference formulas the final estimate "Numerical Methods for Scientists and Engineers", H.M.Antia, 2nd edition" if the argument params is null, the current function parameters are used, otherwise the parameters in params are used. the argument eps may be specified to control the step size (precision). the step size is taken as eps*(xmax-xmin). the default value (0.001) should be good enough for the vast majority of functions. Give a smaller value if your function has many changes of the second derivative in the function range. Getting the error via TF1::DerivativeError: (total error = roundoff error + interpolation error) the estimate of the roundoff error is taken as follows: where k is the double precision, ai are coefficients used in central difference formulas interpolation error is decreased by making the step size h smaller. Author: Anna Kreshuk
Static function returning the error of the last call to the of Derivative's functions
Compute distance from point px,py to a function. Compute the closest distance of approach from point px,py to this function. The distance is computed in pixels units. Note that px is called with a negative value when the TF1 is in TGraph or TH1 list of functions. In this case there is no point looking at the histogram axis.
Draw this function with its current attributes. Possible option values are: "SAME" superimpose on top of existing picture "L" connect all computed points with a straight line "C" connect all computed points with a smooth curve "FC" draw a fill area below a smooth curve Note that the default value is "L". Therefore to draw on top of an existing picture, specify option "LSAME" NB. You must use DrawCopy if you want to draw several times the same function in the current canvas.
Draw a copy of this function with its current attributes. This function MUST be used instead of Draw when you want to draw the same function with different parameters settings in the same canvas. Possible option values are: "SAME" superimpose on top of existing picture "L" connect all computed points with a straight line "C" connect all computed points with a smooth curve "FC" draw a fill area below a smooth curve Note that the default value is "L". Therefore to draw on top of an existing picture, specify option "LSAME"
Draw derivative of this function An intermediate TGraph object is built and drawn with option. The function returns a pointer to the TGraph object. Do: TGraph *g = (TGraph*)myfunc.DrawDerivative(option); The resulting graph will be drawn into the current pad. If this function is used via the context menu, it recommended to create a new canvas/pad before invoking this function.
Draw integral of this function An intermediate TGraph object is built and drawn with option. The function returns a pointer to the TGraph object. Do: TGraph *g = (TGraph*)myfunc.DrawIntegral(option); The resulting graph will be drawn into the current pad. If this function is used via the context menu, it recommended to create a new canvas/pad before invoking this function.
// Draw function between xmin and xmax.
Evaluate this function. Computes the value of this function (general case for a 3-d function) at point x,y,z. For a 1-d function give y=0 and z=0 The current value of variables x,y,z is passed through x, y and z. The parameters used will be the ones in the array params if params is given otherwise parameters will be taken from the stored data members fParams
Evaluate function with given coordinates and parameters. Compute the value of this function at point defined by array x and current values of parameters in array params. If argument params is omitted or equal 0, the internal values of parameters (array fParams) will be used instead. For a 1-D function only x[0] must be given. In case of a multi-dimemsional function, the arrays x must be filled with the corresponding number of dimensions. WARNING. In case of an interpreted function (fType=2), it is the user's responsability to initialize the parameters via InitArgs before calling this function. InitArgs should be called at least once to specify the addresses of the arguments x and params. InitArgs should be called everytime these addresses change.
Execute action corresponding to one event. This member function is called when a F1 is clicked with the locator
Fix the value of a parameter The specified value will be used in a fit operation
Return the maximum value of the function Method: First, the grid search is used to bracket the maximum with the step size = (xmax-xmin)/fNpx. This way, the step size can be controlled via the SetNpx() function. If the function is unimodal or if its extrema are far apart, setting the fNpx to a small value speeds the algorithm up many times. Then, Brent's method is applied on the bracketed interval epsilon (default = 1.E-10) controls the relative accuracy (if |x| > 1 ) and absolute (if |x| < 1) and maxiter (default = 100) controls the maximum number of iteration of the Brent algorithm If the flag logx is set the grid search is done in log step size This is done automatically if the log scale is set in the current Pad NOTE: see also TF1::GetMaximumX and TF1::GetX
Return the X value corresponding to the maximum value of the function Method: First, the grid search is used to bracket the maximum with the step size = (xmax-xmin)/fNpx. This way, the step size can be controlled via the SetNpx() function. If the function is unimodal or if its extrema are far apart, setting the fNpx to a small value speeds the algorithm up many times. Then, Brent's method is applied on the bracketed interval epsilon (default = 1.E-10) controls the relative accuracy (if |x| > 1 ) and absolute (if |x| < 1) and maxiter (default = 100) controls the maximum number of iteration of the Brent algorithm If the flag logx is set the grid search is done in log step size This is done automatically if the log scale is set in the current Pad NOTE: see also TF1::GetX
Returns the minimum value of the function on the (xmin, xmax) interval Method: First, the grid search is used to bracket the maximum with the step size = (xmax-xmin)/fNpx. This way, the step size can be controlled via the SetNpx() function. If the function is unimodal or if its extrema are far apart, setting the fNpx to a small value speeds the algorithm up many times. Then, Brent's method is applied on the bracketed interval epsilon (default = 1.E-10) controls the relative accuracy (if |x| > 1 ) and absolute (if |x| < 1) and maxiter (default = 100) controls the maximum number of iteration of the Brent algorithm If the flag logx is set the grid search is done in log step size This is done automatically if the log scale is set in the current Pad NOTE: see also TF1::GetMaximumX and TF1::GetX
find the minimum of a function of whatever dimension. While GetMinimum works only for 1D function , GetMinimumNDim works for all dimensions since it uses the minimizer interface vector x at beginning will contained the initial point, on exit will contain the result
Returns the X value corresponding to the minimum value of the function on the (xmin, xmax) interval Method: First, the grid search is used to bracket the maximum with the step size = (xmax-xmin)/fNpx. This way, the step size can be controlled via the SetNpx() function. If the function is unimodal or if its extrema are far apart, setting the fNpx to a small value speeds the algorithm up many times. Then, Brent's method is applied on the bracketed interval epsilon (default = 1.E-10) controls the relative accuracy (if |x| > 1 ) and absolute (if |x| < 1) and maxiter (default = 100) controls the maximum number of iteration of the Brent algorithm If the flag logx is set the grid search is done in log step size This is done automatically if the log scale is set in the current Pad NOTE: see also TF1::GetX
Returns the X value corresponding to the function value fy for (xmin<x<xmax). in other words it can find the roots of the function when fy=0 and successive calls by changing the next call to [xmin+eps,xmax] where xmin is the previous root. Method: First, the grid search is used to bracket the maximum with the step size = (xmax-xmin)/fNpx. This way, the step size can be controlled via the SetNpx() function. If the function is unimodal or if its extrema are far apart, setting the fNpx to a small value speeds the algorithm up many times. Then, Brent's method is applied on the bracketed interval epsilon (default = 1.E-10) controls the relative accuracy (if |x| > 1 ) and absolute (if |x| < 1) and maxiter (default = 100) controls the maximum number of iteration of the Brent algorithm If the flag logx is set the grid search is done in log step size This is done automatically if the log scale is set in the current Pad NOTE: see also TF1::GetMaximumX, TF1::GetMinimumX
Return the number of degrees of freedom in the fit the fNDF parameter has been previously computed during a fit. The number of degrees of freedom corresponds to the number of points used in the fit minus the number of free parameters.
Redefines TObject::GetObjectInfo. Displays the function info (x, function value) corresponding to cursor position px,py
Return limits for parameter ipar.
Compute Quantiles for density distribution of this function Quantile x_q of a probability distribution Function F is defined as For instance the median of a distribution is defined as that value of the random variable for which the distribution function equals 0.5: code from Eddy Offermann, Renaissance input parameters - this TF1 function - nprobSum maximum size of array q and size of array probSum - probSum array of positions where quantiles will be computed. It is assumed to contain at least nprobSum values. output - return value nq (<=nprobSum) with the number of quantiles computed - array q filled with nq quantiles Getting quantiles from two histograms and storing results in a TGraph, a so-called QQ-plot TGraph *gr = new TGraph(nprob); f1->GetQuantiles(nprob,gr->GetX()); f2->GetQuantiles(nprob,gr->GetY()); gr->Draw("alp");
Return a random number following this function shape The distribution contained in the function fname (TF1) is integrated over the channel contents. It is normalized to 1. For each bin the integral is approximated by a parabola. The parabola coefficients are stored as non persistent data members Getting one random number implies: - Generating a random number between 0 and 1 (say r1) - Look in which bin in the normalized integral r1 corresponds to - Evaluate the parabolic curve in the selected bin to find the corresponding X value. if the ratio fXmax/fXmin > fNpx the integral is tabulated in log scale in x The parabolic approximation is very good as soon as the number of bins is greater than 50.
Return a random number following this function shape in [xmin,xmax] The distribution contained in the function fname (TF1) is integrated over the channel contents. It is normalized to 1. For each bin the integral is approximated by a parabola. The parabola coefficients are stored as non persistent data members Getting one random number implies: - Generating a random number between 0 and 1 (say r1) - Look in which bin in the normalized integral r1 corresponds to - Evaluate the parabolic curve in the selected bin to find the corresponding X value. The parabolic approximation is very good as soon as the number of bins is greater than 50. IMPORTANT NOTE The integral of the function is computed at fNpx points. If the function has sharp peaks, you should increase the number of points (SetNpx) such that the peak is correctly tabulated at several points.
Return range of a 2-D function.
Return range of function.
Compute the gradient (derivative) wrt a parameter ipar Parameters: ipar - index of parameter for which the derivative is computed x - point, where the derivative is computed eps - if the errors of parameters have been computed, the step used in numerical differentiation is eps*parameter_error. if the errors have not been computed, step=eps is used default value of eps = 0.01 Method is the same as in Derivative() function If a paramter is fixed, the gradient on this parameter = 0
Compute the gradient wrt parameters Parameters: x - point, were the gradient is computed grad - used to return the computed gradient, assumed to be of at least fNpar size eps - if the errors of parameters have been computed, the step used in numerical differentiation is eps*parameter_error. if the errors have not been computed, step=eps is used default value of eps = 0.01 Method is the same as in Derivative() function If a paramter is fixed, the gradient on this parameter = 0
use IntegralOneDim or analytical integral
Return Integral of function between a and b using the given parameter values and relative and absolute tolerance. The defult integrator defined in ROOT::Math::IntegratorOneDimOptions::DefaultIntegrator() is used If ROOT contains the MathMore library the default integrator is set to be the adaptive ROOT::Math::GSLIntegrator (based on QUADPACK) or otherwise the ROOT::Math::GaussIntegrator is used See the reference documentation of these classes for more information about the integration algorithms To change integration algorithm just do : ROOT::Math::IntegratorOneDimOptions::SetDefaultIntegrator(IntegratorName); Valid integrator names are: - Gauss : for ROOT::Math::GaussIntegrator - GaussLegendre : for ROOT::Math::GaussLegendreIntegrator - Adaptive : for ROOT::Math::GSLIntegrator adaptive method (QAG) - AdaptiveSingular : for ROOT::Math::GSLIntegrator adaptive singular method (QAGS) - NonAdaptive : for ROOT::Math::GSLIntegrator non adaptive (QNG) In order to use the GSL integrators one needs to have the MathMore library installed Note 1: Values of the function f(x) at the interval end-points A and B are not required. The subprogram may therefore be used when these values are undefined. Note 2: Instead of TF1::Integral, you may want to use the combination of TF1::CalcGaussLegendreSamplingPoints and TF1::IntegralFast. See an example with the following script: void gint() { TF1 *g = new TF1("g","gaus",-5,5); g->SetParameters(1,0,1); //default gaus integration method uses 6 points //not suitable to integrate on a large domain double r1 = g->Integral(0,5); double r2 = g->Integral(0,1000); //try with user directives computing more points Int_t np = 1000; double *x=new double[np]; double *w=new double[np]; g->CalcGaussLegendreSamplingPoints(np,x,w,1e-15); double r3 = g->IntegralFast(np,x,w,0,5); double r4 = g->IntegralFast(np,x,w,0,1000); double r5 = g->IntegralFast(np,x,w,0,10000); double r6 = g->IntegralFast(np,x,w,0,100000); printf("g->Integral(0,5) = %g\n",r1); printf("g->Integral(0,1000) = %g\n",r2); printf("g->IntegralFast(n,x,w,0,5) = %g\n",r3); printf("g->IntegralFast(n,x,w,0,1000) = %g\n",r4); printf("g->IntegralFast(n,x,w,0,10000) = %g\n",r5); printf("g->IntegralFast(n,x,w,0,100000)= %g\n",r6); delete [] x; delete [] w; } This example produces the following results: g->Integral(0,5) = 1.25331 g->Integral(0,1000) = 1.25319 g->IntegralFast(n,x,w,0,5) = 1.25331 g->IntegralFast(n,x,w,0,1000) = 1.25331 g->IntegralFast(n,x,w,0,10000) = 1.25331 g->IntegralFast(n,x,w,0,100000)= 1.253
Return Error on Integral of a parameteric function between a and b due to the parameter uncertainties. A pointer to a vector of parameter values and to the elements of the covariance matrix (covmat) can be optionally passed. By default (i.e. when a zero pointer is passed) the current stored parameter values are used to estimate the integral error together with the covariance matrix from the last fit (retrieved from the global fitter instance) IMPORTANT NOTE1: When no covariance matrix is passed and in the meantime a fit is done using another function, the routine will signal an error and it will return zero only when the number of fit parameter is different than the values stored in TF1 (TF1::GetNpar() ). In the case that npar is the same, an incorrect result is returned. IMPORTANT NOTE2: The user must pass a pointer to the elements of the full covariance matrix dimensioned with the right size (npar*npar), where npar is the total number of parameters (TF1::GetNpar()), including also the fixed parameters. When there are fixed parameters, the pointer returned from TVirtualFitter::GetCovarianceMatrix() cannot be used. One should use the TFitResult class, as shown in the example below. To get the matrix and values from an old fit do for example: TFitResultPtr r = histo->Fit(func, "S"); ..... after performing other fits on the same function do func->IntegralError(x1,x2,r->GetParams(), r->GetCovarianceMatrix()->GetMatrixArray() );
Return Error on Integral of a parameteric function with dimension larger tan one between a[] and b[] due to the parameters uncertainties. For a TF1 with dimension larger than 1 (for example a TF2 or TF3) TF1::IntegralMultiple is used for the integral calculation A pointer to a vector of parameter values and to the elements of the covariance matrix (covmat) can be optionally passed. By default (i.e. when a zero pointer is passed) the current stored parameter values are used to estimate the integral error together with the covariance matrix from the last fit (retrieved from the global fitter instance). IMPORTANT NOTE1: When no covariance matrix is passed and in the meantime a fit is done using another function, the routine will signal an error and it will return zero only when the number of fit parameter is different than the values stored in TF1 (TF1::GetNpar() ). In the case that npar is the same, an incorrect result is returned. IMPORTANT NOTE2: The user must pass a pointer to the elements of the full covariance matrix dimensioned with the right size (npar*npar), where npar is the total number of parameters (TF1::GetNpar()), including also the fixed parameters. When there are fixed parameters, the pointer returned from TVirtualFitter::GetCovarianceMatrix() cannot be used. One should use the TFitResult class, as shown in the example below. To get the matrix and values from an old fit do for example: TFitResultPtr r = histo->Fit(func, "S"); ..... after performing other fits on the same function do func->IntegralError(x1,x2,r->GetParams(), r->GetCovarianceMatrix()->GetMatrixArray() );
Gauss-Legendre integral, see CalcGaussLegendreSamplingPoints
See more general prototype below. This interface kept for back compatibility It is reccomended to use the other interface where one can specify also epsabs and the maximum number of points
This function computes, to an attempted specified accuracy, the value of the integral Input parameters: n : Number of dimensions [2,15] a,b : One-dimensional arrays of length >= N . On entry A[i], and B[i], contain the lower and upper limits of integration, respectively. maxpts: Maximum number of function evaluations to be allowed. maxpts >= 2^n +2*n*(n+1) +1 if maxpts<minpts, maxpts is set to 10*minpts epsrel : Specified relative accuracy. epsabs : Specified absolute accuracy. The integration algorithm will attempt to reach either the relative or the absolute accuracy. In case the maximum funcion called is reached the algorithm will stop earlier without having reached the desired accuracy Output parameters: relerr : Contains, on exit, an estimation of the relative accuracy of the result. nfnevl : number of function evaluations performed. ifail : 0 Normal exit. . At least minpts and at most maxpts calls to the function were performed. 1 maxpts is too small for the specified accuracy eps. The result and relerr contain the values obtainable for the specified value of maxpts. 3 n<2 or n>15 Method: The defult method used is the Genz-Mallik adaptive multidimensional algorithm using the class ROOT::Math::AdaptiveIntegratorMultiDim (see the reference documentation of the class) Other methods can be used by setting ROOT::Math::IntegratorMultiDimOptions::SetDefaultIntegrator() to different integrators. Other possible integrators are MC integrators based on the ROOT::Math::GSLMCIntegrator class Possible methods are : Vegas, Miser or Plain IN case of MC integration the accuracy is determined by the number of function calls, one should be careful not to use a too large value of maxpts
Paint this function with its current attributes. The function is going to be converted in an histogram and the corresponding histogram is painted. The painted histogram can be retrieved calling afterwards the method TF1::GetHistogram()
create histogram with bin content equal to function value computed at the bin center This histogram will be used to paint the function A re-creation is forced and a new histogram is done if recreate=true
Release parameter number ipar If used in a fit, the parameter can vary freely. The parameter limits are reset to 0,0.
Save primitive as a C++ statement(s) on output stream out
Static function setting the current function. the current function may be accessed in static C-like functions when fitting or painting a function.
Set the result from the fit parameter values, errors, chi2, etc... Optionally a pointer to a vector (with size fNpar) of the parameter indices in the FitResult can be passed This is useful in the case of a combined fit with different functions, and the FitResult contains the global result By default it is assume that indpar = {0,1,2,....,fNpar-1}.
Set the maximum value along Y for this function In case the function is already drawn, set also the maximum in the helper histogram
Set the minimum value along Y for this function In case the function is already drawn, set also the minimum in the helper histogram
Set the number of degrees of freedom ndf should be the number of points used in a fit - the number of free parameters
Set the number of points used to draw the function The default number of points along x is 100 for 1-d functions and 30 for 2-d/3-d functions You can increase this value to get a better resolution when drawing pictures with sharp peaks or to get a better result when using TF1::GetRandom the minimum number of points is 4, the maximum is 10000000 for 1-d and 10000 for 2-d/3-d functions
Set up to 10 parameter names*-*-*-*-*- *-* ============================
Set errors for all active parameters when calling this function, the array errors must have at least fNpar values
Set limits for parameter ipar. The specified limits will be used in a fit operation when the option "B" is specified (Bounds). To fix a parameter, use TF1::FixParameter
Initialize the upper and lower bounds to draw the function.
The function range is also used in an histogram fit operation
when the option "R" is specified.
Set function title if title has the form "fffffff;xxxx;yyyy", it is assumed that the function title is "fffffff" and "xxxx" and "yyyy" are the titles for the X and Y axis respectively.
Called by functions such as SetRange, SetNpx, SetParameters to force the deletion of the associated histogram or Integral
Static function to set the global flag to reject points the fgRejectPoint global flag is tested by all fit functions if TRUE the point is not included in the fit. This flag can be set by a user in a fitting function. The fgRejectPoint flag is reset by the TH1 and TGraph fitting functions.
Type safe interface (static method) The number of sampling points are taken from the TGraph
{ return Eval(x,y,z,t); }
virtual void AddParameters(const pair<TString,Double_t> *pairs, Int_t size) { fFormula->AddParameters(pairs,size); } virtual void AddVariable(const TString &name, Double_t value = 0) { if (fFormula) fFormula->AddVariable(name,value); } virtual void AddVariables(const TString *vars, Int_t size) { if (fFormula) fFormula->AddVariables(vars,size); }
{ if (fFormula) fFormula->AddParameter(name,value); }
{ return (fFormula) ? fFormula->GetExpFormula(option) : ""; }
{ return (fFormula) ? fFormula->GetLinearPart(i) : nullptr;}
for backward compatibility
return kTRUE if the point is inside the function range
{ return fNormalized; }
{return Moment(1,a,b,params,epsilon);}
{return CentralMoment(2,a,b,params,epsilon);}