4 #include "KVIDGridEditor.h"
6 #include "TObjString.h"
13 #include <KeySymbols.h>
14 #include <KVSpIdGUI.h>
15 #include <KVZAFinderDialog.h>
16 #include "KVTreeAnalyzer.h"
17 #include <KVHistogram.h>
18 #include "KVTestIDGridDialog.h"
19 #include "KVItvFinderDialog.h"
36 fSpiderOption =
"DRLF";
37 gStyle->SetPalette(55);
40 gStyle->SetPadLeftMargin(0.1);
41 gStyle->SetPadBottomMargin(0.1);
42 gStyle->SetPadTopMargin(0.1);
43 gStyle->SetPadRightMargin(0.1);
44 gStyle->SetPadTickX(1);
45 gStyle->SetPadTickY(1);
46 gStyle->SetNdivisions(310,
"xyz");
47 gStyle->SetLabelSize(0.05,
"xyz");
48 gStyle->SetTitleSize(0.05,
"xyz");
49 gStyle->SetTitleOffset(1.,
"xzy");
50 gStyle->SetTitleFont(42,
"xyz");
51 gStyle->SetLabelFont(42,
"xyz");
52 gStyle->SetOptStat(0);
53 gStyle->SetOptTitle(0);
61 SetName(
"gIDGridEditor");
68 AddMethod(
"SaveCurrentGrid");
69 AddMethod(
"SpiderIdentification");
70 AddMethod(
"ChangeMasses");
71 AddMethod(
"ChangeCharges");
72 AddMethod(
"SelectLinesByZ");
73 AddMethod(
"MakeScaleX");
74 AddMethod(
"MakeScaleY");
75 AddMethod(
"SetSelectedColor");
76 AddMethod(
"SetPointStyle");
77 AddMethod(
"SetPointSize");
78 AddMethod(
"SetVarXVarY");
79 AddMethod(
"SetRunList");
80 AddMethod(
"AddParameter");
81 AddMethod(
"SetXScaleFactor");
82 AddMethod(
"SetYScaleFactor");
83 AddMethod(
"SetSVGMode");
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);
96 lplabel->SetOwner(kTRUE);
98 lplabel2->SetOwner(kTRUE);
100 lplabel3->SetOwner(kTRUE);
102 lplabel4->SetOwner(kTRUE);
104 lplabel5->SetOwner(kTRUE);
122 fCanvas =
new KVIDGridEditorCanvas(Form(
"%sCanvas", GetName()), Form(
"%sCanvas", GetName()), 800, 600);
123 fCanvas->AddExec(
"transform",
"gIDGridEditor->MakeTransformation()");
124 fCanvas->AddExec(
"recommence",
"gIDGridEditor->SelectLabel()");
128 dynamic_cast<TGMainFrame*
>(fCanvas->GetCanvasImp())->Connect(
"CloseWindow()",
"KVIDGridEditor",
this,
"CanvasWasClosed()");
129 fPad = fCanvas->cd();
132 if (TheHisto) TheHisto->Draw(
"col");
133 if (TheGrid) TheGrid->Draw();
175 itrans = iact = iopt = 0;
194 SelectedColor = kOrange + 1;
214 dynamic_cast<TGMainFrame*
>(fCanvas->GetCanvasImp())->Disconnect(
"CloseWindow()",
"KVIDGridEditor",
this,
"CanvasWasClosed()");
237 SelectedColor = kOrange + 1;
239 ResetColor(ListOfLines);
240 ListOfLines->Clear();
242 if (option.Contains(
"AL")) {
253 if (!IsClosed()) TheGrid->UnDraw();
261 lplabel->Execute(
"SetTextSize",
"0.625");
262 lplabel->Execute(
"SetFillColor",
"kWhite");
263 lplabel2->Execute(
"SetTextSize",
"0.625");
264 lplabel2->Execute(
"SetFillColor",
"kWhite");
265 lplabel3->Execute(
"SetTextSize",
"0.6");
266 lplabel3->Execute(
"SetFillColor",
"kWhite");
267 lplabel4->Execute(
"SetTextSize",
"0.6");
268 lplabel4->Execute(
"SetFillColor",
"kWhite");
270 lplabel->Execute(
"SetBorderSize",
"1");
271 lplabel2->Execute(
"SetBorderSize",
"1");
272 lplabel3->Execute(
"SetBorderSize",
"1");
273 lplabel4->Execute(
"SetBorderSize",
"1");
274 lplabel5->Execute(
"SetBorderSize",
"1");
290 TString dir(
"$SVGDOC");
291 if (gSystem->ExpandPathName(dir)) dir =
".";
292 fCanvas->SaveAs(Form(
"%s/gIDGridEditorPrint-%d.png", dir.Data(), fSVGIndex));
294 if (!gSystem->AccessPathName(Form(
"%s/gIDGridEditorPrint-%d.png", dir.Data(), fSVGIndex))) fSVGIndex++;
350 if (gIDGridEditor ==
this) gIDGridEditor = 0x0;
351 dynamic_cast<TGMainFrame*
>(
fCanvas->GetCanvasImp())->Disconnect(
"CloseWindow()",
"KVIDGridEditor",
this,
"CanvasWasClosed()");
414 gStyle->SetOptTitle(0);
415 gStyle->SetOptStat(0);
437 Double_t y1 = 0.90 - i * 0.06;
438 Double_t y2 = y1 - 0.05;
440 TPaveLabel* templabel = 0;
442 templabel =
new TPaveLabel(x1, y1, x2, y2,
"+",
"NDC");
443 templabel->SetName(templabel->GetTitle());
444 templabel->SetFillColor(kWhite);
448 y1 = 0.90 - i * 0.06;
451 modulator =
new TPaveLabel(x1, y1, x2, y2, Form(
"%d",
imod),
"NDC");
452 modulator->SetName(templabel->GetTitle());
457 y1 = 0.90 - i * 0.06;
460 templabel =
new TPaveLabel(x1, y1, x2, y2,
"-",
"NDC");
461 templabel->SetName(templabel->GetTitle());
462 templabel->SetFillColor(kWhite);
477 Double_t x1 = 0.10 +
itrans * 0.06;
478 Double_t x2 = x1 + 0.05;
480 TPaveLabel* templabel = 0;
482 templabel =
new TPaveLabel(x1, y1, x2, y2, label.Data(),
"NDC");
483 templabel->SetName(templabel->GetTitle());
499 Double_t x2 = 0.90 -
iact * 0.06;
500 Double_t x1 = x2 - 0.05;
502 TPaveLabel* templabel = 0;
504 templabel =
new TPaveLabel(x1, y1, x2, y2, label.Data(),
"NDC");
505 templabel->SetName(templabel->GetTitle());
521 Double_t y1 = 0.10 +
iopt * 0.06;
522 Double_t y2 = y1 + 0.05;
524 TPaveLabel* templabel = 0;
526 templabel =
new TPaveLabel(x1, y1, x2, y2, label.Data(),
"NDC");
527 templabel->SetName(templabel->GetTitle());
528 thelist->
Add(templabel);
545 if (!the_directory)
return;
546 TIter next_key(the_directory->GetListOfKeys());
548 while ((key = (TKey*)next_key())) {
549 if (key->IsFolder()) {
553 TString key_class = key->GetClassName();
554 if (key_class.Contains(
"TH2")) hist_names += Form(
" %s", key->GetName());
582 TIter nextmem(gROOT->GetList());
584 while ((obj = nextmem())) {
586 if (obj->InheritsFrom(
"TH2")) histos.
Add(
new TObjString(obj->GetName()));
591 TIter next(gROOT->GetListOfFiles());
592 while ((f = (TFile*)next())) {
594 if (!strcmp(gSystem->BaseName(f->GetName()),
"DataBase.root"))
continue;
597 HistosNames.
Begin(
" ");
598 while (!HistosNames.
End()) {
600 if (g !=
"gIDGridEditorDefaultHistogram") histos.
Add(
new TObjString(g.Data()));
605 TIter nextc(gROOT->GetListOfCanvases());
607 while ((canv = (TCanvas*)nextc())) {
609 if (strcmp(canv->GetName(),
"gIDGridEditorCanvas")) {
610 TIter next_step1(canv->GetListOfPrimitives());
612 while ((obj1 = next_step1())) {
614 if (obj1->InheritsFrom(
"TPad")) {
616 TIter next_step2(((TPad*)obj1)->GetListOfPrimitives());
617 while ((obj2 = next_step2())) {
618 printf(
"%s\n", obj2->GetName());
619 if (obj2->InheritsFrom(
"TH2")) {
621 histos.
Add(
new TObjString(obj2->GetName()));
625 else if (obj1->InheritsFrom(
"TH2")) {
627 histos.
Add(
new TObjString(obj1->GetName()));
639 if (obj->
IsType(
"Histo") && obj->
GetHisto()->InheritsFrom(
"TH2")) {
641 histos.
Add(
new TObjString(obj->GetName()));
646 TObjString* s = (TObjString*)histos.
FindObject(
"gIDGridEditorDefaultHistogram");
654 while ((s = (TObjString*)ith())) {
655 HistosNames += Form(
" %s", s->GetString().Data());
679 Iter = str.Next(kTRUE);
681 result = Iter.Data();
688 Iter = str.Next(kTRUE);
690 result = Iter.Data();
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());
739 if (Choices.Contains(
" ")) {
740 new KVDropDownDialog(gClient->GetDefaultRoot(),
"Choose a histogram :", Choices.Data(), Default.Data(), &Answer, &okpressed);
746 else Answer = Default;
748 if (!Answer.Contains(
"Current") &&
ownhisto) {
754 if ((!Answer.Contains(
"Current")) && (!Answer.Contains(
"Dummy"))) {
762 else Answer =
"Dummy";
765 if (Answer.Contains(
"Dummy")) {
766 TString hname = Form(
"%sDefaultHistogram", GetName());
767 Double_t Xmax = 4096.;
768 Double_t Ymax = 4096;
779 if ((TmpH = (TH2*)gROOT->FindObject(hname.Data())))
delete TmpH;
780 TheHisto =
new TH2F(hname.Data(), hname.Data(), 2048, 0, Xmax, 2048, 0, Ymax);
784 else if (!hh->InheritsFrom(
"TH2")) {
785 cout <<
"ERROR: KVIDGridEditor::SetHisto(): '" << hh->GetName() <<
"' must be a 2D histogram !" << endl;
821 TIter nextc(gROOT->GetListOfCanvases());
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;
896 Bool_t sethisto =
true;
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();
910 if (proposename && (!strcmp(
TheHisto->GetName(), Answer.Data()))) sethisto =
false;
914 if (!gIDGridManager)
return;
916 cout <<
"WARNING: KVIDGridEditor::SetGrid(): Unknown grid named '" << GridName.Data() <<
"' !" << endl;
919 else SetGrid(tempgrid, sethisto);
932 fPivot->SetMarkerStyle(2);
934 fPivot->SetMarkerColor(kRed);
935 fPivot->SetName(
"ThePivot");
937 else fPivot->SetPoint(0, xx0, yy0);
950 fPivot->SetMarkerStyle(2);
952 fPivot->SetMarkerColor(kBlack);
953 fPivot->SetName(
"ThePiedestal");
955 else fPivot->SetPoint(1, ppdx, ppdy);
964 Int_t
event =
fPad->GetEvent();
965 if (event == kMouseMotion)
return;
966 TObject* select =
fPad->GetSelected();
969 if (!select->InheritsFrom(
"TPaveLabel"))
return;
971 if (
fSVGMode && ((event == kButton1Down) || (event == kButton1Double) || (event == kButton1Shift))) {
973 if (event == kButton1Down) tmpStr =
"click";
974 else if (event == kButton1Double) tmpStr =
"double click";
975 else if (event == kButton1Shift) tmpStr =
"shift click";
977 Int_t px =
fPad->AbsPixeltoX(
fPad->GetEventX());
978 Int_t py =
fPad->AbsPixeltoY(
fPad->GetEventY());
980 TLatex* mouse =
new TLatex(px, py, tmpStr.Data());
982 if (mouse->GetX() >= 0.5) mouse->SetTextAlign(32);
983 else mouse->SetTextAlign(12);
991 TPaveLabel* label = (TPaveLabel*)select;
992 if (event == kButton1Down) {
993 Int_t color = label->GetFillColor();
994 if (
lplabel->Contains(label)) {
996 if (color == kWhite || color == kBlack) label->SetFillColor(kRed);
997 else if (color == kRed) label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1000 else if (
lplabel2->Contains(label)) {
1001 label->SetFillColor(kRed);
1005 else if (
lplabel4->Contains(label)) {
1008 else if (
lplabel3->Contains(label)) {
1010 if (color == kWhite || color == kBlack) label->SetFillColor(kGreen);
1011 if (color == kGreen) label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1017 label->SetFillColor(kGreen);
1022 else if (event == kButton1Up) {
1024 label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1028 label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1032 else if (event == kButton1Double) {
1034 label->SetFillColor(kGreen);
1039 else if (event == kButton1Shift) {
1041 label->SetFillColor(kGreen);
1045 else if (
lplabel3->Contains(label)) {
1062 Int_t
event =
fPad->GetEvent();
1063 TObject* select =
fPad->GetSelected();
1065 if (
fSVGMode && ((event == kButton1Down) || (event == kButton1Double) || (event == kButton1Shift) || (event == kWheelUp) || (event == kWheelDown))) {
1067 if (event == kButton1Down) tmpStr =
"click";
1068 else if (event == kButton1Double) tmpStr =
"double click";
1069 else if (event == kButton1Shift) tmpStr =
"shift click";
1070 else if (event == kWheelUp) tmpStr =
"wheel up";
1071 else if (event == kWheelDown) tmpStr =
"wheel down";
1073 Int_t px =
fPad->AbsPixeltoX(
fPad->GetEventX());
1074 Int_t py =
fPad->AbsPixeltoY(
fPad->GetEventY());
1076 TLatex* mouse =
new TLatex(px, py, tmpStr.Data());
1078 if (mouse->GetX() >= 0.5) mouse->SetTextAlign(32);
1079 else mouse->SetTextAlign(12);
1088 if (((event == kMouseMotion) || (event == kButton1Motion)) && (
TheHisto)) {
1096 Int_t px =
fPad->GetEventX();
1097 Int_t py =
fPad->GetEventY();
1099 Double_t ppx =
fPad->AbsPixeltoX(px);
1100 Double_t ppy =
fPad->AbsPixeltoY(py);
1103 Int_t X0 = ax->GetFirst();
1104 Int_t X1 = ax->GetLast();
1105 Int_t NbinsX = ax->GetNbins();
1106 px = ax->FindBin(ppx);
1108 Double_t ddX = (X1 + X0) * 0.5 - px;
1109 Double_t distX = TMath::Abs(ddX) / (X1 - X0);
1110 if (distX >= 0.5)
return;
1113 Int_t Y0 = ay->GetFirst();
1114 Int_t Y1 = ay->GetLast();
1115 Int_t NbinsY = ay->GetNbins();
1116 py = ay->FindBin(ppy);
1118 Double_t ddY = (Y1 + Y0) * 0.5 - py;
1119 Double_t distY = TMath::Abs(ddY) / (Y1 - Y0);
1120 if (distY >= 0.5)
return;
1122 if ((distX <= size) && (distY <= size))
return;
1124 dX = TMath::Nint(ddX * (0.05 + 0.05 *
venermode));
1125 dY = TMath::Nint(ddY * (0.05 + 0.05 *
venermode));
1127 if (TMath::Abs(dX) < 1) dX = TMath::Sign(1., ddX);
1128 if (TMath::Abs(dY) < 1) dY = TMath::Sign(1., ddY);
1132 if ((X0 - dX > 0) && (X1 - dX < NbinsX)) {
1133 ax->SetRange(X0 - dX, X1 - dX);
1136 if ((Y0 - dY > 0) && (Y1 - dY < NbinsY)) {
1137 ay->SetRange(Y0 - dY, Y1 - dY);
1146 if (select->InheritsFrom(
"TPaveLabel"))
return;
1149 if ((event == kButton1Up) && (
dlmode) && (select)) {
1163 if ((event == kButton1Up) && (select) && (!
dlmode)) {
1164 if (select->InheritsFrom(
"KVIDentifier")) {
1192 if ((event == kButton1Shift) && (select) && (!
dlmode)) {
1193 if (!select->InheritsFrom(
"KVIDZALine") ||
ListOfLines->IsEmpty());
1198 Int_t SeleZ = line->
GetZ();
1200 Int_t SeleA = line->
GetA();
1201 Int_t zmin, zmax, amin, amax;
1202 if (LastZ == SeleZ) {
1205 amin = TMath::Min(LastA, SeleA);
1206 amax = TMath::Max(LastA, SeleA);
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)) {
1255 if (event == kButton1Double) {
1257 else if (!select->InheritsFrom(
"KVIDentifier")) {
1258 Int_t xx =
fPad->GetEventX();
1259 Int_t yy =
fPad->GetEventY();
1261 x0 =
fPad->AbsPixeltoX(xx);
1262 y0 =
fPad->AbsPixeltoY(yy);
1269 if ((event == kButton1Shift) && (!
drawmode)) {
1270 if (!select->InheritsFrom(
"KVIDentifier")) {
1271 Int_t xx =
fPad->GetEventX();
1272 Int_t yy =
fPad->GetEventY();
1274 x0 =
fPad->AbsPixeltoX(xx);
1275 y0 =
fPad->AbsPixeltoY(yy);
1282 if ((event == kWheelUp) || (event == kWheelDown)) {
1283 Int_t sign = (
event == kWheelUp ? 1 : -1);
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);
1312 Double_t ratio1 = (
xmin -
fPad->GetUxmin()) / (
fPad->GetUxmax() -
fPad->GetUxmin());
1313 Double_t ratio2 = (
xmax -
fPad->GetUxmin()) / (
fPad->GetUxmax() -
fPad->GetUxmin());
1315 if ((ratio2 - ratio1 > 0.05)) {
1321 ratio1 = (
ymin -
fPad->GetUymin()) / (
fPad->GetUymax() -
fPad->GetUymin());
1322 ratio2 = (
ymax -
fPad->GetUymin()) / (
fPad->GetUymax() -
fPad->GetUymin());
1324 if ((ratio2 - ratio1 > 0.05)) {
1338 TString commande(label->GetName());
1340 if (commande.Contains(
"#Leftarrow"))
Undo();
1341 else if (commande.Contains(
"0"))
SetPivot(0, 0);
1342 else if (commande.Contains(
"#odot"))
Unzoom();
1343 else if (commande.Contains(
"Lz"))
SetLogz();
1344 else if (commande.Contains(
"Ly"))
SetLogy();
1345 else if (commande.Contains(
"Lx"))
SetLogx();
1346 else if (commande.Contains(
"Cut"))
NewCut();
1347 else if (commande.Contains(
"Line"))
NewLine();
1348 else if (commande.Contains(
"Edit"))
SetEditable(label);
1349 else if (commande.Contains(
"Fit")) {
1350 label->SetFillColor(kRed);
1353 label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1356 else if (commande.Contains(
"Test")) {
1357 label->SetFillColor(kRed);
1360 label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1363 else if (commande.Contains(
"Mass")) {
1364 label->SetFillColor(kRed);
1367 label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1370 else if (commande.Contains(
"Info")) {
1371 label->SetFillColor(kRed);
1378 else if (commande.Contains(
"More")) {
1379 label->SetFillColor(kRed);
1382 label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1385 else if (commande.Contains(
"Delete")) {
1387 Int_t color = label->GetFillColor();
1388 if (color == kRed) {
1389 label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1393 else if (color == kWhite || color == kBlack) {
1394 label->SetFillColor(kRed);
1399 else cout <<
"WARNING: KVIDGridEditor::DispatchOrder(): unknown order '" << commande <<
"' !" << endl;
1409 Bool_t iseditable =
TheGrid->IsEditable();
1411 if (iseditable) label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1412 else label->SetFillColor(kRed);
1414 else label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1428 TString title(label);
1429 Int_t color = ((TPaveLabel*)
lplabel3->
At(0))->GetFillColor();
1431 if (title.Contains(
"All")) {
1447 if (title.Contains(
"Select")) {
1448 if (color == kWhite || color == kBlack) {
1453 if (color == kGreen) {
1470 label->SetFillColor(kRed);
1476 resname.Form(
"%s.IDClass",
TheGrid->ClassName());
1477 TString cut_choices = gEnv->GetValue(resname.Data(),
"");
1478 resname.Form(
"%s.DefaultIDClass",
TheGrid->ClassName());
1479 TString cut_default = gEnv->GetValue(resname.Data(),
"");
1483 if (cut_choices.Contains(
" ")) {
1485 "Choose class of new identifier :",
1490 if (!okpressed)
return;
1492 else cut_class = cut_choices;
1496 label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1500 if (
fDebug) cout <<
"INFO: KVIDGridEditor::NewLine(): New Line has been added to the current grid..." << endl;
1513 label->SetFillColor(kRed);
1519 resname.Form(
"%s.CutClass",
TheGrid->ClassName());
1520 TString cut_choices = gEnv->GetValue(resname.Data(),
"");
1521 resname.Form(
"%s.DefaultCutClass",
TheGrid->ClassName());
1522 TString cut_default = gEnv->GetValue(resname.Data(),
"");
1523 cut_default.ReplaceAll(
" ",
"");
1524 cut_default.ReplaceAll(
"KVID",
"");
1527 cut_types.ReplaceAll(
"KVID",
"");
1530 if (cut_choices.Contains(
" ")) {
1531 if (!strcmp(cut_default,
"")) {
1532 cut_types.
Begin(
" ");
1533 cut_default = cut_types.
Next();
1536 "Choose class of new cut :",
1542 label->SetFillColor(kWhite);
1548 else cut_class = cut_types;
1550 cut_class.Prepend(
"KVID");
1551 if (!cut_class.Contains(
"ZoneContour"))
TheGrid->
DrawAndAdd(
"CUT", cut_class.Data());
1554 label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1557 if (
fDebug) cout <<
"INFO: KVIDGridEditor::NewCut(): New Cut has been added to the current grid..." << endl;
1570 label->SetFillColor(kRed);
1575 TString info_choices = gEnv->GetValue(Form(
"%s.InfoClass",
TheGrid->ClassName()),
"");
1576 if (info_choices ==
"") info_choices = gEnv->GetValue(Form(
"%s.InfoClass",
"KVIDGraph"),
"");
1578 TString info_default = gEnv->GetValue(Form(
"%s.DefaultInfoClass",
TheGrid->ClassName()),
"");
1579 if (info_choices ==
"") info_choices = gEnv->GetValue(Form(
"%s.DefaultInfoClass",
"KVIDGraph"),
"");
1581 info_default.ReplaceAll(
" ",
"");
1582 info_default.ReplaceAll(
"KVID",
"");
1584 KVString info_types = info_choices;
1585 info_types.ReplaceAll(
"KVID",
"");
1588 if (info_choices.Contains(
" ")) {
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(),
1600 label->SetFillColor(kWhite);
1606 else info_class = info_types;
1608 info_class.Prepend(
"KVID");
1611 Info(
"NewInfo",
"Adding new info contour or line of class '%s'", info_class.Data());
1613 label->SetFillColor(
fBlackMode ? kBlack : kWhite);
1616 if (
fDebug) cout <<
"INFO: KVIDGridEditor::NewInfo(): New info has been added to the current grid..." << endl;
1626 return fPivot->GetX()[0];
1635 return fPivot->GetY()[0];
1645 return fPivot->GetX()[1];
1655 return fPivot->GetY()[1];
1813 if (
fDebug) cout <<
"INFO: KVIDGridEditor::TestGrid(): testing the current grid..." << endl;
1827 TMethod* m = fitter->IsA()->GetMethodAny(
"FitPanel");
1828 TContextMenu* cm =
new TContextMenu(
"FitPanel",
"Context menu for KVVirtualIDFitter::FitPanel");
1829 cm->Action(fitter, m);
1832 if (
fDebug) cout <<
"INFO: KVIDGridEditor::FitGrid(): fitting grid '" <<
TheGrid->
GetName() <<
"'..." << endl;
1848 new KVDropDownDialog(gClient->GetDefaultRoot(),
"Choose an action :", Choices.Data(), Default.Data(), &Answer, &okpressed);
1849 if (!okpressed)
return;
1853 else if ((m =
TheGrid->IsA()->GetMethodAllAny(Answer.Data()))) {
1854 TContextMenu* cm =
new TContextMenu(Answer.Data(), Form(
"Context menu for KVIDGridEditor::%s", Answer.Data()));
1858 else if ((m = IsA()->GetMethodAllAny(Answer.Data()))) {
1859 TContextMenu* cm =
new TContextMenu(Answer.Data(), Form(
"Context menu for KVIDGridEditor::%s", Answer.Data()));
1860 cm->Action(
this, m);
1863 else cout <<
"INFO: KVIDGridEditor::SuggestMoreAction(): '" << Answer <<
"' not implemented..." << endl;
1884 Int_t Z = ZL.
Next();
1886 if ((found == -1) || (!line))
continue;
1904 TString currentdir(gSystem->ExpandPathName(
"."));
1912 gClient->GetDefaultRoot(),
1913 "KVIDGridEditor::SaveCurrentGrid", Form(
"Do you wat to save the grid here : %s", fn.Data()),
1914 kMBIconExclamation, kMBYes | kMBNo, &ret_code
1917 if (ret_code == kMBYes) {
1922 static TString dir(gSystem->ExpandPathName(
"."));
1923 const char* filetypes[] = {
1924 "ID Grid files",
"*.dat",
1929 fi.fFileTypes = filetypes;
1930 fi.fIniDir = StrDup(dir);
1932 new TGFileDialog(gClient->GetDefaultRoot(), gClient->GetDefaultRoot(), kFDSave, &fi);
1935 TString filenam(fi.fFilename);
1936 if (filenam.Contains(
"toto")) filenam.ReplaceAll(
"toto",
TheHisto->GetName());
1937 if (!filenam.Contains(
'.')) filenam +=
".dat";
1941 gSystem->cd(currentdir.Data());
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;
1964 int xbin =
TheHisto->GetXaxis()->FindBin(xx);
1965 TH1* hh =
TheHisto->ProjectionY(
"toto", xbin - nbin, xbin + nbin,
"goff");
1966 if (dyref > 0) hh->GetXaxis()->SetRangeUser(yy - dyref * 2, yy + dyref * 2);
1967 int nfound = spec.Search(hh, dyref,
"goff", 0.05);
1968 Double_t* xpeaks = spec.GetPositionX();
1969 Double_t* ypeaks = spec.GetPositionY();
1971 markers.SetOwner(kTRUE);
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");
1999 TString currentdir(gSystem->ExpandPathName(
"."));
2001 if (gSystem->ExpandPathName(dir)) dir =
".";
2003 const char* filetypes[] = {
"Root files",
"*.root",
"All files",
"*", 0, 0};
2005 fi.fFileTypes = filetypes;
2006 fi.fIniDir = StrDup(dir);
2007 new TGFileDialog(gClient->GetDefaultRoot(), gClient->GetDefaultRoot(), kFDOpen, &fi);
2009 if (!(TFile::Open(fi.fFilename))) {
2010 new TGMsgBox(gClient->GetDefaultRoot(), gClient->GetDefaultRoot(),
"ID Grid Editor", Form(
"Could not open file %s", fi.fFilename), 0, kMBOk);
2014 gSystem->cd(currentdir.Data());
2023 TString Default =
"kOrange";
2024 TString Choices = Default;
2026 Choices +=
"kBlack kGreen kBlue kRed kYellow kCyan kMagenta";
2030 new KVDropDownDialog(gClient->GetDefaultRoot(),
"Choose an action :", Choices.Data(), Default.Data(), &Answer, &okpressed);
2031 if (!okpressed)
return;
2073 TString commande(title);
2074 if (commande.Contains(
"+")) {
2077 else if (commande.Contains(
"-")) {
2093 else fPad->SetLogz(1);
2103 else fPad->SetLogy(1);
2113 else fPad->SetLogx(1);
2143 TString username = gSystem->GetUserInfo()->fRealName;
2144 username.ReplaceAll(
",",
"");
2146 new TGMsgBox(gClient->GetDefaultRoot(), gClient->GetDefaultRoot(),
"ID Grid Editor",
2147 Form(
"This will undo all changes to the grid. Are you sure, %s?", username.Data()),
2148 kMBIconExclamation, kMBOk | kMBCancel, &ret_val);
2150 if (ret_val & kMBOk) {
2157 tmplabel->SetFillColor(kWhite);
2167 TPaveLabel* label = 0;
2169 while ((label = (TPaveLabel*)nextlabel())) {
2170 if (label->GetFillColor() == kRed)
return label->GetName();
2185 Double_t step =
TheHisto->GetXaxis()->GetBinWidth(1) * (
imod) * 0.02;
2186 Double_t factor = Sign * step;
2188 ft->SetParameter(0, factor);
2192 if (
fDebug) cout <<
"INFO: KVIDGridEditor::TranslateX(): translation on the X axis (" << (Sign > 0 ?
"+" :
"-") << step <<
") !" << endl;
2206 Double_t step =
TheHisto->GetXaxis()->GetBinWidth(1) * (
imod) * 0.02;
2207 Double_t factor = Sign * step;
2209 ft->SetParameter(0, factor);
2213 if (
fDebug) cout <<
"INFO: KVIDGridEditor::TranslateY(): translation on the Y axis (" << (Sign > 0 ?
"+" :
"-") << step <<
") !" << endl;
2228 Double_t percent = TMath::Abs(0.15 * speed - Sign * 0.05);
2233 if (px == 0) px = (
TheHisto->GetXaxis()->GetFirst() +
TheHisto->GetXaxis()->GetLast()) / 2;
2234 else px =
fPad->AbsPixeltoX(px);
2236 if (py == 0) py = (
TheHisto->GetYaxis()->GetFirst() +
TheHisto->GetYaxis()->GetLast()) / 2;
2237 else py =
fPad->AbsPixeltoY(py);
2240 Int_t NbinsX = ax->GetNbins();
2241 Int_t X0 = ax->GetFirst();
2242 Int_t X1 = ax->GetLast();
2243 Int_t step = TMath::Min(TMath::Max(1, (Int_t)(percent * (X1 - X0))), NbinsX / 2);
2245 X0 = TMath::Min(TMath::Max(X0 + step, 1), X1 - step);
2246 X1 = TMath::Max(TMath::Min(X1 - step, NbinsX), X0);
2247 if (X0 >= X1) X0 = X1 - 1;
2248 if (Sign > 0) dX = (Int_t)(X0 + (X1 - X0) * 0.5 - ax->FindBin(px));
2249 if ((X0 - dX) < 0) ax->SetRange(0, X1 - X0);
2250 else if ((X1 - dX) > ax->GetNbins()) ax->SetRange(ax->GetNbins() - (X1 - X0), ax->GetNbins());
2251 else ax->SetRange(X0 - dX, X1 - dX);
2254 Int_t NbinsY = ax->GetNbins();
2255 Int_t Y0 = ax->GetFirst();
2256 Int_t Y1 = ax->GetLast();
2257 step = TMath::Min(TMath::Max(1, (Int_t)(percent * (Y1 - Y0))), NbinsY / 2);
2259 Y0 = TMath::Min(TMath::Max(Y0 + step, 1), Y1 - step);
2260 Y1 = TMath::Max(TMath::Min(Y1 - step, NbinsY), Y0);
2261 if (Y0 >= Y1) Y0 = Y1 - 1;
2262 if (Sign > 0) dY = (Int_t)(Y0 + (Y1 - Y0) * 0.5 - ax->FindBin(py));
2263 if ((Y0 - dY) < 0) ax->SetRange(0, Y1 - Y0);
2264 else if ((Y1 - dY) > ax->GetNbins()) ax->SetRange(ax->GetNbins() - (Y1 - Y0), ax->GetNbins());
2265 else ax->SetRange(Y0 - dY, Y1 - dY);
2281 Double_t step = 1.*(
imod / 100.);
2282 if (step >= 45.) step = 45.;
2283 Double_t theta = Sign * step * TMath::DegToRad();
2288 frx->SetParameters(
x0,
y0, theta);
2289 fry->SetParameters(
x0,
y0, theta);
2294 if (
fDebug) cout <<
"INFO: KVIDGridEditor::RotateZ(): rotation around the Z axis (" << (Sign > 0 ?
"+" :
"-") << step <<
") !" << endl;
2311 fs->SetParameters(
x0, scaleFactor);
2335 fs->SetParameters(
y0, scaleFactor);
2357 Double_t step = 0.05 * (
imod / 100.);
2358 Double_t factor = 1. + Sign * step;
2363 fs->SetParameters(
x0, factor);
2367 if (
fDebug) Info(
"ScaleX",
"scaling on the X axis (*%f) !", factor);
2381 Double_t step = 0.05 * (
imod / 100.);
2382 Double_t factor = 1. + Sign * step;
2387 fs->SetParameters(
y0, factor);
2391 if (
fDebug) Info(
"ScaleY",
"scaling on the Y axis (*%f) !", factor);
2405 Double_t step = 0.05 * (
imod / 100.);
2406 Double_t factor = 1. + Sign * step;
2411 fs->SetParameters(
x0, factor);
2412 fsy->SetParameters(
y0, factor);
2423 if (
fDebug) Info(
"ScaleXY",
"scaling (*%f) !", factor);
2437 Double_t step = 0.05 * (
imod / 100.);
2438 Double_t factor = 1. + Sign * step;
2444 Double_t x1 = idd->GetX()[0];
2445 Double_t x2 = idd->GetX()[idd->GetN() - 1];
2446 Double_t y1 = idd->GetY()[0];
2447 Double_t y2 = idd->GetY()[idd->GetN() - 1];
2449 Double_t a = (y2 - y1) / (x2 - x1);
2451 Double_t theta = TMath::ATan(a);
2453 frx->SetParameters(x1, y1, -theta);
2454 fry->SetParameters(x1, y1, -theta);
2457 fs->SetParameters(y1, factor);
2460 frx->SetParameters(x1, y1, theta);
2461 fry->SetParameters(x1, y1, theta);
2478 Ident->SetLineColor(
fBlackMode ? kBlue : kBlack);
2479 Ident->SetMarkerColor(
fBlackMode ? kRed : kBlack);
2482 Ident->SetLineColor(kRed);
2483 Ident->SetMarkerColor(kRed);
2486 Ident->SetLineColor(kBlue);
2487 Ident->SetMarkerColor(kBlue);
2499 TIter nextidd(IdentList);
2525 if (
fDebug) cout <<
"INFO: KVIDGridEditor::ForceUpdate(): Canvas and Co has been updated !" << endl;
2540 TPaveLabel* label = 0;
2544 TString tmpStr(tmp);
2547 fKeyShow =
new TPaveText(0.8, 0.8, 0.9, 0.9,
"brNDC");
2557 switch ((EKeySym)py) {
2653 fPad->SetFillStyle(1001);
2654 fPad->GetFrame()->SetFillStyle(1001);
2656 fPad->SetFillColor(kWhite);
2657 fPad->GetFrame()->SetFillColor(kWhite);
2658 gStyle->SetFrameFillColor(kWhite);
2659 gROOT->ForceStyle();
2660 gStyle->SetPalette(55);
2661 TheHisto->GetXaxis()->SetAxisColor(kBlack);
2662 TheHisto->GetYaxis()->SetAxisColor(kBlack);
2663 TheHisto->GetXaxis()->SetLabelColor(kBlack);
2664 TheHisto->GetYaxis()->SetLabelColor(kBlack);
2685 TPaveLabel* dummy = 0;
2686 while ((dummy = (TPaveLabel*)it()))
2688 dummy->SetFillColor(kWhite);
2689 dummy->SetTextColor(kBlack);
2690 dummy->SetLineColor(kBlack);
2697 fPad->SetFillStyle(3905);
2698 fPad->SetFillColor(kBlack);
2699 fPad->GetFrame()->SetFillStyle(3905);
2700 fPad->GetFrame()->SetFillColor(kBlack);
2701 gStyle->SetHatchesSpacing(1.5);
2702 gStyle->SetHatchesLineWidth(17);
2705 fPad->SetFillColor(kBlack);
2706 fPad->GetFrame()->SetFillColor(kBlack);
2707 gStyle->SetFrameFillColor(kBlack);
2708 gROOT->ForceStyle();
2709 gStyle->SetPalette(56);
2710 TheHisto->GetXaxis()->SetAxisColor(kWhite);
2711 TheHisto->GetYaxis()->SetAxisColor(kWhite);
2712 TheHisto->GetXaxis()->SetLabelColor(kWhite);
2713 TheHisto->GetYaxis()->SetLabelColor(kWhite);
2734 TPaveLabel* dummy = 0;
2735 while ((dummy = (TPaveLabel*)it()))
2737 dummy->SetFillColor(kBlack);
2738 dummy->SetTextColor(kWhite);
2739 dummy->SetLineColor(kWhite);
2795 color = label->GetFillColor();
2797 if (color == kWhite || color == kBlack) label->SetFillColor(kGreen);
2798 if (color == kGreen) label->SetFillColor(
fBlackMode ? kBlack : kWhite);
2888 TAxis* xAxis =
TheHisto->GetXaxis();
2890 Int_t XX1 = xAxis->GetFirst();
2891 Int_t XX2 = xAxis->GetLast();
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);
2911 if (sign < 0) axis =
TheHisto->GetXaxis();
2914 Int_t XX1 = axis->GetFirst();
2915 Int_t XX2 = axis->GetLast();
2917 Int_t dX = (Int_t) - 1 * (XX1 - XX2) * 0.1 * speed;
2919 axis->SetRange(XX1 + dX, XX2 - dX);
2932 TAxis* yAxis =
TheHisto->GetYaxis();
2934 Int_t XX1 = yAxis->GetFirst();
2935 Int_t XX2 = yAxis->GetLast();
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);
2964 Int_t color = label->GetFillColor();
2966 if (color == kWhite || color == kBlack) label->SetFillColor(kRed);
2967 else if (color == kRed) label->SetFillColor(
fBlackMode ? kBlack : kWhite);
3027 Int_t Z = ZL.
Next();
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);
3050 Int_t n = ztab.size();
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"
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="")
const KVList * GetCuts() const
TVirtualPad * GetPad() const
const KVList * GetInfos() const
void RevertToLastSavedVersion()
virtual void Identify(Double_t, Double_t, KVIdentificationResult *) const =0
KVIDentifier * GetIdentifier(Int_t Z, Int_t A) const
void FindAxisLimits()
Calculate X/Y min/max of all objects in graph.
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.
virtual void SetEditable(Bool_t editable=kTRUE)
virtual void Initialize()=0
void RemoveCut(KVIDentifier *)
Remove and destroy cut.
const KVList * GetIdentifiers() const
Extended version of KVCanvas used by KVIDGridEditor.
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
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
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)
virtual Int_t GetA() const
virtual Int_t GetZ() const
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
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 TObject * At(Int_t idx) const
virtual void Execute(const char *method, const char *params, Int_t *error=0)
virtual void Add(TObject *obj)
virtual TObject * Remove(TObject *obj)
Remove object from list.
virtual void Delete(Option_t *option="")
virtual TObject * FindObject(const char *name) const
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.