Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
ParseComparision.cxx
Go to the documentation of this file.
3#include "onnx_proto3.pb.h"
4
5namespace TMVA {
6namespace Experimental {
7namespace SOFIE {
8
9template <EComparisionOperator Op>
10std::unique_ptr<ROperator> ParseComparision(RModelParser_ONNX &parser, const onnx::NodeProto &nodeproto)
11{
13
14 for (int i = 0; i < 2; ++i) {
15 auto input_name = nodeproto.input(i);
16 if (parser.IsRegisteredTensorType(input_name)) {
17 // according to ONNX both inputs have same type
18 if (i == 0)
19 input_type = parser.GetTensorType(input_name);
20 else
21 if (input_type != parser.GetTensorType(input_name)) {
22 throw
23 std::runtime_error("TMVA::SOFIE ONNX parser Comparision op has input tensors of different types");
24 }
25 } else {
26 throw std::runtime_error("TMVA::SOFIE ONNX Parser Comparision op has input tensor " + input_name +
27 " but its type is not yet registered");
28 }
29 }
30
31
32 std::string output_name = nodeproto.output(0);
33
34 std::unique_ptr<ROperator> op;
35 switch (input_type) {
37 op.reset(new ROperator_Comparision<float, Op>(nodeproto.input(0), nodeproto.input(1), output_name));
38 break;
40 op.reset(new ROperator_Comparision<int64_t, Op>(nodeproto.input(0), nodeproto.input(1), output_name));
41 break;
43 op.reset(new ROperator_Comparision<int32_t, Op>(nodeproto.input(0), nodeproto.input(1), output_name));
44 break;
45 default:
46 throw std::runtime_error("TMVA::SOFIE - Unsupported - Comparision Operator does not yet support input type " +
47 ConvertTypeToString(input_type));
48 }
49
50 // Infer the output type
51 if (!parser.IsRegisteredTensorType(output_name)) {
52 parser.RegisterTensorType(output_name, ETensorType::BOOL);
53 }
54
55 return op;
56};
57
58// Parse Equal
59ParserFuncSignature ParseEq = [](RModelParser_ONNX &parser, const onnx::NodeProto &nodeproto) {
60 return ParseComparision<EComparisionOperator::Eq>(parser, nodeproto);
61};
62
63// Parse Less
64ParserFuncSignature ParseLess = [](RModelParser_ONNX &parser, const onnx::NodeProto &nodeproto) {
65 return ParseComparision<EComparisionOperator::Less>(parser, nodeproto);
66};
67
68// Parse Mul
69ParserFuncSignature ParseLessEq = [](RModelParser_ONNX &parser, const onnx::NodeProto &nodeproto) {
70 return ParseComparision<EComparisionOperator::LessEq>(parser, nodeproto);
71};
72
73// Parse Div
74ParserFuncSignature ParseGreater = [](RModelParser_ONNX &parser, const onnx::NodeProto &nodeproto) {
75 return ParseComparision<EComparisionOperator::Greater>(parser, nodeproto);
76};
77
78// Parse Pow
79ParserFuncSignature ParseGreaterEq = [](RModelParser_ONNX &parser, const onnx::NodeProto &nodeproto) {
80 return ParseComparision<EComparisionOperator::GreaterEq>(parser, nodeproto);
81};
82
83} // namespace SOFIE
84} // namespace Experimental
85} // namespace TMVA
void RegisterTensorType(const std::string &, ETensorType)
ETensorType GetTensorType(const std::string &name)
ParserFuncSignature ParseGreater
ParserFuncSignature ParseEq
ParserFuncSignature ParseLess
std::function< std::unique_ptr< ROperator >(RModelParser_ONNX &, const onnx::NodeProto &)> ParserFuncSignature
ParserFuncSignature ParseGreaterEq
std::string ConvertTypeToString(ETensorType type)
ParserFuncSignature ParseLessEq
std::unique_ptr< ROperator > ParseComparision(RModelParser_ONNX &parser, const onnx::NodeProto &nodeproto)
create variable transformations