![]() |
KaliVeda
Toolkit for HIC analysis
|
Global variable for defining random subevents.
This variable will create a group for a given fraction \(0<f<1\) of all particles in an event, chosen at random. The name of the variable is used as the name for the group. The fraction is given as a parameter.
Example of use:
For each event, a random subset of half of the particles will be added to the group "SubEvent1"
.
If the required fraction does not correspond to a whole number of particles, the number of particles included in the subevent will be drawn at random so that the mean number of particles in all subevents for a given total multiplicity \(N\) is equal to \(fN\). In other words, the probability distribution of the number of particles \(n\) in each subevent will be
\[ P(n) = \delta(n-n_0)(1-x)+\delta(n-(n_0+1))x \]
with
\[ n_0=\lfloor fN\rfloor, x=fN-n_0 \]
Definition at line 41 of file KVSubEventMaker.h.
#include <KVSubEventMaker.h>
Public Member Functions | |
KVSubEventMaker () | |
KVSubEventMaker (const Char_t *nom) | |
virtual | ~KVSubEventMaker () |
void | Calculate () |
Calculation of global variable value(s) after filling is finished. More... | |
void | Copy (TObject &obj) const |
void | Init () |
Initialisation of internal variables, called once before beginning treatment. More... | |
void | Reset () |
Reset internal variables, called before treatment of each event. More... | |
![]() | |
KVVarGlob () | |
KVVarGlob (const Char_t *nom) | |
virtual | ~KVVarGlob (void) |
void | AddSelection (const KVParticleCondition &sel) |
Double_t | AsDouble () const |
void | Copy (TObject &obj) const |
void | DefineNewFrame (KVEvent *e) const |
void | Fill (const KVNucleus *c) |
void | Fill2 (const KVNucleus *n1, const KVNucleus *n2) |
virtual void | FillN (const KVEvent *) |
const TString & | GetFrame () const |
Int_t | GetNameIndex (const Char_t *name) const |
Double_t | GetNormalization () const |
Int_t | GetNumberOfBranches () const |
virtual Int_t | GetNumberOfValues () const |
TString | GetOptionString (const Char_t *opt) const |
Double_t | GetParameter (const Char_t *par) const |
Double_t | GetValue (const Char_t *name) const |
Double_t | GetValue (Int_t i) const |
Double_t | GetValue (void) const |
virtual TString | GetValueName (Int_t i) const |
const KVNameValueList & | GetValueNameList () const |
virtual Char_t | GetValueType (Int_t) const |
virtual std::vector< Double_t > | GetValueVector (void) const |
Bool_t | HasValue (const Char_t *name) const |
bool | IsDefiningNewFrame () const |
virtual Bool_t | IsGlobalVariable () const |
Bool_t | IsNBody () const |
Bool_t | IsOneBody () const |
Bool_t | IsOptionGiven (const Char_t *opt) |
Bool_t | IsParameterSet (const Char_t *par) |
bool | IsSelectingEvents () const |
Bool_t | IsTwoBody () const |
void | ListInit () |
operator double () const | |
Double_t | operator() (const Char_t *name) const |
Double_t | operator() (Int_t i) const |
Double_t | operator() (void) const |
void | Print (Option_t *="") const |
void | SetDefineGroup (const KVString &groupname="") |
void | SetEventSelection (const EventSelector &f) |
void | SetFrame (const Char_t *ref) |
void | SetMaxNumBranches (Int_t n) |
void | SetNewFrameDefinition (const FrameSetter &f) |
virtual void | SetNormalization (Double_t norm) |
void | SetOption (const Char_t *option, const Char_t *value) |
void | SetParameter (const Char_t *par, Double_t value) |
void | SetSelection (const KVParticleCondition &sel) |
bool | TestEventSelection () const |
void | UnsetOption (const Char_t *opt) |
void | UnsetParameter (const Char_t *par) |
![]() | |
KVBase () | |
Default constructor. More... | |
KVBase (const Char_t *name, const Char_t *title="") | |
Ctor for object with given name and type. More... | |
KVBase (const KVBase &) | |
copy ctor More... | |
virtual | ~ KVBase () |
virtual void | Clear (Option_t *opt="") |
Clear object properties : name, type/title, number, label. More... | |
const Char_t * | GetLabel () const |
UInt_t | GetNumber () const |
UInt_t | GetNumberOfObjects () const |
virtual TObject * | GetObject () const |
virtual const Char_t * | GetType () const |
Bool_t | HasLabel () const |
virtual Bool_t | IsCalled (const Char_t *name) const |
Bool_t | IsLabelled (const Char_t *l) const |
virtual Bool_t | IsType (const Char_t *typ) const |
virtual void | List () |
KVBase & | operator= (const KVBase &) |
copy assignment operator More... | |
Double_t | ProtectedGetX (const TF1 *func, Double_t val, int &status, Double_t xmin=0.0, Double_t xmax=0.0) const |
void | SetLabel (const Char_t *lab) |
virtual void | SetNumber (UInt_t num) |
virtual void | SetType (const Char_t *str) |
Private Member Functions | |
void | fill (const KVNucleus *) |
add to internal list More... | |
Double_t | getvalue_int (Int_t) const |
void | init () |
PRIVATE method. More... | |
Private Attributes | |
std::vector< KVNucleus * > | particles |
Additional Inherited Members | |
![]() | |
enum | { kOneBody , kTwoBody , kNBody } |
![]() | |
enum | EKaliVedaBits { kIsKaliVedaObject = BIT(23) } |
![]() | |
static void | MakeClass (const Char_t *classname, const Char_t *classdesc, int type=kOneBody) |
![]() | |
static Bool_t | AreEqual (Double_t x, Double_t y, Long64_t maxdif=1) |
Comparison between two 64-bit floating-point values. More... | |
static void | BackupFileWithDate (const Char_t *path) |
static void | CombineFiles (const Char_t *file1, const Char_t *file2, const Char_t *newfilename, Bool_t keep=kTRUE) |
static void | Deprecated (const char *method, const char *advice) |
static Bool_t | FindClassSourceFiles (const Char_t *class_name, KVString &imp_file, KVString &dec_file, const Char_t *dir_name=".") |
static Bool_t | FindExecutable (TString &exec, const Char_t *path="$(PATH)") |
static const Char_t * | FindFile (const Char_t *search, TString &wfil) |
static const Char_t * | GetBINDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetDATABASEFilePath () |
static const Char_t * | GetDATADIRFilePath (const Char_t *namefile="") |
static Bool_t | GetDataSetEnv (const Char_t *dataset, const Char_t *type, Bool_t defval) |
static const Char_t * | GetDataSetEnv (const Char_t *dataset, const Char_t *type, const Char_t *defval) |
static Double_t | GetDataSetEnv (const Char_t *dataset, const Char_t *type, Double_t defval) |
static const Char_t * | GetETCDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetExampleFilePath (const Char_t *library, const Char_t *namefile) |
Return full path to example file for given library (="KVMultiDet", "BackTrack", etc.) More... | |
static const Char_t * | GetINCDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetKVBuildDate () |
Returns KaliVeda build date. More... | |
static const Char_t * | GetKVBuildDir () |
Returns top-level directory used for build. More... | |
static const Char_t * | GetKVBuildTime () |
Returns KaliVeda build time. More... | |
static const Char_t * | GetKVBuildType () |
Returns KaliVeda build type (cmake build: Release, Debug, RelWithDebInfo, ...) More... | |
static const Char_t * | GetKVBuildUser () |
Returns username of person who performed build. More... | |
static const Char_t * | GetKVSourceDir () |
Returns top-level directory of source tree used for build. More... | |
static const Char_t * | GetKVVersion () |
Returns KaliVeda version string. More... | |
static const Char_t * | GetLIBDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetListOfPlugins (const Char_t *base) |
static const Char_t * | GetListOfPluginURIs (const Char_t *base) |
static const Char_t * | GetPluginURI (const Char_t *base, const Char_t *plugin) |
static void | GetTempFileName (TString &base) |
static const Char_t * | GetTEMPLATEDIRFilePath (const Char_t *namefile="") |
static const Char_t * | GetWORKDIRFilePath (const Char_t *namefile="") |
static const Char_t * | gitBranch () |
Returns git branch of sources. More... | |
static const Char_t * | gitCommit () |
Returns last git commit of sources. More... | |
static void | InitEnvironment () |
static bool | is_gnuinstall () |
static Bool_t | IsThisAPlugin (const TString &uri, TString &base) |
static TPluginHandler * | LoadPlugin (const Char_t *base, const Char_t *uri="0") |
static Bool_t | OpenContextMenu (const char *method, TObject *obj, const char *alt_method_name="") |
static void | OpenTempFile (TString &base, std::ofstream &fp) |
static void | PrintSplashScreen () |
Prints welcome message and infos on version etc. More... | |
static Bool_t | SearchAndOpenKVFile (const Char_t *name, KVSQLite::database &dbfile, const Char_t *kvsubdir="") |
static Bool_t | SearchAndOpenKVFile (const Char_t *name, std::ifstream &file, const Char_t *kvsubdir="", KVLockfile *locks=0) |
static Bool_t | SearchAndOpenKVFile (const Char_t *name, std::ofstream &file, const Char_t *kvsubdir="", KVLockfile *locks=0) |
static Bool_t | SearchKVFile (const Char_t *name, TString &fullpath, const Char_t *kvsubdir="") |
static const Char_t * | WorkingDirectory () |
|
inline |
Definition at line 51 of file KVSubEventMaker.h.
|
inline |
Definition at line 56 of file KVSubEventMaker.h.
|
inlinevirtual |
Definition at line 64 of file KVSubEventMaker.h.
|
virtual |
Calculation of global variable value(s) after filling is finished.
Set group for required fraction of particles (starting from the first one)
Implements KVVarGlob.
Definition at line 60 of file KVSubEventMaker.cpp.
|
virtual |
Copy state of 'this' object into the KVSubEventMaker object referenced by 'a'. This is needed for the automatically generated copy constructor and copy assignment operator to work correctly.
Reimplemented from KVBase.
Definition at line 14 of file KVSubEventMaker.cpp.
|
privatevirtual |
add to internal list
Reimplemented from KVVarGlob.
Definition at line 131 of file KVSubEventMaker.cpp.
|
privatevirtual |
Protected method, called by GetValue(Int_t) and GetValue(const Char_t*) If your variable calculates several different values, this method allows to access each value based on a unique index number.
You should implement something like the following:
switch(index){ case 0: return val0; break; case 1: return val1; break; }
where 'val0' and 'val1' are the internal variables of your class corresponding to the required values.
In order for GetValue(const Char_t*) to work, you need to associate each named value with an index corresponding to the above 'switch' statement, e.g.
SetNameIndex("val0", 0); SetNameIndex("val1", 1);
This should be done in the init() method.
Implements KVVarGlob.
Definition at line 120 of file KVSubEventMaker.cpp.
|
virtual |
Initialisation of internal variables, called once before beginning treatment.
Implements KVVarGlob.
Definition at line 36 of file KVSubEventMaker.cpp.
|
private |
PRIVATE method.
Private initialisation method called by all constructors. All member initialisations should be done here. You should also (if your variable calculates several different quantities) set up a correspondance between named values and index number using method SetNameIndex(const Char_t*,Int_t) in order for GetValue(const Char_t*) to work correctly. The index numbers should be the same as in your getvalue_int(Int_t) method.
Definition at line 151 of file KVSubEventMaker.cpp.
|
virtual |
Reset internal variables, called before treatment of each event.
Implements KVVarGlob.
Definition at line 47 of file KVSubEventMaker.cpp.
|
private |
Definition at line 43 of file KVSubEventMaker.h.