#ifndef __CORRELATOR_H
#define __CORRELATOR_H
#include "KVReconEventSelector.h"
#include "KVEventMixerN.h"
#include "KVEventClassifier.h"
#include <vector>
#include <deque>
struct particle {
double phi;
int det_index;
particle() = default;
particle(particle&&) = default;
particle(const particle&) = default;
det_index{
p.GetStoppingDetector()->GetIndex()}
{}
};
{
return Form(
"h_cor_%s_bin_%d", quantity.
Data(), bin);
}
{
return Form(
"h_uncor_%s_bin_%d", quantity.
Data(), bin);
}
public:
ClassDef(ExampleAnalysis_KVEventMixerN_2Body, 0)
};
#endif
#define ClassDef(name, id)
winID h TVirtualViewer3D TVirtualGLPainter p
char * Form(const char *fmt,...)
Simple class for sorting events according to global variables.
Generic event mixing algorithm for N-particle correlation studies.
virtual void InitAnalysis()
virtual Bool_t Analysis()
void AddHisto(TH1 *histo)
virtual void EndAnalysis()
Base class for user analysis of reconstructed data.
Nuclei reconstructed from data measured by a detector array .
const char * Data() const
#include "ExampleAnalysis_KVEventMixerN_2Body.h"
ClassImp(ExampleAnalysis_KVEventMixerN_2Body)
void ExampleAnalysis_KVEventMixerN_2Body::InitAnalysis(void)
{
AddGV("KVMult", "mtot");
mult_bin = GetGVList()->AddEventClassifier("mtot");
std::vector<Double_t> mult_slices = {8.4195047, 14.449584, 21.173604, 28.044737};
for (auto cut : mult_slices) mult_bin->AddCut(cut);
for (int i = 0; i <= mult_slices.size(); ++i) {
AddHisto<TH1F>(get_cor_histo_name(i,
"dphi"),
Form(
"Correlated spectrum #Delta#phi bin %d", i), 21, -4.5, 184.5);
AddHisto<TH1F>(get_uncor_histo_name(i,
"dphi"),
Form(
"Uncorrelated spectrum #Delta#phi bin %d", i), 21, -4.5, 184.5);
}
auto t = AddTree("check_tree", "check event classifier");
GetGVList()->MakeBranches(t);
SetJobOutputFileName("ExampleAnalysis_KVEventMixerN_2Body_results.root");
}
void ExampleAnalysis_KVEventMixerN_2Body::InitRun(void)
{
SetTriggerConditionsForRun(GetCurrentRun()->GetNumber());
}
Bool_t ExampleAnalysis_KVEventMixerN_2Body::Analysis(
void)
{
auto bin = mult_bin->GetEventClassification();
GetGVList()->FillBranches();
event_mixer.ProcessEvent(bin,
if (&alpha[0] == &alpha[1]) return;
if (dphi > 180) dphi = 360 - dphi;
GetHisto(get_cor_histo_name(bin_num, "dphi"))->Fill(dphi);
},
if (other_alpha[0].det_index != alpha.GetStoppingDetector()->GetIndex()) {
if (dphi > 180) dphi = 360 - dphi;
GetHisto(get_uncor_histo_name(bin_num, "dphi"))->Fill(dphi);
}
},
"alpha",
{
return n->IsOK() &&
n->IsAMeasured() &&
n->IsIsotope(2, 4);
}
}),
"alpha",
{
return n->IsOK() &&
n->IsAMeasured() &&
n->IsIsotope(2, 4);
}
})
);
}
Base class used for handling geometry in a multidetector array.
Double_t GetAzimuthalWidth(Double_t phmin=-1., Double_t phimax=-1.) const
Vector of references to objects.
Wrapper class for iterating over nuclei in KVReconstructedEvent accessed through base pointer or refe...
void FillTree(TTree &myTree, const RooDataSet &data)