Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Crayon鑫
Paddle
提交
c576169b
P
Paddle
项目概览
Crayon鑫
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
c576169b
编写于
9月 28, 2021
作者:
R
ronnywang
提交者:
GitHub
9月 28, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[cherry-pick] [ROCM] bugfix for bilinear_interp_v2_grad (#36160) #36161
ATT, cherry-pick #36160
上级
cea0bc26
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
14 addition
and
2 deletion
+14
-2
paddle/fluid/operators/interpolate_v2_op.cu
paddle/fluid/operators/interpolate_v2_op.cu
+14
-2
未找到文件。
paddle/fluid/operators/interpolate_v2_op.cu
浏览文件 @
c576169b
...
...
@@ -1198,7 +1198,12 @@ static void Interpolate2DCUDAFwd(const framework::ExecutionContext& ctx,
input_data
,
in_h
,
in_w
,
n
,
in_chw
,
output_data
,
out_h
,
out_w
,
n
,
out_chw
,
c
,
ratio_h
,
ratio_w
,
align_corners
,
align_mode
,
data_layout
);
}
else
if
(
"bicubic"
==
interp_method
)
{
KeBicubicInterpFw
<
T
><<<
config
.
block_per_grid
,
512
,
0
,
#ifdef __HIPCC__
constexpr
int
thread_per_block
=
256
;
#else
constexpr
int
thread_per_block
=
512
;
#endif
KeBicubicInterpFw
<
T
><<<
config
.
block_per_grid
,
thread_per_block
,
0
,
ctx
.
cuda_device_context
().
stream
()
>>>
(
input_data
,
in_h
,
in_w
,
n
,
in_chw
,
output_data
,
out_h
,
out_w
,
n
,
out_chw
,
c
,
ratio_h
,
ratio_w
,
align_corners
,
data_layout
);
...
...
@@ -1606,9 +1611,11 @@ static void Interpolate2DCUDABwd(const framework::ExecutionContext& ctx,
const
T
align_type_value
=
(
align_mode
==
0
&&
!
align_corners
)
?
0.5
f
:
0
;
bool
is_nchw
=
(
data_layout
==
DataLayout
::
kNCHW
)
?
true
:
false
;
bool
optimize_flag
=
false
;
#ifndef __HIPCC__
optimize_flag
=
(
in_h
<
(
out_h
>>
6
)
&&
in_w
<
(
out_w
>>
6
))
?
true
:
((
in_h
==
1
&&
in_w
==
1
)
?
true
:
false
);
#endif
if
(
optimize_flag
&
is_nchw
)
{
KeBilinearInterpBwShareMemory
<
...
...
@@ -1623,7 +1630,12 @@ static void Interpolate2DCUDABwd(const framework::ExecutionContext& ctx,
ratio_h
,
ratio_w
,
align_type_value
,
is_nchw
);
}
}
else
if
(
"bicubic"
==
interp_method
)
{
KeBicubicInterpBw
<
T
><<<
config
.
block_per_grid
,
512
,
0
,
#ifdef __HIPCC__
constexpr
int
thread_per_block
=
256
;
#else
constexpr
int
thread_per_block
=
512
;
#endif
KeBicubicInterpBw
<
T
><<<
config
.
block_per_grid
,
thread_per_block
,
0
,
ctx
.
cuda_device_context
().
stream
()
>>>
(
input_grad_data
,
in_h
,
in_w
,
n
,
in_chw
,
output_grad_data
,
out_h
,
out_w
,
n
,
out_chw
,
c
,
ratio_h
,
ratio_w
,
align_corners
,
data_layout
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录