// Copyright (c) 2019 PaddlePaddle Authors. 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 "lite/kernels/host/reshape_compute.h" #include #include #include "lite/core/op_registry.h" namespace paddle { namespace lite { namespace kernels { namespace host { TEST(reshape_host, init) { ReshapeCompute reshape; ASSERT_EQ(reshape.precision(), PRECISION(kAny)); ASSERT_EQ(reshape.target(), TARGET(kHost)); } TEST(reshape_host, compute) { ReshapeCompute reshape; operators::ReshapeParam param; Tensor x; Tensor actual_shape; Tensor output; x.Resize(DDim(std::vector({1, 2, 4, 6}))); actual_shape.Resize(DDim(std::vector({2}))); auto* x_data = x.mutable_data(); auto* actual_shape_data = actual_shape.mutable_data(); for (int i = 0; i < x.dims().production(); i++) { x_data[i] = i; } actual_shape_data[0] = 6; actual_shape_data[1] = 8; param.x = &x; param.shape = {-1, 0, 3, 2, 1}; param.output = &output; param.actual_shape = &actual_shape; param.inplace = false; reshape.SetParam(param); reshape.Run(); // check output dims CHECK_EQ(actual_shape.dims().production(), output.dims().size()); for (int i = 0; i < output.dims().size(); i++) { CHECK_EQ(output.dims()[i], actual_shape_data[i]); } // check output data auto* output_data = output.mutable_data(); CHECK_NE(output_data, x_data); for (int i = 0; i < output.dims().production(); i++) { EXPECT_NEAR(output_data[i], x_data[i], 1e-6); } // check output data if inplace = true; param.inplace = true; reshape.SetParam(param); reshape.Run(); output_data = output.mutable_data(); CHECK_EQ(output_data, x_data); } TEST(reshape, retrive_op) { auto reshape = KernelRegistry::Global() .Create("reshape"); ASSERT_FALSE(reshape.empty()); ASSERT_TRUE(reshape.front()); } TEST(reshape2, retrive_op) { auto reshape2 = KernelRegistry::Global() .Create("reshape2"); ASSERT_FALSE(reshape2.empty()); ASSERT_TRUE(reshape2.front()); } } // namespace host } // namespace kernels } // namespace lite } // namespace paddle USE_LITE_KERNEL(reshape, kHost, kAny, kAny, def); USE_LITE_KERNEL(reshape2, kHost, kAny, kAny, def);