1#ifndef TMVA_SOFIE_ROPERATOR_Shape
2#define TMVA_SOFIE_ROPERATOR_Shape
39 if (model.CheckIfTensorAlreadyExist(
fNX) ==
false){
40 throw std::runtime_error(
"TMVA SOFIE Shape Op Input Tensor " +
fNX +
" is not found in model");
55 auto shape = model.GetTensorShape(
fNX);
57 auto shape_values = std::vector<int64_t>(shape.begin()+
fStart, shape.begin() +
fEnd );
58 std::memcpy(
data.get(), (
void*) shape_values.data(),
length *
sizeof(int64_t));
61 if (model.Verbose()) {
63 for (
size_t i = 0; i < shape_values.size(); i++)
64 std::cout << shape_values[i] <<
" ";
65 std::cout << std::endl;
77 std::string
Generate(std::string OpName)
override {
81 OpName =
"op_" + OpName;
83 throw std::runtime_error(
"TMVA SOFIE Shape op called to Generate without being initialized first");
85 std::stringstream out;
87 out <<
"\n//------ Shape\n";
89 out <<
SP <<
"(void) tensor_" <<
fNX <<
";\n";
91 for (
size_t id = 0;
id <
length;
id++) {
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void data
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h length
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize id
ROperator_Shape(int start, int end, std::string nameX, std::string nameY)
std::vector< Dim > fShape
std::vector< size_t > fOutput_shape
std::string Generate(std::string OpName) override
void Initialize(RModel &model) override
std::vector< std::string_view > fInputTensorNames
bool fIsOutputConstant
flag to identify if operator has a constant output (no need to generate code)
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