Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
b72d4cb4
P
Paddle
项目概览
机器未来
/
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看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
b72d4cb4
编写于
2月 17, 2022
作者:
Z
zyfncg
提交者:
GitHub
2月 17, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix selected_rows bug in C++ API (#39658)
上级
a1ad003c
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
24 addition
and
7 deletion
+24
-7
paddle/pten/api/lib/kernel_dispatch.h
paddle/pten/api/lib/kernel_dispatch.h
+23
-5
python/paddle/utils/code_gen/api_base.py
python/paddle/utils/code_gen/api_base.py
+1
-2
未找到文件。
paddle/pten/api/lib/kernel_dispatch.h
浏览文件 @
b72d4cb4
...
...
@@ -46,8 +46,6 @@ enum class KernelType {
// TODO(chenweihang): support DataLayout and DataType selected
struct
KernelKeySet
{
KernelType
kernel_type
{
KernelType
::
DENSE_TENSOR_KENREL
};
BackendSet
backend_set
{
Backend
::
UNDEFINED
};
DataLayout
layout
{
DataLayout
::
UNDEFINED
};
DataType
dtype
{
DataType
::
UNDEFINED
};
...
...
@@ -97,9 +95,6 @@ struct KernelKeyParser : ArgsIterator<KernelKeyParser> {
void
operator
()(
const
Tensor
&
x
)
{
key_set
.
backend_set
=
key_set
.
backend_set
|
detail
::
GetTensorBackendSet
(
x
);
// TODO(chenweihang): selecte multi layout and dtype
if
(
pten
::
SelectedRows
::
classof
(
x
.
impl
().
get
()))
{
key_set
.
kernel_type
=
KernelType
::
SELECTED_ROWS_KENREL
;
}
key_set
.
layout
=
x
.
layout
();
key_set
.
dtype
=
x
.
type
();
dtype_set
=
dtype_set
|
DataTypeSet
(
x
.
dtype
());
...
...
@@ -124,6 +119,24 @@ struct KernelKeyParser : ArgsIterator<KernelKeyParser> {
}
};
struct
KernelTypeParser
:
ArgsIterator
<
KernelTypeParser
>
{
KernelType
kernel_type
{
KernelType
::
DENSE_TENSOR_KENREL
};
// TODO(chenweihang): deal with multiple diff input Tensors
// TODO(chenweihang): add global device guard method to set backend
void
operator
()(
const
Tensor
&
x
)
{
if
(
pten
::
SelectedRows
::
classof
(
x
.
impl
().
get
()))
{
kernel_type
=
KernelType
::
SELECTED_ROWS_KENREL
;
}
}
// skip other type args, these args don't used in kernel selection
template
<
typename
T
>
void
operator
()(
const
T
&
x
)
{
// do nothing
}
};
}
// namespace detail
template
<
typename
...
Args
>
...
...
@@ -131,6 +144,11 @@ KernelKeySet ParseKernelKeyByInputArgs(const Args&... args) {
return
detail
::
KernelKeyParser
().
apply
(
args
...).
key_set
;
}
template
<
typename
...
Args
>
KernelType
ParseKernelTypeByInputArgs
(
const
Args
&
...
args
)
{
return
detail
::
KernelTypeParser
().
apply
(
args
...).
kernel_type
;
}
DataType
ParseDataType
(
DataType
dtype
);
DataType
ParseDataType
(
const
Tensor
&
tensor
);
DataType
ParseDataType
(
const
std
::
vector
<
Tensor
>&
tensors
);
...
...
python/paddle/utils/code_gen/api_base.py
浏览文件 @
b72d4cb4
...
...
@@ -345,7 +345,7 @@ PADDLE_API {self.outputs['return_type']} {self.api}({self.args_str['args_declare
if
len
(
input_names
)
>
0
:
if
self
.
support_selected_rows_kernel
:
kernel_select_code
=
kernel_select_code
+
f
"""
KernelType kernel_type;
KernelType kernel_type
= ParseKernelTypeByInputArgs(
{
", "
.
join
(
input_names
)
}
)
;
"""
kernel_select_code
=
kernel_select_code
+
f
"""
...
...
@@ -354,7 +354,6 @@ PADDLE_API {self.outputs['return_type']} {self.api}({self.args_str['args_declare
|| kernel_data_type == DataType::UNDEFINED ) {{
auto kernel_key_set = ParseKernelKeyByInputArgs(
{
kernel_select_args
}
);
auto kernel_key = kernel_key_set.GetHigestPriorityKernelKey();
{
'kernel_type = kernel_key_set.kernel_type;'
if
self
.
support_selected_rows_kernel
else
''
}
if (kernel_backend == Backend::UNDEFINED) {{
kernel_backend = kernel_key.backend();
}}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录