|
|
|
@ -19,6 +19,8 @@
|
|
|
|
|
#include "common/common_test.h"
|
|
|
|
|
#include "nnacl/resize_parameter.h"
|
|
|
|
|
#include "mindspore/lite/src/kernel_registry.h"
|
|
|
|
|
#include "mindspore/lite/schema/ops_generated.h"
|
|
|
|
|
using mindspore::schema::Format_NHWC;
|
|
|
|
|
|
|
|
|
|
namespace mindspore {
|
|
|
|
|
|
|
|
|
@ -52,6 +54,7 @@ void TestResizeBilinearFp32::Prepare(const std::vector<int> &input_shape, const
|
|
|
|
|
float *input_data, float *output_data, const bool align_corners,
|
|
|
|
|
const int thread_num) {
|
|
|
|
|
in_tensor_.set_data_type(kNumberTypeFloat32);
|
|
|
|
|
in_tensor_.SetFormat(Format_NHWC);
|
|
|
|
|
in_tensor_.set_shape(input_shape);
|
|
|
|
|
out_tensor_.set_data_type(kNumberTypeFloat32);
|
|
|
|
|
out_tensor_.set_shape(output_shape);
|
|
|
|
@ -377,4 +380,30 @@ TEST_F(TestResizeBilinearFp32, ResizeBilinearTest15) {
|
|
|
|
|
|
|
|
|
|
CompareOutputData(output_data, expect.data(), output_size, err_tol);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 5*5 -> 2*2
|
|
|
|
|
TEST_F(TestResizeBilinearFp32, ResizeBilinearTest16) {
|
|
|
|
|
float input_data[] = {
|
|
|
|
|
0.0, 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0, 11.0, 12.0, 13.0, 14.0, 15.0,
|
|
|
|
|
16.0, 17.0, 18.0, 19.0, 20.0, 21.0, 22.0, 23.0, 24.0, 25.0, 26.0, 27.0, 28.0, 29.0, 30.0, 31.0,
|
|
|
|
|
32.0, 33.0, 34.0, 35.0, 36.0, 37.0, 38.0, 39.0, 40.0, 41.0, 42.0, 43.0, 44.0, 45.0, 46.0, 47.0,
|
|
|
|
|
48.0, 49.0, 50.0, 51.0, 52.0, 53.0, 54.0, 55.0, 56.0, 57.0, 58.0, 59.0, 60.0, 61.0, 62.0, 63.0,
|
|
|
|
|
64.0, 65.0, 66.0, 67.0, 68.0, 69.0, 70.0, 71.0, 72.0, 73.0, 74.0, 75.0, 76.0, 77.0, 78.0, 79.0,
|
|
|
|
|
80.0, 81.0, 82.0, 83.0, 84.0, 85.0, 86.0, 87.0, 88.0, 89.0, 90.0, 91.0, 92.0, 93.0, 94.0, 95.0,
|
|
|
|
|
96.0, 97.0, 98.0, 99.0, 100.0, 101.0, 102.0, 103.0, 104.0, 105.0, 106.0, 107.0, 108.0, 109.0, 110.0, 111.0,
|
|
|
|
|
112.0, 113.0, 114.0, 115.0, 116.0, 117.0, 118.0, 119.0, 120.0, 121.0, 122.0, 123.0, 124.0};
|
|
|
|
|
float output_data[20] = {0};
|
|
|
|
|
std::vector<int> input_shape = {1, 5, 5, 5};
|
|
|
|
|
std::vector<int> output_shape = {1, 2, 2, 5};
|
|
|
|
|
std::vector<float> expect = {0.0, 1.0, 2.0, 3.0, 4.0, 12.5, 13.5, 14.5, 15.5, 16.5,
|
|
|
|
|
62.5, 63.5, 64.5, 65.5, 66.5, 75.0, 76.0, 77.0, 78.0, 79.0};
|
|
|
|
|
bool align_corners = false;
|
|
|
|
|
auto output_size = 20;
|
|
|
|
|
|
|
|
|
|
Prepare(input_shape, output_shape, input_data, output_data, align_corners, 2);
|
|
|
|
|
auto ret = kernel_->Run();
|
|
|
|
|
EXPECT_EQ(0, ret);
|
|
|
|
|
|
|
|
|
|
CompareOutputData(output_data, expect.data(), output_size, err_tol);
|
|
|
|
|
}
|
|
|
|
|
} // namespace mindspore
|
|
|
|
|