|
- /**
- * Copyright 2020 Huawei Technologies Co., Ltd
- *
- * 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.
- */
-
- #ifndef GE_GRAPH_PASSES_FOLDING_KERNEL_SSD_PRIOR_BOX_KERNEL_H_
- #define GE_GRAPH_PASSES_FOLDING_KERNEL_SSD_PRIOR_BOX_KERNEL_H_
-
- #include <memory>
- #include <vector>
-
- #include "inc/kernel.h"
-
- namespace ge {
- class SsdPriorboxKernel : public Kernel {
- public:
- /**
- * Entry of the SsdPriorboxKernel optimizer
- * @param [in] node: Input Node
- * @return SUCCESS: node output compute success
- * @return OTHERS: Execution failed
- * @author
- */
- Status Compute(const NodePtr &node, std::vector<GeTensorPtr> &v_output) override;
-
- private:
- /**
- * Get specific op_desc attr value
- * @param [in] op_desc: Input op_desc
- * @param [in/out] img_width: img_width attr_value
- * @param [in/out] img_height: img_height attr_value
- * @param [in/out] step_h: step_h attr_value
- * @param [in/out] step_w: step_w attr_value
- * @param [in/out] layer_width: layer_width attr_value
- * @param [in/out] layer_height: layer_height attr_value
- * @return SUCCESS: node get attr value success
- * @return OTHERS: Execution failed
- * @author
- */
- Status GetPriorSizeParam(const OpDescPtr &op_desc, int &img_width, int &img_height, float &step_w, float &step_h,
- int &layer_width, int &layer_height);
- /**
- * Get specific op_desc size attr value,min_size_num etc.
- * @param [in] op_desc: Input op_desc
- * @param [in/out] offset: offset attr_value
- * @param [in/out] clip: clip attr_value
- * @return SUCCESS: get attr success
- * @return OTHERS: Execution failed
- * @author
- */
- Status GetPriorOtherParam(const OpDescPtr &op_desc, float &offset, bool &clip);
- /**
- * Get specific op_desc list attr value,min_size_list etc.
- * @param [in] op_desc: Input op_desc
- * @param [in/out] min_size_list: min_size_list attr_value
- * @param [in/out] max_size_list: max_size_list attr_value
- * @param [in/out] aspect_ratio_list: aspect_ratio_list attr_value
- * @param [in/out] variance_list: variance_list attr_value
- * @param [in/out] clip: clip attr_value
- * @return SUCCESS: get list attr success
- * @return OTHERS: Execution failed
- * @author
- */
- Status GetPriorListParam(const OpDescPtr &op_desc, vector<float> &min_size_list, vector<float> &max_size_list,
- vector<float> &aspect_ratio_list, vector<float> &variance_list);
- /**
- * set variance param to output_data.
- * @param [in] variance: variance list
- * @param [in] dim: output_data second channel offset
- * @param [in] layer_height: layer_height
- * @param [in] num_priors: num_priors
- * @param [in/out] output_data: output_data
- * @return SUCCESS: set variance success
- * @return OTHERS: Execution failed
- * @author
- */
- Status SetVariance(const vector<float> &variance, const int dim, const int32_t layer_height,
- const int32_t layer_width, const int num_priors, float *output_data);
- /**
- * get num priors and dim size.
- * @param [in] aspect_ratios_size: aspect_ratio_list size
- * @param [in] min_sizes_size: min_size_list size
- * @param [in] max_sizes_size: max_size_list size
- * @param [in] layer_width: layer_width
- * @param [in] layer_height: layer_height
- * @param [in/out] num_priors: num_priors
- * @param [in/out] dim_size: dim_size
- * @return SUCCESS: set variance success
- * @return OTHERS: Execution failed
- * @author
- */
- Status GetNumPriorAndDimSize(uint32_t aspect_ratios_size, uint32_t min_sizes_size, uint32_t max_sizes_size,
- int layer_width, int layer_height, int &num_priors, int &dim_size) const;
- void DataCalulate(float x, float y, float box_x, float box_y, int img_x, int img_y, vector<float> &result);
- std::unique_ptr<float[]> BoundaryCalulate(int dim_size, int layer_width, int layer_height, float step_width,
- float step_height, int img_width, int img_height, float offset,
- vector<float> min_sizes, vector<float> max_sizes,
- vector<float> aspect_ratios);
- };
- } // namespace ge
-
- #endif // GE_GRAPH_PASSES_FOLDING_KERNEL_SSD_PRIOR_BOX_KERNEL_H_
|