From 1e696f3560a23bf998ca51043db47f1fb236defd Mon Sep 17 00:00:00 2001 From: liuqi Date: Thu, 14 Mar 2019 10:50:13 +0800 Subject: [PATCH] Bug: fix the data format bug of Shape and InferConv2dShape ops. --- mace/ops/infer_conv2d_shape.cc | 3 ++- mace/ops/ops_test_util.cc | 3 ++- mace/ops/shape.cc | 4 ++-- 3 files changed, 6 insertions(+), 4 deletions(-) diff --git a/mace/ops/infer_conv2d_shape.cc b/mace/ops/infer_conv2d_shape.cc index 50b9a9e1..38f711f5 100644 --- a/mace/ops/infer_conv2d_shape.cc +++ b/mace/ops/infer_conv2d_shape.cc @@ -36,7 +36,8 @@ class InferConv2dShapeOp : public Operation { auto has_data_format = Operation::GetOptionalArg("has_data_format", 0); - const bool isNCHW = (has_data_format && D == DeviceType::CPU); + const bool isNCHW = (has_data_format && + input->data_format() == DataFormat::NCHW); Padding padding_type = static_cast(Operation::GetOptionalArg( diff --git a/mace/ops/ops_test_util.cc b/mace/ops/ops_test_util.cc index 7462548a..dec3bd50 100644 --- a/mace/ops/ops_test_util.cc +++ b/mace/ops/ops_test_util.cc @@ -129,7 +129,8 @@ OpTestContext::OpTestContext(int num_threads, device_map_[DeviceType::GPU] = make_unique( gpu_context_->opencl_tuner(), gpu_context_->opencl_cache_storage(), - GPUPriorityHint::PRIORITY_NORMAL); + GPUPriorityHint::PRIORITY_NORMAL, + GPUPerfHint::PERF_HIGH); } std::shared_ptr OpTestContext::gpu_context() const { diff --git a/mace/ops/shape.cc b/mace/ops/shape.cc index 1ee3ee02..dcca202f 100644 --- a/mace/ops/shape.cc +++ b/mace/ops/shape.cc @@ -37,8 +37,8 @@ class ShapeOp : public Operation { auto has_df = Operation::GetOptionalArg( "has_data_format", 0); - if (D == DeviceType::CPU && - has_df && input->dim_size() == 4) { + if (has_df && input->data_format() == DataFormat::NCHW && + input->dim_size() != 4) { // transpose NCHW to NHWC for cpu runtime output_data[0] = static_cast(input->dim(0)); output_data[1] = static_cast(input->dim(2)); -- GitLab