diff --git a/reference-implementation/include/emitc/tosa.h b/reference-implementation/include/emitc/tosa.h index 12d5e955..787d62a3 100644 --- a/reference-implementation/include/emitc/tosa.h +++ b/reference-implementation/include/emitc/tosa.h @@ -217,7 +217,7 @@ inline Src minimum(Src x, Src y) { } template = true> -inline Src mul(Src x, Src y, const int32_t shift) { +inline Src mul(Src x, Src y, const int8_t shift) { // Adopted from // https://git.mlplatform.org/tosa/reference_model.git/tree/reference_model/src/ops/ewise_binary.cc?id=df8626976df6c779bb30df9c5ceef689462109c0#n436 if (shift > 0) { @@ -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..6014e688 100644 --- a/reference-implementation/unittests/tosa.cpp +++ b/reference-implementation/unittests/tosa.cpp @@ -552,7 +552,7 @@ TEST(tosa, mul) { Tensor2D t2{1, 2, 3, 4}; auto lambda_1d_int_shift = [&s2, &t2]() -> Tensor2D { - int32_t shift{2}; + int8_t shift{2}; return tosa::mul(s2, t2, shift); }; @@ -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);