diff --git a/lite/kernels/npu/bridges/pool_op.cc b/lite/kernels/npu/bridges/pool_op.cc index 1738b8467f5cc091d78bc5ebc67f0b6ed7e42de8..87fe705705fc90d1a82fa8c458523d2afb3ff060 100644 --- a/lite/kernels/npu/bridges/pool_op.cc +++ b/lite/kernels/npu/bridges/pool_op.cc @@ -47,8 +47,7 @@ node_map_type PoolConverter(const std::shared_ptr pool_op, auto ksize = op_info->GetAttr>("ksize"); auto npu_window = ge::AttrValue::LIST_INT(ksize.begin(), ksize.end()); - auto padding = - *(op_info->GetAttr>>("paddings")); + auto padding = op_info->GetAttr>("paddings"); bool pads_equal = (padding[0] == padding[1]) && (padding[2] == padding[3]); if (!pads_equal) { LOG(FATAL) diff --git a/lite/kernels/npu/bridges/pool_op_test.cc b/lite/kernels/npu/bridges/pool_op_test.cc index 3e3ef5862cdc71b592b13104456e890b5144e567..298e06554776e0f9efeade540d6498d1f71f8a16 100644 --- a/lite/kernels/npu/bridges/pool_op_test.cc +++ b/lite/kernels/npu/bridges/pool_op_test.cc @@ -39,8 +39,7 @@ void pool_ref(const std::shared_ptr op) { std::vector ksize = op_info->GetAttr>("ksize"); std::vector strides = op_info->GetAttr>("strides"); - std::vector paddings = - *(op_info->GetAttr>>("paddings")); + std::vector paddings = op_info->GetAttr>("paddings"); bool exclusive = op_info->GetAttr("exclusive"); std::string pooling_type = op_info->GetAttr("pooling_type"); bool global_pooling = op_info->GetAttr("global_pooling"); @@ -164,9 +163,8 @@ void test_pool(int bs, opdesc.SetAttr("global_pooling", global_pooling); opdesc.SetAttr("exclusive", exclusive); opdesc.SetAttr("strides", std::vector({stride, stride})); - opdesc.SetAttr( - "paddings", - std::shared_ptr>({padding, padding, padding, padding})); + opdesc.SetAttr("paddings", + std::vector({padding, padding, padding, padding})); // create and convert op to NPU model, then run it on NPU auto op = CreateOp(opdesc, &scope); diff --git a/lite/kernels/opencl/pool_compute_test.cc b/lite/kernels/opencl/pool_compute_test.cc index 354f31a68b0ab10a75a7e8312ff49f76d12706d8..25f0e72634775f4c5e82a6bd800f9ca980da2e34 100644 --- a/lite/kernels/opencl/pool_compute_test.cc +++ b/lite/kernels/opencl/pool_compute_test.cc @@ -89,9 +89,10 @@ TEST(pool2d, compute) { param.output = &out; param.global_pooling = true; param.pooling_type = "avg"; - param.paddings = std::make_shared>({0, 0, 0, 0}); + std::vector paddings = {0, 0, 0, 0}; param.strides = std::vector{1, 1}; param.ksize = std::vector{7, 7}; + param.paddings = std::make_shared>(paddings); std::unique_ptr context(new KernelContext); context->As().InitOnce(); diff --git a/lite/kernels/x86/pool_compute_test.cc b/lite/kernels/x86/pool_compute_test.cc index be17a3deed978deff8ab466eaba5f1644dd8e2a5..4ea727cedd5206f5f1ac2685297f72c3019bb313 100644 --- a/lite/kernels/x86/pool_compute_test.cc +++ b/lite/kernels/x86/pool_compute_test.cc @@ -60,7 +60,8 @@ TEST(pool2d_x86, run_test) { param.x = &x; param.output = &out; param.strides = {2, 2}; - param.paddings = std::make_shared>({0, 0, 0, 0}); + std::vector paddings = {0, 0, 0, 0}; + param.paddings = std::make_shared>(paddings); param.ksize = {2, 2}; param.pooling_type = "max"; std::unique_ptr ctx(new KernelContext); diff --git a/lite/kernels/xpu/bridges/pool_op.cc b/lite/kernels/xpu/bridges/pool_op.cc index 4ecad2f036d4f515147ff0036d81c14b93fe8db2..fbc6a9919c446508afa5a3b8a1c35352f9b8ecfa 100644 --- a/lite/kernels/xpu/bridges/pool_op.cc +++ b/lite/kernels/xpu/bridges/pool_op.cc @@ -38,8 +38,7 @@ node_map_type PoolConverter(const std::shared_ptr op, auto x_var_name = op_info->Input("X").front(); auto pooling_type = op_info->GetAttr("pooling_type"); auto ceil_mode = op_info->GetAttr("ceil_mode"); - auto paddings = - op_info->GetAttr>>("paddings"); + auto paddings = op_info->GetAttr>("paddings"); auto global_pooling = op_info->GetAttr("global_pooling"); auto ksize = op_info->GetAttr>("ksize"); auto strides = op_info->GetAttr>("strides"); @@ -58,7 +57,7 @@ node_map_type PoolConverter(const std::shared_ptr op, graph_ctx->builder->CreateMaxPool2D(*input_nodes.at(x_var_name), lite::xpu::CvtShape(ksize), lite::xpu::CvtShape(strides), - lite::xpu::CvtShape(*paddings), + lite::xpu::CvtShape(paddings), "NCHW", ceil_mode)); } @@ -73,7 +72,7 @@ node_map_type PoolConverter(const std::shared_ptr op, graph_ctx->builder->CreateAvgPool2D(*input_nodes.at(x_var_name), lite::xpu::CvtShape(ksize), lite::xpu::CvtShape(strides), - lite::xpu::CvtShape(*paddings), + lite::xpu::CvtShape(paddings), "NCHW", ceil_mode, !exclusive)); diff --git a/lite/kernels/xpu/bridges/pool_op_test.cc b/lite/kernels/xpu/bridges/pool_op_test.cc index bc1ecad2cf713270d89df8f883dfdd9bc7def092..7efc6b464c00c945c71c8c5689e18823cde10f97 100644 --- a/lite/kernels/xpu/bridges/pool_op_test.cc +++ b/lite/kernels/xpu/bridges/pool_op_test.cc @@ -38,8 +38,7 @@ void pool_ref(const std::shared_ptr op) { std::vector ksize = op_info->GetAttr>("ksize"); std::vector strides = op_info->GetAttr>("strides"); - std::vector paddings = - *(op_info->GetAttr>>("paddings")); + std::vector paddings = op_info->GetAttr>("paddings"); bool exclusive = op_info->GetAttr("exclusive"); std::string pooling_type = op_info->GetAttr("pooling_type"); bool global_pooling = op_info->GetAttr("global_pooling"); @@ -163,9 +162,8 @@ void test_pool(int bs, opdesc.SetAttr("global_pooling", global_pooling); opdesc.SetAttr("exclusive", exclusive); opdesc.SetAttr("strides", std::vector({stride, stride})); - opdesc.SetAttr( - "paddings", - std::shared_ptr>({padding, padding, padding, padding})); + opdesc.SetAttr("paddings", + std::vector({padding, padding, padding, padding})); opdesc.SetAttr("ceil_mode", ceil_mode); // create and convert op to XPU model, then run it on XPU