14#ifndef ALICEO2_EVENTGEN_TPCLOOPERS_H_
15#define ALICEO2_EVENTGEN_TPCLOOPERS_H_
17#ifdef GENERATORS_WITH_TPCLOOPERS
18#include <onnxruntime_cxx_api.h>
21#include <rapidjson/document.h>
26#ifdef GENERATORS_WITH_TPCLOOPERS
35 std::vector<double> normal_min;
36 std::vector<double> normal_max;
37 std::vector<double> outlier_center;
38 std::vector<double> outlier_scale;
40 void load(
const std::string&
filename);
42 std::vector<double> inverse_transform(
const std::vector<double>& input);
45 std::vector<double> jsonArrayToVector(
const rapidjson::Value& jsonArray);
52 ONNXGenerator(Ort::Env& shared_env,
const std::string& model_path);
54 std::vector<double> generate_sample();
68#ifdef GENERATORS_WITH_TPCLOOPERS
86 GenTPCLoopers(std::string model_pairs =
"tpcloopmodel.onnx", std::string model_compton =
"tpcloopmodelcompton.onnx",
87 std::string poisson =
"poisson.csv", std::string gauss =
"gauss.csv", std::string scaler_pair =
"scaler_pair.json",
88 std::string scaler_compton =
"scaler_compton.json");
90 Bool_t generateEvent();
92 Bool_t generateEvent(
double time_limit);
94 std::vector<TParticle> importParticles();
96 unsigned int PoissonPairs();
98 unsigned int GaussianElectrons();
100 void SetNLoopers(
unsigned int nsig_pair,
unsigned int nsig_compton);
102 void SetMultiplier(
const std::array<float, 2>& mult);
104 void setFlatGas(Bool_t flat, Int_t number = -1, Int_t nloopers_orbit = -1);
106 void setFractionPairs(
float fractionPairs);
108 void SetRate(
const std::string& rateFile,
bool isPbPb,
int intRate = 50000);
110 void SetAdjust(
float adjust = 0.f);
112 unsigned int getNLoopers()
const {
return (mNLoopersPairs + mNLoopersCompton); }
115 std::unique_ptr<ONNXGenerator> mONNX_pair =
nullptr;
116 std::unique_ptr<ONNXGenerator> mONNX_compton =
nullptr;
117 std::unique_ptr<Scaler> mScaler_pair =
nullptr;
118 std::unique_ptr<Scaler> mScaler_compton =
nullptr;
119 double mPoisson[3] = {0.0, 0.0, 0.0};
120 double mGauss[4] = {0.0, 0.0, 0.0, 0.0};
121 std::vector<std::vector<double>> mGenPairs;
122 std::vector<std::vector<double>> mGenElectrons;
123 unsigned int mNLoopersPairs = -1;
124 unsigned int mNLoopersCompton = -1;
125 std::array<float, 2> mMultiplier = {1., 1.};
126 bool mPoissonSet =
false;
127 bool mGaussSet =
false;
130 int mCurrentEvent = 0;
131 TFile* mContextFile =
nullptr;
133 std::vector<o2::InteractionTimeRecord> mInteractionTimeRecords;
134 Bool_t mFlatGas =
false;
135 Bool_t mFlatGasOrbit =
false;
136 Int_t mFlatGasNumber = -1;
137 double mIntTimeRecMean = 1.0;
138 double mTimeLimit = 0.0;
139 double mTimeEnd = 0.0;
140 float mLoopsFractionPairs = 0.08;
141 int mInteractionRate = 50000;
Ort::Env global_env(ORT_LOGGING_LEVEL_WARNING, "GlobalEnv")
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...