From 3f3785e464b0c7cbe3ee029e5c42c48d18e8bce9 Mon Sep 17 00:00:00 2001 From: icodo98 Date: Wed, 25 Sep 2024 11:20:06 +0900 Subject: [PATCH 1/3] [onert/cker] Add cker for avgpool This commit add chekr for average pooling ONE-DCO-1.0-Signed-off-by: JuYoung Lee rsb98759@gmail.com --- .../include/cker/train/operation/AvgPool.h | 150 +++++++++ compute/cker/src/train/AvgPool.test.cc | 286 ++++++++++++++++++ 2 files changed, 436 insertions(+) create mode 100644 compute/cker/include/cker/train/operation/AvgPool.h create mode 100644 compute/cker/src/train/AvgPool.test.cc diff --git a/compute/cker/include/cker/train/operation/AvgPool.h b/compute/cker/include/cker/train/operation/AvgPool.h new file mode 100644 index 00000000000..c16c5daddba --- /dev/null +++ b/compute/cker/include/cker/train/operation/AvgPool.h @@ -0,0 +1,150 @@ +/* + * Copyright (c) 2024 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 __NNFW_CKER_TRAIN_OPERATION_AVGPOOL_H__ +#define __NNFW_CKER_TRAIN_OPERATION_AVGPOOL_H__ + +#include "cker/Shape.h" +#include "cker/Utils.h" +#include "cker/eigen/Utils.h" + +#include + +namespace nnfw +{ +namespace cker +{ +namespace train +{ +inline void AvgPool2D(const PoolParams ¶ms, const Shape &input_shape, const float *input_data, + const Shape &output_shape, float *output_data) +{ + assert(input_shape.DimensionsCount() == 4); + assert(output_shape.DimensionsCount() == 4); + const int batches = MatchingDim(input_shape, 0, output_shape, 0); + const int input_height = input_shape.Dims(1); + const int input_width = input_shape.Dims(2); + const int output_height = output_shape.Dims(1); + const int output_width = output_shape.Dims(2); + const int stride_height = params.stride_height; + const int stride_width = params.stride_width; + + // TODO(benoitjacob) make this a proper reference impl without Eigen! + const auto in_mat = MapAsMatrixWithLastDimAsRows(input_data, input_shape); + auto out_mat = MapAsMatrixWithLastDimAsRows(output_data, output_shape); + + // Prefill the output to 0. + out_mat.setZero(); + + for (int b = 0; b < batches; ++b) + { + for (int h = 0; h < output_height; ++h) + { + for (int w = 0; w < output_width; ++w) + { + // (h_start, h_end) * (w_start, w_end) is input range + // that output is projected from. + int h_start = h * stride_height - params.padding_values.height; + int h_end = std::min(h_start + params.filter_height, input_height); + h_start = h_start < 0 ? 0 : h_start; + + int w_start = w * stride_width - params.padding_values.width; + int w_end = std::min(w_start + params.filter_width, input_width); + w_start = w_start < 0 ? 0 : w_start; + + int count = (h_end - h_start) * (w_end - w_start); + if (h_end <= 0 || w_end <= 0 || count <= 0 || h_start >= input_height || + w_start >= input_width) + continue; + + int out_offset = NodeOffset(b, h, w, output_height, output_width); + for (int ph = h_start; ph < h_end; ++ph) + { + for (int pw = w_start; pw < w_end; ++pw) + { + int in_offset = NodeOffset(b, ph, pw, input_height, input_width); + out_mat.col(out_offset) += in_mat.col(in_offset); + } + } + out_mat.col(out_offset) /= count; + } + } + } + + out_mat.cwiseMin(params.float_activation_min).cwiseMax(params.float_activation_max); +} + +inline void AvgPool2DGrad(const PoolParams ¶ms, const Shape &incoming_shape, + const float *incoming_data, const Shape &grad_shape, float *grad_data) +{ + assert(grad_shape.DimensionsCount() == 4); + assert(incoming_shape.DimensionsCount() == 4); + + const int batches = MatchingDim(incoming_shape, 0, grad_shape, 0); + const int grad_height = grad_shape.Dims(1); + const int grad_width = grad_shape.Dims(2); + const int incoming_height = incoming_shape.Dims(1); + const int incoming_width = incoming_shape.Dims(2); + const int stride_height = params.stride_height; + const int stride_width = params.stride_width; + + // initialize grad_data + std::fill(grad_data, grad_data + grad_shape.FlatSize(), 0.0); + + const auto incoming_mat = MapAsMatrixWithLastDimAsRows(incoming_data, incoming_shape); + auto grad_mat = MapAsMatrixWithLastDimAsRows(grad_data, grad_shape); + + for (int b = 0; b < batches; ++b) + { + for (int h = 0; h < incoming_height; ++h) + { + for (int w = 0; w < incoming_width; ++w) + { + // (h_start, h_end) * (w_start, w_end) is input range + // that output is projected from. + int h_start = h * stride_height - params.padding_values.height; + int h_end = std::min(h_start + params.filter_height, grad_height); + h_start = h_start < 0 ? 0 : h_start; + + int w_start = w * stride_width - params.padding_values.width; + int w_end = std::min(w_start + params.filter_width, grad_width); + w_start = w_start < 0 ? 0 : w_start; + + int count = (h_end - h_start) * (w_end - w_start); + + if (h_end <= 0 || w_end <= 0 || count <= 0 || h_start >= grad_height || + w_start >= grad_width) + continue; + + int incoming_offset = NodeOffset(b, h, w, incoming_height, incoming_width); + for (int ph = h_start; ph < h_end; ++ph) + { + for (int pw = w_start; pw < w_end; ++pw) + { + int grad_offset = NodeOffset(b, ph, pw, grad_height, grad_width); + grad_mat.col(grad_offset) += incoming_mat.col(incoming_offset) / count; + } + } + } + } + } +} + +} // namespace train +} // namespace cker +} // namespace nnfw + +#endif // __NNFW_CKER_TRAIN_OPERATION_AVGPOOL_H__ diff --git a/compute/cker/src/train/AvgPool.test.cc b/compute/cker/src/train/AvgPool.test.cc new file mode 100644 index 00000000000..307ac118ab9 --- /dev/null +++ b/compute/cker/src/train/AvgPool.test.cc @@ -0,0 +1,286 @@ +/* + * Copyright (c) 2023 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 +#include +#include +#include + +#include +#include + +namespace +{ +using namespace nnfw::cker; + +template class AvgPoolOpVerifier +{ +private: + const PoolParams _op_params; + const Shape _in_shape; + const Shape _out_shape; + +public: + AvgPoolOpVerifier(const nnfw::cker::PoolParams &op_params, const Shape &in_shape, + const Shape &out_shape) + : _op_params(op_params), _in_shape(in_shape), _out_shape(out_shape) + { + } + +public: + void verifyForward(const std::vector input, const std::vector expected_output, + bool expect_eq = true) + { + assert(input.size() == _in_shape.FlatSize()); + assert(expected_output.size() == _out_shape.FlatSize()); + + std::vector cacluated_output(_out_shape.FlatSize()); + nnfw::cker::train::AvgPool2D(_op_params, _in_shape, input.data(), _out_shape, + cacluated_output.data()); + + if (expect_eq) + for (size_t i = 0; i < expected_output.size(); i++) + { + EXPECT_FLOAT_EQ(expected_output[i], cacluated_output[i]); + } + else + EXPECT_NE(expected_output, cacluated_output); + } + + void verifyBackward(const std::vector incoming_data, const std::vector expected_grad_data, + bool expect_eq = true) + { + assert(incoming_data.size() == _out_shape.FlatSize()); + assert(expected_grad_data.size() == _in_shape.FlatSize()); + + std::vector calcuated_grad(_in_shape.FlatSize()); + nnfw::cker::train::AvgPool2DGrad(_op_params, _out_shape, incoming_data.data(), _in_shape, + calcuated_grad.data()); + + if (expect_eq) + { + for (size_t i = 0; i < expected_grad_data.size(); i++) + { + EXPECT_FLOAT_EQ(expected_grad_data[i], calcuated_grad[i]); + } + } + + else + EXPECT_NE(expected_grad_data, calcuated_grad); + } +}; + +} // namespace + +TEST(CKer_Operation, AvgPool2D) +{ + // Depth 1 case + { + nnfw::cker::PoolParams op_param; + { + op_param.stride_height = 1; + op_param.stride_width = 1; + op_param.filter_height = 2; + op_param.filter_width = 2; + op_param.padding_values.height = 0; + op_param.padding_values.width = 0; + } + nnfw::cker::Shape in = {1, 3, 3, 1}; + nnfw::cker::Shape out = {1, 2, 2, 1}; + + AvgPoolOpVerifier verifier(op_param, in, out); + + /** + * input(index) : output(arg-count): + * + * 10(0) 15(1) 2(2) + * 7(3) 8(4) 9(5) - (forward) -> 10(4) 8.5(4) + * 10(6) 1(7) 0(8) 6.5(4) 4.5(4) + */ + + std::vector input = {10, 15, 2, 7, 8, 9, 10, 1, 0}; + std::vector expected_output = {10, 8.5, 6.5, 4.5}; + verifier.verifyForward(input, expected_output); + + /** + * output_deriv: input_deriv: + * (randomly filled) + * + * 0.4 0.4 0.1 0.2 0.1 + * 0.4 0.4 - (backward) -> 0.2 0.4 0.2 + * 0.1 0.2 0.1 + */ + + std::vector output_deriv = {0.4, 0.4, 0.4, 0.4}; + std::vector expected_input_deriv = {0.1, 0.2, 0.1, 0.2, 0.4, 0.2, 0.1, 0.2, 0.1}; + verifier.verifyBackward(output_deriv, expected_input_deriv); + } + + // Depth 2 case + { + nnfw::cker::PoolParams op_param; + { + op_param.stride_height = 1; + op_param.stride_width = 1; + op_param.filter_height = 3; + op_param.filter_width = 3; + op_param.padding_values.height = 0; + op_param.padding_values.width = 0; + } + nnfw::cker::Shape in = {1, 3, 3, 2}; + nnfw::cker::Shape out = {1, 1, 1, 2}; + + AvgPoolOpVerifier verifier(op_param, in, out); + + /** + * depth[0] + * input(index) : output(index): + * + * 10(0) 15(1) 2(2) + * 10(3) 12(4) 17(5) -(forward)-> 16(0) + * 50(6) 30(7) -2(8) + * + * + * depth[1] + * input(index): output(index): + * + * -1(0) 2(1) 3(2) + * 8(3) 9(4) 2(5) -(forward)-> 4(0) + * 4(6) 2(7) 7(8) + */ + + std::vector input(in.FlatSize()); + auto input_mat = MapAsMatrixWithLastDimAsRows(input.data(), in); + input_mat << /* depth0 */ 10, 15, 2, 10, 12, 17, 50, 30, -2, + /* depth1 */ -1, 2, 3, 8, 9, 2, 4, 2, 7; + std::vector expected_output = {16, 4}; + verifier.verifyForward(input, expected_output); + + /** + * depth[0] + * ouput_deriv: input_deriv: + * + * 0.02 0.02 0.02 + * 0.18 -(backward)-> 0.02 0.02 0.02 + * 0.02 0.02 0.02 + * + * + * depth[1] + * output_deriv: input_deriv: + * 0.04 0.04 0.04 + * 0.36 -(backward)-> 0.04 0.04 0.04 + * 0.04 0.04 0.04 + */ + + std::vector output_deriv = {0.18, 0.36}; + std::vector expected_input_deriv(in.FlatSize()); + auto input_deriv_mat = MapAsMatrixWithLastDimAsRows(expected_input_deriv.data(), in); + input_deriv_mat << /* depth0 */ 0.02, 0.02, 0.02, 0.02, 0.02, 0.02, 0.02, 0.02, 0.02, + /* depth1 */ 0.04, 0.04, 0.04, 0.04, 0.04, 0.04, 0.04, 0.04, 0.04; + verifier.verifyBackward(output_deriv, expected_input_deriv); + } + + // with padding case + { + nnfw::cker::PoolParams op_param; + { + op_param.stride_height = 2; + op_param.stride_width = 2; + op_param.filter_height = 2; + op_param.filter_width = 2; + op_param.padding_values.height = 2; + op_param.padding_values.width = 2; + } + nnfw::cker::Shape in = {1, 2, 2, 1}; + nnfw::cker::Shape out = {1, 3, 3, 1}; + + AvgPoolOpVerifier verifier(op_param, in, out); + + /** + * input_with_padding: expected_output: + * + * 4 8 0 0 0 + * 9 2 -(forward)-> 0 5.75 0 + * 0 0 0 + */ + + std::vector input = {4, 8, 9, 2}; + std::vector expected_output = {0, 0, 0, 0, 5.75, 0, 0, 0, 0}; + verifier.verifyForward(input, expected_output); + + /** + * output_deriv: input_deriv: + * + * 0.1 0.1 0.1 0.1 0.1 + * 0.1 0.4 0.3 -(backward)-> 0.1 0.1 + * 0.5 0.1 0.1 + */ + std::vector output_deriv = {0.1, 0.1, 0.1, 0.1, 0.4, 0.3, 0.5, 0.1, 0.1}; + std::vector expected_input_deriv = {0.1, 0.1, 0.1, 0.1}; + verifier.verifyBackward(output_deriv, expected_input_deriv); + } +} + +TEST(CKer_Operation, neg_AvgPool) +{ + // Invalid expected value + { + nnfw::cker::PoolParams op_param; + { + op_param.stride_height = 1; + op_param.stride_width = 1; + op_param.filter_height = 2; + op_param.filter_width = 2; + op_param.padding_values.height = 0; + op_param.padding_values.width = 0; + } + nnfw::cker::Shape in = {1, 2, 2, 1}; + nnfw::cker::Shape out = {1, 1, 1, 1}; + + AvgPoolOpVerifier verifier(op_param, in, out); + + std::vector input = {0, 0, 0, 0}; + std::vector expected_output = {-1}; + + verifier.verifyForward(input, expected_output, false); + } + + // Invalid expected value + { + nnfw::cker::PoolParams op_param; + { + op_param.stride_height = 2; + op_param.stride_width = 2; + op_param.filter_height = 2; + op_param.filter_width = 2; + op_param.padding_values.height = 1; + op_param.padding_values.width = 1; + } + + nnfw::cker::Shape in = {1, 2, 2, 1}; + nnfw::cker::Shape out = {1, 2, 2, 1}; + + AvgPoolOpVerifier verifier(op_param, in, out); + + std::vector input = {0, 0, 0, 0}; + std::vector expected_output = {0, 0, 0, 0}; + verifier.verifyForward(input, expected_output); + + std::vector output_deriv = {0.1, 0.1, 0.1, 0.2}; + std::vector expected_input_deriv = {0.1, 0.1, 0.1, 0.1}; + verifier.verifyBackward(output_deriv, expected_input_deriv, false); + } +} From c3b7f20890b263de95b098c2508266dbdf137d85 Mon Sep 17 00:00:00 2001 From: Ju Young Date: Sun, 29 Sep 2024 04:52:15 +0000 Subject: [PATCH 2/3] [cker] update forwarding function use existing forwarding function. update notaion. ONE-DCO-1.0-Signed-off-by: JuYoung Lee rsb98759@gmail.com --- .../operation/{AvgPool.h => AveragePool.h} | 61 +-------------- .../{AvgPool.test.cc => AveragePool.test.cc} | 77 +++++-------------- 2 files changed, 23 insertions(+), 115 deletions(-) rename compute/cker/include/cker/train/operation/{AvgPool.h => AveragePool.h} (55%) rename compute/cker/src/train/{AvgPool.test.cc => AveragePool.test.cc} (76%) diff --git a/compute/cker/include/cker/train/operation/AvgPool.h b/compute/cker/include/cker/train/operation/AveragePool.h similarity index 55% rename from compute/cker/include/cker/train/operation/AvgPool.h rename to compute/cker/include/cker/train/operation/AveragePool.h index c16c5daddba..937d2383f9e 100644 --- a/compute/cker/include/cker/train/operation/AvgPool.h +++ b/compute/cker/include/cker/train/operation/AveragePool.h @@ -29,66 +29,9 @@ namespace cker { namespace train { -inline void AvgPool2D(const PoolParams ¶ms, const Shape &input_shape, const float *input_data, - const Shape &output_shape, float *output_data) -{ - assert(input_shape.DimensionsCount() == 4); - assert(output_shape.DimensionsCount() == 4); - const int batches = MatchingDim(input_shape, 0, output_shape, 0); - const int input_height = input_shape.Dims(1); - const int input_width = input_shape.Dims(2); - const int output_height = output_shape.Dims(1); - const int output_width = output_shape.Dims(2); - const int stride_height = params.stride_height; - const int stride_width = params.stride_width; - - // TODO(benoitjacob) make this a proper reference impl without Eigen! - const auto in_mat = MapAsMatrixWithLastDimAsRows(input_data, input_shape); - auto out_mat = MapAsMatrixWithLastDimAsRows(output_data, output_shape); - - // Prefill the output to 0. - out_mat.setZero(); - - for (int b = 0; b < batches; ++b) - { - for (int h = 0; h < output_height; ++h) - { - for (int w = 0; w < output_width; ++w) - { - // (h_start, h_end) * (w_start, w_end) is input range - // that output is projected from. - int h_start = h * stride_height - params.padding_values.height; - int h_end = std::min(h_start + params.filter_height, input_height); - h_start = h_start < 0 ? 0 : h_start; - - int w_start = w * stride_width - params.padding_values.width; - int w_end = std::min(w_start + params.filter_width, input_width); - w_start = w_start < 0 ? 0 : w_start; - - int count = (h_end - h_start) * (w_end - w_start); - if (h_end <= 0 || w_end <= 0 || count <= 0 || h_start >= input_height || - w_start >= input_width) - continue; - - int out_offset = NodeOffset(b, h, w, output_height, output_width); - for (int ph = h_start; ph < h_end; ++ph) - { - for (int pw = w_start; pw < w_end; ++pw) - { - int in_offset = NodeOffset(b, ph, pw, input_height, input_width); - out_mat.col(out_offset) += in_mat.col(in_offset); - } - } - out_mat.col(out_offset) /= count; - } - } - } - - out_mat.cwiseMin(params.float_activation_min).cwiseMax(params.float_activation_max); -} -inline void AvgPool2DGrad(const PoolParams ¶ms, const Shape &incoming_shape, - const float *incoming_data, const Shape &grad_shape, float *grad_data) +inline void AveragePool2DGrad(const PoolParams ¶ms, const Shape &incoming_shape, + const float *incoming_data, const Shape &grad_shape, float *grad_data) { assert(grad_shape.DimensionsCount() == 4); assert(incoming_shape.DimensionsCount() == 4); diff --git a/compute/cker/src/train/AvgPool.test.cc b/compute/cker/src/train/AveragePool.test.cc similarity index 76% rename from compute/cker/src/train/AvgPool.test.cc rename to compute/cker/src/train/AveragePool.test.cc index 307ac118ab9..51be5e5edd7 100644 --- a/compute/cker/src/train/AvgPool.test.cc +++ b/compute/cker/src/train/AveragePool.test.cc @@ -1,5 +1,5 @@ /* - * Copyright (c) 2023 Samsung Electronics Co., Ltd. All Rights Reserved + * Copyright (c) 2024 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. @@ -16,7 +16,7 @@ #include #include -#include +#include #include #include @@ -48,14 +48,11 @@ template class AvgPoolOpVerifier assert(expected_output.size() == _out_shape.FlatSize()); std::vector cacluated_output(_out_shape.FlatSize()); - nnfw::cker::train::AvgPool2D(_op_params, _in_shape, input.data(), _out_shape, - cacluated_output.data()); + nnfw::cker::AveragePool(_op_params, _in_shape, input.data(), _out_shape, + cacluated_output.data()); if (expect_eq) - for (size_t i = 0; i < expected_output.size(); i++) - { - EXPECT_FLOAT_EQ(expected_output[i], cacluated_output[i]); - } + EXPECT_EQ(expected_output, cacluated_output); else EXPECT_NE(expected_output, cacluated_output); } @@ -67,8 +64,8 @@ template class AvgPoolOpVerifier assert(expected_grad_data.size() == _in_shape.FlatSize()); std::vector calcuated_grad(_in_shape.FlatSize()); - nnfw::cker::train::AvgPool2DGrad(_op_params, _out_shape, incoming_data.data(), _in_shape, - calcuated_grad.data()); + nnfw::cker::train::AveragePool2DGrad(_op_params, _out_shape, incoming_data.data(), _in_shape, + calcuated_grad.data()); if (expect_eq) { @@ -85,7 +82,7 @@ template class AvgPoolOpVerifier } // namespace -TEST(CKer_Operation, AvgPool2D) +TEST(CKer_Operation, AveragePool2D) { // Depth 1 case { @@ -97,6 +94,8 @@ TEST(CKer_Operation, AvgPool2D) op_param.filter_width = 2; op_param.padding_values.height = 0; op_param.padding_values.width = 0; + op_param.float_activation_max = std::numeric_limits::max(); + op_param.float_activation_min = std::numeric_limits::lowest(); } nnfw::cker::Shape in = {1, 3, 3, 1}; nnfw::cker::Shape out = {1, 2, 2, 1}; @@ -104,7 +103,7 @@ TEST(CKer_Operation, AvgPool2D) AvgPoolOpVerifier verifier(op_param, in, out); /** - * input(index) : output(arg-count): + * input : output: * * 10(0) 15(1) 2(2) * 7(3) 8(4) 9(5) - (forward) -> 10(4) 8.5(4) @@ -117,7 +116,7 @@ TEST(CKer_Operation, AvgPool2D) /** * output_deriv: input_deriv: - * (randomly filled) + * * * 0.4 0.4 0.1 0.2 0.1 * 0.4 0.4 - (backward) -> 0.2 0.4 0.2 @@ -139,6 +138,8 @@ TEST(CKer_Operation, AvgPool2D) op_param.filter_width = 3; op_param.padding_values.height = 0; op_param.padding_values.width = 0; + op_param.float_activation_max = std::numeric_limits::max(); + op_param.float_activation_min = std::numeric_limits::lowest(); } nnfw::cker::Shape in = {1, 3, 3, 2}; nnfw::cker::Shape out = {1, 1, 1, 2}; @@ -147,7 +148,7 @@ TEST(CKer_Operation, AvgPool2D) /** * depth[0] - * input(index) : output(index): + * input : output: * * 10(0) 15(1) 2(2) * 10(3) 12(4) 17(5) -(forward)-> 16(0) @@ -155,7 +156,7 @@ TEST(CKer_Operation, AvgPool2D) * * * depth[1] - * input(index): output(index): + * input: output: * * -1(0) 2(1) 3(2) * 8(3) 9(4) 2(5) -(forward)-> 4(0) @@ -192,49 +193,9 @@ TEST(CKer_Operation, AvgPool2D) /* depth1 */ 0.04, 0.04, 0.04, 0.04, 0.04, 0.04, 0.04, 0.04, 0.04; verifier.verifyBackward(output_deriv, expected_input_deriv); } - - // with padding case - { - nnfw::cker::PoolParams op_param; - { - op_param.stride_height = 2; - op_param.stride_width = 2; - op_param.filter_height = 2; - op_param.filter_width = 2; - op_param.padding_values.height = 2; - op_param.padding_values.width = 2; - } - nnfw::cker::Shape in = {1, 2, 2, 1}; - nnfw::cker::Shape out = {1, 3, 3, 1}; - - AvgPoolOpVerifier verifier(op_param, in, out); - - /** - * input_with_padding: expected_output: - * - * 4 8 0 0 0 - * 9 2 -(forward)-> 0 5.75 0 - * 0 0 0 - */ - - std::vector input = {4, 8, 9, 2}; - std::vector expected_output = {0, 0, 0, 0, 5.75, 0, 0, 0, 0}; - verifier.verifyForward(input, expected_output); - - /** - * output_deriv: input_deriv: - * - * 0.1 0.1 0.1 0.1 0.1 - * 0.1 0.4 0.3 -(backward)-> 0.1 0.1 - * 0.5 0.1 0.1 - */ - std::vector output_deriv = {0.1, 0.1, 0.1, 0.1, 0.4, 0.3, 0.5, 0.1, 0.1}; - std::vector expected_input_deriv = {0.1, 0.1, 0.1, 0.1}; - verifier.verifyBackward(output_deriv, expected_input_deriv); - } } -TEST(CKer_Operation, neg_AvgPool) +TEST(CKer_Operation, neg_AveragePoolInvalidExpectedValue) { // Invalid expected value { @@ -246,6 +207,8 @@ TEST(CKer_Operation, neg_AvgPool) op_param.filter_width = 2; op_param.padding_values.height = 0; op_param.padding_values.width = 0; + op_param.float_activation_max = std::numeric_limits::max(); + op_param.float_activation_min = std::numeric_limits::lowest(); } nnfw::cker::Shape in = {1, 2, 2, 1}; nnfw::cker::Shape out = {1, 1, 1, 1}; @@ -268,6 +231,8 @@ TEST(CKer_Operation, neg_AvgPool) op_param.filter_width = 2; op_param.padding_values.height = 1; op_param.padding_values.width = 1; + op_param.float_activation_max = std::numeric_limits::max(); + op_param.float_activation_min = std::numeric_limits::lowest(); } nnfw::cker::Shape in = {1, 2, 2, 1}; From 0cacca922849c044f2c0d5a4b9cf8b2f9ccc42ae Mon Sep 17 00:00:00 2001 From: icodo98 Date: Mon, 30 Sep 2024 17:44:10 +0900 Subject: [PATCH 3/3] [cker] update header guard This commit updates header guard. ONE-DCO-1.0-Signed-off-by: JuYoung Lee rsb98759@gmail.com --- compute/cker/include/cker/train/operation/AveragePool.h | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/compute/cker/include/cker/train/operation/AveragePool.h b/compute/cker/include/cker/train/operation/AveragePool.h index 937d2383f9e..7f68845130e 100644 --- a/compute/cker/include/cker/train/operation/AveragePool.h +++ b/compute/cker/include/cker/train/operation/AveragePool.h @@ -14,8 +14,8 @@ * limitations under the License. */ -#ifndef __NNFW_CKER_TRAIN_OPERATION_AVGPOOL_H__ -#define __NNFW_CKER_TRAIN_OPERATION_AVGPOOL_H__ +#ifndef __NNFW_CKER_TRAIN_OPERATION_AVERAGEPOOL_H__ +#define __NNFW_CKER_TRAIN_OPERATION_AVERAGEPOOL_H__ #include "cker/Shape.h" #include "cker/Utils.h" @@ -90,4 +90,4 @@ inline void AveragePool2DGrad(const PoolParams ¶ms, const Shape &incoming_sh } // namespace cker } // namespace nnfw -#endif // __NNFW_CKER_TRAIN_OPERATION_AVGPOOL_H__ +#endif // __NNFW_CKER_TRAIN_OPERATION_AVERAGEPOOL_H__