KaliVeda
Toolkit for HIC analysis
KVSimDirGUI.cpp
1 //Created by KVClassFactory on Wed Jul 18 11:55:11 2012
2 //Author: John Frankland,,,
3 
4 #include "KVUnownedList.h"
5 #include "KVSimDirGUI.h"
6 #include "KVDataSetManager.h"
7 #include "KVBatchSystemManager.h"
8 #include "KVDataSet.h"
9 #include "KVDBSystem.h"
10 #include "KVDBRun.h"
11 #include "KVSimFile.h"
12 #include "KVFileDialog.h"
13 #include "KVInputDialog.h"
14 #include "KV2Body.h"
15 #include "TGLabel.h"
16 #include "TGButtonGroup.h"
17 #include "TGMsgBox.h"
18 #include "TSystem.h"
19 #include <KVDataAnalyser.h>
20 #include <KVSimDirFilterAnalyser.h>
21 #include <KVSimReader.h>
22 #include <TG3DLine.h>
23 #include <iostream>
24 using namespace std;
25 
26 #include "KVBatchSystemParametersGUI.h"
27 #include "KVDropDownDialog.h"
28 
30 
31 #ifdef WITH_RSQLITE
32 
35 
37 {
38  // Add a new dataset table for the given KVSimDir object
39 
40  TString ds_table_name = Form("Table_%d", ds_table_number);
41  KVSQLite::table DStable(ds_table_name);
43  DStable.primary_key("Id");
44  DStable.add_column("FileName", KVSQLite::column_type::TEXT);
45  DStable.add_column("TreeInfo", KVSQLite::column_type::TEXT);
46  DStable.add_column("AuxDir", KVSQLite::column_type::INTEGER);
47  DStable.add_column("Filtered", KVSQLite::column_type::INTEGER);
48  DStable.add_column("Events", KVSQLite::column_type::INTEGER);
49  DStable.add_column("DataSet", KVSQLite::column_type::TEXT);
50  DStable.add_column("System", KVSQLite::column_type::TEXT);
52  DStable.add_column("TreeName", KVSQLite::column_type::TEXT);
53  DStable.add_column("BranchName", KVSQLite::column_type::TEXT);
54  DStable.add_column("OrigFile", KVSQLite::column_type::TEXT);
55  DStable.add_column("FiltType", KVSQLite::column_type::TEXT);
56  DStable.add_column("DataQualityAudit", KVSQLite::column_type::TEXT);
57  DStable.add_column("Gemini", KVSQLite::column_type::INTEGER);
58  DStable.add_column("GemDecayPerEvent", KVSQLite::column_type::INTEGER);
59  fConfigDB.add_table(DStable);
60  // update name of dataset table in main table
61  fConfigDB["Datasets"]["Table"] = ds_table_name;
62  fConfigDB.update("Datasets", "Table", Form("Name=\"%s\"", sd->GetName()));
63  return ds_table_name;
64 }
65 
66 
67 
71 
73 {
74  // backwards-compatibility: add missing 'AuxDir' and 'DataQualityAudit' columns
75  // to table for each dataset
76  if(!fConfigDB[ds_table_name].has_column("AuxDir"))
77  fConfigDB.add_column(ds_table_name, "AuxDir", "INTEGER");
78  if(!fConfigDB[ds_table_name].has_column("DataQualityAudit"))
79  fConfigDB.add_column(ds_table_name, "DataQualityAudit", "TEXT");
80  fConfigDB.prepare_data_insertion(ds_table_name);
81  KVSQLite::table& dstable = fConfigDB[ds_table_name];
82  if (sd->GetSimDataList()->GetEntries()) {
83  TIter it1(sd->GetSimDataList());
84  KVSimFile* sf = nullptr;
85  while ((sf = (KVSimFile*)it1())) {
86  dstable["Id"].set_null();
87  dstable["FileName"] = sf->GetName();
88  dstable["TreeInfo"] = sf->GetTitle();
89  dstable["AuxDir"] = (int)sd->IsFromAuxDirectory(sf);
90  dstable["Filtered"] = 0;
91  dstable["Events"] = (Int_t)sf->GetEvents();
92  dstable["TreeName"] = sf->GetTreeName();
93  dstable["BranchName"] = sf->GetBranchName();
94  fConfigDB.insert_data_row();
95  }
96  }
97  if (sd->GetFiltDataList()->GetEntries()) {
98  TIter it1(sd->GetFiltDataList());
99  KVSimFile* sf = nullptr;
100  while ((sf = (KVSimFile*)it1())) {
101  dstable["Id"].set_null();
102  dstable["FileName"] = sf->GetName();
103  dstable["TreeInfo"] = sf->GetTitle();
104  dstable["AuxDir"] = (int)sd->IsFromAuxDirectory(sf);
105  dstable["Filtered"] = 1;
106  dstable["Events"] = (Int_t)sf->GetEvents();
107  dstable["TreeName"] = sf->GetTreeName();
108  dstable["BranchName"] = sf->GetBranchName();
109  dstable["DataSet"] = sf->GetDataSet();
110  dstable["System"] = sf->GetSystem();
111  dstable["Run"] = sf->GetRun();
112  dstable["FiltType"] = sf->GetFilterType();
113  dstable["DataQualityAudit"] = sf->GetDataQualityAudit();
114  dstable["OrigFile"] = sf->GetOriginalFile();
115  dstable["Gemini"] = sf->IsGemini();
116  dstable["GemDecayPerEvent"] = sf->GetGemDecayPerEvent();
117  fConfigDB.insert_data_row();
118  }
119  }
120  fConfigDB.end_data_insertion();
121 }
122 
123 #endif
124 
125 
129 
131  : fGuirc(".kvsimdirguirc")
132 #ifdef WITH_RSQLITE
133  , fConfigDB(gSystem->ExpandPathName("$(HOME)/.kvsimdirguidb"))
134 #endif
135  , menus {this}
136 {
137  // Default constructor
138  // main frame
139 
140  fSelectedSimDir = nullptr;
141  fWithPROOF = kFALSE;
142 
143  // make Aclic create all *.so *.d files in separate temporary directories
144  //this is to avoid problems with KVParticleCondition when using PROOF
146 
147  MainFrame = new TGMainFrame(gClient->GetRoot(), 10, 10, kMainFrame | kVerticalFrame);
148  MainFrame->SetName("KaliVedaSim GUI");
149  MainFrame->SetWindowName("KaliVedaSim GUI");
150  MainFrame->Connect("CloseWindow()", "KVSimDirGUI", this, "Exit()");
151 
152  // create menu bar
154 
155  // mode menu
156  menus.mode.menu = menus.add_popup("&Mode");
157  menus.mode.menu->AddEntry("Analysis", menus.mode.analysis);
158  menus.mode.menu->AddEntry("Filter", menus.mode.filter);
161 
162  // analysis menu
163  menus.analysis.menu = menus.add_popup("&Analysis");
164  menus.analysis.menu->AddEntry("Select analysis class", menus.analysis.select_analysis_class);
166  menus.analysis.generate = menus.add_popup("Generate analysis class...", menus.analysis.menu);
169 
171 
172  // filtering menu
173  menus.filter.menu = menus.add_popup("&Filtering");
174  menus.filter.geometry = menus.add_popup("Detector geometry", menus.filter.menu);
175  if (!gDataSetManager) {
177  dsm->Init();
178  }
179  // datasets have id = 100 + i where i can be given to gDataSetManager->GetDataSet(i)
180  menus.filter.ndatasets = gDataSetManager->GetNtotal();
181  for (int i = 0; i < menus.filter.ndatasets; i++)
182  menus.filter.geometry->AddEntry(gDataSetManager->GetDataSet(i)->GetName(), menus.filter.first_dataset + i);
183 
184  menus.filter.reaction = menus.add_popup("Entrance channel", menus.filter.menu);
186 
189 
191 
192  menus.filter.data_quality = menus.add_popup("Detector performances", menus.filter.menu);
193  for(int i = 0; i<gDataSetManager->GetNtotal(); ++i)
194  fill_dqa_menus_for_dataset(gDataSetManager->GetDataSet(i));
195 
196  menus.filter.id_extension = menus.add_popup("Extend ID range...", menus.filter.menu);
197 
199  menus.filter.options->AddLabel("Filter type");
203  //menus.filter.options->AddEntry("Full", menus.filter.full_filter);
205  menus.filter.options->AddLabel("Kinematics");
211  menus.filter.options->AddLabel("Rotation");
213  menus.filter.options->AddEntry("Randomize phi", menus.filter.random_phi);
215  menus.filter.options->AddLabel("Secondary decay");
217  menus.filter.options->AddEntry("Use Gemini++", menus.filter.use_gemini);
218  menus.filter.options->AddEntry("Add Erot to E*", menus.filter.add_rot_energy);
219 
220  // set default options
223  Kinematics(kKCM);
225  SetRandomPhi(true);
227  SetGeminiDecay(false);
230 
231  fFilterMode = false;
232  fAnalysisMode = true;
233  menus.menu_bar->RemovePopup("Filtering");
234 
235  // add menu bar to main frame
236  MainFrame->AddFrame(menus.menu_bar);//, new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsExpandX, 0, 0, 1, 1));
237  auto lh = new TGHorizontal3DLine(MainFrame);
239 
240  // status bar
243 
245 
247 
248  TGCompositeFrame* vf = new TGVerticalFrame(hftop, 200, 500, kVerticalFrame);
249  // sim dir buttons
250  TGCompositeFrame* hf = new TGHorizontalFrame(vf, 10, 10, kHorizontalFrame);
251  BaddDir = new TGPictureButton(hf, gClient->GetPicture("package_add.xpm"));
252  hf->AddFrame(BaddDir, new TGLayoutHints(kLHintsLeft | kLHintsTop, 3, 2, 2, 2));
253  BaddDir->Resize(40, 40);
254  BaddDir->SetToolTipText("Add dataset");
255  BaddDir->Connect("Clicked()", "KVSimDirGUI", this, "AddSimDir()");
256  BimpSim = new TGPictureButton(hf, gClient->GetPicture("bld_text.xpm"));
257  hf->AddFrame(BimpSim, new TGLayoutHints(kLHintsLeft | kLHintsTop, 2, 2, 2, 2));
258  BimpSim->Resize(40, 40);
259  BimpSim->SetToolTipText("Import simulation");
260  BimpSim->Connect("Clicked()", "KVSimDirGUI", this, "ImportSimulation()");
261  BremDir = new TGPictureButton(hf, gClient->GetPicture("package_delete.xpm"));
262  hf->AddFrame(BremDir, new TGLayoutHints(kLHintsLeft | kLHintsTop, 2, 2, 2, 2));
263  BremDir->Resize(40, 40);
264  BremDir->SetToolTipText("Remove dataset");
265  BremDir->Connect("Clicked()", "KVSimDirGUI", this, "RemSimDir()");
266  BrefreshDir = new TGPictureButton(hf, gClient->GetPicture("refresh2.xpm"));
267  hf->AddFrame(BrefreshDir, new TGLayoutHints(kLHintsLeft | kLHintsTop, 2, 2, 2, 2));
268  BrefreshDir->Resize(40, 40);
269  BrefreshDir->SetToolTipText("Update");
270  BrefreshDir->Connect("Clicked()", "KVSimDirGUI", this, "RefreshSimDir()");
274 
275  vf->AddFrame(hf, new TGLayoutHints(kLHintsTop | kLHintsLeft, 2, 2, 2, 2));
276 
277  // canvas widget
278  fDirListCanvas = new TGCanvas(vf, 172, 400);
279  // canvas viewport
281  // list tree
283 
284  popen = gClient->GetPicture("package_add.xpm");
285  pclose = gClient->GetPicture("package_add.xpm");
286 
290  fDirListTree->Connect("Clicked(TGListTreeItem*,Int_t)", "KVSimDirGUI", this, "SelectSimDir(TGListTreeItem*,Int_t)");
291  fDirListTree->Connect("DoubleClicked(TGListTreeItem*,Int_t)", "KVSimDirGUI", this, "AddAuxDir(TGListTreeItem*,Int_t)");
295 
296  hftop->AddFrame(vf, new TGLayoutHints(kLHintsExpandY | kLHintsTop, 2, 2, 2, 2));
297 
298  /* lists of data in simdir */
299  vf = new TGVerticalFrame(hftop, 600, 500, kVerticalFrame);
300  TGGroupFrame* group = new TGGroupFrame(vf, "Simulations");
301  fLVsimData = new KVListView(KVSimFile::Class(), group, 550, 200);
303  fLVsimData->SetDataColumn(0, "Name");
304  fLVsimData->SetDataColumn(1, "Info", "GetTitle");
305  fLVsimData->SetDataColumn(2, "Events");
308  group->AddFrame(fLVsimData, new TGLayoutHints(kLHintsTop | kLHintsExpandX | kLHintsExpandY, 5, 5, 10, 10));
310  group = new TGGroupFrame(vf, "Filtered Simulations");
311  fLVfiltData = new KVListView(KVSimFile::Class(), group, 550, 200);
313  fLVfiltData->SetDataColumn(0, "Simulation", "GetOriginalFile");
314  fLVfiltData->SetDataColumn(1, "DataSet/Geometry", "GetDataSet");
315  fLVfiltData->SetDataColumn(2, "System/Kinematics", "GetSystem");
316  fLVfiltData->SetDataColumn(3, "Run");
317  fLVfiltData->SetDataColumn(4, "FilterType");
318  fLVfiltData->SetDataColumn(5, "Detector performances", "GetDataQualityAudit");
319  fLVfiltData->SetDataColumn(6, "Gemini", "IsGemini");
320  fLVfiltData->SetDataColumn(7, "Decay/event", "GetGemDecayPerEvent");
321  fLVfiltData->SetDataColumn(8, "Events");
324  group->AddFrame(fLVfiltData, new TGLayoutHints(kLHintsTop | kLHintsExpandX | kLHintsExpandY, 5, 5, 10, 10));
326 
327  hftop->AddFrame(vf, new TGLayoutHints(kLHintsExpandX | kLHintsExpandY, 10, 10, 10, 10));
328  MainFrame->AddFrame(hftop, new TGLayoutHints(kLHintsExpandX | kLHintsExpandY, 1, 1, 1, 1));
329 
330  vf = new TGVerticalFrame(MainFrame, 600, 200, kVerticalFrame);
331  hf = new TGHorizontalFrame(vf, 600, 200, kHorizontalFrame);
332 
333  auto lab = new TGLabel(hf, "Events : ");
334  hf->AddFrame(lab, new TGLayoutHints(kLHintsCenterY | kLHintsLeft, 2, 2, 2, 2));
335  fCBAllEvents = new TGCheckButton(hf, "all");
339  fCBAllEvents->Connect("Toggled(Bool_t)", "KVSimDirGUI", this, "EnableEventNumberEntry(Bool_t)");
341 
342  proof_analysis = new TGPictureButton(hf, gClient->GetPicture("proof_base.xpm"));
343  proof_analysis->Connect("Pressed()", "KVSimDirGUI", this, "EnableProof()");
344  proof_analysis->Connect("Released()", "KVSimDirGUI", this, "DisableProof()");
345  if (!gBatchSystemManager) new KVBatchSystemManager;
346  gBatchSystemManager->GetDefaultBatchSystem()->cd();
347  proof_analysis->SetToolTipText(gBatchSystem->GetTitle());
348  proof_analysis->Resize(40, 40);
350 
351  TGPictureButton* launch_analysis = new TGPictureButton(hf, gClient->GetPicture("query_submit.xpm"));
352  launch_analysis->Connect("Clicked()", "KVSimDirGUI", this, "Run()");
353  launch_analysis->SetToolTipText("Run analysis/filter");
354  launch_analysis->Resize(40, 40);
355 
356  hf->AddFrame(launch_analysis, new TGLayoutHints(kLHintsCenterY | kLHintsRight, 5, 2, 2, 2));
358 
359  vf->AddFrame(hf, new TGLayoutHints(kLHintsExpandX | kLHintsTop, 0, 0, 0, 0));
360  MainFrame->AddFrame(vf, new TGLayoutHints(kLHintsExpandX | kLHintsTop, 10, 10, 15, 10));
361 
362 
364  kMWMFuncAll,
367 
369  MainFrame->MapWindow();
370  // MainFrame->Resize(200,500);
371 #ifdef WITH_RSQLITE
372  // define tables in DB if not already done
373  bool sqlite_conversion = false;
375  sqlite_conversion = true;
376  KVSQLite::table datasets("Datasets");
377  datasets.add_column("Id", "INTEGER");
378  datasets.primary_key("Id");
379  datasets.add_column("Name", "TEXT");
380  datasets.add_column("Directory", "TEXT");
381  datasets.add_column("AuxDir", "TEXT");
382  datasets.add_column("Table", "TEXT");
383  fConfigDB.add_table(datasets);
384  }
385  if (!sqlite_conversion) {
386  // check Datasets table has AuxDir column
387  if (!fConfigDB["Datasets"].has_column("AuxDir"))
388  fConfigDB.add_column("Datasets", "AuxDir", "TEXT");
389  // use existing sqlite database to reconstruct simdirs
391  FillTreeList();
392  return;
393  }
394 #endif
395  // use .guirc to fill the list of sim dirs
396  KVString simdirs = fGuirc.GetValue("SimDirs", "");
397  if (simdirs != "") {
398 #ifdef WITH_RSQLITE
399  if (sqlite_conversion) {
400  // we are converting from the old TEnv back end to sqlite
401  // need to fill table of Datasets
402  fConfigDB.prepare_data_insertion("Datasets");
403  }
404  int ds_table = 0;
405 #endif
406  simdirs.Begin(" ");
407  while (!simdirs.End()) {
408  KVString simdir = simdirs.Next();
409  KVString simdirectory = fGuirc.GetValue(Form("%s.Directory", simdir.Data()), "");
410  KVSimDir* sd = new KVSimDir(simdir, simdirectory);
411 #ifdef WITH_RSQLITE
412  if (sqlite_conversion) {
413  fConfigDB["Datasets"]["Name"] = simdir;
414  fConfigDB["Datasets"]["Directory"] = simdirectory;
415  fConfigDB["Datasets"]["AuxDir"].set_null();
417  }
418 #endif
419  sd->AnalyseDirectory();
420  fListOfDirs.Add(sd);
421  }
422 #ifdef WITH_RSQLITE
423  if (sqlite_conversion) {
425  TIter itdir(&fListOfDirs);
426  KVSimDir* sd = nullptr;
427  while ((sd = (KVSimDir*)itdir())) {
428  // add table for dataset
429  TString ds_table_name = AddTableForDataSet(sd, ds_table);
430  // fill table with infos
431  FillDataSetTableWithInfos(ds_table_name, sd);
432  ++ds_table;
433  }
434  }
435 #endif
436  FillTreeList();
437  }
438 }
439 
440 
441 
443 
445 {
446  EmptyTreeList();
447  TIter next(&fListOfDirs);
448  TObject* o;
449  while ((o = next())) {
450  TGListTreeItem* item0 = fDirListTree->AddItem(NULL, o->GetName());
451  item0->SetPictures(popen, pclose);
452  fDirListTree->CloseItem(item0);
453  }
454 }
455 
456 
457 
459 
461 {
463  while (first) {
466  }
470 }
471 
472 
473 
475 
477 {
478  static TString dir(".");
479  TGFileInfo fi;
480  fi.fIniDir = StrDup(dir);
481  new KVFileDialog(gClient->GetDefaultRoot(), MainFrame, kKVFDDirectory, &fi);
482  if (fi.fFilename) {
483  TString simdirname;
484  Bool_t ok;
485  TString quest;
486  quest.Form("Enter name for dataset %s", fi.fIniDir);
487  new KVInputDialog(MainFrame, quest, &simdirname, &ok);
488  simdirname.ReplaceAll(" ", "_"); //no spaces in name
489  if (ok) {
490  KVSimDir* sd = new KVSimDir(simdirname, fi.fIniDir);
491  sd->AnalyseDirectory();
492  fListOfDirs.Add(sd);
493  FillTreeList();
496  // add to guirc file
497  TString simdirs = fGuirc.GetValue("SimDirs", "");
498  if (simdirs != "") simdirs += " ";
499  simdirs += simdirname;
500  fGuirc.SetValue("SimDirs", simdirs);
501  fGuirc.SetValue(Form("%s.Directory", simdirname.Data()), sd->GetDirectory());
503 #ifdef WITH_RSQLITE
504  //update database
505  int ds_table_num = 0;
506  if (fConfigDB.count("Datasets")) {
507  // get name/number of last dataset table
508  KVNameValueList table_names = fConfigDB.get_name_value_list("Datasets", "Name", "Table");
509  // don't assume tables are sorted according to table number!
510  for(auto& par : table_names)
511  {
512  int tab_num = -1;
513  if(sscanf(par.GetString(), "Table_%d", &tab_num)==1)
514  if(tab_num>ds_table_num) ds_table_num=tab_num;
515  }
516  ++ds_table_num;
517  }
518  fConfigDB.prepare_data_insertion("Datasets");
519  fConfigDB["Datasets"]["Name"] = simdirname;
520  fConfigDB["Datasets"]["Directory"] = sd->GetDirectory();
521  fConfigDB["Datasets"]["AuxDir"].set_null();
524  TString table_name = AddTableForDataSet(sd, ds_table_num);
525  FillDataSetTableWithInfos(table_name, sd);
526 #endif
527  }
528  }
529  dir = fi.fIniDir;
530 }
531 
532 
533 
535 
537 {
538  if (!fSelectedSimDir) return;
542 #ifdef WITH_RSQLITE
543  fConfigDB.select_data("Datasets", "Table", Form("Name=\"%s\"", fSelectedSimDir->GetName()));
544  TString ds_table_name;
545  while (fConfigDB.get_next_result()) ds_table_name = fConfigDB["Datasets"]["Table"].get_data<TString>();
546  fConfigDB.clear_table(ds_table_name);
548 #endif
549 }
550 
551 
552 
554 
556 {
557  if (!fSelectedSimDir) return;
559  // there is no way of removing a name-value pair from a TEnv!!
560  fGuirc.SetValue(Form("%s.Directory", fSelectedSimDir->GetName()), "");
561 #ifdef WITH_RSQLITE
562  // remove from datasets table
563  fConfigDB.select_data("Datasets", "Table", Form("Name = '%s'", fSelectedSimDir->GetName()));
564  TString ds_table_name;
565  while (fConfigDB.get_next_result()) ds_table_name = fConfigDB["Datasets"]["Table"].get_data<TString>();
566  fConfigDB.delete_rows_in_table("Datasets", Form("Name = '%s'", fSelectedSimDir->GetName()));
567  // and delete table with dataset data
568  fConfigDB.delete_table(ds_table_name);
569 #endif
570  delete fSelectedSimDir;
571  fSelectedSimDir = nullptr;
572  FillTreeList();
575  // update guirc file
576  TString simdirs = "";
577  TIter next(&fListOfDirs);
578  KVSimDir* togo;
579  while ((togo = (KVSimDir*)next())) {
580  if (simdirs != "") simdirs += " ";
581  simdirs += togo->GetName();
582  fGuirc.SetValue(Form("%s.Directory", togo->GetName()), togo->GetDirectory());
583  }
584  fGuirc.SetValue("SimDirs", simdirs);
586 }
587 
588 
589 
591 
593 {
595  if (fSelectedSimDir) {
598  BremDir->SetEnabled();
599  BimpSim->SetEnabled();
601  }
602  else {
606  }
607 }
608 
609 
611 
613 {
615  if (fSelectedSimDir) {
618  TGFileInfo fi;
619  fi.fIniDir = StrDup(dir);
620  new KVFileDialog(gClient->GetDefaultRoot(), MainFrame, kKVFDDirectory, &fi);
621  if (fi.fFilename && TString(fi.fIniDir) != fSelectedSimDir->GetDirectory()) {
623  // add info to dataset table in db for next time
624 #ifdef WITH_RSQLITE
625  fConfigDB["Datasets"]["AuxDir"] = fi.fIniDir;
626  fConfigDB.update("Datasets", "AuxDir", Form("Name = '%s'", fSelectedSimDir->GetName()));
627 #endif
628  RefreshSimDir();
629  }
630  }
631  }
632 }
633 
634 
635 
637 
639 {
640  static TString dir(gSystem->pwd());
641  const char* filetypes[] = {
642  "Class header files", "*.h",
643  0, 0
644  };
645  TGFileInfo fi;
646  fi.fIniDir = StrDup(dir);
647  fi.fFileTypes = filetypes;
648  new KVFileDialog(gClient->GetDefaultRoot(), MainFrame, kKVFDOpen, &fi);
649  if (fi.fFilename) {
651  Int_t idot = fAnalClass.name.Index(".");
652  if (idot < 0) return;
653  fAnalClass.name.Remove(idot, 2);
657  }
658  }
659  dir = fi.fIniDir;
660 }
661 
662 
663 
665 
667 {
669 }
670 
671 
672 
682 
684 {
685 // TIter itdqa(menus.filter.data_quality->GetListOfEntries());
686 // while (auto entry = (TGMenuEntry*)itdqa()) {
687 // if (entry->GetPopup())
688 // delete entry->GetPopup();
689 // menus.filter.data_quality->DeleteEntry(entry);
690 // }
691 // menus.filter.DQA_map.clear();
692  // fill data quality menu
693  if(!menus.filter.last_dqa)
694  {
699  menus.filter.data_quality->AddEntry("From file...", menus.filter.last_dqa++);
700 
701  }
702  if (ds->FindDataSetFile("DataQualityAudit.root")) {
703  Info("KVSimDirGUI", "Adding data quality audits for dataset %s...", ds->GetName());
704  std::unique_ptr<TFile> dqaf(TFile::Open(ds->GetFullPathToDataSetFile("DataQualityAudit.root")));
705  // add pop-up with name of dataset
706  auto ds_popup = menus.add_popup(ds->GetName(), menus.filter.data_quality);
707  std::unordered_map<std::string, TGPopupMenu*> DQA_system_popups;
708  menus.filter.DQA_map[menus.filter.last_dqa] = {ds->GetName(), ds_popup/*menus.filter.data_quality*/};
709  ds_popup/*menus.filter.data_quality*/->AddEntry("all reactions", menus.filter.last_dqa++);
710  auto systems = ds->GetDataBase("minimal")->GetSystems();
711  TIter next(systems);
712  KVDBSystem* sys;
713  while ((sys = (KVDBSystem*)next())) {
714  if (sys->IsCollision()) {
715  if (dqaf->FindKey(sys->GetBatchNameWithoutEnergy())) {
716  if (DQA_system_popups.find(sys->GetBatchNameWithoutEnergy().Data()) == DQA_system_popups.end()) {
717  DQA_system_popups[sys->GetBatchNameWithoutEnergy().Data()] =
718  menus.add_popup(sys->GetReactionNameWithoutEnergy(), ds_popup /*menus.filter.data_quality*/);
720  DQA_system_popups[sys->GetBatchNameWithoutEnergy().Data()]};
721  DQA_system_popups[sys->GetBatchNameWithoutEnergy().Data()]->AddEntry("all energies", menus.filter.last_dqa++);
722  }
723  if (dqaf->FindKey(sys->GetBatchName())) {
724  menus.filter.DQA_map[menus.filter.last_dqa] = {Form("%s/%s", ds->GetName(), sys->GetBatchName().Data()),
725  DQA_system_popups[sys->GetBatchNameWithoutEnergy().Data()]};
726  DQA_system_popups[sys->GetBatchNameWithoutEnergy().Data()]->AddEntry(sys->GetReactionEnergyWithoutName(), menus.filter.last_dqa++);
727  }
728  }
729  }
730  }
731  }
732 }
733 
734 
735 
737 
738 void KVSimDirGUI::SelectDataSet(const char* name)
739 {
740  KVDataSet* ds = gDataSetManager->GetDataSet(name);
741  if (ds) {
742  fDataset = name;
743  fSystem = "";
744  fRun = 0;
745  GeoType(kGTROOT);
746  auto systems = ds->GetDataBase("minimal")->GetSystems();
748  while (auto me = (TGMenuEntry*)it()) {
749  if (me->GetEntryId() != menus.filter.ad_hoc_reaction) menus.filter.reaction->DeleteEntry(me);
750  }
752  if (systems) {
753  TIter next(systems);
754  KVDBSystem* sys;
755  int i = menus.filter.ad_hoc_reaction;
756  while ((sys = (KVDBSystem*)next())) {
757  if (sys->IsCollision()) menus.filter.reaction->AddEntry(sys->GetName(), ++i);
758  }
760  }
761  }
762  else
763  fDataset="";
764  // update list of extendible identification telescopes
766 }
767 
768 
769 
775 
777 {
778  // Called when a data quality audit is selected in the list.
779  //
780  // The name of the audit is in fDataQualityAudit: "[dataset]/[system]" or "[dataset]"
781  // (if fDataQualityAudit="" this means no data quality audit, i.e. "[none]" was selected)
782 
784  auto DQA_dataset = fDataQualityAudit.Next();
785 
786  // remove any existing entries in 'extensible id' list
788  while (auto me = (TGMenuEntry*)it()) {
790  }
791 
792  // no DQA required or no dataset selected: nothing to do
793  if(DQA_dataset.IsNull() || fDataset.IsNull()) return;
794 
795  if(DQA_dataset=="file")
796  {
797  // use audit in file
798  static TString audit_dir(gSystem->pwd());
799  const char* filetypes[] = {
800  "ROOT files", "*.root",
801  0, 0
802  };
803  TGFileInfo fi;
804  fi.fIniDir = StrDup(audit_dir);
805  fi.fFileTypes = filetypes;
806  new KVFileDialog(gClient->GetDefaultRoot(), MainFrame, kKVFDOpen, &fi);
807  if (fi.fFilename) {
808  fDataQualityAudit = Form("file:%s",fi.fFilename);
809  Info("SelectDataQualityAudit","path:%s",fDataQualityAudit.Data());
810  }
811  audit_dir = fi.fIniDir;
812  }
813 
814  KVString arrays_with_exId = gEnv->GetValue("FilterGroupReconstructor.HasExtendibleIdentifications", "");
815  if(arrays_with_exId.IsNull()) return;
816 
817  // we deduce the names of the arrays from the name of the dataset chosen
818  // to define the detector geometry used to filter the data
819  arrays_with_exId.Begin(" ");
820  int i = menus.filter.id_extensions;
821  while(!arrays_with_exId.End())
822  {
823  auto array = arrays_with_exId.Next(kTRUE);
824  if(fDataset.Contains(array))
825  {
826  KVString exId_for_array = gEnv->GetValue(Form("%s.ExtendibleIdentifications",array.Data()),"");
827  if(!exId_for_array.IsNull())
828  {
829  exId_for_array.Begin(" ");
830  while(!exId_for_array.End())
831  {
832  menus.filter.id_extension->AddEntry(exId_for_array.Next(true), i++);
833  }
834  }
835  }
836  }
837 }
838 
839 
840 
842 
843 void KVSimDirGUI::SelectSystem(const char* sysname)
844 {
846  while (auto me = (TGMenuEntry*)it()) {
847  if (me->GetEntryId() != menus.filter.no_run_number) menus.filter.run_number->DeleteEntry(me);
848  }
850  fRun = 0;
851  fSystem = sysname;
852  KVDBSystem* sys = gDataSetManager->GetDataSet(fDataset)->GetDataBase("minimal")->GetSystem(sysname);
853  if (sys) {
854  for(auto p_dbr : sys->GetRuns())
855  {
856  auto dbr = dynamic_cast<KVDBRun*>(p_dbr);
857  menus.filter.run_number->AddEntry(Form("%d", dbr->GetNumber()), dbr->GetNumber() + menus.filter.no_run_number);
858  menus.filter.last_run = dbr->GetNumber() + menus.filter.no_run_number;
859  }
860  }
861 }
862 
863 
864 
867 
869 {
870  // Called when "Process" button is pressed to launch the analysis
871 
872  if (fAnalysisMode)
873  RunAnalysis("tree");
874  else if (fFilterMode) {
875  if (fDataset == "") { // Make sure a dataset has been chosen
876  new TGMsgBox(gClient->GetRoot(), MainFrame, "KVSimDirGUI::Run", "First choose the dataset which describes the geometry!", kMBIconExclamation);
877  return;
878  }
879  RunAnalysis("filter");
880  }
881 }
882 
883 
884 
886 
888 {
889  auto selected_sim_runs = fLVsimData->GetSelectedObjects();
890  auto selected_filt_runs = fLVfiltData->GetSelectedObjects();
891  KVUnownedList runs_to_analyse, aux_runs_to_analyse;
892  TString analysis_task;
893  if (type == "tree") { // analysis of simulated or filtered events
894  if (!selected_sim_runs.GetEntries() && !selected_filt_runs.GetEntries()) {
895  new TGMsgBox(gClient->GetRoot(), MainFrame, "KVSimDirGUI::RunAnalysis", "Choose one or more simulated or filtered data files!", kMBIconExclamation);
896  return;
897  }
898  // if (selected_sim_runs->GetEntries() && selected_filt_runs->GetEntries()) {
899  // new TGMsgBox(gClient->GetRoot(), MainFrame, "KVSimDirGUI::RunAnalysis", "Choose EITHER simulated or filtered data files!", kMBIconExclamation);
900  // return;
901  // }
902  if (!fAnalClass.with_files()) {
903  new TGMsgBox(gClient->GetRoot(), MainFrame, "KVSimDirGUI::RunAnalysis", "Choose a valid analysis class!", kMBIconExclamation);
904  return;
905  }
906  if (selected_sim_runs.GetEntries()) {
907  if (selected_filt_runs.GetEntries()) {
908  // if both simulated & filtered events are selected, we assume the user wants to analyse filtered
909  // data while having access to the original non-filtered data as an auxiliary/"friend" tree
910  runs_to_analyse = selected_filt_runs;
911  analysis_task = "analysis filtered";
912  aux_runs_to_analyse = selected_sim_runs;
913  }
914  else {
915  runs_to_analyse = selected_sim_runs;
916  analysis_task = "analysis simulated";
917  }
918  }
919  else {
920  runs_to_analyse = selected_filt_runs;
921  analysis_task = "analysis filtered";
922  }
923  }
924  else {
925  // filtering
926  if (selected_filt_runs.GetEntries()) {
927  new TGMsgBox(gClient->GetRoot(), MainFrame, "KVSimDirGUI::RunFilter", "Only simulated events can be filtered!", kMBIconExclamation);
928  return;
929  }
930  if (!selected_sim_runs.GetEntries()) {
931  new TGMsgBox(gClient->GetRoot(), MainFrame, "KVSimDirGUI::RunFilter", "Choose a simulated data file to filter!", kMBIconExclamation);
932  return;
933  }
934  runs_to_analyse = selected_sim_runs;
935  analysis_task = "filter simulated";
936  // set auxiliary directory of current KVSimDir to current working directory
937  // (where filter should output any new files)
938  fSelectedSimDir = dynamic_cast<KVSimFile*>(runs_to_analyse.First())->GetSimDir();
941 #ifdef WITH_RSQLITE
942  // add info to dataset table in db for next time
943  fConfigDB["Datasets"]["AuxDir"] = gSystem->pwd();
944  fConfigDB.update("Datasets", "AuxDir", Form("Name = '%s'", fSelectedSimDir->GetName()));
945 #endif
946  }
947  }
948  KVDataAnalysisTask* anTask = gDataSetManager->GetAnalysisTaskAny(analysis_task);
949  gDataAnalyser = KVDataAnalyser::GetAnalyser(anTask->GetDataAnalyser());
950  gDataAnalyser->SetAnalysisTask(anTask);
951  gDataAnalyser->SetFileList(runs_to_analyse);
952  if (aux_runs_to_analyse.GetEntries()) gDataAnalyser->SetAuxFileList(aux_runs_to_analyse);
953  if (anTask->WithUserClass()) {
954  gDataAnalyser->SetUserClass(fAnalClass);
955  if (!gDataAnalyser->IsUserClassValid()) {
956  new TGMsgBox(gClient->GetRoot(), MainFrame, "KVSimDirGUI::RunAnalysis", "Compilation failed. Correct mistakes and try again!", kMBIconExclamation);
957  }
958  }
959  else if (strcmp(anTask->GetUserBaseClass(), ""))
960  gDataAnalyser->SetUserClass(KVDataAnalyser::UserClass{anTask->GetUserBaseClass()}, kFALSE);//task with default "user" class
961  Bool_t all_events = fCBAllEvents->IsDown();
962  if (!all_events)
964  else
965  gDataAnalyser->SetNbEventToRead(0);
966  fCancelJob = kFALSE;
967  if (type == "filter") {
968  // set extra infos in kvsimdiranalyser for auto jobname
969  if (fCustomKinematics) {
970  // if an ad hoc system is used for the kinematics, we have to use it instead of fSystem,
971  // but only after first checking if it is legit
973  // check valid ad hoc system given by user
974  if (cd.IsZombie()) {
975  Error("SetFilterOptions", "Please check the format of the ad hoc system name you gave");
976  WarningBox("Bad System", "Please check the format of the ad hoc system name you gave", kFALSE);
977  fCancelJob = kTRUE;
978  }
979  else {
980  cd.CalculateKinematics();
981  cd.Print();
983  }
984  }
985 
986  KVSimDirAnalyser* simda = dynamic_cast<KVSimDirAnalyser*>(gDataAnalyser);
988  simda->SetSystemForFilter(fSystem);
989  }
990  Bool_t cancel_batch_job = kFALSE;
991  if (fWithPROOF) {
992  gBatchSystem->Clear();
993  KVNameValueList batchParams;
994  gBatchSystem->GetBatchSystemParameterList(batchParams);
995  new KVBatchSystemParametersGUI(MainFrame, &batchParams, gDataAnalyser, &cancel_batch_job);
996  if (!cancel_batch_job) {
997  gBatchSystem->SetBatchSystemParameters(batchParams);
998  gDataAnalyser->SetBatchSystem(gBatchSystem);
999  }
1000  }
1001  if (!cancel_batch_job && !fCancelJob) {
1002  if (type == "filter")
1003  SetFilterOptions(); // this may yet set fCancelJob=true...
1004  if (!fCancelJob) {
1005  if(type == "filter")
1006  {
1007  // at this point it is best to make sure the full database has been built and is available for the dataset
1008  // we may have only built a minimal db with runs&systems. we don't want every prooflite/batch job to try
1009  // to build the database at the same time
1010  Info("RunAnalysis", "Forcing rebuild of complete dataset for %s if necessary", fDataset.Data());
1011  gDataSetManager->GetDataSet(fDataset)->cd();
1012  }
1013  gDataAnalyser->Run();
1014  }
1015  }
1016  if(!fWithPROOF || (fWithPROOF && gBatchSystem->IsCalled("PROOFLite")))
1017  RefreshSimDir();
1018 }
1019 
1020 
1021 
1023 
1024 TString KVSimDirGUI::GetKinematicsString()
1025 {
1026  TString kinema;
1027  if (fKine == kKCM) kinema = "cm";
1028  else if (fKine == kKProj) kinema = "proj";
1029  else kinema = "lab";
1030 
1031  return kinema;
1032 }
1033 
1034 
1035 
1037 
1039 {
1040  TString filter;
1041  switch (fFilterType) {
1042  case kFTGeo:
1043  filter = "Geo";
1044  break;
1045  case kFTSeuils:
1046  filter = "GeoThresh";
1047  break;
1048  case kFTFull:
1049  filter = "Full";
1050  }
1051 
1052  return filter;
1053 }
1054 
1055 
1056 
1058 
1060 {
1061  TString kinema = GetKinematicsString();
1062  TString filter = GetFilterTypeString();
1063 
1064  TString options;
1065  options = Form("Dataset=%s,", fDataset.Data());
1066  if (fSystem != "") options += Form("System=%s,", fSystem.Data());
1067  else if (kinema != "lab") {
1068  // a kinematical frame transform is required, but no system is given!
1069  new TGMsgBox(gClient->GetRoot(), MainFrame,
1070  "KVSimDirGUI::SetFilterOptions",
1071  Form("Cannot transform kinematics from %s to lab without a defined reaction (system)!", kinema.Data()),
1073  fCancelJob = true;
1074  return;
1075  }
1076  options += Form("Filter=%s,", filter.Data());
1077  options += Form("Kinematics=%s", kinema.Data());
1078  if (fDataQualityAudit != "") {
1079  options += Form(",DataQualityAudit=%s", fDataQualityAudit.Data());
1080  // add list of any extensible IDs given
1081  fExtensibleIDs="";
1083  while (auto me = (TGMenuEntry*)it())
1084  {
1085  if(menus.filter.id_extension->IsEntryChecked(me->GetEntryId()))
1086  {
1087  if(fExtensibleIDs.Length())
1088  fExtensibleIDs+="|";
1089  fExtensibleIDs+=me->GetName();
1090  }
1091  }
1092  if(fExtensibleIDs.Length())
1093  options += Form(",ExtensibleID=%s",fExtensibleIDs.Data());
1094  }
1095  if (fRun != 0) {
1096  TString r;
1097  r.Form(",Run=%d", fRun);
1098  options += r;
1099  }
1100  else if (filter == "Full" && (fCustomKinematics || fSystem == "")) {
1101  // "Full" filter requires run number to work: either given explicitly or taken from first run of database system (not ad hoc)
1102  new TGMsgBox(gClient->GetRoot(), MainFrame,
1103  "KVSimDirGUI::SetFilterOptions",
1104  Form("To use 'FULL' (run-dependent) filter requires either a run number or a system from the dataset!"),
1106  fCancelJob = true;
1107  return;
1108  }
1109  if (!fRandomPhi) options += ",PhiRot=no";
1110  if (fGemDecay) {
1111  options += ",Gemini=yes";
1112  options += Form(",GemDecayPerEvent=%d", fGemDecayPerEvent);
1113  if (fGemAddRotEner) options += Form(",GemAddRotEner=yes");
1114  }
1115 
1116  gDataAnalyser->SetUserClassOptions(options);
1117 
1118  std::cout << options << std::endl;
1119 }
1120 
1121 
1122 
1125 
1127 {
1128  // Import simulation data from currently selected directory
1129 
1130  const char* filetypes[] = {
1131  "All files", "*.*",
1132  0, 0
1133  };
1134  TGFileInfo fi;
1136  fi.fFileTypes = filetypes;
1137  fi.SetMultipleSelection(true);
1138 
1139  new KVFileDialog(gClient->GetDefaultRoot(), MainFrame, kKVFDOpen, &fi);
1140 
1141  bool one_file = (!fi.fMultipleSelection && fi.fFilename);
1142  bool many_files = (fi.fMultipleSelection && fi.fFileNamesList);//may only be one
1143  if (one_file || many_files) {
1144  // set up list of KVSimReader plugins
1145  KVString plugins = KVBase::GetListOfPlugins("KVSimReader");
1146  KVString choices;
1147  plugins.Begin(" ");
1148  while (!plugins.End()) {
1149  // get URI corresponding to plugin
1150  KVString uri = KVBase::GetPluginURI("KVSimReader", plugins.Next());
1151  if (choices.Length()) choices += " ";
1152  choices += uri;
1153  }
1154  // get model from user
1155  TString model;
1156  Bool_t ok;
1157  new KVDropDownDialog(MainFrame, "Choose the simulation model and type of events", choices, 0, &model, &ok);
1158  if (ok) {
1159 
1160  if (one_file) {
1161  unique_ptr<KVSimReader> SR(KVSimReader::MakeSimReader(model));
1162  SR->SetOutputDirectory(fSelectedSimDir->GetDirectory());
1163  SR->ConvertAndSaveEventsInFile(fi.fFilename);
1164  }
1165  else {
1166  if (fi.fFileNamesList->GetEntries() == 1) {
1167  unique_ptr<KVSimReader> SR(KVSimReader::MakeSimReader(model));
1168  SR->SetOutputDirectory(fSelectedSimDir->GetDirectory());
1169  SR->ConvertAndSaveEventsInFile(fi.fFileNamesList->First()->GetName());
1170  }
1171  else {
1172  TIter it(fi.fFileNamesList);
1173  TObject* o;
1174  int i = 1;
1175  while ((o = it())) {
1176  unique_ptr<KVSimReader> SR(KVSimReader::MakeSimReader(model));
1177  SR->SetMultiFiles();
1178  SR->SetFileIndex(i++);
1179  SR->SetOutputDirectory(fSelectedSimDir->GetDirectory());
1180  SR->ConvertAndSaveEventsInFile(o->GetName());
1181  }
1182  }
1183  }
1184 
1185  RefreshSimDir();
1186  }
1187  }
1188  else if (fi.fMultipleSelection && fi.fFileNamesList) {
1189  fi.fFileNamesList->ls();
1190  }
1191 }
1192 
1193 
1194 
1197 
1199 {
1200  // Get name of new class
1201  TString classname;
1202  Bool_t ok;
1203  new KVInputDialog(MainFrame, "Enter name of new analysis class", &classname, &ok, "Enter name of new analysis class");
1204  // check new classname is not name of existing class
1205  KVString impfile, decfile;
1206  if (KVBase::FindClassSourceFiles(classname, impfile, decfile)) {
1207  ok = ok && WarningBox("Replacing existing class",
1208  Form("%s is the name of an existing class defined in [%s,%s].\nDo you want to overwrite this class?\n(All existing code will be lost)",
1209  classname.Data(), decfile.Data(), impfile.Data()),
1210  kTRUE);
1211  }
1212  if (ok) {
1213  KVSimDirFilterAnalyser::Make(classname);
1214  fStatusBar->SetText(Form("Generated new filtered analysis class %s", classname.Data()), 1);
1215  }
1216 }
1217 
1218 
1219 
1222 
1224 {
1225  // Get name of new class
1226  TString classname;
1227  Bool_t ok;
1228  new KVInputDialog(MainFrame, "Enter name of new analysis class", &classname, &ok, "Enter name of new analysis class");
1229  // check new classname is not name of existing class
1230  KVString impfile, decfile;
1231  if (KVBase::FindClassSourceFiles(classname, impfile, decfile)) {
1232  ok = ok && WarningBox("Replacing existing class",
1233  Form("%s is the name of an existing class defined in [%s,%s].\nDo you want to overwrite this class?\n(All existing code will be lost)",
1234  classname.Data(), decfile.Data(), impfile.Data()),
1235  kTRUE);
1236  }
1237  if (ok) {
1238  KVSimDirAnalyser::Make(classname);
1239  fStatusBar->SetText(Form("Generated new simulated analysis class %s", classname.Data()), 1);
1240  }
1241 }
1242 
1243 
1244 
1250 
1251 Bool_t KVSimDirGUI::WarningBox(const char* title, const char* msg, Bool_t confirm)
1252 {
1253  // Warning box in case of problems
1254  // if confirm=kTRUE we ask for a yes/no answer from the user:
1255  // if 'yes' is pressed, we return kTRUE, if 'no', kFALSE.
1256  // by default, only a 'dismiss' button is shown, and this method always returns kTRUE.
1257 
1258  Bool_t reply = kTRUE;
1259  if (!confirm)
1260  new TGMsgBox(gClient->GetRoot(), MainFrame, title, msg, kMBIconExclamation);
1261  else {
1262  Int_t ret_code = 0;
1263  new TGMsgBox(gClient->GetRoot(), MainFrame, title, msg, kMBIconExclamation, kMBYes | kMBNo, &ret_code);
1264  reply = (ret_code & kMBYes);
1265  }
1266  return reply;
1267 }
1268 
1269 
1270 
1272 
1274 {
1275  int parts[] = {14, 25, 10, 14, 9, 7, 10};
1276  fStatusBar->SetParts(parts, 7);
1279  fStatusBar->SetText(Form("Run: %d", fRun), 2);
1280  fStatusBar->SetText(Form("Audit: %s", fDataQualityAudit.Data()), 3);
1281  fStatusBar->SetText(GetFilterTypeString().Data(), 4);
1282  fStatusBar->SetText(GetKinematicsString().Data(), 5);
1283  TString gemphi;
1284  if (fGemDecay) {
1285  gemphi = Form("Gem++, %d/ev.", fGemDecayPerEvent);
1286  if (fGemAddRotEner) gemphi += " +Erot";
1287  }
1288  if (fRandomPhi) {
1289  if (gemphi.Length()) gemphi += "; ";
1290  gemphi += "phi RNDM";
1291  }
1292  fStatusBar->SetText(gemphi, 6);
1293 }
1294 
1295 
1296 
1298 
1300 {
1301  fStatusBar->SetParts(2);
1302  if (!fAnalClass.name.IsNull()) {
1303  fStatusBar->SetText(Form("Analysis class: %s", fAnalClass.name.Data()), 0);
1304  fStatusBar->SetText(Form("Found header file %s and implementation file %s", fAnalClass.dec_file.Data(), fAnalClass.imp_file.Data()), 1);
1305  }
1306  else
1307  fStatusBar->SetText("Analysis class:", 0);
1308 }
1309 
1310 
1311 #ifdef WITH_RSQLITE
1312 
1316 
1318 {
1319  // Rebuild all KVSimDir/KVSimFile objects from information in sqlite DB
1320 
1321  // backwards-compatility: add any missing columns to dataset tables
1322  fConfigDB.select_data("Datasets");
1323  KVNameValueList tables;
1324  while (fConfigDB.get_next_result()) {
1325  auto sd = new KVSimDir(fConfigDB["Datasets"]["Name"].get_data<TString>(),
1326  fConfigDB["Datasets"]["Directory"].get_data<TString>());
1327  if (!fConfigDB["Datasets"]["AuxDir"].is_null())
1328  sd->SetAuxDirectory(fConfigDB["Datasets"]["AuxDir"].get_data<TString>());
1329  fListOfDirs.Add(sd);
1330  tables.SetValue(fConfigDB["Datasets"]["Name"].get_data<TString>(),
1331  fConfigDB["Datasets"]["Table"].get_data<TString>());
1332  }
1333  for (int i = 0; i < tables.GetNpar(); ++i)
1334  {
1335  auto tab = tables.GetValue<TString>(i);
1336  if(!fConfigDB[tab].has_column("AuxDir"))
1337  fConfigDB.add_column(tab, "AuxDir", "INTEGER");
1338  if(!fConfigDB[tab].has_column("DataQualityAudit"))
1339  fConfigDB.add_column(tab, "DataQualityAudit", "TEXT");
1340  }
1341  for (int i = 0; i < tables.GetNpar(); ++i) {
1343  fConfigDB.select_data(tables.GetValue<TString>(i));
1344  KVSQLite::table& dstable = fConfigDB[tables.GetValue<TString>(i)];
1345  while (fConfigDB.get_next_result()) {
1346  bool from_aux_dir = !dstable["AuxDir"].is_null() ? dstable["AuxDir"].get_data<int>() : false;
1347  if (dstable["Filtered"].get_data<int>()) {
1348  // filtered/reconstructed data
1349  TString dqa;
1350  if (!dstable["DataQualityAudit"].is_null())
1351  dqa = dstable["DataQualityAudit"].get_data<TString>();
1352  KVSimFile* f = new KVSimFile(
1353  nullptr,
1354  dstable["FileName"].get_data<TString>(), dstable["TreeInfo"].get_data<TString>(),
1355  dstable["Events"].get_data<int>(), dstable["TreeName"].get_data<TString>(),
1356  dstable["BranchName"].get_data<TString>(), dstable["DataSet"].get_data<TString>(),
1357  dstable["System"].get_data<TString>(), dstable["Run"].get_data<int>(),
1358  dstable["OrigFile"].get_data<TString>(),
1359  dstable["FiltType"].get_data<TString>(),
1360  dqa
1361  );
1362  f->SetGemini(dstable["Gemini"].get_data<bool>());
1363  if (f->IsGemini()) f->SetGemDecayPerEvent(dstable["GemDecayPerEvent"].get_data<int>());
1364  sd->AddFiltData(f, from_aux_dir);
1365  }
1366  else {
1367  // simulation data
1368  KVSimFile* f = new KVSimFile(
1369  nullptr,
1370  dstable["FileName"].get_data<TString>(), dstable["TreeInfo"].get_data<TString>(),
1371  dstable["Events"].get_data<int>(), dstable["TreeName"].get_data<TString>(),
1372  dstable["BranchName"].get_data<TString>());
1373  sd->AddSimData(f, from_aux_dir);
1374  }
1375  }
1376  }
1377 }
1378 
1379 #endif
1380 
int Int_t
kVerticalFrame
kHorizontalFrame
kMainFrame
ROOT::R::TRInterface & r
#define f(i)
bool Bool_t
constexpr Bool_t kFALSE
constexpr Bool_t kTRUE
R__EXTERN TEnv * gEnv
kEnvUser
kButtonDown
#define gClient
kMWMFuncAll
kMWMDecorAll
kMWMInputModeless
kLHintsRight
kLHintsExpandY
kLHintsLeft
kLHintsCenterY
kLHintsTop
kLHintsExpandX
kMBNo
kMBYes
kMBIconExclamation
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void on
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 Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t type
char name[80]
#define quest
char * Form(const char *fmt,...)
char * StrDup(const char *str)
R__EXTERN TSystem * gSystem
Relativistic binary kinematics calculator.
Definition: KV2Body.h:178
void CalculateKinematics()
Definition: KV2Body.cpp:693
void Print(Option_t *opt="") const override
Definition: KV2Body.cpp:874
void Error(const char *method, const char *msgfmt,...) const override
Definition: KVBase.cpp:1709
static const Char_t * GetListOfPlugins(const Char_t *base)
Definition: KVBase.cpp:1252
static Bool_t FindClassSourceFiles(const KVString &class_name, KVString &imp_file, KVString &dec_file, const KVString &dir_name=".")
Definition: KVBase.cpp:1096
virtual Bool_t IsCalled(const Char_t *name) const
Definition: KVBase.h:189
static const Char_t * GetPluginURI(const Char_t *base, const Char_t *plugin)
Definition: KVBase.cpp:1169
Handles list of all available batch systems for processing non-interactive data analysis tasks.
KVBatchSystem * GetDefaultBatchSystem() const
Utility GUI used for setting batch system parameters.
void Clear(Option_t *opt="") override
void cd()
Make this the default batch system.
virtual void SetBatchSystemParameters(const KVNameValueList &)
Use the parameters in the list to set all relevant parameters for batch system.
virtual void GetBatchSystemParameterList(KVNameValueList &)
Description of an experimental run in database ,,.
Definition: KVDBRun.h:41
Database class used to store information on different colliding systems studied during an experiment....
Definition: KVDBSystem.h:51
Bool_t IsCollision() const
retourne kTRUE, si le systeme est une collision ie projectile+cible
Definition: KVDBSystem.cpp:128
TString GetBatchName()
Definition: KVDBSystem.cpp:657
TString GetBatchNameWithoutEnergy()
Definition: KVDBSystem.cpp:690
TString GetReactionNameWithoutEnergy()
Definition: KVDBSystem.cpp:721
TString GetReactionEnergyWithoutName()
Definition: KVDBSystem.cpp:746
KVUnownedList GetRuns() const
Returns a sorted list of all the runs associated with this system.
Definition: KVDBSystem.cpp:139
virtual void SetFileList(const KVUnownedList &)
virtual void Run()
Check all task variables, then run analyser.
void SetBatchSystem(KVBatchSystem *bs)
void SetUserClassOptions(const Char_t *o="")
virtual void SetAuxFileList(const KVUnownedList &)
void SetAnalysisTask(KVDataAnalysisTask *at)
void SetUserClass(const UserClass &kvs, Bool_t check=kTRUE)
static KVDataAnalyser * GetAnalyser(const Char_t *plugin)
Bool_t IsUserClassValid() const
void SetNbEventToRead(Long64_t nb=0)
Define and manage data analysis tasks.
virtual Bool_t WithUserClass() const
virtual const Char_t * GetDataAnalyser() const
virtual const Char_t * GetUserBaseClass() const
Manage all datasets contained in a given data repository.
virtual Bool_t Init(KVDataRepository *=0)
virtual Int_t GetNtotal() const
KVDataAnalysisTask * GetAnalysisTaskAny(const Char_t *keywords) const
KVDataSet * GetDataSet(Int_t) const
Return pointer to DataSet using index in list of all datasets, index>=0.
Manage an experimental dataset corresponding to a given experiment or campaign.
Definition: KVDataSet.h:146
TString GetFullPathToDataSetFile(const Char_t *filename) const
Definition: KVDataSet.cpp:2067
KVExpDB * GetDataBase(const TString &opt="") const
Definition: KVDataSet.cpp:290
void cd() const
Definition: KVDataSet.cpp:784
static Bool_t FindDataSetFile(const TString &dataset, const Char_t *filename)
Definition: KVDataSet.cpp:2102
Ask user to choose between several options in a drop-down list.
virtual KVDBSystem * GetSystem(const Char_t *system) const
Definition: KVExpDB.h:164
virtual KVSeqCollection * GetSystems() const
Definition: KVExpDB.h:168
Modified version of TGFileDialog file selection dialog.
Definition: KVFileDialog.h:49
General purpose dialog box asking for some input in the form of a string.
Definition: KVInputDialog.h:24
Enhanced version of ROOT TGListView widget.
Definition: KVListView.h:146
virtual void ActivateSortButtons()
Definition: KVListView.cpp:72
virtual void SetDataColumns(Int_t ncolumns)
Definition: KVListView.cpp:91
virtual void Display(const TCollection *l)
Definition: KVListView.h:173
KVUnownedList GetSelectedObjects() const
Definition: KVListView.h:252
virtual void RemoveAll()
Definition: KVListView.h:193
void AllowContextMenu(Bool_t on=kTRUE)
Definition: KVListView.h:291
virtual void SetDataColumn(Int_t index, const Char_t *name, const Char_t *method="", Int_t mode=kTextCenterX)
Definition: KVListView.cpp:106
Handles lists of named parameters with different types, a list of KVNamedParameter objects.
KVNamedParameter * GetParameter(Int_t idx) const
return the parameter object with index idx
void SetValue(const Char_t *name, value_type value)
Int_t GetNpar() const
return the number of stored parameters
value_type GetValue(const Char_t *name) const
int get_number_of_tables() const
Definition: SQLiteDB.h:518
table & add_table(const table &)
Definition: SQLiteDB.cpp:254
bool update(const TString &table, const TString &columns, const TString &selection="")
Definition: SQLiteDB.cpp:1169
void delete_table(const TString &table)
Definition: SQLiteDB.cpp:1227
column & add_column(const TString &table, const TString &name, const TString &type)
Definition: SQLiteDB.cpp:1272
void delete_rows_in_table(const TString &table, const TString &selection="")
Definition: SQLiteDB.cpp:1249
void insert_data_row()
Definition: SQLiteDB.cpp:529
void end_data_insertion()
Definition: SQLiteDB.cpp:616
bool select_data(const TString &tables, const TString &columns="*", const TString &selection="", bool distinct=false, const TString &anything_else="") const
Definition: SQLiteDB.cpp:822
KVNameValueList get_name_value_list(const TString &table, const TString &name_column, const TString &value_column, const TString &selection="", const TString &anything_else="")
Definition: SQLiteDB.cpp:1032
bool get_next_result() const
Definition: SQLiteDB.cpp:941
bool prepare_data_insertion(const TString &)
Definition: SQLiteDB.cpp:303
void clear_table(const TString &name)
Delete all rows in table, but does not remove table.
Definition: SQLiteDB.cpp:1080
int count(const TString &tables, const TString &column="*", const TString &selection="", bool distinct=false, const TString &anything_else="") const
Definition: SQLiteDB.cpp:1111
void primary_key(const TString &cols)
Definition: SQLiteDB.h:428
column & add_column(const KVSQLite::column &c)
Definition: SQLiteDB.cpp:1610
TObject * First() const override
TObject * Remove(TObject *obj) override
Remove object from list.
void Add(TObject *obj) override
TObject * FindObject(const char *name) const override
Class piloting analyses of simulated data.
void SetDataSetForFilter(const TString &f)
void SetSystemForFilter(const TString &f)
static void Make(const Char_t *kvsname="MySimulatedAnalysis")
Generate a new simulated analysis selector class.
static void Make(const Char_t *kvsname="MyFilteredAnalysis")
Generate a new filtered analysis selector class.
GUI for analysing and filtering simulated data.
Definition: KVSimDirGUI.h:168
TGStatusBar * fStatusBar
Definition: KVSimDirGUI.h:175
KVString fDataQualityAudit
Definition: KVSimDirGUI.h:196
TGPictureButton * BremDir
Definition: KVSimDirGUI.h:179
Int_t fGemDecayPerEvent
Definition: KVSimDirGUI.h:202
void SelectDataSet(const char *)
void ReconstructSimDirsFromDB()
void NewFilteredAnalysisClass()
Get name of new class.
Bool_t fGemAddRotEner
Definition: KVSimDirGUI.h:201
KVSQLite::database fConfigDB
Definition: KVSimDirGUI.h:225
void RemSimDir()
void EmptyTreeList()
Bool_t fFilterMode
Definition: KVSimDirGUI.h:229
void RefreshSimDir()
void SelectAnalysisClass()
Bool_t fGemDecay
Definition: KVSimDirGUI.h:200
void FilterType(Int_t i)
Definition: KVSimDirGUI.h:508
void SetFilterOptions()
KVDataAnalyser::UserClass fAnalClass
Definition: KVSimDirGUI.h:190
void AddSimDir()
TGCheckButton * fCBAllEvents
Definition: KVSimDirGUI.h:191
void NewSimulatedAnalysisClass()
Get name of new class.
KVList fListOfDirs
Definition: KVSimDirGUI.h:171
TGMainFrame * MainFrame
Definition: KVSimDirGUI.h:174
void SetAnalysisStatusBar()
TGViewPort * fDirListViewPort
Definition: KVSimDirGUI.h:183
TGNumberEntry * fNENumberEvents
Definition: KVSimDirGUI.h:192
void SelectSystem(const char *)
Bool_t fAnalysisMode
Definition: KVSimDirGUI.h:229
menu_struct menus
Definition: KVSimDirGUI.h:458
void FillTreeList()
Int_t fFilterType
Definition: KVSimDirGUI.h:217
KVString fExtensibleIDs
Definition: KVSimDirGUI.h:197
KVSimDir * fSelectedSimDir
Definition: KVSimDirGUI.h:172
KVString fReactionKinematics
Definition: KVSimDirGUI.h:194
KVString fSystem
Definition: KVSimDirGUI.h:194
TGListTree * fDirListTree
Definition: KVSimDirGUI.h:184
TGCanvas * fDirListCanvas
Definition: KVSimDirGUI.h:182
void SelectDataQualityAudit()
void AddAuxDir(TGListTreeItem *simdir, Int_t)
const TGPicture * pclose
used for list tree items
Definition: KVSimDirGUI.h:186
void SetRandomPhi(Bool_t on)
Definition: KVSimDirGUI.h:524
const TGPicture * popen
used for list tree items
Definition: KVSimDirGUI.h:185
void SetFilterStatusBar()
Bool_t fCustomKinematics
Definition: KVSimDirGUI.h:198
KVListView * fLVfiltData
Definition: KVSimDirGUI.h:189
void Run()
void ChangeOutputDirectory();
void FillDataSetTableWithInfos(TString ds_table_name, KVSimDir *sd)
Definition: KVSimDirGUI.cpp:72
void fill_dqa_menus_for_dataset(const KVDataSet *ds)
TGPictureButton * proof_analysis
TGTextEntry* fTEOutputDir;.
Definition: KVSimDirGUI.h:221
void EnableEventNumberEntry(Bool_t)
TString GetFilterTypeString()
void RunAnalysis(const TString &type)
Bool_t WarningBox(const char *title, const char *msg, Bool_t confirm)
TGPictureButton * BaddDir
Definition: KVSimDirGUI.h:177
void SetGeminiDecay(Bool_t on)
Definition: KVSimDirGUI.h:528
Bool_t fWithPROOF
=kTRUE when running with PROOF-lite
Definition: KVSimDirGUI.h:227
void GeoType(Int_t i)
Definition: KVSimDirGUI.h:512
Bool_t fCancelJob
if job parameters are not valid
Definition: KVSimDirGUI.h:228
void Kinematics(Int_t i)
Definition: KVSimDirGUI.h:516
Bool_t fRandomPhi
Definition: KVSimDirGUI.h:199
KVListView * fLVsimData
Definition: KVSimDirGUI.h:188
TGPictureButton * BimpSim
Definition: KVSimDirGUI.h:178
TGPictureButton * BrefreshDir
Definition: KVSimDirGUI.h:180
void SelectSimDir(TGListTreeItem *, Int_t)
TString AddTableForDataSet(KVSimDir *sd, int ds_table_number)
Add a new dataset table for the given KVSimDir object.
Definition: KVSimDirGUI.cpp:36
void ImportSimulation()
Import simulation data from currently selected directory.
KVString fDataset
Definition: KVSimDirGUI.h:193
Handle directory containing simulated and/or filtered simulated data ,.
Definition: KVSimDir.h:43
const KVList * GetFiltDataList() const
Definition: KVSimDir.h:76
void SetAuxDirectory(const TString &)
Definition: KVSimDir.cpp:118
void AddFiltData(KVSimFile *, bool=false)
Definition: KVSimDir.cpp:337
Bool_t HasAuxDirectory() const
Definition: KVSimDir.cpp:143
const Char_t * GetDirectory() const
Definition: KVSimDir.h:61
Bool_t IsFromAuxDirectory(KVSimFile *) const
returns true if given file is in the auxiliary directory
Definition: KVSimDir.cpp:153
const KVList * GetSimDataList() const
Definition: KVSimDir.h:72
void AnalyseDirectory()
Definition: KVSimDir.cpp:171
void AddSimData(KVSimFile *, bool=false)
Definition: KVSimDir.cpp:320
Handle file containing simulated and/or filtered simulated data ,.
Definition: KVSimFile.h:20
const Char_t * GetSystem() const
Definition: KVSimFile.h:88
const Char_t * GetBranchName() const
Definition: KVSimFile.h:125
const Char_t * GetOriginalFile() const
Definition: KVSimFile.h:130
Int_t GetRun() const
Definition: KVSimFile.h:103
const Char_t * GetFilterType() const
Definition: KVSimFile.h:98
Bool_t IsGemini() const
Definition: KVSimFile.h:50
const Char_t * GetDataSet() const
Definition: KVSimFile.h:83
Long64_t GetEvents() const
Definition: KVSimFile.h:78
const Char_t * GetDataQualityAudit() const
Definition: KVSimFile.h:135
const Char_t * GetTreeName() const
Definition: KVSimFile.h:120
Int_t GetGemDecayPerEvent() const
Definition: KVSimFile.h:62
static KVSimReader * MakeSimReader(const char *model_uri)
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....
Definition: KVString.h:73
void Begin(TString delim) const
Definition: KVString.cpp:565
Bool_t End() const
Definition: KVString.cpp:634
KVString Next(Bool_t strip_whitespace=kFALSE) const
Definition: KVString.cpp:695
Extended TList class which does not own its objects by default.
Definition: KVUnownedList.h:20
void ls(Option_t *option="") const override
virtual Int_t GetEntries() const
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)
virtual void SaveLevel(EEnvLevel level)
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 SetToolTipText(const char *text, Long_t delayms=400)
virtual void AllowStayDown(Bool_t a)
virtual void SetEnabled(Bool_t e=kTRUE)
virtual void SetContainer(TGFrame *f)
TGViewPort * GetViewPort() const
void MapSubwindows() override
Bool_t IsDown() const override
void SetState(EButtonState state, Bool_t emit=kFALSE) override
TGDimension GetDefaultSize() const override
virtual void SetLayoutManager(TGLayoutManager *l)
virtual void AddFrame(TGFrame *f, TGLayoutHints *l=nullptr)
void MapSubwindows() override
TList * fFileNamesList
char * fFilename
void SetMultipleSelection(Bool_t option)
const char ** fFileTypes
char * fIniDir
Bool_t fMultipleSelection
virtual void Resize(TGDimension size)
void MapWindow() override
virtual const char * GetText() const=0
virtual void SetPictures(const TGPicture *, const TGPicture *)
Int_t DeleteItem(TGListTreeItem *item)
TGListTreeItem * GetFirstItem() const
void AddItem(const char *string)
void CloseItem(TGListTreeItem *item)
void SetWindowName(const char *name=nullptr) override
void SetMWMHints(UInt_t value, UInt_t funcs, UInt_t input)
virtual TGPopupMenu * RemovePopup(const char *s)
virtual void SetState(Bool_t enable=kTRUE)
virtual Double_t GetNumber() const
virtual Bool_t IsEntryChecked(Int_t id)
virtual void AddLabel(const char *s, const TGPicture *p=nullptr, TGMenuEntry *before=nullptr)
virtual void CheckEntry(Int_t id)
virtual void DisableEntry(Int_t id)
virtual void AddEntry(const char *s, Int_t id, void *ud=nullptr, const TGPicture *p=nullptr, TGMenuEntry *before=nullptr)
virtual void UnCheckEntry(Int_t id)
virtual void DeleteEntry(Int_t id)
virtual void AddSeparator(TGMenuEntry *before=nullptr)
virtual void RCheckEntry(Int_t id, Int_t IDfirst, Int_t IDlast)
const TList * GetListOfEntries() const
virtual void SetParts(Int_t *parts, Int_t npart)
virtual void SetText(const char *text, Int_t partidx=0)
virtual void SetName(const char *name)
TObject * First() const override
const char * GetName() const override
const char * GetTitle() const override
static TClass * Class()
virtual const char * GetName() const
R__ALWAYS_INLINE Bool_t IsZombie() const
virtual void Info(const char *method, const char *msgfmt,...) const
Bool_t Connect(const char *signal, const char *receiver_class, void *receiver, const char *slot)
Ssiz_t Length() const
const char * Data() const
Bool_t IsNull() const
TString & Remove(EStripType s, char c)
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
TString & ReplaceAll(const char *s1, const char *s2)
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
const char * pwd()
virtual const char * BaseName(const char *pathname)
virtual void SetBuildDir(const char *build_dir, Bool_t isflat=kFALSE)
virtual const char * TempDirectory() const
long long Long64_t
std::map< int, DQA_entry > DQA_map
Definition: KVSimDirGUI.h:322
void handle_menu(menu_type &m)
Definition: KVSimDirGUI.h:453
TGPopupMenu * add_popup(const char *name, TGPopupMenu *parent)
Definition: KVSimDirGUI.h:442
analysis_struct analysis
Definition: KVSimDirGUI.h:300
ClassImp(TPyArg)