KaliVeda
Toolkit for HIC analysis
|
Fit of E-DE functional.
Created by KVClassFactory on Mon Apr 21 09:26:24 2008 Author: franklan
This class interfaces the Fortran package written by Laurent Tassan-Got to fit KVIDGrid objects using his functionals (see Nucl.Instrum.Meth. B194 (2002) 503-512). The following is the documentation from Laurent's code.
Automatic fit * globede : user-friendly routine in which only the data have to be supplied. The routine estimates good initial values, reasonnable limits, automatically from the data and manages the whole fit procedure call globede(npts,zd,ad,xd,yd,ixt,ih,par,istate,irc) INPUT : npts : [I] number of data points really used in zd, ad, xd, yd zd : [R] array of Z's (npts values) ad : [R] array of A's (npts values) xd : [R] array of E's (npts values) yd : [R] array of DE's (npts values) ixt : [I] =0->basic functional <>0->extended functional For the basic formula : yy = ((g*E)**(mu+1)+lambda**(mu+1)*Z**2*A**mu)**(1/(mu+1))-g*E + pdy For the extended formula : yy = ((g*E)**(mu+nu+1)+(lambda*Z**alpha*A**beta)**(mu+nu+1)+ xi*Z**2*A**mu*(g*E)**nu)**(1/(mu+nu+1))-g*E + pdy If ih=0 no non-linear light response : E=xx-pdx If ih<>0 non-linear light response included : E = sqrt(h**2+2*rho*h*(1+log(1+h/rho))) rho=eta*Z**2*A and h=xx-pdx ih : [I] =0->no non-linear light response <>0->non-linear light response included OUTPUT : par : [R] array of parameters resulting from the fit, according to the ixt, ih combination the numbers and orders of parameters are : ixt=0 ih=0 5 parameters: lambda, mu, g, pdx, pdy ixt=0 ih<>0 6 parameters: lambda, mu, g, pdx, pdy, eta ixt<>0 ih=0 9 parameters: lambda, alpha, beta, mu, nu, xi, g, pdx, pdy ixt<>0 ih<>0 10 parameters: lambda, alpha, beta, mu, nu, xi, g, pdx, pdy, eta istate : [I] array of status of parameters =0 -> free parameter =1 -> parameter constrained by the lower limit =2 -> parameter constrained by the upper limit =3 -> constant parameter (bl(i)=bu(i)=par(i)) irc : [I] return code of the fit : 0 -> convergence reached 1 -> convergence reached, but not well marked minimum 2 -> too many iterations, convergence not reached -1 -> no identification line with at least 2 points -2 -> too few data points -3 -> addressing problem between Fortran and C
Definition at line 81 of file KVTGIDFitter.h.
#include <KVTGIDFitter.h>
Public Member Functions | |
KVTGIDFitter () | |
Default constructor. | |
virtual | ~KVTGIDFitter () |
Destructor. | |
virtual void | Fit (KVIDGraph *) |
void | FitPanel (Int_t functional_type=1, Bool_t with_csi_light_energy=kTRUE, Int_t first_Z=-1, Int_t last_Z=-1, Double_t xmin=0.0, Double_t xmax=0.0) |
Int_t | GetFitStatus () const |
const Char_t * | GetFitStatusString () const |
String with meaning of fit status codes (see GetFitStatus) | |
Int_t | GetFunctionalType () const |
Int_t | GetLight () const |
Float_t * | GetParameters () const |
Int_t * | GetStatusOfParameters () const |
KVTGID * | GetTGID () const |
void | SetFunctionalType (Int_t t) |
void | SetLight (Int_t ih) |
Public Member Functions inherited from KVVirtualIDFitter | |
KVVirtualIDFitter () | |
Default constructor. | |
virtual | ~KVVirtualIDFitter () |
Destructor. | |
KVIDGraph * | GetGrid () const |
TVirtualPad * | GetPad () const |
void | SetGrid (KVIDGraph *g) |
void | SetPad (TVirtualPad *p) |
Public Member Functions inherited from KVBase | |
KVBase () | |
Default constructor. | |
KVBase (const Char_t *name, const Char_t *title="") | |
Ctor for object with given name and type. | |
KVBase (const KVBase &) | |
copy ctor | |
virtual | ~KVBase () |
virtual void | Clear (Option_t *opt="") |
Clear object properties : name, type/title, number, label. | |
virtual void | Copy (TObject &) const |
Make a copy of this object. | |
const Char_t * | GetLabel () const |
UInt_t | GetNumber () const |
UInt_t | GetNumberOfObjects () const |
virtual TObject * | GetObject () const |
virtual const Char_t * | GetType () const |
Bool_t | HasLabel () const |
virtual Bool_t | IsCalled (const Char_t *name) const |
Bool_t | IsLabelled (const Char_t *l) const |
virtual Bool_t | IsType (const Char_t *typ) const |
virtual void | List () |
KVBase & | operator= (const KVBase &) |
copy assignment operator | |
virtual void | Print (Option_t *option="") const |
Double_t | ProtectedGetX (const TF1 *func, Double_t val, int &status, Double_t xmin=0.0, Double_t xmax=0.0) const |
void | SetLabel (const Char_t *lab) |
virtual void | SetNumber (UInt_t num) |
virtual void | SetType (const Char_t *str) |
Public Member Functions inherited from TNamed | |
TNamed () | |
TNamed (const char *name, const char *title) | |
TNamed (const TNamed &named) | |
TNamed (const TString &name, const TString &title) | |
virtual | ~TNamed () |
void | Clear (Option_t *option="") override |
TObject * | Clone (const char *newname="") const override |
Int_t | Compare (const TObject *obj) const override |
void | Copy (TObject &named) const override |
virtual void | FillBuffer (char *&buffer) |
const char * | GetName () const override |
const char * | GetTitle () const override |
ULong_t | Hash () const override |
TClass * | IsA () const override |
Bool_t | IsSortable () const override |
void | ls (Option_t *option="") const override |
TNamed & | operator= (const TNamed &rhs) |
void | Print (Option_t *option="") const override |
virtual void | SetName (const char *name) |
virtual void | SetNameTitle (const char *name, const char *title) |
virtual void | SetTitle (const char *title="") |
virtual Int_t | Sizeof () const |
void | Streamer (TBuffer &) override |
void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) |
Public Member Functions inherited from TObject | |
TObject () | |
TObject (const TObject &object) | |
virtual | ~TObject () |
void | AbstractMethod (const char *method) const |
virtual void | AppendPad (Option_t *option="") |
virtual void | Browse (TBrowser *b) |
ULong_t | CheckedHash () |
virtual const char * | ClassName () const |
virtual void | Delete (Option_t *option="") |
virtual Int_t | DistancetoPrimitive (Int_t px, Int_t py) |
virtual void | Draw (Option_t *option="") |
virtual void | DrawClass () const |
virtual TObject * | DrawClone (Option_t *option="") const |
virtual void | Dump () const |
virtual void | Error (const char *method, const char *msgfmt,...) const |
virtual void | Execute (const char *method, const char *params, Int_t *error=nullptr) |
virtual void | Execute (TMethod *method, TObjArray *params, Int_t *error=nullptr) |
virtual void | ExecuteEvent (Int_t event, Int_t px, Int_t py) |
virtual void | Fatal (const char *method, const char *msgfmt,...) const |
virtual TObject * | FindObject (const char *name) const |
virtual TObject * | FindObject (const TObject *obj) const |
virtual Option_t * | GetDrawOption () const |
virtual const char * | GetIconName () const |
virtual char * | GetObjectInfo (Int_t px, Int_t py) const |
virtual Option_t * | GetOption () const |
virtual UInt_t | GetUniqueID () const |
virtual Bool_t | HandleTimer (TTimer *timer) |
Bool_t | HasInconsistentHash () const |
virtual void | Info (const char *method, const char *msgfmt,...) const |
virtual Bool_t | InheritsFrom (const char *classname) const |
virtual Bool_t | InheritsFrom (const TClass *cl) const |
virtual void | Inspect () const |
void | InvertBit (UInt_t f) |
Bool_t | IsDestructed () const |
virtual Bool_t | IsEqual (const TObject *obj) const |
virtual Bool_t | IsFolder () const |
R__ALWAYS_INLINE Bool_t | IsOnHeap () const |
R__ALWAYS_INLINE Bool_t | IsZombie () const |
void | MayNotUse (const char *method) const |
virtual Bool_t | Notify () |
void | Obsolete (const char *method, const char *asOfVers, const char *removedFromVers) const |
void | operator delete (void *ptr) |
void | operator delete (void *ptr, void *vp) |
void | operator delete[] (void *ptr) |
void | operator delete[] (void *ptr, void *vp) |
void * | operator new (size_t sz) |
void * | operator new (size_t sz, void *vp) |
void * | operator new[] (size_t sz) |
void * | operator new[] (size_t sz, void *vp) |
TObject & | operator= (const TObject &rhs) |
virtual void | Paint (Option_t *option="") |
virtual void | Pop () |
virtual Int_t | Read (const char *name) |
virtual void | RecursiveRemove (TObject *obj) |
void | ResetBit (UInt_t f) |
virtual void | SaveAs (const char *filename="", Option_t *option="") const |
virtual void | SavePrimitive (std::ostream &out, Option_t *option="") |
void | SetBit (UInt_t f) |
void | SetBit (UInt_t f, Bool_t set) |
virtual void | SetDrawOption (Option_t *option="") |
virtual void | SetUniqueID (UInt_t uid) |
void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) |
virtual void | SysError (const char *method, const char *msgfmt,...) const |
R__ALWAYS_INLINE Bool_t | TestBit (UInt_t f) const |
Int_t | TestBits (UInt_t f) const |
virtual void | UseCurrentStyle () |
virtual void | Warning (const char *method, const char *msgfmt,...) const |
virtual Int_t | Write (const char *name=nullptr, Int_t option=0, Int_t bufsize=0) |
virtual Int_t | Write (const char *name=nullptr, Int_t option=0, Int_t bufsize=0) const |
Private Member Functions | |
void | MakeTGID () |
Make a KVTGID out of fit result, if fit converged (irc<2) | |
Private Attributes | |
Float_t * | ad |
array of A's | |
Int_t | fLight |
handles CsI total light-energy conversion | |
Float_t * | fPar |
array of fit parameters | |
KVTGID * | fTGID |
KVTGID object representing fit result. | |
Int_t | fType |
type of functional | |
Double_t | fXmax |
limit for fit | |
Double_t | fXmin |
limit for fit | |
Int_t | fZorA |
is grid for Z&A or only Z identification ? | |
Int_t | irc |
status code | |
Int_t * | istate |
status of parameters | |
Float_t * | xd |
array of X coordinates | |
Float_t * | yd |
array of Y coordinates | |
Float_t * | zd |
array of Z's | |
Additional Inherited Members | |
Public Types inherited from KVBase | |
enum | EKaliVedaBits { kIsKaliVedaObject = BIT(23) } |
Public Types inherited from TObject | |
enum | EDeprecatedStatusBits |
enum | EStatusBits |
Static Public Member Functions inherited from KVVirtualIDFitter | |
static KVVirtualIDFitter * | GetDefaultFitter () |
Static Public Member Functions inherited from KVBase | |
static Bool_t | AreEqual (Double_t x, Double_t y, Long64_t maxdif=1) |
Comparison between two 64-bit floating-point values. | |
static void | BackupFileWithDate (const Char_t *path) |
static void | CombineFiles (const Char_t *file1, const Char_t *file2, const Char_t *newfilename, Bool_t keep=kTRUE) |
static void | Deprecated (const char *method, const char *advice) |
static Bool_t | FindClassSourceFiles (const Char_t *class_name, KVString &imp_file, KVString &dec_file, const Char_t *dir_name=".") |
static Bool_t | FindExecutable (TString &exec, const Char_t *path="$(PATH)") |
static const Char_t * | FindFile (const Char_t *search, TString &wfil) |
static const Char_t * | GetBINDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetDATABASEFilePath () |
static const Char_t * | GetDATADIRFilePath (const Char_t *namefile="") |
static Bool_t | GetDataSetEnv (const Char_t *dataset, const Char_t *type, Bool_t defval) |
static const Char_t * | GetDataSetEnv (const Char_t *dataset, const Char_t *type, const Char_t *defval) |
static Double_t | GetDataSetEnv (const Char_t *dataset, const Char_t *type, Double_t defval) |
static const Char_t * | GetETCDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetExampleFilePath (const Char_t *library, const Char_t *namefile) |
Return full path to example file for given library (="KVMultiDet", "BackTrack", etc.) | |
static const Char_t * | GetINCDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetKVBuildDate () |
Returns KaliVeda build date. | |
static const Char_t * | GetKVBuildDir () |
Returns top-level directory used for build. | |
static const Char_t * | GetKVBuildTime () |
Returns KaliVeda build time. | |
static const Char_t * | GetKVBuildType () |
Returns KaliVeda build type (cmake build: Release, Debug, RelWithDebInfo, ...) | |
static const Char_t * | GetKVBuildUser () |
Returns username of person who performed build. | |
static const Char_t * | GetKVSourceDir () |
Returns top-level directory of source tree used for build. | |
static const Char_t * | GetKVVersion () |
Returns KaliVeda version string. | |
static const Char_t * | GetLIBDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetListOfPlugins (const Char_t *base) |
static const Char_t * | GetListOfPluginURIs (const Char_t *base) |
static const Char_t * | GetPluginURI (const Char_t *base, const Char_t *plugin) |
static void | GetTempFileName (TString &base) |
static const Char_t * | GetTEMPLATEDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetWORKDIRFilePath (const Char_t *namefile="") |
static const Char_t * | gitBranch () |
Returns git branch of sources. | |
static const Char_t * | gitCommit () |
Returns last git commit of sources. | |
static void | InitEnvironment () |
static bool | is_gnuinstall () |
static Bool_t | IsThisAPlugin (const TString &uri, TString &base) |
static TPluginHandler * | LoadPlugin (const Char_t *base, const Char_t *uri="0") |
static Bool_t | OpenContextMenu (const char *method, TObject *obj, const char *alt_method_name="") |
static void | OpenTempFile (TString &base, std::ofstream &fp) |
static void | PrintSplashScreen () |
Prints welcome message and infos on version etc. | |
static Bool_t | SearchAndOpenKVFile (const Char_t *name, KVSQLite::database &dbfile, const Char_t *kvsubdir="") |
static Bool_t | SearchAndOpenKVFile (const Char_t *name, std::ifstream &file, const Char_t *kvsubdir="", KVLockfile *locks=0) |
static Bool_t | SearchAndOpenKVFile (const Char_t *name, std::ofstream &file, const Char_t *kvsubdir="", KVLockfile *locks=0) |
static Bool_t | SearchKVFile (const Char_t *name, TString &fullpath, const Char_t *kvsubdir="") |
static const Char_t * | WorkingDirectory () |
Static Public Member Functions inherited from TNamed | |
static TClass * | Class () |
static const char * | Class_Name () |
static constexpr Version_t | Class_Version () |
static const char * | DeclFileName () |
Static Public Member Functions inherited from TObject | |
static TClass * | Class () |
static const char * | Class_Name () |
static constexpr Version_t | Class_Version () |
static const char * | DeclFileName () |
static Longptr_t | GetDtorOnly () |
static Bool_t | GetObjectStat () |
static void | SetDtorOnly (void *obj) |
static void | SetObjectStat (Bool_t stat) |
Public Attributes inherited from TObject | |
kBitMask | |
kCanDelete | |
kCannotPick | |
kHasUUID | |
kInconsistent | |
kInvalidObject | |
kIsOnHeap | |
kIsReferenced | |
kMustCleanup | |
kNoContextMenu | |
kNotDeleted | |
kObjInCanvas | |
kOverwrite | |
kSingleKey | |
kWriteDelete | |
kZombie | |
Protected Member Functions inherited from TObject | |
virtual void | DoError (int level, const char *location, const char *fmt, va_list va) const |
void | MakeZombie () |
Protected Attributes inherited from TNamed | |
TString | fName |
TString | fTitle |
Protected Attributes inherited from TObject | |
kOnlyPrepStep | |
KVTGIDFitter::KVTGIDFitter | ( | ) |
Default constructor.
Definition at line 25 of file KVTGIDFitter.cpp.
|
virtual |
Destructor.
Definition at line 43 of file KVTGIDFitter.cpp.
Fit the grid using the functional chosen with SetType and SetLight. Status of fit after this call can be retrieved with GetFitStatus(). must inherit from KVIDZAGrid!
Implements KVVirtualIDFitter.
Definition at line 63 of file KVTGIDFitter.cpp.
void KVTGIDFitter::FitPanel | ( | Int_t | functional_type = 1 , |
Bool_t | with_csi_light_energy = kTRUE , |
||
Int_t | first_Z = -1 , |
||
Int_t | last_Z = -1 , |
||
Double_t | xmin = 0.0 , |
||
Double_t | xmax = 0.0 |
||
) |
GUI method used to fit grid previously set with SetGrid(KVIDGraph*). functional_type = 0 (standard) or 1 (extended functional) with_csi_light_energy = kTRUE (with) or kFALSE (without CsI light-energy relation for 'X') first_Z, last_Z: set minimum & maximum Z for which fit is valid in KVTGID object resulting from fit. (default: -1, take first and last Z of grid) xmin, xmax: only fit points with abscissa between limits [xmin,xmax] (default: use all points regardless of abscissa)
Definition at line 250 of file KVTGIDFitter.cpp.
Int_t KVTGIDFitter::GetFitStatus | ( | ) | const |
Return status code of last fit. 0 -> convergence reached 1 -> convergence reached, but not well marked minimum 2 -> too many iterations, convergence not reached -1 -> no identification line with at least 2 points -2 -> too few data points -3 -> addressing problem between Fortran and C
Definition at line 159 of file KVTGIDFitter.cpp.
const Char_t * KVTGIDFitter::GetFitStatusString | ( | ) | const |
String with meaning of fit status codes (see GetFitStatus)
Definition at line 176 of file KVTGIDFitter.cpp.
|
inline |
Definition at line 119 of file KVTGIDFitter.h.
|
inline |
Definition at line 133 of file KVTGIDFitter.h.
|
inline |
Definition at line 140 of file KVTGIDFitter.h.
Int_t * KVTGIDFitter::GetStatusOfParameters | ( | ) | const |
Returns array containing status of each parameter: =0 -> free parameter =1 -> parameter constrained by the lower limit =2 -> parameter constrained by the upper limit =3 -> constant parameter (bl(i)=bu(i)=par(i))
Definition at line 202 of file KVTGIDFitter.cpp.
|
inline |
Definition at line 146 of file KVTGIDFitter.h.
|
private |
Make a KVTGID out of fit result, if fit converged (irc<2)
Definition at line 219 of file KVTGIDFitter.cpp.
Set type of functional to use: t=0->basic functional t<>0->extended functional
Definition at line 108 of file KVTGIDFitter.h.
Set whether to calculate non-linear light response or not (if X-coordinate is CsI total light response).
Definition at line 123 of file KVTGIDFitter.h.
|
private |
array of A's
Definition at line 88 of file KVTGIDFitter.h.
|
private |
handles CsI total light-energy conversion
Definition at line 84 of file KVTGIDFitter.h.
|
private |
array of fit parameters
Definition at line 86 of file KVTGIDFitter.h.
|
private |
KVTGID object representing fit result.
Definition at line 93 of file KVTGIDFitter.h.
|
private |
type of functional
Definition at line 83 of file KVTGIDFitter.h.
|
private |
limit for fit
Definition at line 95 of file KVTGIDFitter.h.
|
private |
limit for fit
Definition at line 94 of file KVTGIDFitter.h.
|
private |
is grid for Z&A or only Z identification ?
Definition at line 85 of file KVTGIDFitter.h.
|
private |
status code
Definition at line 91 of file KVTGIDFitter.h.
|
private |
status of parameters
Definition at line 92 of file KVTGIDFitter.h.
|
private |
array of X coordinates
Definition at line 89 of file KVTGIDFitter.h.
|
private |
array of Y coordinates
Definition at line 90 of file KVTGIDFitter.h.
|
private |
array of Z's
Definition at line 87 of file KVTGIDFitter.h.