Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
96a8bbe7
P
Paddle
项目概览
BaiXuePrincess
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
96a8bbe7
编写于
11月 30, 2022
作者:
W
wanghuancoder
提交者:
GitHub
11月 30, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refine conv add for xpu (#48432)
上级
cbb1cfbb
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
11 addition
and
32 deletion
+11
-32
python/paddle/nn/functional/conv.py
python/paddle/nn/functional/conv.py
+11
-32
未找到文件。
python/paddle/nn/functional/conv.py
浏览文件 @
96a8bbe7
...
...
@@ -145,20 +145,9 @@ def _conv_nd(
data_format
,
)
if
bias
is
not
None
:
channel_dim
=
(
channel_dim
+
len
(
x
.
shape
)
if
channel_dim
<
0
else
channel_dim
)
if
isinstance
(
x
,
tuple
):
x
=
x
[
0
]
if
isinstance
(
bias
,
tuple
):
bias
=
bias
[
0
]
if
len
(
bias
.
shape
)
<
len
(
x
.
shape
):
bias
=
_C_ops
.
reshape
(
bias
,
[
1
for
i
in
range
(
channel_dim
)]
+
bias
.
shape
+
[
1
for
i
in
range
(
len
(
x
.
shape
)
-
channel_dim
-
1
)],
)
new_shape
=
[
1
]
*
len
(
x
.
shape
)
new_shape
[
channel_dim
]
=
-
1
bias
=
bias
.
reshape
(
new_shape
)
# TODO(qili93): temporary for ascned npu performance to be removed along with npu_identity op
if
'npu'
in
get_all_custom_device_type
():
with
no_grad
():
...
...
@@ -182,16 +171,10 @@ def _conv_nd(
data_format
,
)
if
bias
is
not
None
:
channel_dim
=
(
channel_dim
+
len
(
x
.
shape
)
if
channel_dim
<
0
else
channel_dim
)
tmp_bias
=
_C_ops
.
reshape
(
bias
,
[
1
for
i
in
range
(
channel_dim
)]
+
bias
.
shape
+
[
1
for
i
in
range
(
len
(
x
.
shape
)
-
channel_dim
-
1
)],
)
return
_C_ops
.
add
(
pre_bias
,
tmp_bias
)
new_shape
=
[
1
]
*
len
(
x
.
shape
)
new_shape
[
channel_dim
]
=
-
1
bias
=
bias
.
reshape
(
new_shape
)
return
_C_ops
.
add
(
pre_bias
,
bias
)
else
:
return
pre_bias
...
...
@@ -207,14 +190,10 @@ def _conv_nd(
data_format
,
)
if
bias
is
not
None
:
channel_dim
=
(
channel_dim
+
len
(
x
.
shape
)
if
channel_dim
<
0
else
channel_dim
)
tmp_bias
=
_C_ops
.
reshape
(
bias
,
bias
.
shape
+
[
1
for
i
in
range
(
len
(
x
.
shape
)
-
channel_dim
-
1
)],
)
return
_C_ops
.
add
(
pre_bias
,
tmp_bias
)
new_shape
=
[
1
]
*
len
(
x
.
shape
)
new_shape
[
channel_dim
]
=
-
1
bias
=
bias
.
reshape
(
new_shape
)
return
_C_ops
.
add
(
pre_bias
,
bias
)
else
:
return
pre_bias
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录