From 4578f40953d7b502279cc915bbe847bf86affa7c Mon Sep 17 00:00:00 2001 From: Chen Feiyue <69809761+chenfeiyue-cfy@users.noreply.github.com> Date: Thu, 30 Nov 2023 15:01:33 +0800 Subject: [PATCH] Added 2 cases for stack (#664) Added int32 and uint8 ut for stack op Type: Code Improvement Signed-off-by: Feiyue Chen --- src/tim/vx/ops/stack_test.cc | 93 ++++++++++++++++++++++++++++++++++++ 1 file changed, 93 insertions(+) diff --git a/src/tim/vx/ops/stack_test.cc b/src/tim/vx/ops/stack_test.cc index d147ff3..ae15069 100644 --- a/src/tim/vx/ops/stack_test.cc +++ b/src/tim/vx/ops/stack_test.cc @@ -168,3 +168,96 @@ TEST(Stack, shape_3_4_axis_0) { EXPECT_TRUE(output_tensor->CopyDataFromTensor(output.data())); EXPECT_EQ(golden, output); } + +TEST(Stack, shape_3_4_axis_0_int32) { + auto ctx = tim::vx::Context::Create(); + auto graph = ctx->CreateGraph(); + + tim::vx::ShapeType input_shape({4, 3}); + tim::vx::ShapeType output_shape({2, 4, 3}); + tim::vx::TensorSpec input_spec(tim::vx::DataType::INT32, input_shape, + tim::vx::TensorAttribute::INPUT); + tim::vx::TensorSpec output_spec(tim::vx::DataType::INT32, output_shape, + tim::vx::TensorAttribute::OUTPUT); + + auto input_tensor1 = graph->CreateTensor(input_spec); + auto input_tensor2 = graph->CreateTensor(input_spec); + auto output_tensor = graph->CreateTensor(output_spec); + + std::vector in_data = { + 2, 1, 0, 1, + 2, 4, 4, 4, + 3, 2, 1, 4, + }; + std::vector golden = { + 2, 2, + 1, 1, + 0, 0, + 1, 1, + + 2, 2, + 4, 4, + 4, 4, + 4, 4, + + 3, 3, + 2, 2, + 1, 1, + 4, 4, + }; + + EXPECT_TRUE(input_tensor1->CopyDataToTensor(in_data.data(), + in_data.size() * sizeof(int32_t))); + EXPECT_TRUE(input_tensor2->CopyDataToTensor(in_data.data(), + in_data.size() * sizeof(int32_t))); + auto op = graph->CreateOperation(0, 2); + (*op).BindInputs({input_tensor1, input_tensor2}).BindOutputs({output_tensor}); + + EXPECT_TRUE(graph->Compile()); + EXPECT_TRUE(graph->Run()); + + std::vector output(golden.size()); + EXPECT_TRUE(output_tensor->CopyDataFromTensor(output.data())); + EXPECT_EQ(golden, output); +} + +TEST(Stack, Stack_shape_2_4_axis_1_u8) { + auto ctx = tim::vx::Context::Create(); + auto graph = ctx->CreateGraph(); + + tim::vx::ShapeType input_shape({4}); + tim::vx::ShapeType output_shape({4, 2}); + tim::vx::TensorSpec input_spec(tim::vx::DataType::UINT8, input_shape, + tim::vx::TensorAttribute::INPUT); + tim::vx::TensorSpec output_spec(tim::vx::DataType::UINT8, output_shape, + tim::vx::TensorAttribute::OUTPUT); + + auto input_tensor1 = graph->CreateTensor(input_spec); + auto input_tensor2 = graph->CreateTensor(input_spec); + auto output_tensor = graph->CreateTensor(output_spec); + + std::vector in_data1 = { + 2, 1, 0, 1, + }; + std::vector in_data2 = { + 1, 0, 1, 2 + }; + std::vector golden = { + 2, 1, 0, 1, + 1,0, 1, 2 + }; + + EXPECT_TRUE(input_tensor1->CopyDataToTensor(in_data1.data(), + in_data1.size() * sizeof(uint8_t))); + EXPECT_TRUE(input_tensor2->CopyDataToTensor(in_data2.data(), + in_data2.size() * sizeof(uint8_t))); + auto op = graph->CreateOperation(1, 2); + (*op).BindInputs({input_tensor1, input_tensor2}).BindOutputs({output_tensor}); + + EXPECT_TRUE(graph->Compile()); + EXPECT_TRUE(graph->Run()); + + std::vector output(golden.size()); + EXPECT_TRUE(output_tensor->CopyDataFromTensor(output.data())); + EXPECT_EQ(golden, output); +}