4 #include "KVUnownedList.h"
5 #include "KVSimDirGUI.h"
6 #include "KVDataSetManager.h"
7 #include "KVBatchSystemManager.h"
9 #include "KVDBSystem.h"
11 #include "KVSimFile.h"
12 #include "KVFileDialog.h"
13 #include "KVInputDialog.h"
19 #include <KVDataAnalyser.h>
20 #include <KVSimDirFilterAnalyser.h>
21 #include <KVSimReader.h>
26 #include "KVBatchSystemParametersGUI.h"
27 #include "KVDropDownDialog.h"
40 TString ds_table_name =
Form(
"Table_%d", ds_table_number);
59 fConfigDB.add_table(DStable);
61 fConfigDB[
"Datasets"][
"Table"] = ds_table_name;
62 fConfigDB.update(
"Datasets",
"Table",
Form(
"Name=\"%s\"", sd->
GetName()));
72 fConfigDB.prepare_data_insertion(ds_table_name);
78 dstable[
"Id"].set_null();
79 dstable[
"FileName"] = sf->
GetName();
80 dstable[
"TreeInfo"] = sf->
GetTitle();
82 dstable[
"Filtered"] = 0;
86 fConfigDB.insert_data_row();
93 dstable[
"Id"].set_null();
94 dstable[
"FileName"] = sf->
GetName();
95 dstable[
"TreeInfo"] = sf->
GetTitle();
97 dstable[
"Filtered"] = 1;
103 dstable[
"Run"] = sf->
GetRun();
109 fConfigDB.insert_data_row();
112 fConfigDB.end_data_insertion();
123 : fGuirc(
".kvsimdirguirc")
125 , fConfigDB(
gSystem->ExpandPathName(
"$(HOME)/.kvsimdirguidb"))
167 if (!gDataSetManager) {
236 BaddDir->
Connect(
"Clicked()",
"KVSimDirGUI",
this,
"AddSimDir()");
241 BimpSim->
Connect(
"Clicked()",
"KVSimDirGUI",
this,
"ImportSimulation()");
246 BremDir->
Connect(
"Clicked()",
"KVSimDirGUI",
this,
"RemSimDir()");
271 fDirListTree->
Connect(
"Clicked(TGListTreeItem*,Int_t)",
"KVSimDirGUI",
this,
"SelectSimDir(TGListTreeItem*,Int_t)");
272 fDirListTree->
Connect(
"DoubleClicked(TGListTreeItem*,Int_t)",
"KVSimDirGUI",
this,
"AddAuxDir(TGListTreeItem*,Int_t)");
314 auto lab =
new TGLabel(hf,
"Events : ");
320 fCBAllEvents->
Connect(
"Toggled(Bool_t)",
"KVSimDirGUI",
this,
"EnableEventNumberEntry(Bool_t)");
333 launch_analysis->
Connect(
"Clicked()",
"KVSimDirGUI",
this,
"Run()");
335 launch_analysis->
Resize(40, 40);
354 bool sqlite_conversion =
false;
356 sqlite_conversion =
true;
366 if (!sqlite_conversion) {
368 if(!
fConfigDB[
"Datasets"].has_column(
"AuxDir"))
380 if (sqlite_conversion) {
388 while (!simdirs.
End()) {
393 if (sqlite_conversion) {
395 fConfigDB[
"Datasets"][
"Directory"] = simdirectory;
396 fConfigDB[
"Datasets"][
"AuxDir"].set_null();
404 if (sqlite_conversion) {
430 while ((o = next())) {
479 if (simdirs !=
"") simdirs +=
" ";
480 simdirs += simdirname;
486 int ds_table_num = 0;
491 "Table_%d", &ds_table_num);
495 fConfigDB[
"Datasets"][
"Name"] = simdirname;
497 fConfigDB[
"Datasets"][
"AuxDir"].set_null();
555 while ((togo = (
KVSimDir*)next())) {
556 if (simdirs !=
"") simdirs +=
" ";
617 const char* filetypes[] = {
618 "Class header files",
"*.h",
628 if (idot < 0)
return;
679 if (entry->GetPopup())
680 delete entry->GetPopup();
691 std::unordered_map<std::string, TGPopupMenu*> DQA_system_popups;
737 while ((dbr = (
KVDBRun*)next())) {
784 TList* runs_to_analyse(
nullptr);
785 TList* aux_runs_to_analyse(
nullptr);
787 if (
type ==
"tree") {
788 if (!selected_sim_runs->GetEntries() && !selected_filt_runs->GetEntries()) {
800 if (selected_sim_runs->GetEntries()) {
801 if (selected_filt_runs->GetEntries()) {
804 runs_to_analyse = selected_filt_runs.get();
805 analysis_task =
"analysis filtered";
806 aux_runs_to_analyse = selected_sim_runs.get();
809 runs_to_analyse = selected_sim_runs.get();
810 analysis_task =
"analysis simulated";
814 runs_to_analyse = selected_filt_runs.get();
815 analysis_task =
"analysis filtered";
820 if (selected_filt_runs->GetEntries()) {
824 if (!selected_sim_runs->GetEntries()) {
828 runs_to_analyse = selected_sim_runs.get();
829 analysis_task =
"filter simulated";
845 if (aux_runs_to_analyse) gDataAnalyser->
SetAuxFileList(aux_runs_to_analyse);
860 if (
type ==
"filter") {
868 Error(
"SetFilterOptions",
"Please check the format of the ad hoc system name you gave");
869 WarningBox(
"Bad System",
"Please check the format of the ad hoc system name you gave",
kFALSE);
885 gBatchSystem->
Clear();
889 if (!cancel_batch_job) {
898 selected_filt_runs.reset(
nullptr);
899 selected_sim_runs.reset(
nullptr);
907 TString KVSimDirGUI::GetKinematicsString()
929 filter =
"GeoThresh";
944 TString kinema = GetKinematicsString();
950 else if (kinema !=
"lab") {
953 "KVSimDirGUI::SetFilterOptions",
954 Form(
"Cannot transform kinematics from %s to lab without a defined reaction (system)!", kinema.
Data()),
959 options +=
Form(
"Filter=%s,", filter.
Data());
960 options +=
Form(
"Kinematics=%s", kinema.
Data());
964 r.Form(
",Run=%d",
fRun);
970 "KVSimDirGUI::SetFilterOptions",
971 Form(
"To use 'FULL' (run-dependent) filter requires either a run number or a system from the dataset!"),
978 options +=
",Gemini=yes";
986 std::cout << options << std::endl;
998 const char* filetypes[] = {
1011 if (one_file || many_files) {
1016 while (!plugins.
End()) {
1019 if (choices.
Length()) choices +=
" ";
1031 SR->ConvertAndSaveEventsInFile(fi.
fFilename);
1043 while ((o = it())) {
1045 SR->SetMultiFiles();
1046 SR->SetFileIndex(i++);
1048 SR->ConvertAndSaveEventsInFile(o->
GetName());
1071 new KVInputDialog(
MainFrame,
"Enter name of new analysis class", &classname, &ok,
"Enter name of new analysis class");
1075 ok = ok &&
WarningBox(
"Replacing existing class",
1076 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)",
1096 new KVInputDialog(
MainFrame,
"Enter name of new analysis class", &classname, &ok,
"Enter name of new analysis class");
1100 ok = ok &&
WarningBox(
"Replacing existing class",
1101 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)",
1132 reply = (ret_code &
kMBYes);
1143 int parts[] = {14, 25, 10, 14, 9, 7, 10};
1183 fConfigDB[
"Datasets"][
"Directory"].get_data<TString>());
1184 if(!
fConfigDB[
"Datasets"][
"AuxDir"].is_null())
1185 sd->SetAuxDirectory(
fConfigDB[
"Datasets"][
"AuxDir"].get_data<TString>());
1188 fConfigDB[
"Datasets"][
"Table"].get_data<TString>());
1190 for (
int i = 0; i < tables.
GetNpar(); ++i) {
1195 bool from_aux_dir = dstable[
"AuxDir"].get_data<
int>();
1196 if (dstable[
"Filtered"].get_data<int>()) {
1200 dstable[
"FileName"].get_data<TString>(), dstable[
"TreeInfo"].get_data<TString>(),
1201 dstable[
"Events"].get_data<int>(), dstable[
"TreeName"].get_data<TString>(),
1202 dstable[
"BranchName"].get_data<TString>(), dstable[
"DataSet"].get_data<TString>(),
1203 dstable[
"System"].get_data<TString>(), dstable[
"Run"].get_data<int>(),
1204 dstable[
"OrigFile"].get_data<TString>(),
1205 dstable[
"FiltType"].get_data<TString>(),
1206 dstable[
"DataQualityAudit"].get_data<TString>()
1208 f->SetGemini(dstable[
"Gemini"].get_data<bool>());
1209 if (
f->IsGemini())
f->SetGemDecayPerEvent(dstable[
"GemDecayPerEvent"].get_data<int>());
1216 dstable[
"FileName"].get_data<TString>(), dstable[
"TreeInfo"].get_data<TString>(),
1217 dstable[
"Events"].get_data<int>(), dstable[
"TreeName"].get_data<TString>(),
1218 dstable[
"BranchName"].get_data<TString>());
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 * Form(const char *fmt,...)
char * StrDup(const char *str)
R__EXTERN TSystem * gSystem
Relativistic binary kinematics calculator.
void CalculateKinematics()
void Print(Option_t *opt="") const override
static const Char_t * GetListOfPlugins(const Char_t *base)
static Bool_t FindClassSourceFiles(const KVString &class_name, KVString &imp_file, KVString &dec_file, const KVString &dir_name=".")
static const Char_t * GetPluginURI(const Char_t *base, const Char_t *plugin)
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 &)
virtual Int_t GetNumber() const
Description of an experimental run in database ,,.
Database class used to store information on different colliding systems studied during an experiment....
Bool_t IsCollision() const
retourne kTRUE, si le systeme est une collision ie projectile+cible
KVUnownedList * GetRuns() const
Returns a sorted list of all the runs associated with this system.
TString GetBatchNameWithoutEnergy()
TString GetReactionNameWithoutEnergy()
TString GetReactionEnergyWithoutName()
virtual void Run()
Check all task variables, then run analyser.
virtual void SetAuxFileList(TList *)
void SetBatchSystem(KVBatchSystem *bs)
void SetUserClassOptions(const Char_t *o="")
void SetAnalysisTask(KVDataAnalysisTask *at)
void SetUserClass(const UserClass &kvs, Bool_t check=kTRUE)
virtual void SetFileList(TList *)
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.
TString GetFullPathToDataSetFile(const Char_t *filename)
static Bool_t FindDataSetFile(const TString &dataset, const Char_t *filename)
Ask user to choose between several options in a drop-down list.
virtual KVDBSystem * GetSystem(const Char_t *system) const
virtual KVSeqCollection * GetSystems() const
Modified version of TGFileDialog file selection dialog.
Enhanced version of ROOT TGListView widget.
virtual void ActivateSortButtons()
virtual void SetDataColumns(Int_t ncolumns)
virtual void Display(const TCollection *l)
TList * GetSelectedObjects() const
void AllowContextMenu(Bool_t on=kTRUE)
virtual void SetDataColumn(Int_t index, const Char_t *name, const Char_t *method="", Int_t mode=kTextCenterX)
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
const Char_t * GetString() const
int get_number_of_tables() const
table & add_table(const table &)
bool update(const TString &table, const TString &columns, const TString &selection="")
void delete_data(const TString &table, const TString &selection="")
void delete_table(const TString &table)
column & add_column(const TString &table, const TString &name, const TString &type)
void end_data_insertion()
bool select_data(const TString &tables, const TString &columns="*", const TString &selection="", bool distinct=false, const TString &anything_else="") const
KVNameValueList get_name_value_list(const TString &table, const TString &name_column, const TString &value_column, const TString &selection="", const TString &anything_else="")
bool get_next_result() const
bool prepare_data_insertion(const TString &)
void clear_table(const TString &name)
Delete all data from table.
int count(const TString &tables, const TString &column="*", const TString &selection="", bool distinct=false, const TString &anything_else="") const
void primary_key(const TString &cols)
column & add_column(const KVSQLite::column &c)
KaliVeda extensions to ROOT collection classes.
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.
KVString fDataQualityAudit
TGPictureButton * BremDir
void SelectDataSet(const char *)
void ReconstructSimDirsFromDB()
Rebuild all KVSimDir/KVSimFile objects from information in sqlite DB.
void NewFilteredAnalysisClass()
Get name of new class.
KVSQLite::database fConfigDB
void SelectAnalysisClass()
KVDataAnalyser::UserClass fAnalClass
TGCheckButton * fCBAllEvents
void NewSimulatedAnalysisClass()
Get name of new class.
void SetAnalysisStatusBar()
TGViewPort * fDirListViewPort
TGNumberEntry * fNENumberEvents
void SelectSystem(const char *)
KVSimDir * fSelectedSimDir
KVString fReactionKinematics
TGListTree * fDirListTree
TGCanvas * fDirListCanvas
void AddAuxDir(TGListTreeItem *simdir, Int_t)
const TGPicture * pclose
used for list tree items
void SetRandomPhi(Bool_t on)
const TGPicture * popen
used for list tree items
void SetFilterStatusBar()
void Run()
void ChangeOutputDirectory();
void FillDataSetTableWithInfos(TString ds_table_name, KVSimDir *sd)
TGPictureButton * proof_analysis
TGTextEntry* fTEOutputDir;.
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
Bool_t fWithPROOF
=kTRUE when running with PROOF-lite
Bool_t fCancelJob
if job parameters are not valid
TGPictureButton * BimpSim
TGPictureButton * BrefreshDir
void SelectSimDir(TGListTreeItem *, Int_t)
TString AddTableForDataSet(KVSimDir *sd, int ds_table_number)
Add a new dataset table for the given KVSimDir object.
void ImportSimulation()
Import simulation data from currently selected directory.
Handle directory containing simulated and/or filtered simulated data ,.
const KVList * GetFiltDataList() const
void SetAuxDirectory(const TString &)
void AddFiltData(KVSimFile *, bool=false)
Bool_t HasAuxDirectory() const
const Char_t * GetDirectory() const
Bool_t IsFromAuxDirectory(KVSimFile *) const
returns true if given file is in the auxiliary directory
const KVList * GetSimDataList() const
void AddSimData(KVSimFile *, bool=false)
Handle file containing simulated and/or filtered simulated data ,.
const Char_t * GetSystem() const
const Char_t * GetBranchName() const
const Char_t * GetOriginalFile() const
const Char_t * GetFilterType() const
const Char_t * GetDataSet() const
Long64_t GetEvents() const
const Char_t * GetDataQualityAudit() const
const Char_t * GetTreeName() const
Int_t GetGemDecayPerEvent() const
static KVSimReader * MakeSimReader(const char *model_uri)
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
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 SetContainer(TGFrame *f)
TGViewPort * GetViewPort() const
void MapSubwindows() override
TGDimension GetDefaultSize() const override
virtual void SetLayoutManager(TGLayoutManager *l)
virtual void AddFrame(TGFrame *f, TGLayoutHints *l=nullptr)
void MapSubwindows() override
void SetMultipleSelection(Bool_t option)
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 void SetState(Bool_t enable=kTRUE)
virtual Double_t GetNumber() 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
virtual const char * GetName() const
R__ALWAYS_INLINE Bool_t IsZombie() const
virtual void Error(const char *method, const char *msgfmt,...) const
Bool_t Connect(const char *signal, const char *receiver_class, void *receiver, const char *slot)
const char * Data() const
TString & Remove(EStripType s, char c)
TString & ReplaceAll(const char *s1, const char *s2)
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
virtual const char * BaseName(const char *pathname)
virtual void SetBuildDir(const char *build_dir, Bool_t isflat=kFALSE)
virtual const char * TempDirectory() const
Bool_t with_files() const