KaliVeda
Toolkit for HIC analysis
ExampleFilteredSimDataAnalysis.cpp

Example of an analysis class for filtered simulated data

A simple example of analysis of filtered simulated data, for use with kaliveda-sim.

#ifndef __EXAMPLEFILTEREDSIMDATAANALYSIS_H
#define __EXAMPLEFILTEREDSIMDATAANALYSIS_H
#include "KVEventSelector.h"
#include "KVZmax.h"
#include "KVDataAnalyser.h"
class ExampleFilteredSimDataAnalysis : public KVEventSelector {
double ZVproj;
Bool_t link_to_unfiltered_simulation;
public:
ExampleFilteredSimDataAnalysis() {}
virtual ~ExampleFilteredSimDataAnalysis() {}
void InitAnalysis();
void InitRun();
void EndRun() {}
void EndAnalysis() {}
ClassDef(ExampleFilteredSimDataAnalysis, 1) //Analysis of filtered simulated events
};
#endif
bool Bool_t
#define ClassDef(name, id)
General purpose analysis base class for TTree containing KVEvent objects.
virtual void InitAnalysis()
virtual void EndRun()
virtual Bool_t Analysis()
virtual void EndAnalysis()
virtual void InitRun()
#include "ExampleFilteredSimDataAnalysis.h"
#include "KVReconstructedNucleus.h"
#include "KVBatchSystem.h"
ClassImp(ExampleFilteredSimDataAnalysis)
#include "KVMultiDetArray.h"
void ExampleFilteredSimDataAnalysis::InitAnalysis()
{
// INITIALISATION PERFORMED AT BEGINNING OF ANALYSIS
// Here you define:
// - global variables
// - histograms
// - trees
//
// NB: no access to multidetector array or reaction
// kinematics yet: see InitRun()
// DEFINITION OF GLOBAL VARIABLES FOR ANALYSIS
AddGV("KVMult", "mult"); // total multiplicity of each event
auto zvtot = AddGV("KVZVtot", "ZVTOT"); // total pseudo-momentum
// Rejection of less-well measured events:
// here we require reconstruction of at least 80% of projectile quasi-momentum
zvtot->SetEventSelection([&](const KVVarGlob * vg) {
return vg->GetValue() > 0.8 * ZVproj;
});
// ZVproj = projectile quasi-momentum, will be defined in InitRun()
// DEFINITION OF HISTOGRAMS
AddHisto<TH2F>("Z_Vpar", "Z vs V_{par} [cm/ns] in CM", 250, -10, 10, 75, .5, 75.5);
// DEFINITION OF TREE USED TO STORE RESULTS
auto t = AddTree("data", GetOpt("SimulationInfos"));
// add a branch to tree for each defined global variable
GetGVList()->MakeBranches(t);
// check if we can access the original simulated events before filtering
// (activated when selecting both filtered & simulated files in kaliveda-sim GUI)
link_to_unfiltered_simulation = IsOptGiven("AuxFiles");
}
//____________________________________________________________________________________
void ExampleFilteredSimDataAnalysis::InitRun()
{
// INITIALISATION PERFORMED JUST BEFORE ANALYSIS
// In this method the multidetector array/setup used to filter
// the simulation is available (gMultiDetArray)
// The kinematics of the reaction is available (KV2Body*)
// using gDataAnalyser->GetKinematics()
// retrieve projectile quasi-momentum for run
const KV2Body* kin = gDataAnalyser->GetKinematics();
ZVproj = kin->GetNucleus(1)->GetVpar() * kin->GetNucleus(1)->GetZ();
// reject reconstructed events which are not consistent with the DAQ trigger
SetTriggerConditionsForRun(gMultiDetArray->GetCurrentRunNumber());
}
//____________________________________________________________________________________
Bool_t ExampleFilteredSimDataAnalysis::Analysis()
{
// EVENT BY EVENT ANALYSIS
// if we can access the events of the unfiltered simulation, read in the event corresponding
// to the currently analysed reconstructed event
if (link_to_unfiltered_simulation) GetFriendTreeEntry(GetEvent()->GetParameters()->GetIntValue("SIMEVENT_TREE_ENTRY"));
for (auto& part : ReconEventOKIterator(GetEvent())) {
// if we can access the events of the unfiltered simulation, and if Gemini++ was used
// to decay events before filtering, this is how you can access the "parent" nucleus
// of the current detected decay product
// KVSimNucleus* papa = (KVSimNucleus*)GetFriendEvent()->GetParticle( part.GetParameters()->GetIntValue("GEMINI_PARENT_INDEX") );
FillHisto("Z_Vpar", part.GetFrame("CM")->GetVpar(), part.GetZ());
}
GetGVList()->FillBranches();
return kTRUE;
}
constexpr Bool_t kTRUE
void GetParameters(TFitEditor::FuncParams_t &pars, TF1 *func)
Relativistic binary kinematics calculator.
Definition: KV2Body.h:166
KVNucleus * GetNucleus(Int_t i) const
Definition: KV2Body.cpp:456
virtual const KV2Body * GetKinematics() const
UInt_t GetCurrentRunNumber() const
Int_t GetZ() const
Return the number of proton / atomic number.
Definition: KVNucleus.cpp:773
Double_t GetVpar() const
Definition: KVParticle.h:675
Base class for all global variable implementations.
Definition: KVVarGlob.h:233
Double_t GetValue(void) const
Definition: KVVarGlob.h:443
Wrapper class for iterating over "OK" nuclei in KVReconstructedEvent accessed through base pointer or...
void FillTree(TTree &myTree, const RooDataSet &data)
ClassImp(TPyArg)