4#include "KVIDGridEditor.h"
15#include <KVZAFinderDialog.h>
16#include "KVTreeAnalyzer.h"
17#include <KVHistogram.h>
18#include "KVTestIDGridDialog.h"
19#include "KVItvFinderDialog.h"
85 ft =
new TF1(
"tranlation",
"(x+[0])", 0, 50000);
86 fs =
new TF1(
"scale",
"(x-[0])*[1]+[0]", 0, 50000);
87 fsy =
new TF1(
"scale_y",
"(x-[0])*[1]+[0]", 0, 50000);
89 frx =
new TF2(
"rotation_x",
"(x-[0])*TMath::Cos([2])-(y-[1])*TMath::Sin([2])+[0]", 0, 50000);
90 fry =
new TF2(
"rotation_y",
"(x-[0])*TMath::Sin([2])+(y-[1])*TMath::Cos([2])+[1]", 0, 50000);
123 fCanvas->
AddExec(
"transform",
"gIDGridEditor->MakeTransformation()");
242 if (
option.Contains(
"AL")) {
350 if (gIDGridEditor ==
this) gIDGridEditor = 0x0;
448 y1 = 0.90 - i * 0.06;
457 y1 = 0.90 - i * 0.06;
528 thelist->
Add(templabel);
545 if (!the_directory)
return;
548 while ((key = (
TKey*)next_key())) {
584 while ((obj = nextmem())) {
592 while ((
f = (
TFile*)next())) {
597 HistosNames.
Begin(
" ");
598 while (!HistosNames.
End()) {
600 if (
g !=
"gIDGridEditorDefaultHistogram") histos.
Add(
new TObjString(
g.Data()));
607 while ((canv = (
TCanvas*)nextc())) {
609 if (strcmp(canv->
GetName(),
"gIDGridEditorCanvas")) {
612 while ((obj1 = next_step1())) {
616 TIter next_step2(((
TPad*)obj1)->GetListOfPrimitives());
617 while ((obj2 = next_step2())) {
618 printf(
"%s\n", obj2->
GetName());
655 HistosNames +=
Form(
" %s", s->GetString().Data());
679 Iter = str.Next(
kTRUE);
688 Iter = str.Next(
kTRUE);
714 Choices +=
"Current ";
716 else Default =
"Dummy";
720 else if (Select ==
"") {
725 Choices += Select.
Data();
730 while (!Listo.
End()) {
732 if (s != Select) Choices +=
Form(
"%s ", s.Data());
746 else Answer = Default;
762 else Answer =
"Dummy";
779 if ((TmpH = (
TH2*)
gROOT->FindObject(hname.
Data())))
delete TmpH;
785 cout <<
"ERROR: KVIDGridEditor::SetHisto(): '" << hh->
GetName() <<
"' must be a 2D histogram !" << endl;
824 while ((cc = (
TCanvas*)nextc())) {
825 if (strcmp(cc->GetName(),
"gIDGridEditorCanvas")) {
826 if ((obj = cc->FindObject(histoname))) {
867 cout <<
"ERROR: KVIDGridEditor::SetHisto(): invalid pointer on the grid !" << endl;
898 if (!strcmp(GridName.
Data(),
"")) {
900 Bool_t proposename =
false;
907 new KVInputDialog(
gClient->GetDefaultRoot(),
"Enter the name of your grid :", &Answer, &okpressed);
908 if (!okpressed)
return;
909 GridName = Answer.
Data();
914 if (!gIDGridManager)
return;
916 cout <<
"WARNING: KVIDGridEditor::SetGrid(): Unknown grid named '" << GridName.
Data() <<
"' !" << endl;
919 else SetGrid(tempgrid, sethisto);
1108 Double_t ddX = (X1 + X0) * 0.5 - px;
1110 if (distX >= 0.5)
return;
1118 Double_t ddY = (Y1 + Y0) * 0.5 - py;
1120 if (distY >= 0.5)
return;
1122 if ((distX <=
size) && (distY <=
size))
return;
1132 if ((X0 - dX > 0) && (X1 - dX < NbinsX)) {
1136 if ((Y0 - dY > 0) && (Y1 - dY < NbinsY)) {
1201 Int_t zmin, zmax, amin, amax;
1202 if (LastZ == SeleZ) {
1208 else if (LastZ < SeleZ) {
1222 for (
int Z = zmin; Z <= zmax; Z++) {
1229 if ((
line->GetA() > amin) && (
line->GetA() < amax)) {
1235 if ((
line->GetZ() == zmin) && (
line->GetA() > amin)) {
1240 if ((
line->GetZ() == zmax) && (
line->GetA() < amax)) {
1245 if ((
line->GetZ() != zmax) && (
line->GetZ() != zmin)) {
1288 else if (!strcmp(who,
"T_{X}"))
TranslateX(sign);
1289 else if (!strcmp(who,
"T_{Y}"))
TranslateY(sign);
1290 else if (!strcmp(who,
"R_{Z}"))
RotateZ(sign);
1291 else if (!strcmp(who,
"S_{X}"))
ScaleX(sign);
1292 else if (!strcmp(who,
"S_{Y}"))
ScaleY(sign);
1293 else if (!strcmp(who,
"S_{XY}"))
ScaleXY(sign);
1315 if ((ratio2 - ratio1 > 0.05)) {
1324 if ((ratio2 - ratio1 > 0.05)) {
1349 else if (commande.
Contains(
"Fit")) {
1356 else if (commande.
Contains(
"Test")) {
1363 else if (commande.
Contains(
"Mass")) {
1370 else if (commande.
Contains(
"Info")) {
1378 else if (commande.
Contains(
"More")) {
1385 else if (commande.
Contains(
"Delete")) {
1388 if (color ==
kRed) {
1399 else cout <<
"WARNING: KVIDGridEditor::DispatchOrder(): unknown order '" << commande <<
"' !" << endl;
1485 "Choose class of new identifier :",
1490 if (!okpressed)
return;
1492 else cut_class = cut_choices;
1500 if (
fDebug) cout <<
"INFO: KVIDGridEditor::NewLine(): New Line has been added to the current grid..." << endl;
1531 if (!strcmp(cut_default,
"")) {
1532 cut_types.
Begin(
" ");
1533 cut_default = cut_types.
Next();
1536 "Choose class of new cut :",
1548 else cut_class = cut_types;
1557 if (
fDebug) cout <<
"INFO: KVIDGridEditor::NewCut(): New Cut has been added to the current grid..." << endl;
1576 if (info_choices ==
"") info_choices =
gEnv->
GetValue(
Form(
"%s.InfoClass",
"KVIDGraph"),
"");
1579 if (info_choices ==
"") info_choices =
gEnv->
GetValue(
Form(
"%s.DefaultInfoClass",
"KVIDGraph"),
"");
1584 KVString info_types = info_choices;
1589 if (!strcmp(info_default,
"")) {
1590 info_types.
Begin(
" ");
1591 info_default = info_types.
Next();
1594 "Choose class of new info :",
1596 info_default.
Data(),
1606 else info_class = info_types;
1611 Info(
"NewInfo",
"Adding new info contour or line of class '%s'", info_class.
Data());
1616 if (
fDebug) cout <<
"INFO: KVIDGridEditor::NewInfo(): New info has been added to the current grid..." << endl;
1813 if (
fDebug) cout <<
"INFO: KVIDGridEditor::TestGrid(): testing the current grid..." << endl;
1829 cm->Action(fitter,
m);
1832 if (
fDebug) cout <<
"INFO: KVIDGridEditor::FitGrid(): fitting grid '" <<
TheGrid->
GetName() <<
"'..." << endl;
1849 if (!okpressed)
return;
1858 else if ((
m =
IsA()->GetMethodAllAny(Answer.
Data()))) {
1860 cm->Action(
this,
m);
1863 else cout <<
"INFO: KVIDGridEditor::SuggestMoreAction(): '" << Answer <<
"' not implemented..." << endl;
1886 if ((found == -1) || (!
line))
continue;
1913 "KVIDGridEditor::SaveCurrentGrid",
Form(
"Do you wat to save the grid here : %s", fn.
Data()),
1917 if (ret_code ==
kMBYes) {
1923 const char* filetypes[] = {
1924 "ID Grid files",
"*.dat",
1937 if (!filenam.
Contains(
'.')) filenam +=
".dat";
1959 for (
int ii = 0; ii <
id->GetN(); ii++) {
1960 double xx =
id->
GetX()[ii];
1961 double yy =
id->GetY()[ii];
1963 if (ref) dyref =
abs(yy - ref->
Eval(xx)) / 2;
1967 int nfound = spec.
Search(hh, dyref,
"goff", 0.05);
1974 for (
int ip = 0; ip < nfound; ip++) {
1978 if (ypeaks[ip] > threshold && (idr.
Z ==
id->GetZ() && idr.
A ==
id->GetA())) {}
1981 if (
abs(xpeaks[ip] - yy) < dy) {
1982 dy =
abs(xpeaks[ip] - yy);
1986 if (ygood > 0)
id->GetY()[ii] = ygood;
1998 static TString dir(
"$HISTOROOT");
2003 const char* filetypes[] = {
"Root files",
"*.root",
"All files",
"*", 0, 0};
2026 Choices +=
"kBlack kGreen kBlue kRed kYellow kCyan kMagenta";
2031 if (!okpressed)
return;
2147 Form(
"This will undo all changes to the grid. Are you sure, %s?", username.
Data()),
2150 if (ret_val &
kMBOk) {
2192 if (
fDebug) cout <<
"INFO: KVIDGridEditor::TranslateX(): translation on the X axis (" << (
Sign > 0 ?
"+" :
"-") << step <<
") !" << endl;
2213 if (
fDebug) cout <<
"INFO: KVIDGridEditor::TranslateY(): translation on the Y axis (" << (
Sign > 0 ?
"+" :
"-") << step <<
") !" << endl;
2247 if (X0 >= X1) X0 = X1 - 1;
2249 if ((X0 - dX) < 0) ax->
SetRange(0, X1 - X0);
2251 else ax->
SetRange(X0 - dX, X1 - dX);
2261 if (Y0 >= Y1) Y0 = Y1 - 1;
2263 if ((Y0 - dY) < 0) ax->
SetRange(0, Y1 - Y0);
2265 else ax->
SetRange(Y0 - dY, Y1 - dY);
2282 if (step >= 45.) step = 45.;
2294 if (
fDebug) cout <<
"INFO: KVIDGridEditor::RotateZ(): rotation around the Z axis (" << (
Sign > 0 ?
"+" :
"-") << step <<
") !" << endl;
2367 if (
fDebug)
Info(
"ScaleX",
"scaling on the X axis (*%f) !", factor);
2391 if (
fDebug)
Info(
"ScaleY",
"scaling on the Y axis (*%f) !", factor);
2423 if (
fDebug)
Info(
"ScaleXY",
"scaling (*%f) !", factor);
2499 TIter nextidd(IdentList);
2525 if (
fDebug) cout <<
"INFO: KVIDGridEditor::ForceUpdate(): Canvas and Co has been updated !" << endl;
2659 gROOT->ForceStyle();
2708 gROOT->ForceStyle();
2893 if ((XX1 == 1) && (sign == 1))
return;
2894 if ((XX2 == xAxis->
GetNbins() - 1) && (sign == -1))
return;
2896 Int_t dX = (
Int_t)sign * (XX1 - XX2) * 0.25 * speed;
2898 xAxis->
SetRange(XX1 + dX, XX2 + dX);
2917 Int_t dX = (
Int_t) - 1 * (XX1 - XX2) * 0.1 * speed;
2919 axis->
SetRange(XX1 + dX, XX2 - dX);
2937 if ((XX1 == 1) && (sign == 1))
return;
2938 if ((XX2 == yAxis->
GetNbins() - 1) && (sign == -1))
return;
2940 Int_t dX = (
Int_t)sign * (XX1 - XX2) * 0.25 * speed;
2942 yAxis->
SetRange(XX1 + dX, XX2 + dX);
3029 Info(
"ChangeMasses",
"%d lines found for Z=%d", ll->
GetSize(), Z);
3034 Info(
"ChangeMasses",
"A=%d -> A=%d",
id->GetA(),
id->GetA() + dA);
3035 id->SetA(
id->GetA() + dA);
3053 for (
int i =
n - 1; i > 0; i--) {
3056 Info(
"ChangeMasses",
"%d lines found for Z=%d", ll->
GetSize(), Z);
3061 Info(
"ChangeMasses",
"Z=%d -> Z=%d",
id->GetZ(),
id->GetZ() + dZ);
3062 id->SetZ(
id->GetZ() + dZ);
3091 Info(
"PrintScalingRecap",
3092 "Scaling recap:\n X --> %f X + %f\n Y --> %f Y + %f"
size_t size(const MatrixT &matrix)
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t result
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize id
Option_t Option_t SetLineColor
Option_t Option_t TPoint TPoint const char x2
Option_t Option_t TPoint TPoint const char x1
Option_t Option_t TPoint TPoint const char y2
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t g
Option_t Option_t TPoint TPoint percent
Option_t Option_t TPoint TPoint const char y1
char * Form(const char *fmt,...)
char * StrDup(const char *str)
R__EXTERN TStyle * gStyle
R__EXTERN TSystem * gSystem
Base class for KaliVeda framework.
virtual Bool_t IsType(const Char_t *typ) const
virtual void Copy(TObject &) const
Make a copy of this object.
Ask user to choose between several options in a drop-down list.
Extended version of ROOT THashList.
Wrapper for histograms and graphical cuts used by KVTreeAnalyzer.
Base class for particle identification in a 2D map.
void RemoveIdentifier(KVIDentifier *)
Remove and destroy identifier.
void UpdateLastSavedVersion()
update last saved version. mkae copy of current state of graph.
void RemoveInfo(KVIDentifier *)
Remove and destroy cut.
void Draw(Option_t *opt="")
void RevertToLastSavedVersion()
virtual void Identify(Double_t, Double_t, KVIdentificationResult *) const =0
KVIDentifier * GetIdentifier(Int_t Z, Int_t A) const
TVirtualPad * GetPad() const
void FindAxisLimits()
Calculate X/Y min/max of all objects in graph.
const KVList * GetIdentifiers() const
virtual void DrawAndAdd(const Char_t *type="ID", const Char_t *classname="KVIDentifier")
const Char_t * GetName() const
void WriteAsciiFile(const Char_t *filename)
Open, write and close ascii file containing this grid.
const KVList * GetInfos() const
const KVList * GetCuts() const
virtual void SetEditable(Bool_t editable=kTRUE)
virtual void Initialize()=0
void RemoveCut(KVIDentifier *)
Remove and destroy cut.
Identification grid editor GUI ,.
Bool_t drawmode
true si mode draw (line, cut)
void SelectLinesByZ(const Char_t *ListOfZ)
Int_t imod
utilise pour le placement des boutons
void AddTransformation(TString label)
void DynamicZoom(Int_t Sign, Int_t px=0, Int_t py=0, Double_t speed=.5)
Zoom in or out of histogram with mouse wheel.
void Copy(TObject &) const
void SelectLines(const Char_t *label)
KVIDGridEditor()
Default constructor.
void MakeTransformation()
KVHashList * lplabel5
contient la liste des TPaveLabel pour moduler les pas (vert)
KVHashList * lplabel4
contient la liste des TPaveLabel pour editer la grille (rouge)
void SetGrid(KVIDGraph *gg, Bool_t histo=true)
void SetPiedestal(Double_t ppdx, Double_t ppdy)
piedestal used during SpiderIdentification
Bool_t moved
utilise pour les differents zooms
void MoveHor(Int_t sign, Double_t speed=1, Bool_t update=true)
Bool_t aoemode
true si mode age of empire
void RecurseFileStructureFindHistos(TString &hist_names, TDirectory *the_directory)
TString ListOfHistogramInMemory()
void ChangeZoomRatio(Int_t sign, Double_t speed=.5)
TString PreselectHistogram(TString ListOfName, Int_t ipert=0)
void TranslateX(Int_t Sign)
void ChooseSelectedColor()
void ConstructModulator()
void ScaleCurvature(Int_t Sign)
void ChangeCharges(const Char_t *Zl, Int_t dZ)
void MakeScaleX(Double_t scaleFactor)
const char * WhoIsSelected()
void ChangeStep(const char *title, Int_t dstep=1)
void AddGridOption(TString label, KVHashList *thelist)
TH2 * FindInCanvases(const Char_t *name)
void SetPointStyle(int pstyle)
void StartViewer()
Close();.
void DispatchOrder(TPaveLabel *label)
virtual ~KVIDGridEditor()
Destructor.
void TranslateY(Int_t Sign)
void MakeScaleY(Double_t scaleFactor)
KVList * ListOfLines
liste des lignes selectionnees
void SetSelectedColor(Int_t color)
TH2 * TheHisto
pointeur sur l'histogramme
void SelectTrans(TPaveLabel *label)
void ResetColor(KVIDentifier *Ident)
void Clear(const Option_t *opt="")
KVIDGridEditorCanvas * fCanvas
void AddMethod(const char *theMethod)
KVIDGraph * TheGrid
pointeur sur la grille courante
Bool_t HandleKey(Int_t px, Int_t py)
Handle keys.
KVHashList * lplabel2
contient la liste des TPaveLabel pour les actions (rouge)
KVHashList * lplabel3
contient la liste des TPaveLabel pour les selections de lignes (vert)
void MoveVert(Int_t sign, Double_t speed=1, Bool_t update=true)
void SetPointSize(double psize)
void ChangeMasses(const Char_t *Zl, Int_t dA)
Int_t SelectedColor
couleur des lignes selectionnees
Bool_t venermode
true si mode select
Bool_t ownhisto
true si histo par defaut
void SetPivot(Double_t xx0, Double_t yy0)
void SetEditable(TPaveLabel *label)
void SpiderIdentification()
Bool_t selectmode
true si mode vener
Double_t fBy
scaling recap for current grid
Double_t ymax
utilises pour les differents zooms
KVHashList * lplabel
contient la liste des TPaveLabel pour les transformations (rouge)
Double_t x0
coordonne x du pivot
void DeleteObject(KVIDentifier *obj)
Double_t y0
coordonne y du pivot
friend class KVIDGridEditorCanvas
friend class KeyHandler;
Bool_t dlmode
true si mode delete
void AddAction(TString label)
Hybrid charge & mass identification grid.
Identification grid with lines corresponding to different nuclear isotopes (KVIDZALine)
Base class for identification ridge lines corresponding to different nuclear species.
Base class for graphical cuts used in particle identification.
virtual void Scale(Double_t sx=-1, Double_t sy=-1)
Full result of one attempted particle identification.
Int_t A
A of particle found (if Aident==kTRUE)
Int_t Z
Z of particle found (if Zident==kTRUE)
GUI for finding/fixing mass identification intervals.
Extended TList class which owns its objects by default.
void Sort(Bool_t order=kSortAscending)
Strings used to represent a set of ranges of values.
IntArray GetArray() const
virtual TObject * FindObject(const char *name) const
KVSeqCollection * GetSubListWithMethod(const Char_t *retvalue, const Char_t *method) const
virtual void AddLast(TObject *obj)
virtual void SetOwner(Bool_t enable=kTRUE)
virtual void Clear(Option_t *option="")
virtual Int_t GetSize() const
virtual void Execute(const char *method, const char *params, Int_t *error=0)
virtual TObject * At(Int_t idx) const
virtual void Add(TObject *obj)
virtual TObject * Remove(TObject *obj)
Remove object from list.
virtual void Delete(Option_t *option="")
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....
void Begin(TString delim) const
KVString Next(Bool_t strip_whitespace=kFALSE) const
GUI for testing identification grids.
const KVList * GetHistoList() const
TH1 * GetHistogram(const Char_t *name) const
Return histogram with given name.
ABC for fitting ID grids with functionals.
static KVVirtualIDFitter * GetDefaultFitter()
void SetPad(TVirtualPad *p)
void SetGrid(KVIDGraph *g)
Dialog box for KVZALineFinder class.
virtual void SetAxisColor(Color_t color=1, Float_t alpha=1.)
virtual void SetLabelColor(Color_t color=1, Float_t alpha=1.)
virtual Color_t GetFillColor() const
virtual void SetFillColor(Color_t fcolor)
virtual void SetFillStyle(Style_t fstyle)
virtual void SetLineColor(Color_t lcolor)
virtual void SetMarkerColor(Color_t mcolor=1)
virtual void SetMarkerStyle(Style_t mstyle=1)
virtual void SetMarkerSize(Size_t msize=1)
virtual void SetTextAlign(Short_t align=11)
virtual void SetTextColor(Color_t tcolor=1)
virtual Int_t FindBin(const char *label)
virtual void SetRangeUser(Double_t ufirst, Double_t ulast)
virtual void SetRange(Int_t first=0, Int_t last=0)
virtual Double_t GetBinWidth(Int_t bin) const
void Clear(Option_t *option="") override
TCanvasImp * GetCanvasImp() const override
void Close(Option_t *option="") override
TVirtualPad * cd(Int_t subpadnumber=0) override
TMethod * GetMethodAllAny(const char *method)
TMethod * GetMethodAny(const char *method)
virtual void AddAll(const TCollection *col)
virtual Int_t GetEntries() const
virtual void SetOwner(Bool_t enable=kTRUE)
virtual Bool_t IsEmpty() const
Bool_t Contains(const char *name) const
TClass * IsA() const override
virtual TDirectory * GetDirectory(const char *namecycle, Bool_t printError=false, const char *funcname="GetDirectory")
virtual TList * GetListOfKeys() const
virtual const char * GetValue(const char *name, const char *dflt) const
virtual void SetParameters(const Double_t *params)
virtual Double_t Eval(Double_t x, Double_t y=0, Double_t z=0, Double_t t=0) const
virtual void SetParameter(const TString &name, Double_t value)
virtual void SetPoint(Int_t i, Double_t x, Double_t y)
virtual Bool_t IsEditable() const
virtual Double_t Eval(Double_t x, TSpline *spline=nullptr, Option_t *option="") const
void SetName(const char *name="") override
void Draw(Option_t *chopt="") override
void Draw(Option_t *option="") override
virtual void SetMinimum(Double_t minimum=-1111)
virtual Double_t GetMinimum(Double_t minval=-FLT_MAX) const
TH1D * ProjectionY(const char *name="_py", Int_t firstxbin=0, Int_t lastxbin=-1, Option_t *option="") const
Bool_t IsFolder() const override
virtual const char * GetClassName() const
const char * GetName() const override
virtual void SetName(const char *name)
TClass * IsA() const override
virtual const char * GetName() const
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual const char * ClassName() const
virtual Bool_t InheritsFrom(const char *classname) const
virtual void Draw(Option_t *option="")
virtual void Info(const char *method, const char *msgfmt,...) const
void AddExec(const char *name, const char *command) override
TList * GetListOfPrimitives() const override
void SaveAs(const char *filename="", Option_t *option="") const override
const char * GetName() const override
virtual void SetLabel(const char *label)
const char * GetTitle() const override
virtual TText * AddText(const char *label)
void Draw(Option_t *option="") override
const char * GetName() const override
virtual void SetName(const char *name="")
virtual void SetBorderSize(Int_t bordersize=4)
Double_t * GetPositionY() const
virtual Int_t Search(const TH1 *hist, Double_t sigma=2, Option_t *option="", Double_t threshold=0.05)
Double_t * GetPositionX() const
Bool_t EndsWith(const char *pat, ECaseCompare cmp=kExact) const
const char * Data() const
Bool_t EqualTo(const char *cs, ECaseCompare cmp=kExact) const
TString & Prepend(char c, Ssiz_t rep=1)
virtual Int_t Sizeof() const
void Form(const char *fmt,...)
TString & Remove(EStripType s, char c)
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
TString & ReplaceAll(const char *s1, const char *s2)
void SetOptTitle(Int_t tit=1)
void SetPadTopMargin(Float_t margin=0.1)
void SetOptStat(Int_t stat=1)
void SetPadBottomMargin(Float_t margin=0.1)
void SetFrameFillColor(Color_t color=1)
void SetPadRightMargin(Float_t margin=0.1)
void SetTitleFont(Style_t font=62, Option_t *axis="X")
void SetPadTickY(Int_t ticky)
void SetTitleOffset(Float_t offset=1, Option_t *axis="X")
void SetPadTickX(Int_t tickx)
void SetPalette(Int_t ncolors=kBird, Int_t *colors=nullptr, Float_t alpha=1.)
void SetLabelFont(Style_t font=62, Option_t *axis="X")
void SetPadLeftMargin(Float_t margin=0.1)
void SetTitleSize(Float_t size=0.02, Option_t *axis="X")
void SetNdivisions(Int_t n=510, Option_t *axis="X")
void SetHatchesSpacing(Double_t h)
void SetHatchesLineWidth(Int_t l)
void SetLabelSize(Float_t size=0.04, Option_t *axis="X")
Bool_t cd(const char *path)
virtual UserGroup_t * GetUserInfo(const char *user=nullptr)
virtual Bool_t AccessPathName(const char *path, EAccessMode mode=kFileExists)
virtual const char * BaseName(const char *pathname)
virtual char * ExpandPathName(const char *path)
virtual void Modified(Bool_t flag=1)=0
virtual void SetLogx(Int_t value=1)=0
virtual Double_t GetUymax() const=0
virtual TFrame * GetFrame()=0
virtual Int_t GetEventX() const=0
virtual TObject * GetSelected() const=0
virtual void SetLogz(Int_t value=1)=0
virtual Double_t AbsPixeltoX(Int_t px)=0
virtual Double_t GetUxmax() const=0
virtual Double_t AbsPixeltoY(Int_t py)=0
virtual Double_t GetUymin() const=0
virtual Int_t GetEvent() const=0
virtual Double_t GetUxmin() const=0
virtual void SetLogy(Int_t value=1)=0
virtual Int_t GetEventY() const=0
void Clear(Option_t *option="") override=0
RVec< PromoteType< T > > abs(const RVec< T > &v)
void update(const LAYERDATA &prevLayerData, LAYERDATA &currLayerData, double factorWeightDecay, EnumRegularization regularization)
Double_t Min(Double_t a, Double_t b)
Double_t Sign(Double_t a, Double_t b)
constexpr Double_t DegToRad()
Double_t Max(Double_t a, Double_t b)