2 * Copyright (c) 2018 Samsung Electronics Co., Ltd. All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
25 bool is_valid(const tflite::OperatorCode *opcode)
27 tflite::BuiltinOperator code = opcode->builtin_code();
28 return (tflite::BuiltinOperator_MIN <= code && code <= tflite::BuiltinOperator_MAX);
31 bool is_custom(const tflite::OperatorCode *opcode)
33 tflite::BuiltinOperator code = opcode->builtin_code();
34 return (code == tflite::BuiltinOperator_CUSTOM);
37 std::string opcode_name(const tflite::OperatorCode *opcode)
41 if (!is_valid(opcode))
43 std::ostringstream oss;
48 if (is_custom(opcode))
50 if (!opcode->custom_code())
51 return "(invalid custom)";
53 std::string custom_op = "CUSTOM(";
54 custom_op += opcode->custom_code()->c_str();
59 tflite::BuiltinOperator code = opcode->builtin_code();
60 return tflite::EnumNameBuiltinOperator(code);
63 const char *tensor_type(const tflite::Tensor *tensor)
65 return tflite::EnumNameTensorType(tensor->type());
68 const char *tensor_name(const tflite::Tensor *tensor)
70 static const char *kEmptyTensorName = "(noname)";
72 auto name = tensor->name();
76 return kEmptyTensorName;
79 Reader::Reader(const tflite::Model *model)
81 _version = model->version();
82 _subgraphs = model->subgraphs();
83 _buffers = model->buffers();
85 auto opcodes = model->operator_codes();
86 for (const ::tflite::OperatorCode *opcode : *opcodes)
88 _op_codes.push_back(opcode);
92 size_t Reader::buffer_info(uint32_t buf_idx, const uint8_t **buff_data)
99 if (auto *buffer = (*_buffers)[buf_idx])
101 if (auto *array = buffer->data())
103 if (size_t size = array->size())
105 *buff_data = reinterpret_cast<const uint8_t *>(array->data());
114 tflite::BuiltinOperator Reader::builtin_code(const tflite::Operator *op) const
116 uint32_t index = op->opcode_index();
117 assert(index < _op_codes.size());
118 const tflite::OperatorCode *opcode = _op_codes.at(index);
120 return opcode->builtin_code();
123 std::string Reader::opcode_name(const tflite::Operator *op) const
125 uint32_t index = op->opcode_index();
126 assert(index < _op_codes.size());
127 const tflite::OperatorCode *opcode = _op_codes.at(index);
129 if (!is_valid(opcode))
131 std::ostringstream oss;
132 oss << "(invalid: " << index << ")";
136 return tflread::opcode_name(opcode);
139 bool Reader::select_subgraph(uint32_t sgindex)
141 _subgraph_index = sgindex;
143 _operators = nullptr;
148 if (_subgraphs->Length() <= sgindex)
154 const tflite::SubGraph *subgraph = (*_subgraphs)[sgindex];
156 auto name = subgraph->name();
157 _subgraph_name = name ? name->c_str() : "(noname)";
159 _tensors = subgraph->tensors();
160 _operators = subgraph->operators();
162 _inputs = as_index_vector(subgraph->inputs());
163 _outputs = as_index_vector(subgraph->outputs());
168 } // namespace tflread