- 
                Notifications
    You must be signed in to change notification settings 
- Fork 5.9k
prior box operator for ssd #6150
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe we can make PriorBoxOp more general to support both Faster RCNN and SSD, please refer the design of TensorFlow. Thanks.
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      |  | ||
| void InferShape(framework::InferShapeContext* ctx) const override { | ||
| PADDLE_ENFORCE(ctx->HasInput("Input"), | ||
| "Input(X) of SequenceSliceOp should not be null."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please check this comment.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | PADDLE_ENFORCE(ctx->HasInput("Input"), | ||
| "Input(X) of SequenceSliceOp should not be null."); | ||
| PADDLE_ENFORCE(ctx->HasInput("Image"), | ||
| "Input(Offset) of SequenceSliceOp should not be null."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same as above.
I think we only use the shape of image. Is it necessary to pass the full image ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
I think to pass the full image is easy for the user to use, and maybe easy to update algo. And the
| "The format of input tensor is NCHW."); | ||
|  | ||
| auto min_sizes = ctx->Attrs().Get<std::vector<int>>("min_sizes"); | ||
| auto max_sizes = ctx->Attrs().Get<std::vector<int>>("max_sizes"); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Any possible to make 'max_sizes' optional?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
add SetDefault({}) to max_sizes at line 126
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | ctx->Attrs().Get<std::vector<float>>("aspect_ratios"); | ||
| bool flip = ctx->Attrs().Get<bool>("flip"); | ||
|  | ||
| PADDLE_ENFORCE_GT(min_sizes.size(), 0, "must provide min_size."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please refine this comment and make sure the first character is upper-case.
I think 'Size of min_size must be at least 1.' is more accurate.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | PADDLE_ENFORCE_GT(step_w, 0.0, "step_w should be larger than 0."); | ||
|  | ||
| const int layer_height = input_dims[3]; | ||
| const int layer_width = input_dims[2]; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The shape of input is NCHW or NCWH?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | dim_vec[2] = layer_width * layer_height * num_priors * 4; | ||
| PADDLE_ENFORCE_GT(dim_vec[2], 0, | ||
| "output_dim[2] must larger than 0." | ||
| "check your data dims"); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If possible, please find the illegal input. For example, layer_width is illegal or layer_height is illegal etc.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done, add PADDLE_ENFORCE(input_dims.size() == 4) and check layer_width or layer_height is smaller than image's.
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | framework::OpAttrChecker* op_checker) | ||
| : OpProtoAndCheckerMaker(proto, op_checker) { | ||
| AddInput("Input", | ||
| "(Tensor), " | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please give type info like default Tensor<float>.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | : OpProtoAndCheckerMaker(proto, op_checker) { | ||
| AddInput("Input", | ||
| "(Tensor), " | ||
| "the input feature data of PriorBoxOp."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Lack shape information and no need to start in a newline.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
update code
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      |  | ||
| void InferShape(framework::InferShapeContext* ctx) const override { | ||
| PADDLE_ENFORCE(ctx->HasInput("Input"), | ||
| "Input(X) of SequenceSliceOp should not be null."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | PADDLE_ENFORCE(ctx->HasInput("Input"), | ||
| "Input(X) of SequenceSliceOp should not be null."); | ||
| PADDLE_ENFORCE(ctx->HasInput("Image"), | ||
| "Input(Offset) of SequenceSliceOp should not be null."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
I think to pass the full image is easy for the user to use, and maybe easy to update algo. And the
| "The format of input tensor is NCHW."); | ||
|  | ||
| auto min_sizes = ctx->Attrs().Get<std::vector<int>>("min_sizes"); | ||
| auto max_sizes = ctx->Attrs().Get<std::vector<int>>("max_sizes"); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
add SetDefault({}) to max_sizes at line 126
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | ctx->Attrs().Get<std::vector<float>>("aspect_ratios"); | ||
| bool flip = ctx->Attrs().Get<bool>("flip"); | ||
|  | ||
| PADDLE_ENFORCE_GT(min_sizes.size(), 0, "must provide min_size."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | PADDLE_ENFORCE_GT(step_w, 0.0, "step_w should be larger than 0."); | ||
|  | ||
| const int layer_height = input_dims[3]; | ||
| const int layer_width = input_dims[2]; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | dim_vec[2] = layer_width * layer_height * num_priors * 4; | ||
| PADDLE_ENFORCE_GT(dim_vec[2], 0, | ||
| "output_dim[2] must larger than 0." | ||
| "check your data dims"); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done, add PADDLE_ENFORCE(input_dims.size() == 4) and check layer_width or layer_height is smaller than image's.
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | framework::OpAttrChecker* op_checker) | ||
| : OpProtoAndCheckerMaker(proto, op_checker) { | ||
| AddInput("Input", | ||
| "(Tensor), " | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | : OpProtoAndCheckerMaker(proto, op_checker) { | ||
| AddInput("Input", | ||
| "(Tensor), " | ||
| "the input feature data of PriorBoxOp."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.h
              
                Outdated
          
        
      | inline void expand_aspect_ratios(const std::vector<float> input_aspect_ratior, | ||
| bool flip, | ||
| std::vector<float>& output_aspect_ratior) { | ||
| constexpr float eps = 1e-6; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
eps建议epsilon,在重构后的版本中看到好像都用这个词。
另外这个建议做成参数
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Need to explain 2, layer_height, layer_width, num_priors, 4. Need more explanation for the layout.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why need attrs of img_w and img_h?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why need .SetDefault({}) ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we need to give more doc for this operator, how to generator box? how to calculate the number of prior boxes, and so on?
The TF doc is:
https://github.com/tensorflow/models/blob/master/research/object_detection/core/anchor_generator.py
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I cannot see any information in this comments.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cu
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If not implement the GPU, do not need to register GPU kernel.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.h
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
int64_t, since the type in input->dims() is int64_t
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.h
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Now support multi-device, there is no need to copy tensor from GPU to CPU.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.h
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
这里的clip看下能不能调用Eigen的函数,而不是4层for循环。
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
可以参考 https://github.com/PaddlePaddle/Paddle/blob/develop/paddle/operators/compare_op.h#L72 ,用 platform::Transform 也行。
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.h
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
同上,这种赋值,看看下能不能调用Eigen的函数,而不是4层for循环。
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
这里用broadcast即可~
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Python单测需要改进,尽量向量操作,不用这么多层的for循环。
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
update code
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.h
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.h
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.h
              
                Outdated
          
        
      | inline void expand_aspect_ratios(const std::vector<float> input_aspect_ratior, | ||
| bool flip, | ||
| std::vector<float>& output_aspect_ratior) { | ||
| constexpr float eps = 1e-6; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | AddAttr<std::vector<float>>( | ||
| "aspect_ratios", "(vector<float>) ", | ||
| "List of aspect ratios of generated prior boxes.") | ||
| .SetDefault({}); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Remove .SetDefault({}) too.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | } | ||
| } | ||
|  | ||
| if (variances.size() > 1) { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It seems line 68 should be removed.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.h
              
                Outdated
          
        
      | for (int w = 0; w < layer_width; ++w) { | ||
| float center_x = (w + offset) * step_width; | ||
| float center_y = (h + offset) * step_height; | ||
| float box_width, box_height; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
template <typename Place, typename T>
If T is double, here also should be double.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
| center_x + box_width / 2.) / self.image_w | ||
| # ymax | ||
| out_boxes[h, w, idx, 3] = ( | ||
| center_y + box_height / 2.) / self.image_h | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
这块代码可以简化下,
c_x = (w + self.offset) * self.step_w
c_y = (h + self.offset) * self.step_h
# ...
c_w = c_h = min_size/2.
out_boxes[h, w, idx, :] = [(c_x - c_w)/self.image_w, (c_y - c_h)/self.image_h, ..., ...]  
# ...下面两处计算相同,可以使代码更短一些。
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      |  | ||
| void InferShape(framework::InferShapeContext* ctx) const override { | ||
| PADDLE_ENFORCE(ctx->HasInput("Input"), | ||
| "Input(X) of PriorBoxOp should not be null."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not Input(X), should be Input(Input).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | PADDLE_ENFORCE(ctx->HasInput("Input"), | ||
| "Input(X) of PriorBoxOp should not be null."); | ||
| PADDLE_ENFORCE(ctx->HasInput("Image"), | ||
| "Input(Offset) of PriorBoxOp should not be null."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Input(Offset) --> Input(Image)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      |  | ||
| auto image_dims = ctx->GetInputDim("Image"); | ||
| auto input_dims = ctx->GetInputDim("Input"); | ||
| PADDLE_ENFORCE(image_dims.size() == 4, "The format of image is NCHW."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think The layout of data is NCHW is better.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | bool flip = ctx->Attrs().Get<bool>("flip"); | ||
|  | ||
| PADDLE_ENFORCE_GT(min_sizes.size(), 0, | ||
| "Size of min_size must be at least 1."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
min_size --> min_sizes
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | int num_priors = aspect_ratios_vec.size() * min_sizes.size(); | ||
| if (max_sizes.size() > 0) { | ||
| PADDLE_ENFORCE_EQ(max_sizes.size(), min_sizes.size(), | ||
| "The length of min_size and max_size must be equal."); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
length --> number
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
|  | ||
| auto min_sizes = ctx->Attrs().Get<std::vector<int>>("min_sizes"); | ||
| auto max_sizes = ctx->Attrs().Get<std::vector<int>>("max_sizes"); | ||
| auto variances = ctx->Attrs().Get<std::vector<float>>("variances"); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should be variances optional?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
here variances are needed for output "Variances"
        
          
                paddle/operators/prior_box_op.h
              
                Outdated
          
        
      | boxes->data<T>(), clip_func); | ||
| } | ||
|  | ||
| Eigen::Tensor<T, 2, Eigen::RowMajor> var_et(1, variances.size()); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it is more efficiency to use framework::Tensor whose memory is allocated from internal pool. @qingqing01 Please help to confirm.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, should use Fluid's memory (or Tenosr) to allocate auxiliary workspace.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.cc
              
                Outdated
          
        
      | AddOutput("Boxes", | ||
| "(Tensor, default Tensor<float>), the output prior boxes of " | ||
| "PriorBoxOp. The layout is [layer_height, layer_width, " | ||
| "num_priors, 4]. layer_height is the height of input, " | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
layer_height -> H,
layer_width -> W
same as below.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
        
          
                paddle/operators/prior_box_op.h
              
                Outdated
          
        
      | auto img_height = image->dims()[2]; | ||
|  | ||
| auto layer_width = input->dims()[3]; | ||
| auto layer_height = input->dims()[2]; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
layer_width -> feature_width or width.
Same as layer_height
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
resolve #6015