1#ifndef TMVA_SOFIE_ROperator_Where
2#define TMVA_SOFIE_ROperator_Where
11namespace Experimental {
51 const std::string &
nameX,
52 const std::string &
nameY,
53 const std::string &
nameZ)
83 throw std::runtime_error(std::string(
"TMVA SOFIE Where Op: condition tensor ") +
fNC +
" not found in model");
85 throw std::runtime_error(std::string(
"TMVA SOFIE Where Op: X tensor ") +
fNX +
" not found in model");
87 throw std::runtime_error(std::string(
"TMVA SOFIE Where Op: Y tensor ") +
fNY +
" not found in model");
152 const std::vector<size_t> &shape,
154 const std::string &prefix) {
158 std::shared_ptr<void>
bcData(
160 std::default_delete<T[]>());
179 for (
size_t i = 0; i <
len; ++i)
224 if (s.isParam && s.param ==
p)
return true;
227 for (
size_t i = 0; i <
fDimShapeZ.size(); i++) {
229 if (s.isParam && s.param.find(
"std::max") != std::string::npos) {
252 std::stringstream out;
263 throw std::runtime_error(
"TMVA SOFIE Where Op called to Generate without being initialized first");
266 std::stringstream out;
278 for (
size_t i = 0; i <
fDimShapeZ.size(); i++) {
284 <<
"throw std::runtime_error(\"SOFIE Where: cannot broadcast X dim " << i <<
" in " <<
opName <<
"\");\n";
291 <<
"throw std::runtime_error(\"SOFIE Where: cannot broadcast Y dim " << i <<
" in " <<
opName <<
"\");\n";
298 <<
"throw std::runtime_error(\"SOFIE Where: cannot broadcast C dim " << i <<
" in " <<
opName <<
"\");\n";
315 const std::vector<Dim> &strides,
316 size_t rankZ) -> std::string {
319 [](
Dim d) { return d.dim == 1 || d.GetVal() ==
"1"; }))
323 for (
size_t i = 0; i <
dimShape.size(); ++i) {
326 if (strides[i].GetVal() !=
"1")
327 expr +=
" * " + strides[i].GetVal();
330 if (
expr.size() >= 3)
331 for (
int j = 0;
j < 3;
j++)
expr.pop_back();
344 [](
Dim d) { return d.dim == 1 || d.GetVal() ==
"1"; })) {
347 for (
size_t i = 0; i <
fDimShapeZ.size(); ++i) {
351 out <<
"for (size_t idx_" << i <<
" = 0; idx_" << i
352 <<
" < " <<
fDimShapeZ[i] <<
"; ++idx_" << i <<
") {\n";
353 idxZ +=
"idx_" + std::to_string(i);
359 if (
idxZ.size() >= 3)
360 for (
int j = 0;
j < 3;
j++)
idxZ.pop_back();
364 for (
int j = 0;
j <
nloop + 1;
j++) out <<
SP;
365 out <<
"tensor_" <<
fNZ <<
"[" <<
idxZ <<
"] = "
366 <<
"tensor_" <<
fNC <<
"[" <<
idxC <<
"] ? "
367 <<
"tensor_" <<
fNX <<
"[" <<
idxX <<
"] : "
368 <<
"tensor_" <<
fNY <<
"[" <<
idxY <<
"];\n";
371 for (
int i =
nloop; i > 0; i--) {
372 for (
int j = 0;
j < i;
j++) out <<
SP;
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
winID h TVirtualViewer3D TVirtualGLPainter p
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 input
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 offset
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 Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t UChar_t len
const_iterator begin() const
const_iterator end() const
std::vector< size_t > GetTensorShape(const std::string &name) const
std::vector< Dim > GetDimTensorShape(const std::string &name) const
bool IsDynamicTensor(const std::string &name) const
void AddIntermediateTensor(std::string tensor_name, ETensorType type, std::vector< Dim > dim_shape)
bool CheckIfTensorAlreadyExist(std::string tensor_name)
void AddConstantTensor(std::string tensor_name, ETensorType type, std::vector< std::size_t > shape, std::shared_ptr< void > data)
bool IsInitializedTensor(const std::string &name) const
std::vector< Dim > GetDynamicTensorShape(const std::string &name) const
std::shared_ptr< void > GetInitializedTensorData(std::string tensor_name)
void SetNotWritableInitializedTensor(const std::string &tensor_name)
ETensorType GetTensorType(std::string name) const
const std::vector< std::string > & GetInputTensorNames() const
bool IsReadyInputTensor(const std::string &name) const
std::vector< Dim > fDimShapeX
std::vector< size_t > fShapeY
std::vector< size_t > fShapeX
std::vector< size_t > fShapeC
std::string fNBroadcastedX
std::vector< std::vector< size_t > > ShapeInference(std::vector< std::vector< size_t > > input) override
std::string Generate(std::string opName) override
std::vector< ETensorType > TypeInference(std::vector< ETensorType > input) override
std::vector< Dim > fDimShapeY
ROperator_Where(const std::string &nameC, const std::string &nameX, const std::string &nameY, const std::string &nameZ)
void Initialize(RModel &model) override
std::vector< Dim > fDimShapeZ
std::string fNBroadcastedC
std::string fNBroadcastedY
std::vector< Dim > fDimShapeC
std::vector< size_t > fShapeZ
std::string GenerateInitCode() 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::vector< size_t > MultidirectionalBroadcastShape(std::vector< std::vector< size_t > >)
T * UnidirectionalBroadcast(const T *data, const std::vector< size_t > &shape, const std::vector< size_t > &targetShape)
std::vector< size_t > ComputeStrideFromShape(const std::vector< size_t > &shape)
compute stride of a tensor given its shape (assume layout is row-major)
std::string ConvertDimShapeToString(const std::vector< Dim > &shape)
std::size_t ConvertShapeToLength(const std::vector< size_t > &shape)
std::string ConvertValuesToString(size_t n, const T *data, size_t maxprint=-1)
std::vector< Dim > ConvertShapeToDim(const std::vector< size_t > &shape)
Convert shape from integer format to dynamic one (based on Dim)
std::string ConvertDimShapeToLength(const std::vector< Dim > &shape)
std::string ConvertShapeToString(const std::vector< size_t > &shape)
create variable transformations