* This file is part of the OpenBOAT project at Harbin Institute of Technology (HIT)
* and is contributed to the CANN Open Software.
*
* Copyright (c) 2025 AISS Group, Harbin Institute of Technology (HIT).
* All Rights Reserved.
*
* Authors (accounts):
* - Qiu Zhuang <@qiu-zhuang>
* - Su Tonghua <@sutonghua>
*
* This program is free software: you can redistribute it and/or modify it.
* Licensed under the CANN Open Software License Agreement Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* See the LICENSE file at the root of the repository for the full text of the License.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTIES OF ANY KIND, EXPRESS OR IMPLIED,
* INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
*/
* \file im2_col_def.cpp
* \brief
*/
#include "register/op_def_registry.h"
namespace ops {
namespace {
constexpr int32_t DEFAULT_KERNEL_H = 2;
constexpr int32_t DEFAULT_KERNEL_W = 2;
constexpr int32_t DEFAULT_STRIDE_H = 1;
constexpr int32_t DEFAULT_STRIDE_W = 1;
constexpr int32_t DEFAULT_PAD_H = 0;
constexpr int32_t DEFAULT_PAD_W = 0;
constexpr int32_t DEFAULT_DILATION_H = 1;
constexpr int32_t DEFAULT_DILATION_W = 1;
}
class Im2Col : public OpDef {
public:
explicit Im2Col(const char* name) : OpDef(name)
{
this->Input("x")
.ParamType(REQUIRED)
.DataType({ge::DT_FLOAT, ge::DT_FLOAT16})
.Format({ge::FORMAT_ND, ge::FORMAT_ND})
.UnknownShapeFormat({ge::FORMAT_ND, ge::FORMAT_ND})
.AutoContiguous();
this->Output("z")
.ParamType(REQUIRED)
.DataType({ge::DT_FLOAT, ge::DT_FLOAT16})
.Format({ge::FORMAT_ND, ge::FORMAT_ND})
.UnknownShapeFormat({ge::FORMAT_ND, ge::FORMAT_ND})
.AutoContiguous();
this->Attr("kernel_h")
.AttrType(OPTIONAL)
.Int(DEFAULT_KERNEL_H);
this->Attr("kernel_w")
.AttrType(OPTIONAL)
.Int(DEFAULT_KERNEL_W);
this->Attr("stride_h")
.AttrType(OPTIONAL)
.Int(DEFAULT_STRIDE_H);
this->Attr("stride_w")
.AttrType(OPTIONAL)
.Int(DEFAULT_STRIDE_W);
this->Attr("pad_h")
.AttrType(OPTIONAL)
.Int(DEFAULT_PAD_H);
this->Attr("pad_w")
.AttrType(OPTIONAL)
.Int(DEFAULT_PAD_W);
this->Attr("dilation_h")
.AttrType(OPTIONAL)
.Int(DEFAULT_DILATION_H);
this->Attr("dilation_w")
.AttrType(OPTIONAL)
.Int(DEFAULT_DILATION_W);
OpAICoreConfig aicoreConfig;
aicoreConfig.DynamicCompileStaticFlag(true)
.DynamicFormatFlag(false)
.DynamicRankSupportFlag(true)
.DynamicShapeSupportFlag(true)
.NeedCheckSupportFlag(false)
.PrecisionReduceFlag(true)
.ExtendCfgInfo("opFile.value", "im2_col");
this->AICore().AddConfig("ascend910b", aicoreConfig);
}
};
OP_ADD(Im2Col);
}