From 0def2f16bdc8e1b84b41a2a0ed214051aa2827bd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Henri=20Gr=C3=BCnder?= Date: Thu, 4 Apr 2024 10:31:28 +0200 Subject: [PATCH] Refactor type of dimension attributes in TOSA reference implementation Closes #390 --- reference-implementation/include/emitc/tosa.h | 16 ++++++++-------- reference-implementation/unittests/tosa.cpp | 10 +++++----- 2 files changed, 13 insertions(+), 13 deletions(-) diff --git a/reference-implementation/include/emitc/tosa.h b/reference-implementation/include/emitc/tosa.h index 12d5e955..31f0f46c 100644 --- a/reference-implementation/include/emitc/tosa.h +++ b/reference-implementation/include/emitc/tosa.h @@ -646,7 +646,7 @@ namespace { // Common reduce function used by specialized TOSA reduce ops. template inline Dest reduce(Src operand, typename get_element_type::type initValue, - int64_t dimension, Computation computation) { + int32_t dimension, Computation computation) { static_assert(is_tensor::value, "Expected tensor argument"); static_assert(is_tensor::value, "Expected tensor result"); @@ -688,7 +688,7 @@ inline Dest reduce(Src operand, typename get_element_type::type initValue, // ArgMaxOp template -inline Dest argmax(Src operand, int64_t dimension) { +inline Dest argmax(Src operand, int32_t dimension) { static_assert(is_tensor::value, "Expected tensor argument"); static_assert(is_tensor::value, "Expected tensor result"); @@ -732,7 +732,7 @@ inline Dest argmax(Src operand, int64_t dimension) { // ReduceAllOp template -inline Dest reduce_all(Src input, int64_t dimension) { +inline Dest reduce_all(Src input, int32_t dimension) { // ReduceAllOp takes only tensors with datatype bool according to the // TOSA specifications. using ET_Src = typename get_element_type::type; @@ -750,7 +750,7 @@ inline Dest reduce_all(Src input, int64_t dimension) { // ReduceAnyOp template -inline Dest reduce_any(Src input, int64_t dimension) { +inline Dest reduce_any(Src input, int32_t dimension) { // ReduceAnyOp takes only tensors with datatype bool according to the // TOSA specifications. using ET_Src = typename get_element_type::type; @@ -768,7 +768,7 @@ inline Dest reduce_any(Src input, int64_t dimension) { // ReduceMaxOp template -inline Dest reduce_max(Src input, int64_t dimension) { +inline Dest reduce_max(Src input, int32_t dimension) { using ET_Src = typename get_element_type::type; auto f = @@ -780,7 +780,7 @@ inline Dest reduce_max(Src input, int64_t dimension) { // ReduceMinOp template -inline Dest reduce_min(Src input, int64_t dimension) { +inline Dest reduce_min(Src input, int32_t dimension) { using ET_Src = typename get_element_type::type; auto f = @@ -792,7 +792,7 @@ inline Dest reduce_min(Src input, int64_t dimension) { // ReduceProdOp template -inline Dest reduce_prod(Src input, int64_t dimension) { +inline Dest reduce_prod(Src input, int32_t dimension) { using ET_Src = typename get_element_type::type; return tosa::reduce(input, 1, dimension, @@ -801,7 +801,7 @@ inline Dest reduce_prod(Src input, int64_t dimension) { // ReduceSumOp template -inline Dest reduce_sum(Src input, int64_t dimension) { +inline Dest reduce_sum(Src input, int32_t dimension) { using ET_Src = typename get_element_type::type; return tosa::reduce(input, 0, dimension, std::plus{}); diff --git a/reference-implementation/unittests/tosa.cpp b/reference-implementation/unittests/tosa.cpp index 4724e48e..3c5f80f5 100644 --- a/reference-implementation/unittests/tosa.cpp +++ b/reference-implementation/unittests/tosa.cpp @@ -1136,7 +1136,7 @@ TEST(tosa, reduce_prod) { TEST(tosa, reduce_sum) { { Tensor input{1, 2, 3, 4, 5, 6}; - int64_t dimension = 0; + int32_t dimension = 0; Tensor expected_result{5, 7, 9}; Tensor result = tosa::reduce_sum>(input, dimension); @@ -1145,7 +1145,7 @@ TEST(tosa, reduce_sum) { } { Tensor input{1, 2, 3, 4, 5, 6}; - int64_t dimension = 1; + int32_t dimension = 1; Tensor expected_result{6, 15}; Tensor result = tosa::reduce_sum>(input, dimension); @@ -1155,7 +1155,7 @@ TEST(tosa, reduce_sum) { { Tensor input{1, 2, 3, 4, 5, 6, 1, 2, 3, 4, 5, 6, 1, 2, 3, 4, 5, 6, 1, 2, 3, 4, 5, 6}; - int64_t dimension = 0; + int32_t dimension = 0; Tensor expected_result{4, 8, 12, 16, 20, 24}; Tensor result = tosa::reduce_sum>(input, dimension); @@ -1165,7 +1165,7 @@ TEST(tosa, reduce_sum) { { Tensor input{1, 2, 3, 4, 5, 6, 1, 2, 3, 4, 5, 6, 1, 2, 3, 4, 5, 6, 1, 2, 3, 4, 5, 6}; - int64_t dimension = 1; + int32_t dimension = 1; Tensor expected_result{5, 7, 9, 5, 7, 9, 5, 7, 9, 5, 7, 9}; Tensor result = tosa::reduce_sum>(input, dimension); @@ -1175,7 +1175,7 @@ TEST(tosa, reduce_sum) { { Tensor input{1, 2, 3, 4, 5, 6, 1, 2, 3, 4, 5, 6, 1, 2, 3, 4, 5, 6, 1, 2, 3, 4, 5, 6}; - int64_t dimension = 2; + int32_t dimension = 2; Tensor expected_result{6, 15, 6, 15, 6, 15, 6, 15}; Tensor result = tosa::reduce_sum>(input, dimension);