![]() |
KaliVeda
Toolkit for HIC analysis
|
#include <KVIDGraph.h>
Public Member Functions | |
KVIDGraph () | |
KVIDGraph (const KVIDGraph &) | |
Copy constructor. More... | |
virtual | ~KVIDGraph () |
virtual Bool_t | AcceptIDForTest (const KVIdentificationResult &idr) |
void | Add (TString, KVIDentifier *) |
KVIDentifier * | Add (TString, TString) |
virtual void | AddCut (KVIDentifier *cut) |
virtual void | AddIdentifier (KVIDentifier *id) |
void | AddIDTelescope (KVBase *t) |
void | AddIDTelescopes (const TList *) |
Associate this graph with all ID telescopes in list. More... | |
virtual void | AddInfo (KVIDentifier *info) |
void | AddParameter (char *Name, char *Value) |
virtual Int_t | CheckVersion (Int_t version) |
virtual void | Clear (Option_t *opt="") |
void | ClearListOfTelescopes () |
void | ClearPad (TVirtualPad *) |
virtual void | Copy (TObject &) const |
Copy this to 'obj'. More... | |
virtual void | Delete (Option_t *option="") |
void | Draw (Option_t *opt="") |
virtual void | DrawAndAdd (const Char_t *type="ID", const Char_t *classname="KVIDentifier") |
virtual void | DrawClass () const |
virtual TObject * | DrawClone (Option_t *option="") const |
virtual void | DrawPanel () |
virtual void | Dump () const |
virtual Bool_t | ExistVersion (Int_t version) |
void | ExtendBeginningAllIdentLines (Double_t, Option_t *="") |
void | ExtendEndAllIdentLines (Double_t, Option_t *="") |
void | FindAxisLimits () |
Calculate X/Y min/max of all objects in graph. More... | |
virtual TFitResultPtr | Fit (const char *formula, Option_t *option="", Option_t *goption="", Axis_t xmin=0, Axis_t xmax=0) |
virtual TFitResultPtr | Fit (TF1 *f1, Option_t *option="", Option_t *goption="", Axis_t xmin=0, Axis_t xmax=0) |
virtual void | FitPanel () |
virtual void SetTitle(const char *title="") {TGraph::SetTitle(title);}; More... | |
KVIDentifier * | GetCut (const Char_t *name) const |
KVList * | GetCuts () |
const KVList * | GetCuts () const |
KVIDentifier * | GetIdentifier (const Char_t *name) const |
KVIDentifier * | GetIdentifier (Int_t Z, Int_t A) const |
KVIDentifier * | GetIdentifierAt (Int_t index) const |
KVList * | GetIdentifiers () |
const KVList * | GetIdentifiers () const |
const Char_t * | GetIDTelescopeLabel () const |
const TList * | GetIDTelescopes () const |
KVIDentifier * | GetInfo (const Char_t *name) const |
KVList * | GetInfos () |
const KVList * | GetInfos () const |
KVIDGraph * | GetLastSavedVersion () const |
Int_t | GetMassFormula () const |
const Char_t * | GetName () const |
const Char_t * | GetNamesOfIDTelescopes () const |
Int_t | GetNumberOfCuts () const |
Int_t | GetNumberOfIdentifiers () const |
Int_t | GetNumberOfInfos () const |
TVirtualPad * | GetPad () const |
KVNameValueList * | GetParameters () |
const KVNameValueList * | GetParameters () const |
TString | GetPattern (void) |
virtual Int_t | GetQualityCode () const |
const Char_t * | GetRunList () const |
const KVNumberList & | GetRuns () const |
Axis_t | GetXmax () const |
Axis_t | GetXmin () const |
Double_t | GetXScaleFactor () |
Axis_t | GetYmax () const |
Axis_t | GetYmin () const |
Double_t | GetYScaleFactor () |
Bool_t | HandlesIDTelescope (KVBase *t) const |
virtual Bool_t | HasMassIDCapability () const |
virtual void | Identify (Double_t, Double_t, KVIdentificationResult *) const =0 |
void | Increment (Float_t x) |
virtual void | Initialize ()=0 |
virtual Int_t | InsertPoint () |
virtual void | Inspect () const |
TVirtualPad * | IsDrawn () const |
virtual Bool_t | IsIdentifiable (Double_t, Double_t, TString *rejected_by=nullptr) const |
Bool_t | IsSorted () const |
void | Modified () |
void | Print (Option_t *opt="") const |
Print out all objects in graph. More... | |
void | ReadAsciiFile (const Char_t *filename) |
virtual void | ReadAsciiFile_WP (Int_t version=-1) |
lecture des grilles avec version suivant un modele de fichier More... | |
virtual void | ReadFromAsciiFile (std::ifstream &gridfile) |
void | RemoveCut (KVIDentifier *) |
Remove and destroy cut. More... | |
void | RemoveIdentifier (KVIDentifier *) |
Remove and destroy identifier. More... | |
void | RemoveIDTelescope (KVBase *t) |
void | RemoveInfo (KVIDentifier *) |
Remove and destroy cut. More... | |
virtual Int_t | RemovePoint () |
virtual Int_t | RemovePoint (Int_t i) |
void | ResetDraw () |
void | ResetPad () |
void | RevertToLastSavedVersion () |
virtual void | SaveAs (const char *filename="", Option_t *option="") const |
void | Scale (TF1 *sx, TF1 *sy) |
virtual void | SetDrawOption (Option_t *option="") |
virtual void | SetEditable (Bool_t editable=kTRUE) |
virtual void | SetFillAttributes () |
virtual void | SetInfos (Double_t, Double_t, KVIdentificationResult *) const |
loop over KVIDGraph::fInfoZones to set flags in KVIdentificationResult More... | |
virtual void | SetLineAttributes () |
void | SetLineColor (Color_t lcolor) |
void | SetLineStyle (Style_t lstyle) |
void | SetLineWidth (Width_t lwidth) |
virtual void | SetMarkerAttributes () |
void | SetMassFormula (Int_t) |
virtual void | SetMassIDCapability (Bool_t yes=kTRUE) |
virtual void | SetMaximum (Double_t maximum=-1111) |
virtual void | SetMinimum (Double_t minimum=-1111) |
virtual void | SetName (const char *name) |
virtual void | SetOnlyZId (Bool_t yes=kTRUE) |
void | SetPattern (TString pattern) |
void | SetRunList (const char *runlist) |
void | SetRuns (const KVNumberList &nl) |
Set list of runs for which grid is valid. More... | |
virtual void | SetVarX (const char *v) |
virtual void | SetVarY (const char *v) |
void | SetXScaleFactor (Double_t=0) |
void | SetXVariable (const char *v) |
void SetIDTelescopes();// MENU={Hierarchy="Set.../ID Telescopes"} More... | |
void | SetYScaleFactor (Double_t=0) |
void | SetYVariable (const char *v) |
void | SortIdentifiers () |
virtual void | TestIdentification (TH2F *data, KVHashList &histos, KVNameValueList &histo_names) |
void | UnDraw () |
void | UpdateLastSavedVersion () |
update last saved version. mkae copy of current state of graph. More... | |
void | WriteAsciiFile (const Char_t *filename) |
Open, write and close ascii file containing this grid. More... | |
virtual void | WriteAsciiFile_WP (Int_t version=-1) |
virtual void | WriteToAsciiFile (std::ofstream &gridfile) |
Static Public Member Functions | |
static KVIDGraph * | AddGraphs (KVIDGraph *g1, Int_t id1_min, Int_t id1_max, KVIDGraph *g2, Int_t id2_min, Int_t id2_max) |
static Bool_t | GetAutoAdd () |
static KVIDGraph * | MakeIDGraph (const Char_t *) |
static void | SetAutoAdd (Bool_t yes=kTRUE) |
Private Member Functions | |
virtual void | BackwardsCompatibilityFix () |
void | init () |
Bool_t | IsOnlyZId () const |
virtual KVIDentifier * | New (const Char_t *) |
Create new object of class "id_class" which derives from KVIDentifier. More... | |
virtual void | ReadIdentifierFromAsciiFile (TString &name, TString &type, TString &cl, std::ifstream &gridfile) |
Read in new identifier object from file. More... | |
void | Scale (Double_t sx=-1, Double_t sy=-1) |
Called by SetX/YScaleFactor methods to rescale every point of every object in the grid. More... | |
void | WriteParameterListOfIDTelescopes () |
Private Attributes | |
KVList | fCuts |
cuts used to define area in which identification is possible More... | |
TString | fDyName |
dynamically generated name More... | |
KVList | fIdentifiers |
list of identification objects More... | |
KVList | fInfoZones |
contours/lines used to add info to particles (ex: punch-through) More... | |
KVIDGraph * | fLastSavedVersion |
copy of last save version of grid, used for 'undo' More... | |
Double_t | fLastScaleX |
last applied scaling factor on X More... | |
Double_t | fLastScaleY |
last applied scaling factor on Y More... | |
Int_t | fMassFormula |
OPTION={GetMethod="GetMassFormula";SetMethod="SetMassFormula";Items=(0="Beta-stability", 1="VEDA mass", 2="EAL mass", 3="EAL residues", 99="2Z+1")} More... | |
Bool_t | fOnlyZId |
set to kTRUE when only to be used to give Z identification of nuclei, no mass info More... | |
TVirtualPad * | fPad |
pad in which graph is drawn More... | |
KVNameValueList | fPar |
parameters associated to grid More... | |
TString | fPattern |
pattern of filenames used to write or read grid More... | |
KVNumberList | fRunList |
runs for which grid is valid More... | |
TList | fTelescopes |
ID telescopes for which grid is valid. More... | |
Axis_t | fXmax |
min/max X coordinates of graph More... | |
Axis_t | fXmin |
Axis_t | fYmax |
min/max Y coordinates of graph More... | |
Axis_t | fYmin |
Static Private Attributes | |
static Bool_t | fAutoAddGridManager = kTRUE |
if =kTRUE, grids are automatically added to ID grid manager on creation (default) More... | |
Friends | |
class | KVIDGridManager |
KVIDGraph::KVIDGraph | ( | ) |
Definition at line 158 of file KVIDGraph.cpp.
KVIDGraph::KVIDGraph | ( | const KVIDGraph & | grid | ) |
Copy constructor.
Definition at line 175 of file KVIDGraph.cpp.
|
virtual |
Destructor remove from grid manager
Definition at line 188 of file KVIDGraph.cpp.
|
inlinevirtual |
Used by TestIdentification method
The result of the identification may be excluded from the histograms of PID and PID vs. Eres, depending on e.g. some status code of the identification algorithm. By default, this returns the value of idr.IDOK, but may be overridden in child classes.
Definition at line 75 of file KVIDGraph.h.
void KVIDGraph::Add | ( | TString | type, |
KVIDentifier * | id | ||
) |
Add the object to the list of cuts or identifiers: type = "ID" --> calls AddIdentifier(id) type = "OK" or "cut" --> calls AddCut(id)
Definition at line 838 of file KVIDGraph.cpp.
KVIDentifier * KVIDGraph::Add | ( | TString | type, |
TString | classname | ||
) |
Create and add the object to the list of cuts or identifiers: type = "ID" --> calls AddIdentifier(id) type = "OK" or "cut" --> calls AddCut(id)
Definition at line 858 of file KVIDGraph.cpp.
|
inlinevirtual |
Add cut to the graph. It will be deleted by the graph.
Definition at line 353 of file KVIDGraph.h.
|
static |
Static method taking lines id1_min to id2_min from grid g1 and lines id2_min to id2_max from grid g2 and making a new grid containing them. Returns the pointer to the new grid.
It is assumed that g1 and g2 are grids of the same class. The new grid will be an object of the same class as g1.
Any scaling factors are applied to the line coordinates as they are copied from their parent grids. As scaling may be different in g1 and g2, the resulting grid has no scaling factor, but the coordinates of all its lines result from application of the different scaling factors of the two grids. make new grid
Definition at line 1219 of file KVIDGraph.cpp.
|
inlinevirtual |
Add identifier to the graph. It will be deleted by the graph.
if grid is Z-identification only, set mass formula for line according to mass formula of grid
Reimplemented in KVTGIDGrid.
Definition at line 340 of file KVIDGraph.h.
|
inline |
Associate this graph with an identification telescope, i.e. add the telescope to the list of telescopes which can use this graph for identification purposes.
Definition at line 407 of file KVIDGraph.h.
void KVIDGraph::AddIDTelescopes | ( | const TList * | tels | ) |
Associate this graph with all ID telescopes in list.
Definition at line 1516 of file KVIDGraph.cpp.
|
inlinevirtual |
Add info lines/cuts to the graph. It will be deleted by the graph.
Definition at line 364 of file KVIDGraph.h.
|
inline |
Definition at line 85 of file KVIDGraph.h.
|
privatevirtual |
Called after reading a grid from an ascii file. Tries to convert information written by an old version of the class:
PARAMETER> First run=... -—> <PARAMETER> Runlist=... PARAMETER> Last run=...
Reimplemented in KVIDGCsI, and KVIDGChIoSi.
Definition at line 1361 of file KVIDGraph.cpp.
|
virtual |
version>=0 check si la version demandee du fichier grille existe version-1 renvoie la derniere version existante si la version demandee n existe pas return -1 creation d un fichier tampon dans le repertoire ou se situe les fichiers grilles efface a la fin de la methode
Definition at line 1423 of file KVIDGraph.cpp.
|
virtual |
reset the grid (destroying any previously defined identifiers) ready to start anew. resets axis limits scaling factors (if any) are removed
Definition at line 203 of file KVIDGraph.cpp.
|
inline |
Definition at line 112 of file KVIDGraph.h.
void KVIDGraph::ClearPad | ( | TVirtualPad * | pad | ) |
Definition at line 49 of file KVIDGraph.cpp.
|
virtual |
Copy this to 'obj'.
Reimplemented in KVIDZAFromZGrid, and KVIDZAGrid.
Definition at line 115 of file KVIDGraph.cpp.
|
inlinevirtual |
-— The following redeclarations are here just to remove the MENU tag which -— is present in TObject.h, to stop these methods appearing in the ID line context menus
Definition at line 485 of file KVIDGraph.h.
void KVIDGraph::Draw | ( | Option_t * | opt = "" | ) |
Draw all objects in graph on the current display, if one exists: i.e. in order to superimpose the grid on a 2D display of data, use KVIDGraph::Draw() (no option "same" needed).
If no TCanvas exists, or if one exists but it is empty, a frame large enough to display all the objects in the graph will be generated.
The title of the canvas is set to the name of the graph
If the graph is already displayed (i.e. if fPad!=0), we call UnDraw() in order to remove it from the display. This is so that double-clicking a graph in the IDGridManagerGUI list makes it disappear if it is already drawn.
Definition at line 888 of file KVIDGraph.cpp.
|
virtual |
Use this method to add objects to a grid which is drawn in the current pad gPad. We wait for the user to draw the line with the graphical editor (we put the pad automatically into this mode, there is no need to use the Editor toolbar). Then we retrieve this TGraph, create a new KVIDentifier-derived object of class "classname", and add it to the "type" list (= "OK"/"cut" or "ID").
Definition at line 1174 of file KVIDGraph.cpp.
|
inlinevirtual |
Definition at line 489 of file KVIDGraph.h.
|
inlinevirtual |
Definition at line 493 of file KVIDGraph.h.
|
inlinevirtual |
Definition at line 469 of file KVIDGraph.h.
|
inlinevirtual |
Definition at line 497 of file KVIDGraph.h.
|
inlinevirtual |
Definition at line 230 of file KVIDGraph.h.
void KVIDGraph::ExtendBeginningAllIdentLines | ( | Double_t | newX, |
Option_t * | Direction = "" |
||
) |
Extend the first segment of each identification line back to new coordinate newX
See KVIDentifier::ExtendLine()
Definition at line 1017 of file KVIDGraph.cpp.
void KVIDGraph::ExtendEndAllIdentLines | ( | Double_t | newX, |
Option_t * | Direction = "" |
||
) |
Extend the last segment of each identification line to new coordinate newX
See KVIDentifier::ExtendLine()
Definition at line 1033 of file KVIDGraph.cpp.
void KVIDGraph::FindAxisLimits | ( | ) |
Calculate X/Y min/max of all objects in graph.
Definition at line 1073 of file KVIDGraph.cpp.
|
inlinevirtual |
Definition at line 474 of file KVIDGraph.h.
|
inlinevirtual |
Definition at line 478 of file KVIDGraph.h.
|
inlinevirtual |
virtual void SetTitle(const char *title="") {TGraph::SetTitle(title);};
Definition at line 465 of file KVIDGraph.h.
|
inlinestatic |
if static method KVIDGraph::GetAutoAdd() returns kTRUE, all grids are automatically added to ID Grid Manager if not, this mechanism is disabled
Definition at line 106 of file KVIDGraph.h.
|
inline |
Definition at line 280 of file KVIDGraph.h.
|
inline |
Returns list of cuts (derived from KVIDentifier)
Definition at line 313 of file KVIDGraph.h.
|
inline |
Returns list of cuts (derived from KVIDentifier)
Definition at line 308 of file KVIDGraph.h.
|
inline |
Definition at line 276 of file KVIDGraph.h.
KVIDentifier * KVIDGraph::GetIdentifier | ( | Int_t | Z, |
Int_t | A | ||
) | const |
Return pointer to identifier with atomic number Z and mass number A. If this is a 'OnlyZId()' graph we ignore A.
Definition at line 310 of file KVIDGraph.cpp.
|
inline |
Return identifier at position 'index' (=0,1,...) in list of identifiers
Definition at line 271 of file KVIDGraph.h.
|
inline |
Returns list of identifier objects (derived from KVIDentifier)
Definition at line 303 of file KVIDGraph.h.
|
inline |
Returns list of identifier objects (derived from KVIDentifier)
Definition at line 298 of file KVIDGraph.h.
|
inline |
Returns type of ID telescope to which this grid is associated (actually returns value of KVBase::GetLabel())
Definition at line 430 of file KVIDGraph.h.
|
inline |
Definition at line 245 of file KVIDGraph.h.
|
inline |
Definition at line 284 of file KVIDGraph.h.
|
inline |
Returns list of cuts (derived from KVIDentifier)
Definition at line 323 of file KVIDGraph.h.
|
inline |
Returns list of cuts (derived from KVIDentifier)
Definition at line 318 of file KVIDGraph.h.
|
inline |
Definition at line 116 of file KVIDGraph.h.
|
inline |
Definition at line 438 of file KVIDGraph.h.
const Char_t * KVIDGraph::GetName | ( | ) | const |
If name of grid is not set explicitly with SetName(const Char_t*), we return the name of the first ID telescope in the list of telescopes with which this grid is associated.
Definition at line 1332 of file KVIDGraph.cpp.
const Char_t * KVIDGraph::GetNamesOfIDTelescopes | ( | ) | const |
Returns a comma-separated list of the names of all ID telescopes for which this grid is valid.
Definition at line 1611 of file KVIDGraph.cpp.
|
inline |
Definition at line 332 of file KVIDGraph.h.
|
inline |
Definition at line 328 of file KVIDGraph.h.
|
inline |
Definition at line 336 of file KVIDGraph.h.
|
inline |
Definition at line 133 of file KVIDGraph.h.
|
inline |
Return pointer to list of parameters associated to grid
Definition at line 293 of file KVIDGraph.h.
|
inline |
Return pointer to list of parameters associated to grid
Definition at line 288 of file KVIDGraph.h.
|
inline |
Definition at line 240 of file KVIDGraph.h.
|
inlinevirtual |
Return quality code related to previously-attempted identification using grid. Redefine in child classes.
Reimplemented in KVIDZAGrid.
Definition at line 401 of file KVIDGraph.h.
|
inline |
Get list of runs for which grid is valid
Definition at line 266 of file KVIDGraph.h.
|
inline |
Get list of runs for which grid is valid
Definition at line 261 of file KVIDGraph.h.
|
inline |
Definition at line 393 of file KVIDGraph.h.
|
inline |
Definition at line 385 of file KVIDGraph.h.
Double_t KVIDGraph::GetXScaleFactor | ( | ) |
Return scaling factor for X-axis If factor not defined, returns 1
Definition at line 274 of file KVIDGraph.cpp.
|
inline |
Definition at line 397 of file KVIDGraph.h.
|
inline |
Definition at line 389 of file KVIDGraph.h.
Double_t KVIDGraph::GetYScaleFactor | ( | ) |
Return scaling factor for Y-axis If factor not defined, returns 1
Definition at line 292 of file KVIDGraph.cpp.
|
inline |
Returns kTRUE if telescope can use this graph for identification purposes.
Definition at line 424 of file KVIDGraph.h.
|
inlinevirtual |
Returns kTRUE if grid can identify masses as well as Z for at least some of the nuclei for which it is defined.
Returns kFALSE if grid only provides Z identification.
Reimplemented in KVIDZAFromZGrid.
Definition at line 169 of file KVIDGraph.h.
|
pure virtual |
Implemented in KVIDZAGrid, KVIDZAFromZGrid, KVIDGCsI, and KVIDGChIoSi.
|
inline |
Used by TestIdentification and KVTestIDGridDialog to send signals to TGHProgressBar about the progress of the identification test
Definition at line 249 of file KVIDGraph.h.
|
private |
Initialisations, used by constructors All graphs are added to gIDGridManager (if it exists).
Definition at line 67 of file KVIDGraph.cpp.
|
pure virtual |
Implemented in KVIDZAGrid, KVIDZAFromZGrid, KVIDGrid, KVIDGCsI, and KVIDGChIoSi.
|
inlinevirtual |
Definition at line 533 of file KVIDGraph.h.
|
inlinevirtual |
Definition at line 501 of file KVIDGraph.h.
|
inline |
Returns pointer to pad currently displaying this graph. Returns 0x0 if graph is not drawn.
Definition at line 444 of file KVIDGraph.h.
|
virtual |
Default method for deciding if point (x,y) corresponds to an identifiable particle or not: we loop over the list of cuts and test the point with the method TestPoint(x,y).
If the point is accepted by all cuts, then (x,y) is identifiable (return kTRUE).
If the point is rejected by a cut we return kFALSE. If rejected_by contains a valid pointer, we set it to the name of the rejecting cut.
Reimplemented in KVIDGChIoSi, and KVIDGCsI.
Definition at line 1269 of file KVIDGraph.cpp.
|
inlineprivate |
Returns kTRUE if the graph is only to be used for Z identification (no isotopic information). Default is to identify both Z & A (fOnlyZid = kFALSE)
Definition at line 57 of file KVIDGraph.h.
|
inline |
Return kTRUE if list of identifiers has been sorted
Definition at line 380 of file KVIDGraph.h.
|
static |
Static function which will create and 'Build' the identification graph of class 'class_name', one of the plugins defined in either $KVROOT/KVFiles/.kvrootrc, or in the user's .kvrootrc file. check and load plugin library
Definition at line 1556 of file KVIDGraph.cpp.
|
inline |
Signal sent out when properties of graph change
Definition at line 255 of file KVIDGraph.h.
|
privatevirtual |
Create new object of class "id_class" which derives from KVIDentifier.
Definition at line 807 of file KVIDGraph.cpp.
void KVIDGraph::Print | ( | Option_t * | opt = "" | ) | const |
Print out all objects in graph.
Definition at line 1047 of file KVIDGraph.cpp.
void KVIDGraph::ReadAsciiFile | ( | const Char_t * | filename | ) |
Open, read and close ascii file containing this grid. Any previous lines in the grid are destroyed. Comment lines begin with # Grid info begins with ++ClassName where ClassName is actual class name of instance of this object New lines begin with +name_of_class '!' signals end of grid
Definition at line 779 of file KVIDGraph.cpp.
|
virtual |
lecture des grilles avec version suivant un modele de fichier
Definition at line 1404 of file KVIDGraph.cpp.
|
virtual |
Read info from already open ascii file stream containing each line of this grid. Any previous lines in the grid are destroyed. Comment lines begin with # Grid info begins with ++ClassName where ClassName is actual class name of instance of this object The names associated to the X & Y axis of the identification map are written on lines beginning with VARX> VARY> Parameter lines begin with <PARAMETER> New lines begin with +name_of_class '!' signals end of grid info Any scaling factors are applied once the coordinates have been read reset grid - destroy old lines, axis limits...
Reimplemented in KVIDZAFromZGrid, and KVTGIDGrid.
Definition at line 601 of file KVIDGraph.cpp.
|
privatevirtual |
Read in new identifier object from file.
Reimplemented in KVIDGrid.
Definition at line 755 of file KVIDGraph.cpp.
void KVIDGraph::RemoveCut | ( | KVIDentifier * | cut | ) |
Remove and destroy cut.
Definition at line 350 of file KVIDGraph.cpp.
void KVIDGraph::RemoveIdentifier | ( | KVIDentifier * | id | ) |
Remove and destroy identifier.
Definition at line 335 of file KVIDGraph.cpp.
|
inline |
Remove telescope from the list of telescopes which can use this graph for identification purposes.
Definition at line 416 of file KVIDGraph.h.
void KVIDGraph::RemoveInfo | ( | KVIDentifier * | info | ) |
Remove and destroy cut.
Definition at line 363 of file KVIDGraph.cpp.
|
inlinevirtual |
Definition at line 537 of file KVIDGraph.h.
|
inlinevirtual |
Definition at line 541 of file KVIDGraph.h.
void KVIDGraph::ResetDraw | ( | ) |
In case the graph can no longer be drawn/undrawn (because fPad contains address of a canvas which died unexpectedly), use this method to reset fPad=0 and hopefully start afresh.
Definition at line 1003 of file KVIDGraph.cpp.
void KVIDGraph::ResetPad | ( | ) |
Definition at line 33 of file KVIDGraph.cpp.
void KVIDGraph::RevertToLastSavedVersion | ( | ) |
Revert to last saved version of grid this will destroy any existing lines in the grid and replace them with copies of the lines as they were at the last moment the grid was saved If the grid is (was) visible in a pad, we redraw the new lines.
Definition at line 555 of file KVIDGraph.cpp.
|
inlinevirtual |
Definition at line 505 of file KVIDGraph.h.
|
private |
Called by SetX/YScaleFactor methods to rescale every point of every object in the grid.
Definition at line 1146 of file KVIDGraph.cpp.
void KVIDGraph::Scale | ( | TF1 * | sx, |
TF1 * | sy | ||
) |
Rescale coordinates of every object in graph according to arbitrary functions of the coordinates (sx & sy can be 1-dimensional or 2-dimensional functions).
If sy is a TF1 function f(x), then the 'x' in this function refers to the y-coordinate. If sy is a TF2 function f(x,y), 'x' and 'y' refer to the x & y-coordinates.
Definition at line 1118 of file KVIDGraph.cpp.
|
inlinestatic |
after calling KVIDGraph::SetAutoAdd(), all grids are automatically added to ID Grid Manager after calling KVIDGraph::SetAutoAdd(kFALSE), this mechanism is disabled
Definition at line 100 of file KVIDGraph.h.
|
inlinevirtual |
Definition at line 509 of file KVIDGraph.h.
|
virtual |
virtual void NewCut();// MENU={Hierarchy="AddLine.../NewCut"} virtual void NewIdentifier();// MENU={Hierarchy="AddLine.../NewIdentifier"}
Toggles 'editable' status of all lines/contours in graph If editable = kTRUE this makes it possible to modify the graph we then take a snapshot of the graph before editing begins and store it in fLastSavedVersion. we can always revert to this version if we want
Definition at line 1582 of file KVIDGraph.cpp.
|
inlinevirtual |
Definition at line 517 of file KVIDGraph.h.
|
virtual |
loop over KVIDGraph::fInfoZones to set flags in KVIdentificationResult
Definition at line 1297 of file KVIDGraph.cpp.
|
inlinevirtual |
Definition at line 513 of file KVIDGraph.h.
|
inline |
Set line colour of all objects in grid
Definition at line 187 of file KVIDGraph.h.
|
inline |
Set line style of all objects in grid
Definition at line 195 of file KVIDGraph.h.
|
inline |
Set line width of all objects in grid
Definition at line 203 of file KVIDGraph.h.
|
inlinevirtual |
Definition at line 521 of file KVIDGraph.h.
void KVIDGraph::SetMassFormula | ( | Int_t | mass | ) |
Set mass formula for all identifiers if graph has OnlyZId()=kTRUE. This will change the mass (A) of each identifier.
Definition at line 1473 of file KVIDGraph.cpp.
|
inlinevirtual |
Used in context menus to define whether grid identifies A & Z or just Z
Definition at line 178 of file KVIDGraph.h.
|
inlinevirtual |
-— The following redeclarations are here just to remove the MENU tag which -— is present in TGraph.h, to stop these methods appearing in the ID line context menus
Definition at line 456 of file KVIDGraph.h.
|
inlinevirtual |
Definition at line 460 of file KVIDGraph.h.
|
inlinevirtual |
Definition at line 140 of file KVIDGraph.h.
|
virtual |
Use this method if the graph is only to be used for Z identification (no isotopic information). Default is to identify both Z & A (fOnlyZid = kFALSE). Note that setting fOnlyZid=kTRUE changes the way line widths are calculated (see KVIDGrid::CalculateLineWidths)
Reimplemented in KVIDZAFromZGrid.
Definition at line 1496 of file KVIDGraph.cpp.
|
inline |
Definition at line 235 of file KVIDGraph.h.
|
inline |
Definition at line 156 of file KVIDGraph.h.
void KVIDGraph::SetRuns | ( | const KVNumberList & | nl | ) |
Set list of runs for which grid is valid.
Definition at line 1316 of file KVIDGraph.cpp.
|
inlinevirtual |
Definition at line 525 of file KVIDGraph.h.
|
inlinevirtual |
Definition at line 529 of file KVIDGraph.h.
void KVIDGraph::SetXScaleFactor | ( | Double_t | s = 0 | ) |
Set scaling factor for X-axis - rescales all objects with this factor SetXScaleFactor() or SetXScaleFactor(0) removes scale factor
Definition at line 226 of file KVIDGraph.cpp.
|
inline |
void SetIDTelescopes();// MENU={Hierarchy="Set.../ID Telescopes"}
Definition at line 146 of file KVIDGraph.h.
void KVIDGraph::SetYScaleFactor | ( | Double_t | s = 0 | ) |
Set scaling factor for Y-axis - rescales all objects with this factor SetYScaleFactor() or SetYScaleFactor(0) removes scale factor
Definition at line 250 of file KVIDGraph.cpp.
|
inline |
Definition at line 151 of file KVIDGraph.h.
|
inline |
Definition at line 375 of file KVIDGraph.h.
|
virtual |
This method allows to test the identification capabilities of the grid using data in a TH2F. We assume that 'data' contains an identification map, whose 'x' and 'y' coordinates correspond to this grid. Then we loop over every bin of the histogram, perform the identification (if IsIdentifiable() returns kTRUE) and fill the histograms with the results of the identification
The "identification" or PID we represent is the result of the KVReconstructedNucleus::GetPID() method for the identified nucleus.
The KVHashList contains histograms to be filled with results The KVNameValueList histo_names contains the name of each histogram passed in the KVHashList i.e. it may have any of the following parameters
"ID_REAL"="[name of histo to fill with PID spectrum]" "ID_REAL_AIDENT"="[name of histo to fill with PID spectrum]" Z&A identification "ID_REAL_ZIDENT"="[name of histo to fill with PID spectrum]" Only Z identification "ID_REAL_VS_ERES" - PID vs. Eres (X) histo "ID_REAL_VS_DE" - PID vs. DeltaE (Y) histo "ID_REAL_VS_ERES_AIDENT" - PID vs. Eres histo, Z&A identification "ID_REAL_VS_ERES_ZIDENT" - PID vs. Eres histo, only Z identification
Definition at line 1707 of file KVIDGraph.cpp.
void KVIDGraph::UnDraw | ( | ) |
Make the graph disappear from the current canvas/pad In case any objects have (accidentally) been drawn more than once, we keep calling gPad->GetListOfPrimitives()->Remove() as long as gPad->GetListOfPrimitives()->FindObject() returns kTRUE for each identifier. if (!fPad) { Error("UnDraw", "Cannot undraw, no pad stored ??"); return; } TIter next_id(fIdentifiers); KVIDentifier* line; //remove the rest of the lines while ((line = (KVIDentifier*) next_id())) { while (fPad->GetListOfPrimitives()->FindObject(line)) fPad->GetListOfPrimitives()->Remove(line); } TIter next_ok(fCuts); while ((line = (KVIDentifier*) next_ok())) { while (fPad->GetListOfPrimitives()->FindObject(line)) fPad->GetListOfPrimitives()->Remove(line); } fPad->Modified(); fPad->Update(); fPad->Disconnect("Closed()", this, "ResetPad()"); if (fPad->GetCanvas()) fPad->GetCanvas()->Disconnect("Cleared(TVirtualPad*)", this, "ClearPad(TVirtualPad*)");
Definition at line 966 of file KVIDGraph.cpp.
void KVIDGraph::UpdateLastSavedVersion | ( | ) |
update last saved version. mkae copy of current state of graph.
Definition at line 534 of file KVIDGraph.cpp.
void KVIDGraph::WriteAsciiFile | ( | const Char_t * | filename | ) |
Open, write and close ascii file containing this grid.
Definition at line 404 of file KVIDGraph.cpp.
|
virtual |
ecriture des grilles avec version suivant un modele de fichier (fPattern) fPattern_vd.grid le modele doit etre initialiser par la methode SetPattern(TString) la valeur par default version=-1 permet l ecriture de la derniere version apres un check des versions existantes (methode CheckVersion) la premiere version est indexee v0
Definition at line 1387 of file KVIDGraph.cpp.
|
private |
Fill parameter "IDTelescopes" with list of names of telescopes associated with this grid, ready to write in ascii file if list of telescope pointers is empty, do nothing this is in case there are telescope names already in the IDTelescopes parameter but they are not telescopes in the current multi det array
Definition at line 382 of file KVIDGraph.cpp.
|
virtual |
Write info on this grid in already-open ascii file stream 'gridfile'. This begins with the line ++ClassName where '"ClassName'" is the name of the class of the actual instance of this object followed by informations on the grid and its objects.
The names associated to the X & Y axis of the identification map are written on lines beginning with VARX> VARY> Any associated parameters are written before the objects, starting with PARAMETER> then the name of the parameter and its value e.e. PARAMETER> ChIo pressure=45.5 A single '!' on a line by itself signals the end of the informations for this grid.
Scaling factors Any scaling factors are written in the file as PARAMETER> XScaleFactor=... PARAMETER> YScaleFactor=... However the coordinates written in the file are the unscaled factors When the file is read back again, the unscaled coordinates are read in and then the scaling is applied.
Reimplemented in KVIDZAFromZGrid, and KVTGIDGrid.
Definition at line 442 of file KVIDGraph.cpp.
|
friend |
Definition at line 33 of file KVIDGraph.h.
|
staticprivate |
if =kTRUE, grids are automatically added to ID grid manager on creation (default)
Definition at line 55 of file KVIDGraph.h.
|
private |
cuts used to define area in which identification is possible
Definition at line 41 of file KVIDGraph.h.
|
mutableprivate |
dynamically generated name
Definition at line 51 of file KVIDGraph.h.
|
private |
list of identification objects
Definition at line 40 of file KVIDGraph.h.
|
private |
contours/lines used to add info to particles (ex: punch-through)
Definition at line 42 of file KVIDGraph.h.
|
private |
copy of last save version of grid, used for 'undo'
Definition at line 54 of file KVIDGraph.h.
|
private |
last applied scaling factor on X
Definition at line 46 of file KVIDGraph.h.
|
private |
last applied scaling factor on Y
Definition at line 47 of file KVIDGraph.h.
|
private |
OPTION={GetMethod="GetMassFormula";SetMethod="SetMassFormula";Items=(0="Beta-stability", 1="VEDA mass", 2="EAL mass", 3="EAL residues", 99="2Z+1")}
Definition at line 53 of file KVIDGraph.h.
|
private |
set to kTRUE when only to be used to give Z identification of nuclei, no mass info
Definition at line 39 of file KVIDGraph.h.
|
private |
pad in which graph is drawn
Definition at line 48 of file KVIDGraph.h.
|
private |
parameters associated to grid
Definition at line 45 of file KVIDGraph.h.
|
private |
pattern of filenames used to write or read grid
Definition at line 52 of file KVIDGraph.h.
|
private |
runs for which grid is valid
Definition at line 49 of file KVIDGraph.h.
|
private |
ID telescopes for which grid is valid.
Definition at line 50 of file KVIDGraph.h.
|
private |
min/max X coordinates of graph
Definition at line 43 of file KVIDGraph.h.
|
private |
Definition at line 43 of file KVIDGraph.h.
|
private |
min/max Y coordinates of graph
Definition at line 44 of file KVIDGraph.h.
|
private |
Definition at line 44 of file KVIDGraph.h.