1#ifndef TMVA_SOFIE_ROPERATOR_Random
2#define TMVA_SOFIE_ROPERATOR_Random
52 std::vector<ETensorType>
TypeInference(std::vector<ETensorType> input)
override {
56 std::vector<std::vector<size_t>>
ShapeInference(std::vector<std::vector<size_t>> input)
override {
66 model.AddNeededCustomHeader(
"TRandom3.h");
71 if (
fParams.count(
"mean") == 0 )
73 if (
fParams.count(
"scale") == 0)
83 if (model.Verbose()) {
84 std::cout <<
"Random";
89 std::cout << p.first <<
" : " << p.second << std::endl;
94 std::stringstream out;
95 out <<
"std::unique_ptr<TRandom> fRndmEngine; // random number engine\n";
100 std::stringstream out;
101 out <<
"//--- creating random number generator ----\n";
104 out <<
SP <<
"fRndmEngine.reset(new TRandom3(" <<
fSeed <<
"));\n";
111 std::string
Generate(std::string OpName)
override {
112 OpName =
"op_" + OpName;
114 std::stringstream out;
115 out <<
"\n//------ Random";
121 out <<
SP <<
"for (int i = 0; i < " << length <<
"; i++) {\n";
125 throw std::runtime_error(
"TMVA SOFIE RandomNormal op : no mean or scale are defined");
127 float scale =
fParams[
"scale"];
128 out <<
SP <<
SP <<
"tensor_" <<
fNY <<
"[i] = this->fRndmEngine->Gaus(" << mean <<
"," << scale <<
");\n";
131 throw std::runtime_error(
"TMVA SOFIE RandomUniform op : no low or high are defined");
134 out <<
SP <<
SP <<
"tensor_" <<
fNY <<
"[i] = this->fRndmEngine->Uniform(" << low <<
"," << high <<
");\n";
143 std::vector<std::string>
ret = {
"memory"};
ROperator_Random(RandomOpMode mode, ETensorType type, const std::string &nameX, const std::string &nameY, const std::vector< size_t > &shape, const std::map< std::string, float > ¶ms, float seed)
std::vector< std::string > GetStdLibs() override
std::string Generate(std::string OpName) override
std::map< std::string, float > fParams
std::vector< std::vector< size_t > > ShapeInference(std::vector< std::vector< size_t > > input) override
std::vector< ETensorType > TypeInference(std::vector< ETensorType > input) override
std::string GenerateInitCode() override
std::vector< size_t > fShapeY
std::string GenerateDeclCode() override
void Initialize(RModel &model) override
std::vector< std::string_view > fInputTensorNames
const std::string SP
space used to correctly indent the generated C++ code
std::vector< std::string_view > fOutputTensorNames
std::size_t ConvertShapeToLength(const std::vector< size_t > &shape)
std::string ConvertShapeToString(const std::vector< size_t > &shape)
create variable transformations