19#include "kernels/Utils.h"
36 const auto input_sizes =
cur_op->inputs()->size();
44 for (int32_t
i = 0;
i < input_sizes; ++
i)
47 const auto *
tensor = runtime_graph->getCircleTensorByIndex(input_index);
49 const auto *
tensor_data = runtime_graph->getDataByTensor(tensor);
51 tensor_data = runtime_graph->getConstDataByTensor(tensor);
57 auto *
output_data =
reinterpret_cast<T *
>(runtime_graph->getDataByTensor(output));
66 const int num_inputs =
cur_op->inputs()->size();
77 for (
int i = 1;
i < num_inputs; ++
i)
79 const auto input_index =
cur_op->inputs()->operator[](
i);
80 assert(input_index != -1);
99 switch (Tensor::element_type(output))
102 case DataType::FLOAT32:
109 assert(
false &&
"Unsupported type.");
const circle::Tensor * getCircleTensorByIndex(int32_t index)
#define LUCI_INTERPRETER_CHECK(cond)
const T * data(const std::vector< T, Alloc > &v)
void AddN(const size_t flat_size, const size_t num_inputs, const T *const *input_data, T *output_data)
void configure_kernel_CircleAddN(const circle::Operator *cur_op, BaseRuntimeGraph *runtime_graph)
RuntimeGraph BaseRuntimeGraph
void execute_kernel_CircleAddN(const circle::Operator *cur_op, BaseRuntimeGraph *runtime_graph)
T must_cast(loco::Node *node)