1 #include "KVIDGridManagerGUI.h"
3 #include "KVIDGridManager.h"
13 #include <KVTestIDGridDialog.h>
15 #include <KVIDGUITelescopeChooserDialog.h>
16 #include <KVDropDownDialog.h>
17 #include <KVIdentificationResult.h>
18 #include <KVReconstructedNucleus.h>
20 #include "KVInputDialog.h"
21 #include "KVIDCutLine.h"
22 #include "KVIDCutContour.h"
23 #include "KVVirtualIDFitter.h"
38 fLastSelectedGrid = 0;
47 gIDGridManager->Connect(
"Modified()",
"KVIDGridManagerGUI",
this,
48 "UpdateListOfGrids()");
56 sgm->
AddEntry(
"Selected", M_GRIDS_SAVE_SEL);
57 sgm->
AddEntry(
"Tab", M_GRIDS_SAVE_TAB);
58 sgm->
AddEntry(
"All", M_GRIDS_SAVE_ALL);
59 fMenuFile->AddPopup(
"Save...", sgm);
61 fMenuFile->AddSeparator();
64 sgm->
AddEntry(
"Selected", M_GRIDS_DEL_SEL);
65 sgm->
AddEntry(
"Tab", M_GRIDS_DEL_TAB);
66 sgm->
AddEntry(
"All", M_GRIDS_DEL_ALL);
67 fMenuFile->AddPopup(
"Delete...", sgm);
68 fMenuFile->AddSeparator();
69 fMenuFile->AddEntry(
"&Quit", M_QUIT);
71 fMenuFile->Connect(
"Activated(Int_t)",
"KVIDGridManagerGUI",
this,
72 "HandleGridsMenu(Int_t)");
80 sgm->
AddEntry(
"Runlist", M_GRIDS_SET_RUNLIST);
81 sgm->
AddEntry(
"X Variable", M_GRIDS_SET_VARX);
82 sgm->
AddEntry(
"Y Variable", M_GRIDS_SET_VARY);
84 sgm->
AddEntry(
"Z ID Only", M_GRIDS_SET_ZID);
85 fMenuEdit->AddPopup(
"Set...", sgm);
86 fMenuEdit->AddEntry(
"Clear", M_GRIDS_CLEAR);
87 fMenuEdit->Connect(
"Activated(Int_t)",
"KVIDGridManagerGUI",
this,
88 "HandleGridsMenu(Int_t)");
94 fMenuBar->AddPopup(
"&File", fMenuFile, fMenuBarItemLayout);
95 fMenuBar->AddPopup(
"&Edit", fMenuEdit, fMenuBarItemLayout);
108 const char* xpms[] = {
121 const char* tips[] = {
122 "Open file containing grids",
123 "Save all grids in current file",
126 "Delete selected grid(s)",
127 "Set ID telescopes for grid",
157 const char* method[] = {
162 "DeleteSelectedGrids()",
166 "UpdateListOfGrids()",
181 *buttons[i] = fToolBar->AddButton(
this, &t[i], spacing[i]);
182 (*buttons[i])->Connect(
"Clicked()",
"KVIDGridManagerGUI",
this, method[i]);
183 fTBbuttons[i] = *buttons[i];
208 fGridListTabs =
new TGTab(fHframe, 550, 400);
209 fGridListTabs->Connect(
"Selected(Int_t)",
"KVIDGridManagerGUI",
this,
"TabSelect(Int_t)");
214 fHframe->AddFrame(fGridListTabs,
219 TGLabel* lab1 =
new TGLabel(line_frame,
"CURRENT GRID IDENTIFIERS");
224 fIDLineList->SetDataColumns(5);
225 fIDLineList->SetDataColumn(0,
"Name",
"",
kTextLeft);
228 fIDLineList->SetDataColumn(3,
"OnlyZId",
"OnlyZId",
kTextCenterX);
229 fIDLineList->SetDataColumn(4,
"MassFormula",
"",
kTextCenterX);
230 fIDLineList->GetDataColumn(3)->SetIsBoolean();
231 fIDLineList->ActivateSortButtons();
232 fIDLineList->AllowBrowse(
kFALSE);
237 lab1 =
new TGLabel(line_frame,
"Cuts");
241 fCUTList->SetDataColumns(3);
242 fCUTList->SetDataColumn(0,
"Name",
"",
kTextLeft);
243 fCUTList->SetDataColumn(1,
"# Points",
"GetN",
kTextCenterX);
244 fCUTList->SetDataColumn(2,
"Class",
"ClassName",
kTextCenterX);
246 fCUTList->ActivateSortButtons();
247 fCUTList->AllowBrowse(
kFALSE);
252 lab1 =
new TGLabel(line_frame,
"Infos");
256 fCUTInfoList->SetDataColumns(3);
257 fCUTInfoList->SetDataColumn(0,
"Name",
"",
kTextLeft);
258 fCUTInfoList->SetDataColumn(1,
"# Points",
"GetN",
kTextCenterX);
259 fCUTInfoList->SetDataColumn(2,
"Class",
"ClassName",
kTextCenterX);
262 fCUTInfoList->ActivateSortButtons();
263 fCUTInfoList->AllowBrowse(
kFALSE);
274 SetWindowName(
"ID Grid Manager");
278 Resize(GetDefaultSize());
280 SetWMSize(1200, 600);
292 KVIDGridManagerGUI::~KVIDGridManagerGUI()
296 gIDGridManager->Disconnect(
"Modified()",
this,
"UpdateListOfGrids()");
317 if (fIDGridEditor->IsClosed()) fIDGridEditor->
StartViewer();
321 fSelectedGrid->UpdateLastSavedVersion();
322 fIDGridEditor->SetGrid(fSelectedGrid);
343 static TString dir(
"$(HISTOROOT)");
352 const char* filetypes[] = {
"Root files",
"*.root",
"All files",
"*", 0, 0};
383 cout <<
"Add new grid" << endl;
390 case M_GRIDS_SAVE_SEL:
392 SaveGridsAs(&fSelectedEntries);
395 case M_GRIDS_SAVE_TAB:
397 SaveGridsAs(GetAllGridsInTab());
400 case M_GRIDS_SAVE_ALL:
406 case M_GRIDS_DEL_SEL:
407 DeleteSelectedGrids();
410 case M_GRIDS_DEL_TAB:
414 new TGMsgBox(fClient->GetDefaultRoot(),
this,
"ID Grid Manager",
415 "This will delete all grids in the current tab. Are you sure ?",
417 if (ret_val &
kMBOk) {
418 DeleteAllGridsInTab();
422 case M_GRIDS_DEL_ALL:
427 new TGMsgBox(fClient->GetDefaultRoot(),
this,
"ID Grid Manager",
428 "This will delete all grids. Are you sure ?",
430 if (ret_val &
kMBOk) {
431 gIDGridManager->
Clear();
440 case M_GRIDS_SET_RUNLIST:
443 if (!fSelectedGrid)
break;
444 TString runs = fSelectedGrid->GetRunList();
446 new KVInputDialog(
this,
"Enter list of runs for grid(s):", &runs, &ok_pressed,
447 "Example: 1-10, 13, 22-657");
448 if (!ok_pressed)
break;
449 TIter next(&fSelectedEntries);
456 case M_GRIDS_SET_VARX:
459 if (!fSelectedGrid)
break;
460 TString runs = fSelectedGrid->GetVarX();
462 new KVInputDialog(
this,
"Enter X variable for grid(s):", &runs, &ok_pressed,
464 if (!ok_pressed)
break;
465 TIter next(&fSelectedEntries);
472 case M_GRIDS_SET_VARY:
475 if (!fSelectedGrid)
break;
476 TString runs = fSelectedGrid->GetVarY();
478 new KVInputDialog(
this,
"Enter Y variable for grid(s):", &runs, &ok_pressed,
480 if (!ok_pressed)
break;
481 TIter next(&fSelectedEntries);
488 case M_GRIDS_SET_ZID:
491 if (!fSelectedGrid)
break;
492 Bool_t runs = !fSelectedGrid->HasMassIDCapability();
493 TIter next(&fSelectedEntries);
503 if (!fSelectedGrid)
break;
504 TIter next(&fSelectedEntries);
527 new TGMsgBox(fClient->GetDefaultRoot(),
this,
"ID Grid Manager",
528 "This will delete the selected grids. Are you sure ?",
530 if (ret_val &
kMBOk) {
542 const char* filetypes[] = {
543 "ID Grid files",
"*.dat",
560 SetStatus(
Form(
"Read %d grids from file %s", ngriread, fi.
fFilename));
565 new TGMsgBox(fClient->GetDefaultRoot(),
this,
"ID Grid Manager",
617 fSelectedEntries = fIDGridList->GetSelectedObjects();
618 fSelectedGrid = (
KVIDGraph*)fIDGridList->GetLastSelectedObject();
619 if (!GetNSelected())fSelectedGrid = 0x0;
622 ActivateToolbarButtons();
623 if (!GetNSelected()) SetStatus();
624 else if (GetNSelected() == 1) SetStatus(
Form(
"Selected grid %s (%s)", fSelectedGrid->GetName(), fSelectedGrid->ClassName()));
625 else SetStatus(
Form(
"Selected %d grids, last selected grid %s (%s)", GetNSelected(), fSelectedGrid->GetName(), fSelectedGrid->ClassName()));
639 if (!GetNSelected())
return;
645 if (fLastSelectedGrid == entry) fLastSelectedGrid = 0;
651 fSelectedEntries.Clear();
671 fSelectedEntries.Clear();
686 telescopes.
AddAll(fSelectedGrid->GetIDTelescopes());
688 fClient->GetDefaultRoot(),
this,
kTRUE);
689 if (cancel || !telescopes.
GetEntries())
return;
690 fSelectedGrid->ClearListOfTelescopes();
691 fSelectedGrid->AddIDTelescopes(&telescopes);
703 if (GetNSelected() == 1)
704 fSelectedGrid->Clear();
705 else if (GetNSelected() > 1) {
707 TIter next(&fSelectedEntries);
716 Clist->R__FOR_EACH(
TCanvas, Modified)();
717 Clist->R__FOR_EACH(
TCanvas, Update)();
727 if (!fSelectedGrid)
return;
728 gIDGridManager->Disconnect(
"Modified()",
this,
"UpdateListOfGrids()");
730 fSelectedGrid->Copy(*new_gr);
735 gIDGridManager->Connect(
"Modified()",
"KVIDGridManagerGUI",
this,
"UpdateListOfGrids()");
736 fIDGridList->Sort(0);
737 fIDGridList->Sort(0);
758 Info(
"NewGrid",
"There are %d grids in the manager", gIDGridManager->
GetGrids()->
GetSize());
759 TString default_class =
"KVIDZAGrid";
761 if (gMultiDetArray) {
764 fClient->GetDefaultRoot(),
this);
765 if (cancel || !telescopes->
At(0)) {
766 Info(
"NewGrid",
"No ID telescopes chosen. Grid creation cancelled.");
770 default_class = ((
KVIDTelescope*)telescopes->
At(0))->GetDefaultIDGridClass();
779 choice.
Data(), default_class.
Data(), &id_grid_class, &ok_pressed);
781 Info(
"NewGrid",
"No ID grid class chosen. Grid creation cancelled.");
784 gIDGridManager->Disconnect(
"Modified()",
this,
"UpdateListOfGrids()");
788 gIDGridManager->Connect(
"Modified()",
"KVIDGridManagerGUI",
this,
"UpdateListOfGrids()");
822 const char* filetypes[] = {
823 "ID Grid files",
"*.dat",
840 SetStatus(
Form(
"Saved %d grids in file %s", n_saved, filenam.
Data()));
845 new TGMsgBox(fClient->GetDefaultRoot(),
this,
"ID Grid Manager",
846 Form(
"Could not write file %s", filenam.
Data()), 0,
873 fIDGridList->SetDataColumns(11);
874 fIDGridList->SetDataColumn(0,
"Name",
"",
kTextLeft);
875 fIDGridList->SetDataColumn(2,
"VarX",
"",
kTextLeft);
876 fIDGridList->SetDataColumn(1,
"VarY",
"",
kTextLeft);
877 fIDGridList->SetDataColumn(3,
"ID Telescopes",
"GetNamesOfIDTelescopes",
kTextLeft);
878 fIDGridList->SetDataColumn(4,
"RunList",
"",
kTextLeft);
879 fIDGridList->SetDataColumn(5,
"Identify Z and A?",
"HasMassIDCapability",
kTextCenterX);
880 fIDGridList->GetDataColumn(5)->SetIsBoolean();
881 fIDGridList->SetDataColumn(6,
"# Ident.",
"GetNumberOfIdentifiers",
kTextRight);
882 fIDGridList->SetDataColumn(7,
"# Cuts",
"GetNumberOfCuts",
kTextRight);
883 fIDGridList->SetDataColumn(8,
"# Infos",
"GetNumberOfInfos",
kTextRight);
884 fIDGridList->SetDataColumn(9,
"X scaling",
"GetXScaleFactor",
kTextRight);
885 fIDGridList->SetDataColumn(10,
"Y scaling",
"GetYScaleFactor",
kTextRight);
886 fIDGridList->ActivateSortButtons();
887 fIDGridList->Connect(
"SelectionChanged()",
"KVIDGridManagerGUI",
this,
888 "SelectionChanged()");
889 fIDGridList->SetDoubleClickAction(
"KVIDGridManagerGUI",
this,
"StartEditor(TObject*)");
893 auto grids = gIDGridManager->
GetGrids();
894 fIDGridList->Display(grids);
899 while (! labels.
End()) {
904 fIDGridList->SetDataColumns(10);
905 fIDGridList->SetDataColumn(0,
"Name",
"",
kTextLeft);
906 fIDGridList->SetDataColumn(2,
"VarX",
"",
kTextLeft);
907 fIDGridList->SetDataColumn(1,
"VarY",
"",
kTextLeft);
908 fIDGridList->SetDataColumn(3,
"ID Telescopes",
"GetNamesOfIDTelescopes",
kTextLeft);
909 fIDGridList->SetDataColumn(4,
"RunList",
"",
kTextLeft);
910 fIDGridList->SetDataColumn(5,
"Identify Z and A?",
"HasMassIDCapability",
kTextCenterX);
911 fIDGridList->GetDataColumn(5)->SetIsBoolean();
912 fIDGridList->SetDataColumn(6,
"# Ident.",
"GetNumberOfIdentifiers",
kTextRight);
913 fIDGridList->SetDataColumn(7,
"# Cuts",
"GetNumberOfCuts",
kTextRight);
914 fIDGridList->SetDataColumn(8,
"X scaling",
"GetXScaleFactor",
kTextRight);
915 fIDGridList->SetDataColumn(9,
"Y scaling",
"GetYScaleFactor",
kTextRight);
916 fIDGridList->ActivateSortButtons();
917 fIDGridList->Connect(
"SelectionChanged()",
"KVIDGridManagerGUI",
this,
918 "SelectionChanged()");
919 fIDGridList->SetDoubleClickAction(
"KVIDGridManagerGUI",
this,
"StartEditor(TObject*)");
924 fIDGridList->Display(grids);
943 fIDGridList->SelectionChanged();
968 fIDGridList->SetDataColumns(10);
969 fIDGridList->SetDataColumn(0,
"Name",
"",
kTextLeft);
970 fIDGridList->SetDataColumn(2,
"VarX",
"",
kTextLeft);
971 fIDGridList->SetDataColumn(1,
"VarY",
"",
kTextLeft);
972 fIDGridList->SetDataColumn(3,
"ID Telescopes",
"GetNamesOfIDTelescopes",
kTextLeft);
973 fIDGridList->SetDataColumn(4,
"RunList",
"",
kTextLeft);
974 fIDGridList->SetDataColumn(5,
"Identify Z and A?",
"HasMassIDCapability",
kTextCenterX);
975 fIDGridList->GetDataColumn(5)->SetIsBoolean();
976 fIDGridList->SetDataColumn(6,
"# Ident.",
"GetNumberOfIdentifiers",
kTextRight);
977 fIDGridList->SetDataColumn(7,
"# Cuts",
"GetNumberOfCuts",
kTextRight);
978 fIDGridList->SetDataColumn(8,
"X scaling",
"GetXScaleFactor",
kTextRight);
979 fIDGridList->SetDataColumn(9,
"Y scaling",
"GetYScaleFactor",
kTextRight);
980 fIDGridList->ActivateSortButtons();
981 fIDGridList->Connect(
"SelectionChanged()",
"KVIDGridManagerGUI",
this,
982 "SelectionChanged()");
986 fGridListTabs->MapSubwindows();
987 fGridListTabs->Layout();
988 Int_t ntabs = fGridListTabs->GetCurrent();
997 cout <<
"cf = 0x0 : label=Grids tab name=" <<
998 fGridListTabs->GetTabTab(
"Grids")->GetText()->GetString() << endl;
1003 auto grids = gIDGridManager->
GetGrids();
1004 fIDGridList->Display(grids);
1007 Int_t ntabs = fGridListTabs->GetCurrent();
1013 while (! labels.
End()) {
1016 if (!fGridListTabs->GetTabContainer(lab.
Data())) {
1021 fIDGridList->SetDataColumns(11);
1022 fIDGridList->SetDataColumn(0,
"Name",
"",
kTextLeft);
1023 fIDGridList->SetDataColumn(2,
"VarX",
"",
kTextLeft);
1024 fIDGridList->SetDataColumn(1,
"VarY",
"",
kTextLeft);
1025 fIDGridList->SetDataColumn(3,
"ID Telescopes",
"GetNamesOfIDTelescopes",
kTextLeft);
1026 fIDGridList->SetDataColumn(4,
"RunList",
"",
kTextLeft);
1027 fIDGridList->SetDataColumn(5,
"Identify Z and A?",
"HasMassIDCapability",
kTextCenterX);
1028 fIDGridList->GetDataColumn(5)->SetIsBoolean();
1029 fIDGridList->SetDataColumn(6,
"# Ident.",
"GetNumberOfIdentifiers",
kTextRight);
1030 fIDGridList->SetDataColumn(7,
"# Cuts",
"GetNumberOfCuts",
kTextRight);
1031 fIDGridList->SetDataColumn(8,
"# Infos",
"GetNumberOfInfos",
kTextRight);
1032 fIDGridList->SetDataColumn(9,
"X scaling",
"GetXScaleFactor",
kTextRight);
1033 fIDGridList->SetDataColumn(10,
"Y scaling",
"GetYScaleFactor",
kTextRight);
1034 fIDGridList->ActivateSortButtons();
1035 fIDGridList->Connect(
"SelectionChanged()",
"KVIDGridManagerGUI",
this,
1036 "SelectionChanged()");
1041 fIDGridList->Display(grids);
1043 fGridListTabs->MapSubwindows();
1044 fGridListTabs->Layout();
1045 fGridListTabs->SetTab(fGridListTabs->GetNumberOfTabs() - 1,
kTRUE);
1051 cout <<
"cf = 0x0 : label=" << lab.
Data() <<
" tab name=" <<
1052 fGridListTabs->GetTabTab(lab.
Data())->GetText()->GetString() << endl;
1063 fIDGridList->Display(grids);
1066 if (grids)
delete grids;
1075 Int_t ntabs = fGridListTabs->GetCurrent();
1089 Int_t ntabs = fGridListTabs->GetNumberOfTabs();
1091 for (
Int_t itab = 0; itab < ntabs; itab++) {
1094 KVString lab = fGridListTabs->GetTabTab(itab)->GetString();
1107 fGridListTabs->RemoveTab(itab,
kFALSE);
1112 if (recursive) RemoveEmptyTabs();
1113 fGridListTabs->MapSubwindows();
1114 fGridListTabs->Layout();
1128 if (!fLastSelectedGrid)
return;
1130 KVList* ids = fLastSelectedGrid->GetIdentifiers();
1133 fIDLineList->Display(ids);
1135 fCUTList->Display(fSelectedGrid->GetCuts());
1139 fCUTInfoList->Display(fSelectedGrid->GetInfos());
1159 if (GetNSelected() == 1 && fSelectedGrid) {
1160 KVList* ids = fSelectedGrid->GetIdentifiers();
1163 fIDLineList->Display(ids);
1165 fCUTList->Display(fSelectedGrid->GetCuts());
1168 fCUTInfoList->Display(fSelectedGrid->GetInfos());
1170 if (fLastSelectedGrid) {
1171 fLastSelectedGrid->Disconnect(
"Modified()",
this,
"UpdateListOfLines()");
1173 fSelectedGrid->Connect(
"Modified()",
"KVIDGridManagerGUI",
this,
"UpdateListOfLines()");
1174 fLastSelectedGrid = fSelectedGrid;
1177 fIDLineList->RemoveAll();
1178 fCUTList->RemoveAll();
1179 fCUTInfoList->RemoveAll();
1180 if (fLastSelectedGrid) {
1181 fLastSelectedGrid->Disconnect(
"Modified()",
this,
"UpdateListOfLines()");
1182 fLastSelectedGrid = 0;
1195 for (
int i = 0; i < fNbButtons; i++) fTBbuttons[i]->SetEnabled(
kFALSE);
1197 fTBOpen->SetEnabled();
1198 fTBRefresh->SetEnabled();
1200 fTBNewG->SetEnabled();
1201 fTBOpenRoot->SetEnabled();
1205 if (!GetNSelected())
return;
1208 fTBDelG->SetEnabled();
1210 if (GetNSelected() == 1) {
1212 fTBStartEditor->SetEnabled();
1213 fTBCopyG->SetEnabled();
1214 if (gMultiDetArray) fTBSetIDG->SetEnabled();
1245 if (!fSelectedGrid || GetNSelected() != 1)
return;
1247 resname.
Form(
"%s.IDClass", fSelectedGrid->ClassName());
1249 resname.
Form(
"%s.DefaultIDClass", fSelectedGrid->ClassName());
1255 "Choose class of new identifier :",
1260 if (!okpressed)
return;
1263 cut_class = cut_choices;
1264 SetStatus(
Form(
"Draw ID line (%s) in current pad", cut_class.
Data()));
1265 fSelectedGrid->DrawAndAdd(
"ID", cut_class.
Data());
1297 if (!fSelectedGrid || GetNSelected() != 1)
return;
1299 resname.
Form(
"%s.CutClass", fSelectedGrid->ClassName());
1301 resname.
Form(
"%s.DefaultCutClass", fSelectedGrid->ClassName());
1304 TString cut_types = cut_choices;
1309 "Choose class of new cut :",
1314 if (!okpressed)
return;
1317 cut_class = cut_types;
1318 SetStatus(
Form(
"Draw cut %s in current pad", cut_class.
Data()));
1320 fSelectedGrid->DrawAndAdd(
"CUT", cut_class.
Data());
1338 if (GetNSelected() != 1)
return;
1339 if (!fSelectedGrid)
return;
1343 TIter next(
gPad->GetListOfPrimitives());
1345 while ((o = next())) {
1353 SetStatus(
"No TH2 found in current pad. Select pad containing 2D histo with data to identify.");
1357 SetStatus(
Form(
"Test identification of data in current pad %s.", histo->
GetName()));
1359 new KVTestIDGridDialog(fClient->GetDefaultRoot(),
this, 10, 10, fSelectedGrid, histo);
1374 if (GetNSelected() != 1)
return;
1375 if (!fSelectedGrid)
return;
1379 TIter next(
gPad->GetListOfPrimitives());
1381 while ((o = next())) {
1389 SetStatus(
"No TH2 found in current pad. Select pad containing 2D histo with data to identify.");
1393 SetStatus(
Form(
"Test identification of data in current pad %s.", histo->
GetName()));
1395 TFile* tmpfiles = TestIdentificationWithTree(fSelectedGrid, histo->
GetName());
1397 SetStatus(
"There was a problem with the test ???");
1401 TH2*
id = (
TH2*)tmpfiles->
Get(
"idcode_map");
1425 TFile* KVIDGridManagerGUI::TestIdentificationWithTree(
KVIDGraph* gr,
const Char_t* name_of_data_histo)
1443 printf(
" KVIDGraph::TestIdentificationWithTree l histo %s n existe pas\n", name_of_data_histo);
1455 if ((tid = (
TTree*)
gROOT->FindObject(
"tree_idresults"))) {
1456 printf(
" KVIDGraph::TestIdentificationWithTree effacemenent de l arbre existant\n");
1460 TString fn(
"IDtestTree.root");
1462 TFile* tmpfile =
new TFile(fn.Data(),
"recreate");
1465 tid =
new TTree(
"tree_idresults",
"pid");
1466 Float_t br_xxx, br_yyy, br_stat, br_pid;
1467 Int_t br_idcode, br_isid;
1469 tid->
Branch(
"X", &br_xxx,
"br_xxx/F");
1470 tid->
Branch(
"Y", &br_yyy,
"br_yyy/F");
1471 tid->
Branch(
"Stat", &br_stat,
"br_stat/F");
1473 tid->
Branch(
"PID", &br_pid,
"br_pid/F");
1474 tid->
Branch(
"IDcode", &br_idcode,
"br_idcode/I");
1475 tid->
Branch(
"IsIdentified", &br_isid,
"br_isid/I");
1478 Int_t events_read = 0;
1482 for (
int i = 1; i <=
data->GetNbinsX(); i++) {
1483 for (
int j = 1; j <=
data->GetNbinsY(); j++) {
1490 Axis_t x0 =
data->GetXaxis()->GetBinCenter(i);
1491 Axis_t y0 =
data->GetYaxis()->GetBinCenter(j);
1492 Axis_t wx =
data->GetXaxis()->GetBinWidth(i);
1493 Axis_t wy =
data->GetYaxis()->GetBinWidth(j);
1505 for (
int k = 0; k < kmax; k++) {
1509 if (
gr->IsIdentifiable(x, y)) {
1511 gr->Identify(x, y, idr);
1514 br_idcode =
gr->GetQualityCode();
1525 events_read += (
Int_t) poids;
1526 percent = (1. * events_read / tot_events) * 100.;
1528 if (percent >= cumul) {
1529 cout << (
Int_t) percent <<
"\% processed" << endl;
1548 if (GetNSelected() != 1)
return;
1549 if (!fSelectedGrid)
return;
1550 SetStatus(
Form(
"Fitting grid %s", fSelectedGrid->GetName()));
1552 fitter->
SetGrid(fSelectedGrid);
1553 fitter->
SetPad(fSelectedGrid->GetPad());
1556 cm->Action(fitter,
m);
const Bool_t kIterBackward
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void data
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize UnmapWindow
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize MapSubwindows
Option_t Option_t TPoint TPoint percent
R__EXTERN TRandom * gRandom
char * Form(const char *fmt,...)
char * StrDup(const char *str)
R__EXTERN TSystem * gSystem
static const Char_t * GetListOfPlugins(const Char_t *base)
static void GetTempFileName(TString &base)
static const Char_t * GetKVVersion()
Returns KaliVeda version string.
Ask user to choose between several options in a drop-down list.
ID Grid Manager dialog for choice of ID telescope(s)
Base class for particle identification in a 2D map.
void SetRunList(const char *runlist)
void Clear(Option_t *opt="") override
void SetVarY(const char *v) override
void SetVarX(const char *v) override
void AddIDTelescopes(const TList *)
Associate this graph with all ID telescopes in list.
static KVIDGraph * MakeIDGraph(const Char_t *)
virtual void SetOnlyZId(Bool_t yes=kTRUE)
Identification grid editor GUI ,.
void StartViewer()
Close();.
Graphical interface tool for managing, creating, testing and fitting identification grids.
void TabSelect(Int_t)
called when a new tab is selected
void SaveGridsAs(const TCollection *=0)
void DeleteSelectedGrids()
warning message and confirmation
void HandleGridsMenu(Int_t id)
Receive signals emitted by items selected in Grids menu.
void DeleteAllGridsInTab()
delete the all grids in currently selected tab
void SetIDTelescopes()
Set ID telescopes for selected grid.
void ActivateToolbarButtons()
disable all buttons
void DeleteGrids()
delete the current selected grid, or all currently selected grids if there are more than one
void ClearGrid()
deletes all lines in currently selected grid(s)
void CloseWindow() override
close viewer
void RemoveEmptyTabs()
Recursively remove any empty tabs.
void Clear(Option_t *opt="") override
Delete all grids and empty list, ready to start anew.
void GetListOfIDTelescopeLabels(KVString &)
void DeleteGrid(KVIDGraph *, Bool_t update=kTRUE)
Int_t WriteAsciiFile(const Char_t *filename, const TCollection *selection=0)
KVSeqCollection * GetGridsForIDTelescope(const Char_t *label)
KVSeqCollection * GetGrids()
Bool_t ReadAsciiFile(const Char_t *filename)
Base class for all detectors or associations of detectors in array which can identify charged particl...
Full result of one attempted particle identification.
Enhanced version of ROOT TGListView widget.
Extended TList class which owns its objects by default.
void Sort(Bool_t order=kSortAscending)
Bool_t ReadGridsFromAsciiFile(const Char_t *) const
Nuclei reconstructed from data measured by a detector array .
void SetIdentification(KVIdentificationResult *, KVIDTelescope *)
virtual Float_t GetPID() const
Int_t GetSize() const override
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.
ABC for fitting ID grids with functionals.
static KVVirtualIDFitter * GetDefaultFitter()
void SetPad(TVirtualPad *p)
void SetGrid(KVIDGraph *g)
TMethod * GetMethodAny(const char *method)
virtual void AddAll(const TCollection *col)
virtual Int_t GetEntries() const
virtual Int_t GetSize() const
T * Get(const char *namecycle)
virtual const char * GetValue(const char *name, const char *dflt) const
virtual void SetValue(const char *name, const char *value, EEnvLevel level=kEnvChange, const char *type=nullptr)
static TFile * Open(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=ROOT::RCompressionSetting::EDefaults::kUseCompiledDefault, Int_t netopt=0)
virtual void AddFrame(TGFrame *f, TGLayoutHints *l=nullptr)
virtual TList * GetList() const
void ChangeOptions(UInt_t options) override
void Reset(Option_t *option="") override
void SetBinContent(Int_t bin, Double_t content) override
TObject * At(Int_t idx) const override
const char * GetName() const override
TClass * IsA() const override
virtual Bool_t InheritsFrom(const char *classname) const
virtual Double_t Uniform(Double_t x1, Double_t x2)
const char * Data() const
TString & Prepend(char c, Ssiz_t rep=1)
void Form(const char *fmt,...)
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
TString & ReplaceAll(const char *s1, const char *s2)
Bool_t cd(const char *path)
virtual const char * Getenv(const char *env)
virtual const char * BaseName(const char *pathname)
virtual char * ExpandPathName(const char *path)
virtual Int_t Branch(const char *folder, Int_t bufsize=32000, Int_t splitlevel=99)
virtual void StartViewer()
TFile * OpenFile(const TString &fin)
Double_t Min(Double_t a, Double_t b)