diff options
Diffstat (limited to 'compiler/tflite2circle')
-rw-r--r-- | compiler/tflite2circle/CMakeLists.txt | 9 | ||||
-rw-r--r-- | compiler/tflite2circle/requires.cmake | 4 | ||||
-rw-r--r-- | compiler/tflite2circle/src/BuildBuiltinOptions.h | 1 | ||||
-rw-r--r-- | compiler/tflite2circle/src/BuildBuiltinOptions/FullyConnectedOptions.cpp | 1 | ||||
-rw-r--r-- | compiler/tflite2circle/src/BuildBuiltinOptions/SVDFOptions.cpp | 41 | ||||
-rw-r--r-- | compiler/tflite2circle/src/BuildBuiltinOptions/SVDFOptions.h | 31 | ||||
-rw-r--r-- | compiler/tflite2circle/src/CircleModel.cpp | 42 | ||||
-rw-r--r-- | compiler/tflite2circle/src/DataLookup.cpp | 16 | ||||
-rw-r--r-- | compiler/tflite2circle/src/DataLookup.h | 2 | ||||
-rw-r--r-- | compiler/tflite2circle/src/TFLBuiltinOptions.lst | 2 |
10 files changed, 124 insertions, 25 deletions
diff --git a/compiler/tflite2circle/CMakeLists.txt b/compiler/tflite2circle/CMakeLists.txt index 4ea01ad31..a317a6305 100644 --- a/compiler/tflite2circle/CMakeLists.txt +++ b/compiler/tflite2circle/CMakeLists.txt @@ -1,8 +1,8 @@ nnas_include(TargetRequire) unset(REQUIRED_TARGETS) -list(APPEND REQUIRED_TARGETS mio_tflite260) -list(APPEND REQUIRED_TARGETS mio_circle) +list(APPEND REQUIRED_TARGETS mio_tflite280) +list(APPEND REQUIRED_TARGETS mio_circle04) TargetRequire_Return(${REQUIRED_TARGETS}) set(DRIVER "driver/Driver.cpp") @@ -13,8 +13,9 @@ target_include_directories(tflite2circle PRIVATE src) target_link_libraries(tflite2circle arser) target_link_libraries(tflite2circle foder) target_link_libraries(tflite2circle safemain) -target_link_libraries(tflite2circle mio_tflite260) -target_link_libraries(tflite2circle mio_circle) +target_link_libraries(tflite2circle mio_tflite280) +target_link_libraries(tflite2circle mio_tflite280_helper) +target_link_libraries(tflite2circle mio_circle04) target_link_libraries(tflite2circle vconone) target_link_libraries(tflite2circle nncc_coverage) diff --git a/compiler/tflite2circle/requires.cmake b/compiler/tflite2circle/requires.cmake index e39f9eeaf..3db9a2f2a 100644 --- a/compiler/tflite2circle/requires.cmake +++ b/compiler/tflite2circle/requires.cmake @@ -1,6 +1,6 @@ require("arser") require("foder") -require("mio-tflite260") -require("mio-circle") +require("mio-tflite280") +require("mio-circle04") require("safemain") require("vconone") diff --git a/compiler/tflite2circle/src/BuildBuiltinOptions.h b/compiler/tflite2circle/src/BuildBuiltinOptions.h index dc6ff086c..88a4f71df 100644 --- a/compiler/tflite2circle/src/BuildBuiltinOptions.h +++ b/compiler/tflite2circle/src/BuildBuiltinOptions.h @@ -102,6 +102,7 @@ #include "BuildBuiltinOptions/SqueezeOptions.h" #include "BuildBuiltinOptions/StridedSliceOptions.h" #include "BuildBuiltinOptions/SubOptions.h" +#include "BuildBuiltinOptions/SVDFOptions.h" #include "BuildBuiltinOptions/TileOptions.h" #include "BuildBuiltinOptions/TopKV2Options.h" #include "BuildBuiltinOptions/TransposeOptions.h" diff --git a/compiler/tflite2circle/src/BuildBuiltinOptions/FullyConnectedOptions.cpp b/compiler/tflite2circle/src/BuildBuiltinOptions/FullyConnectedOptions.cpp index 2619b73eb..27410012d 100644 --- a/compiler/tflite2circle/src/BuildBuiltinOptions/FullyConnectedOptions.cpp +++ b/compiler/tflite2circle/src/BuildBuiltinOptions/FullyConnectedOptions.cpp @@ -37,6 +37,7 @@ build_circle_FullyConnectedOptions(flatbuffers::FlatBufferBuilder &fb, const tfl else if (tflite_weight_format == tflite::FullyConnectedOptionsWeightsFormat_SHUFFLED4x16INT8) builtin_options_builder.add_weights_format( circle::FullyConnectedOptionsWeightsFormat_SHUFFLED4x16INT8); + builtin_options_builder.add_keep_num_dims(tflite_builtin_options->keep_num_dims()); return builtin_options_builder.Finish(); } diff --git a/compiler/tflite2circle/src/BuildBuiltinOptions/SVDFOptions.cpp b/compiler/tflite2circle/src/BuildBuiltinOptions/SVDFOptions.cpp new file mode 100644 index 000000000..e23738a69 --- /dev/null +++ b/compiler/tflite2circle/src/BuildBuiltinOptions/SVDFOptions.cpp @@ -0,0 +1,41 @@ +/* + * Copyright (c) 2021 Samsung Electronics Co., Ltd. All Rights Reserved + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "SVDFOptions.h" +#include "DataLookup.h" + +#include <cassert> + +namespace tflite2circle +{ + +flatbuffers::Offset<circle::SVDFOptions> +build_circle_SVDFOptions(flatbuffers::FlatBufferBuilder &fb, const tflite::Operator *op) +{ + auto *tflite_builtin_options = op->builtin_options_as_SVDFOptions(); + assert(tflite_builtin_options); + + circle::SVDFOptionsBuilder builtin_options_builder{fb}; + builtin_options_builder.add_rank(tflite_builtin_options->rank()); + builtin_options_builder.add_asymmetric_quantize_inputs( + tflite_builtin_options->asymmetric_quantize_inputs()); + builtin_options_builder.add_fused_activation_function( + get_circle_activation_function_type(tflite_builtin_options->fused_activation_function())); + + return builtin_options_builder.Finish(); +} + +} // namespace tflite2circle diff --git a/compiler/tflite2circle/src/BuildBuiltinOptions/SVDFOptions.h b/compiler/tflite2circle/src/BuildBuiltinOptions/SVDFOptions.h new file mode 100644 index 000000000..2ddbd3911 --- /dev/null +++ b/compiler/tflite2circle/src/BuildBuiltinOptions/SVDFOptions.h @@ -0,0 +1,31 @@ +/* + * Copyright (c) 2021 Samsung Electronics Co., Ltd. All Rights Reserved + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __BBO_SVDF_OPTIONS_H__ +#define __BBO_SVDF_OPTIONS_H__ + +#include <mio/tflite/schema_generated.h> +#include <mio/circle/schema_generated.h> + +namespace tflite2circle +{ + +flatbuffers::Offset<circle::SVDFOptions> +build_circle_SVDFOptions(flatbuffers::FlatBufferBuilder &fb, const tflite::Operator *op); + +} // namespace tflite2circle + +#endif // __BBO_SVDF_OPTIONS_H__ diff --git a/compiler/tflite2circle/src/CircleModel.cpp b/compiler/tflite2circle/src/CircleModel.cpp index 90cc415ff..d483b288f 100644 --- a/compiler/tflite2circle/src/CircleModel.cpp +++ b/compiler/tflite2circle/src/CircleModel.cpp @@ -16,11 +16,14 @@ #include <cassert> #include <iostream> +#include <map> #include <memory> #include "CircleModel.h" #include "DataLookup.h" +#include <mio_tflite280/Helper.h> + namespace tflite2circle { @@ -206,7 +209,8 @@ template <> void Offset<SubGraphLink>::build(const TFLFlatBufVec *tflite_flatbuf auto tflite_inputs = it_sg->inputs(); std::vector<int32_t> input_vec{tflite_inputs->begin(), tflite_inputs->end()}; - // apply signature_def to input tensor index so that input orders are correct + // apply signature_def to input tensor index so that input orders follow like tensorflow lite + // interpreter._get_full_signature_list() method, which is ordered(sorted) in name // NOTE we do not need this when circle format supports signature_def if (_tfl_signature_def_offsets != nullptr) { @@ -216,10 +220,16 @@ template <> void Offset<SubGraphLink>::build(const TFLFlatBufVec *tflite_flatbuf { auto inputs = it_signdef->inputs(); assert(inputs->size() == input_vec.size()); - uint32_t input_vec_idx = 0; + + std::map<std::string, uint32_t> map_name_index; for (auto it_tm : *inputs) { - input_vec[input_vec_idx++] = static_cast<int32_t>(it_tm->tensor_index()); + map_name_index[it_tm->name()->str()] = it_tm->tensor_index(); + } + uint32_t input_vec_idx = 0; + for (auto &item : map_name_index) + { + input_vec[input_vec_idx++] = item.second; } } } @@ -240,10 +250,16 @@ template <> void Offset<SubGraphLink>::build(const TFLFlatBufVec *tflite_flatbuf { auto outputs = it_signdef->outputs(); assert(outputs->size() == output_vec.size()); - uint32_t output_vec_idx = 0; + + std::map<std::string, uint32_t> map_name_index; for (auto it_tm : *outputs) { - output_vec[output_vec_idx++] = static_cast<int32_t>(it_tm->tensor_index()); + map_name_index[it_tm->name()->str()] = it_tm->tensor_index(); + } + uint32_t output_vec_idx = 0; + for (auto &item : map_name_index) + { + output_vec[output_vec_idx++] = item.second; } } } @@ -318,17 +334,6 @@ template <> void Offset<SubGraphLink>::build(const TFLFlatBufVec *tflite_flatbuf _circle_flatbuffer_vec_offset = _fb->CreateVector(subgprahs_vec); } -tflite::BuiltinOperator builtin_code_neutral(const tflite::OperatorCode *opcode) -{ - assert(opcode != nullptr); - int8_t dp_code = opcode->deprecated_builtin_code(); - // 127 is max of int8_t which is upper bound of v3 builtin_code - // NOTE TensorFlow uses 'BuiltinOperator_PLACEHOLDER_FOR_GREATER_OP_CODES' for 127 - if (dp_code < 127 && dp_code >= 0) - return tflite::BuiltinOperator(dp_code); - return opcode->builtin_code(); -} - template <> void Offset<OperatorCodeLink>::build(const TFLFlatBufVec *tflite_flatbuffer_vec) { std::vector<flatbuffers::Offset<circle::OperatorCode>> operator_code_vec; @@ -337,8 +342,9 @@ template <> void Offset<OperatorCodeLink>::build(const TFLFlatBufVec *tflite_fla { auto custom_code = _fb->CreateString(it->custom_code()); circle::OperatorCodeBuilder operator_code_builder{*_fb}; - // TODO support circle deprecated_builtin_code - auto bt_code = builtin_code_neutral(it); + auto de_code = it->deprecated_builtin_code(); + auto bt_code = it->builtin_code(); + operator_code_builder.add_deprecated_builtin_code(get_circle_builtin_code(de_code)); operator_code_builder.add_builtin_code(get_circle_builtin_code(bt_code)); operator_code_builder.add_custom_code(custom_code); operator_code_builder.add_version(it->version()); diff --git a/compiler/tflite2circle/src/DataLookup.cpp b/compiler/tflite2circle/src/DataLookup.cpp index c5ed62e31..7c3aab089 100644 --- a/compiler/tflite2circle/src/DataLookup.cpp +++ b/compiler/tflite2circle/src/DataLookup.cpp @@ -34,6 +34,22 @@ circle::BuiltinOperator get_circle_builtin_code(tflite::BuiltinOperator tfl_bop) } } +int8_t get_circle_builtin_code(int8_t tfl_bop_i8) +{ + tflite::BuiltinOperator tfl_bop = static_cast<tflite::BuiltinOperator>(tfl_bop_i8); + + switch (tfl_bop) + { +#define TFL_OPERATOR(OP) \ + case tflite::BuiltinOperator_##OP: \ + return static_cast<int8_t>(circle::BuiltinOperator_##OP); +#include "TFLOperator.lst" +#undef TFL_OPERATOR + default: + throw std::runtime_error("tflite2circle: wrong op"); + } +} + circle::TensorType get_circle_tensortype(tflite::TensorType tfl_tt) { switch (tfl_tt) diff --git a/compiler/tflite2circle/src/DataLookup.h b/compiler/tflite2circle/src/DataLookup.h index 601d014dd..5aeeb6eca 100644 --- a/compiler/tflite2circle/src/DataLookup.h +++ b/compiler/tflite2circle/src/DataLookup.h @@ -30,6 +30,8 @@ namespace tflite2circle */ circle::BuiltinOperator get_circle_builtin_code(tflite::BuiltinOperator tfl_bop); +int8_t get_circle_builtin_code(int8_t tfl_bop_i8); + /** * @brief Returns circle TensorType according to tflite. * diff --git a/compiler/tflite2circle/src/TFLBuiltinOptions.lst b/compiler/tflite2circle/src/TFLBuiltinOptions.lst index f2de7e046..d55ba464a 100644 --- a/compiler/tflite2circle/src/TFLBuiltinOptions.lst +++ b/compiler/tflite2circle/src/TFLBuiltinOptions.lst @@ -9,7 +9,7 @@ TFL_BUILTIN_OPTIONS(DepthwiseConv2DOptions) //TFL_BUILTIN_OPTIONS(ConcatEmbeddingsOptions) //TFL_BUILTIN_OPTIONS(LSHProjectionOptions) TFL_BUILTIN_OPTIONS(Pool2DOptions) -//TFL_BUILTIN_OPTIONS(SVDFOptions) +TFL_BUILTIN_OPTIONS(SVDFOptions) //TFL_BUILTIN_OPTIONS(RNNOptions) TFL_BUILTIN_OPTIONS(FullyConnectedOptions) TFL_BUILTIN_OPTIONS(SoftmaxOptions) |