From 9b774ceaf69ee0067f4b3125f878f2c0bce9129d Mon Sep 17 00:00:00 2001 From: chunseoklee Date: Thu, 5 Sep 2024 13:44:57 +0900 Subject: [PATCH] [onert-micro] use exec sisoheader for quantize kernels (#13924) * [onert-micro] use exec sisoheader for quantize kernels - Use exec SISO header for quantize/dequantize kernel ONE-DCO-1.0-Signed-off-by: Chunseok Lee * use exec sisoheader for quantize kernels - Use exec SISO header for quantize/dequantize kernel ONE-DCO-1.0-Signed-off-by: Chunseok Lee --- .../src/execute/kernels/Dequantize.cpp | 30 +++---------------- .../src/execute/kernels/MathCommon.cpp | 30 +++---------------- .../src/execute/kernels/Quantize.cpp | 29 +++--------------- 3 files changed, 12 insertions(+), 77 deletions(-) diff --git a/onert-micro/onert-micro/src/execute/kernels/Dequantize.cpp b/onert-micro/onert-micro/src/execute/kernels/Dequantize.cpp index 8e0e6a1caf6..5a44d635980 100644 --- a/onert-micro/onert-micro/src/execute/kernels/Dequantize.cpp +++ b/onert-micro/onert-micro/src/execute/kernels/Dequantize.cpp @@ -21,6 +21,8 @@ #include "PALDequantize.h" #include "core/OMRuntimeShape.h" +#include "execute/OMUtils.h" + using namespace onert_micro; using namespace onert_micro::execute; @@ -35,41 +37,17 @@ constexpr uint32_t outputTensorIdx = 0; // NOTE: doesnt currently support dynamic shapes OMStatus onert_micro::execute::execute_kernel_CircleDequantize(const OMExecuteArgs &execute_args) { - core::OMRuntimeContext &runtime_context = execute_args.runtime_context; - core::OMRuntimeStorage &runtime_storage = execute_args.runtime_storage; - uint16_t op_index = execute_args.kernel_index; - const circle::Tensor *input = nullptr; const circle::Tensor *output = nullptr; uint8_t *input_data = nullptr; uint8_t *output_data = nullptr; - OMStatus status = Ok; - - { - OMRuntimeKernel runtime_kernel; - runtime_kernel.readKernel(op_index, runtime_context); - - input = runtime_kernel.inputs[inputTensorIdx]; - output = runtime_kernel.outputs[outputTensorIdx]; - - assert(input != nullptr); - assert(output != nullptr); - - status = runtime_kernel.getDataFromStorage(op_index, runtime_storage, runtime_context); - if (status != Ok) - return status; - - input_data = runtime_kernel.inputs_data[inputTensorIdx]; - output_data = runtime_kernel.outputs_data[outputTensorIdx]; - } - - assert(input_data != nullptr); - assert(output_data != nullptr); + SISOHeader(execute_args, &input, &output, &input_data, &output_data); assert(output->type() == circle::TensorType_FLOAT32); + OMStatus status = Ok; switch (input->type()) { #ifndef DIS_FLOAT diff --git a/onert-micro/onert-micro/src/execute/kernels/MathCommon.cpp b/onert-micro/onert-micro/src/execute/kernels/MathCommon.cpp index b18642f6d2a..0f604dfd13f 100644 --- a/onert-micro/onert-micro/src/execute/kernels/MathCommon.cpp +++ b/onert-micro/onert-micro/src/execute/kernels/MathCommon.cpp @@ -16,6 +16,8 @@ #include "execute/kernels/MathCommon.h" +#include "execute/OMUtils.h" + using namespace onert_micro; using namespace onert_micro::execute; @@ -33,39 +35,15 @@ OMStatus onert_micro::execute::execute_math_common( const std::function &f_float) { - core::OMRuntimeContext &runtime_context = execute_args.runtime_context; - core::OMRuntimeStorage &runtime_storage = execute_args.runtime_storage; - uint16_t op_index = execute_args.kernel_index; - const circle::Tensor *input = nullptr; const circle::Tensor *output = nullptr; uint8_t *input_data = nullptr; uint8_t *output_data = nullptr; - OMStatus status = Ok; - - { - OMRuntimeKernel runtime_kernel; - runtime_kernel.readKernel(op_index, runtime_context); - - input = runtime_kernel.inputs[inputTensorIdx]; - output = runtime_kernel.outputs[outputTensorIdx]; - - assert(input != nullptr); - assert(output != nullptr); - - status = runtime_kernel.getDataFromStorage(op_index, runtime_storage, runtime_context); - if (status != Ok) - return status; - - input_data = runtime_kernel.inputs_data[inputTensorIdx]; - output_data = runtime_kernel.outputs_data[outputTensorIdx]; - } - - assert(input_data != nullptr); - assert(output_data != nullptr); + SISOHeader(execute_args, &input, &output, &input_data, &output_data); + OMStatus status; switch (input->type()) { #ifndef DIS_FLOAT diff --git a/onert-micro/onert-micro/src/execute/kernels/Quantize.cpp b/onert-micro/onert-micro/src/execute/kernels/Quantize.cpp index 3e6301e7628..9220b781ef0 100644 --- a/onert-micro/onert-micro/src/execute/kernels/Quantize.cpp +++ b/onert-micro/onert-micro/src/execute/kernels/Quantize.cpp @@ -22,6 +22,8 @@ #include "PALQuantize.h" +#include "execute/OMUtils.h" + using namespace onert_micro; using namespace onert_micro::execute; @@ -36,38 +38,15 @@ constexpr uint32_t outputTensorIdx = 0; // NOTE: doesnt currently support dynamic shapes OMStatus onert_micro::execute::execute_kernel_CircleQuantize(const OMExecuteArgs &execute_args) { - core::OMRuntimeContext &runtime_context = execute_args.runtime_context; - core::OMRuntimeStorage &runtime_storage = execute_args.runtime_storage; - uint16_t op_index = execute_args.kernel_index; - const circle::Tensor *input = nullptr; const circle::Tensor *output = nullptr; uint8_t *input_data = nullptr; uint8_t *output_data = nullptr; - OMStatus status = Ok; - - { - OMRuntimeKernel runtime_kernel; - runtime_kernel.readKernel(op_index, runtime_context); - - input = runtime_kernel.inputs[inputTensorIdx]; - output = runtime_kernel.outputs[outputTensorIdx]; + SISOHeader(execute_args, &input, &output, &input_data, &output_data); - assert(input != nullptr); - assert(output != nullptr); - - status = runtime_kernel.getDataFromStorage(op_index, runtime_storage, runtime_context); - if (status != Ok) - return status; - - input_data = runtime_kernel.inputs_data[inputTensorIdx]; - output_data = runtime_kernel.outputs_data[outputTensorIdx]; - } - - assert(input_data != nullptr); - assert(output_data != nullptr); + OMStatus status = Ok; assert(input->type() == circle::TensorType_FLOAT32);