CANN/ops-cv双线性抗锯齿上采样算子
UpsampleBilinear2dAA
【免费下载链接】ops-cv本项目是CANN提供的图像处理、目标检测相关的算子库,实现网络在NPU上加速计算。项目地址: https://gitcode.com/cann/ops-cv
产品支持情况
| 产品 | 是否支持 |
|---|---|
| Ascend 950PR/Ascend 950DT | √ |
| Atlas A3 训练系列产品/Atlas A3 推理系列产品 | √ |
| Atlas A2 训练系列产品/Atlas A2 推理系列产品 | √ |
| Atlas 200I/500 A2 推理产品 | × |
| Atlas 推理系列产品 | × |
| Atlas 训练系列产品 | × |
| Kirin X90 处理器系列产品 | √ |
| Kirin 9030 处理器系列产品 | √ |
功能说明
算子功能:对由多个输入通道组成的输入信号应用2D双线性抗锯齿采样。
计算公式:对于一个二维插值点$(N, C, H, W)$, 插值$I(N, C, H, W)$可以表示为:
$$ {I(N, C, H, W)} = \sum_{i=0}^{kW}\sum_{j=0}^{kH}{w(i) * w(j)} * {f(h_i, w_j)}/\sum_{i=0}^{kW}w(i)/\sum_{j=0}^{kH}w(j) $$
$$ scaleH =\begin{cases} (input.dim(2)-1) / (outputSize[0]-1) & alignCorners=true \ 1 / scalesH & alignCorners=false&scalesH>0\ input.dim(2) / outputSize[0] & otherwise \end{cases} $$
$$ scaleW =\begin{cases} (input.dim(3)-1) / (outputSize[1]-1) & alignCorners=true \ 1 / scalesW & alignCorners=false&scalesW>0\ input.dim(3) / outputSize[1] & otherwise \end{cases} $$
其中:
$kW$、$kH$分别表示W方向和H方向影响插值点大小的点的数量
如果$scaleH >= 1$,则$kH = floor(scaleH) * 2 + 1$,否则$kH = 3$
如果$scaleW >= 1$,则$kW = floor(scaleW) * 2 + 1$,否则$kW = 3$
$f(h_i, w_j)$是原图像在$(h_i, w_j)$的像素值
$w(i)$、$w(j)$是双线性抗锯齿插值的W方向和H方向权重,计算公式为:
$$ w(i) = \begin{cases} 1 - |h_i - h| & |h_i -h| < 1 \ 0 & otherwise \end{cases} $$
$$ w(j) = \begin{cases} 1 - |w_j - w| & |w_j -w| < 1 \ 0 & otherwise \end{cases} $$
参数说明
| 参数名 | 输入/输出/属性 | 描述 | 数据类型 | 数据格式 |
|---|---|---|---|---|
| input | 输入 | 表示进行采样的输入张量,对应公式中的`input`。 | FLOAT32、FLOAT16、BFLOAT16 | ND |
| output_size | 属性 | 指定输出空间大小,对应公式中的`outputSize`。size为2,且各元素均大于0。表示指定`output`在H和W维度上的空间大小。 | LISTINT | - |
| align_corners | 可选属性 |
| BOOL | - |
| scales_h | 可选属性 |
| FLOAT32 | - |
| scales_w | 可选属性 |
| FLOAT32 | - |
| output | 输出 | 表示采样后的输出张量,对应公式中的`I`。数据类型和数据格式与入参`input`的数据类型和数据格式保持一致。 | FLOAT32、FLOAT16、BFLOAT16 | ND |
- Kirin X90 处理器系列产品 、 Kirin 9030 处理器系列产品 :不支持BFLOAT16。
约束说明
无
调用说明
| 调用方式 | 样例代码 | 说明 |
|---|---|---|
| aclnn接口 | test_aclnn_upsample_bilinear2d_aa | 通过aclnnUpsampleBilinear2dAA接口方式调用UpsampleBilinear2dAA算子。 |
【免费下载链接】ops-cv本项目是CANN提供的图像处理、目标检测相关的算子库,实现网络在NPU上加速计算。项目地址: https://gitcode.com/cann/ops-cv
创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考
