Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
84b63a26
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看板
未验证
提交
84b63a26
编写于
4月 04, 2022
作者:
C
Chen Weihang
提交者:
GitHub
4月 03, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[Phi] Add add_n(sum) infermeta and yaml (#41362)
* add add_n infermeta * forward run success * add add_n grad yaml
上级
0f165f0b
变更
8
隐藏空白更改
内联
并排
Showing
8 changed file
with
168 addition
and
1 deletion
+168
-1
paddle/phi/api/lib/api_custom_impl.cc
paddle/phi/api/lib/api_custom_impl.cc
+46
-0
paddle/phi/api/lib/api_custom_impl.h
paddle/phi/api/lib/api_custom_impl.h
+3
-0
paddle/phi/infermeta/multiary.cc
paddle/phi/infermeta/multiary.cc
+72
-0
paddle/phi/infermeta/multiary.h
paddle/phi/infermeta/multiary.h
+4
-0
python/paddle/fluid/tests/unittests/test_sum_op.py
python/paddle/fluid/tests/unittests/test_sum_op.py
+22
-0
python/paddle/tensor/math.py
python/paddle/tensor/math.py
+5
-1
python/paddle/utils/code_gen/api.yaml
python/paddle/utils/code_gen/api.yaml
+9
-0
python/paddle/utils/code_gen/backward.yaml
python/paddle/utils/code_gen/backward.yaml
+7
-0
未找到文件。
paddle/phi/api/lib/api_custom_impl.cc
浏览文件 @
84b63a26
...
...
@@ -31,6 +31,52 @@ limitations under the License. */
namespace
paddle
{
namespace
experimental
{
// TODO(chenweihang): the original sum grad op can support higher-level
// differentiation,
// but if we use this impl, it will not support. We need to be able to reuse
// the autograd API here, which is not yet implemented
// TODO(chenweihang): we should support call generated api in custom api impl
std
::
vector
<
Tensor
>
add_n_grad_impl
(
const
std
::
vector
<
Tensor
>&
x
,
const
Tensor
&
out_grad
)
{
auto
kernel_key_set
=
ParseKernelKeyByInputArgs
(
out_grad
);
auto
kernel_key
=
kernel_key_set
.
GetHighestPriorityKernelKey
();
Backend
kernel_backend
=
kernel_key
.
backend
();
DataLayout
kernel_layout
=
kernel_key
.
layout
();
DataType
kernel_data_type
=
kernel_key
.
dtype
();
auto
kernel
=
phi
::
KernelFactory
::
Instance
().
SelectKernelOrThrowError
(
"scale"
,
{
kernel_backend
,
kernel_layout
,
kernel_data_type
});
VLOG
(
6
)
<<
"add_n_grad API kernel key: ["
<<
kernel_backend
<<
", "
<<
kernel_layout
<<
", "
<<
kernel_data_type
<<
"]"
;
VLOG
(
6
)
<<
"add_n_grad API kernel: "
<<
kernel
;
auto
*
dev_ctx
=
GetDeviceContextByBackend
(
kernel_backend
);
auto
dense_out_grad
=
PrepareData
(
out_grad
,
kernel
.
InputAt
(
0
),
{});
size_t
out_number
=
x
.
size
();
std
::
vector
<
Tensor
>
x_grad
;
auto
dense_x_grad
=
SetKernelOutput
(
out_number
,
kernel_backend
,
&
x_grad
);
using
kernel_signature
=
void
(
*
)(
const
platform
::
DeviceContext
&
,
const
phi
::
DenseTensor
&
,
const
phi
::
Scalar
&
,
float
,
bool
,
phi
::
DenseTensor
*
);
auto
*
kernel_fn
=
kernel
.
GetVariadicKernelFn
<
kernel_signature
>
();
for
(
auto
*
dense_x_grad_t
:
dense_x_grad
)
{
phi
::
MetaTensor
meta_out
(
dense_x_grad_t
);
phi
::
UnchangedInferMeta
(
MakeMetaTensor
(
*
dense_out_grad
),
&
meta_out
);
(
*
kernel_fn
)(
*
dev_ctx
,
*
dense_out_grad
,
phi
::
Scalar
(
1.0
),
0.0
,
true
,
dense_x_grad_t
);
}
return
x_grad
;
}
Tensor
copy_to_impl
(
const
Tensor
&
x
,
Place
place
,
bool
blocking
)
{
auto
kernel_key_set
=
ParseKernelKeyByInputArgs
(
x
);
kernel_key_set
.
backend_set
=
...
...
paddle/phi/api/lib/api_custom_impl.h
浏览文件 @
84b63a26
...
...
@@ -22,6 +22,9 @@ limitations under the License. */
namespace
paddle
{
namespace
experimental
{
std
::
vector
<
Tensor
>
add_n_grad_impl
(
const
std
::
vector
<
Tensor
>&
x
,
const
Tensor
&
out_grad
);
Tensor
copy_to_impl
(
const
Tensor
&
x
,
Place
place
,
bool
blocking
);
std
::
vector
<
Tensor
>
split_impl
(
const
Tensor
&
x
,
...
...
paddle/phi/infermeta/multiary.cc
浏览文件 @
84b63a26
...
...
@@ -279,6 +279,78 @@ void AdamwInferMeta(const MetaTensor& param,
master_param_outs
);
}
void
AddNInferMeta
(
const
std
::
vector
<
MetaTensor
*>&
x
,
MetaTensor
*
out
,
MetaConfig
config
)
{
auto
N
=
x
.
size
();
PADDLE_ENFORCE_GT
(
N
,
0
,
phi
::
errors
::
InvalidArgument
(
"The input tensor X's dimensions of SumOp "
"should be larger than 0. But received X's dimensions %d."
,
N
));
if
(
N
==
1
)
{
VLOG
(
3
)
<<
"Warning: SumOp have only one input, may waste memory"
;
}
phi
::
DDim
in_dim
({
0
});
for
(
size_t
i
=
0
;
i
<
x
.
size
();
++
i
)
{
auto
x_dim
=
x
[
i
]
->
dims
();
if
(
phi
::
product
(
x_dim
)
==
0
)
{
continue
;
}
if
(
phi
::
product
(
in_dim
)
==
0
)
{
in_dim
=
x_dim
;
}
else
{
if
(
config
.
is_runtime
)
{
PADDLE_ENFORCE_EQ
(
in_dim
,
x_dim
,
phi
::
errors
::
InvalidArgument
(
"The input tensor X of SumOp must"
" have same shape. But received X[0]'s shape = "
"[%s], X[%d]'s shape = [%s]."
,
in_dim
,
i
,
x_dim
));
}
else
{
PADDLE_ENFORCE_EQ
(
in_dim
.
size
(),
x_dim
.
size
(),
phi
::
errors
::
InvalidArgument
(
"The input tensor X of SumOp must have same "
"dimensions. But received X[0]'s dimensions = %d, X[0]'s "
"shape = "
"[%s], X[%d]'s dimensions = %d, X[%d]'s shape = [%s]."
,
in_dim
.
size
(),
in_dim
,
i
,
x_dim
.
size
(),
i
,
x_dim
));
// if in_dim or x_dim has -1, not check equal
for
(
int
j
=
0
;
j
<
x_dim
.
size
();
++
j
)
{
if
(
x_dim
[
j
]
==
-
1
||
in_dim
[
j
]
==
-
1
)
{
continue
;
}
PADDLE_ENFORCE_EQ
(
in_dim
[
j
],
x_dim
[
j
],
phi
::
errors
::
InvalidArgument
(
"The input tensor X of SumOp must have same shape "
"if not -1."
"But received X[0]'s shape = [%s], X[%d]'s shape = [%s]."
,
in_dim
,
i
,
x_dim
));
}
}
}
}
out
->
set_dims
(
in_dim
);
out
->
share_lod
(
*
x
[
0
]);
}
void
AucInferMeta
(
const
MetaTensor
&
input
,
const
MetaTensor
&
label
,
const
MetaTensor
&
stat_pos
,
...
...
paddle/phi/infermeta/multiary.h
浏览文件 @
84b63a26
...
...
@@ -117,6 +117,10 @@ void AdamwInferMeta(const MetaTensor& param,
MetaTensor
*
beta2_pow_out
,
MetaTensor
*
master_param_outs
);
void
AddNInferMeta
(
const
std
::
vector
<
MetaTensor
*>&
x
,
MetaTensor
*
out
,
MetaConfig
config
=
MetaConfig
());
void
AucInferMeta
(
const
MetaTensor
&
input
,
const
MetaTensor
&
label
,
const
MetaTensor
&
stat_pos
,
...
...
python/paddle/fluid/tests/unittests/test_sum_op.py
浏览文件 @
84b63a26
...
...
@@ -25,6 +25,7 @@ from paddle.fluid.op import Operator
from
paddle.fluid.tests.unittests.op_test
import
(
OpTest
,
convert_float_to_uint16
,
convert_uint16_to_float
)
from
paddle
import
_C_ops
from
paddle.fluid.framework
import
_test_eager_guard
class
TestSumOp
(
OpTest
):
...
...
@@ -347,6 +348,27 @@ class API_Test_Add_n(unittest.TestCase):
self
.
assertEqual
((
sum_value
.
numpy
()
==
expected_result
).
all
(),
True
)
def
test_dygraph_final_state_api
(
self
):
with
fluid
.
dygraph
.
guard
():
with
_test_eager_guard
():
input0
=
paddle
.
ones
(
shape
=
[
2
,
3
],
dtype
=
'float32'
)
input1
=
paddle
.
ones
(
shape
=
[
2
,
3
],
dtype
=
'float32'
)
input0
.
stop_gradient
=
False
input1
.
stop_gradient
=
False
expected_result
=
np
.
empty
((
2
,
3
))
expected_result
.
fill
(
2
)
sum_value
=
paddle
.
add_n
([
input0
,
input1
])
self
.
assertEqual
((
sum_value
.
numpy
()
==
expected_result
).
all
(),
True
)
expected_grad_result
=
np
.
empty
((
2
,
3
))
expected_grad_result
.
fill
(
1
)
sum_value
.
backward
()
self
.
assertEqual
(
(
input0
.
grad
.
numpy
()
==
expected_grad_result
).
all
(),
True
)
self
.
assertEqual
(
(
input1
.
grad
.
numpy
()
==
expected_grad_result
).
all
(),
True
)
class
TestRaiseSumError
(
unittest
.
TestCase
):
def
test_errors
(
self
):
...
...
python/paddle/tensor/math.py
浏览文件 @
84b63a26
...
...
@@ -1068,7 +1068,11 @@ def add_n(inputs, name=None):
# [[8., 10., 12.],
# [14., 16., 18.]]
"""
if
paddle
.
in_dynamic_mode
():
if
in_dygraph_mode
():
if
isinstance
(
inputs
,
Variable
):
inputs
=
[
inputs
]
return
_C_ops
.
final_state_add_n
(
inputs
)
if
_in_legacy_dygraph
():
if
isinstance
(
inputs
,
Variable
):
inputs
=
[
inputs
]
return
_C_ops
.
sum
(
inputs
,
'use_mkldnn'
,
False
)
...
...
python/paddle/utils/code_gen/api.yaml
浏览文件 @
84b63a26
...
...
@@ -63,6 +63,15 @@
backward
:
add_grad
# no_need_buffer : x, y
-
api
:
add_n
args
:
(Tensor[] x)
output
:
Tensor
infer_meta
:
func
:
AddNInferMeta
kernel
:
func
:
add_n
backward
:
add_n_grad
-
api
:
addmm
args
:
(Tensor input, Tensor x, Tensor y, float alpha, float beta)
output
:
Tensor
...
...
python/paddle/utils/code_gen/backward.yaml
浏览文件 @
84b63a26
...
...
@@ -41,6 +41,13 @@
func
:
add_grad
no_need_buffer
:
x, y
-
backward_api
:
add_n_grad
forward
:
add_n (Tensor[] x) -> Tensor(out)
args
:
(Tensor[] x, Tensor out_grad)
output
:
Tensor[](x_grad)
invoke
:
add_n_grad_impl(x, out_grad)
no_need_buffer
:
x
-
backward_api
:
addmm_grad
forward
:
scatter (Tensor input, Tensor x, Tensor y, float alpha, float beta) -> Tensor(out)
args
:
(Tensor input, Tensor x, Tensor y, Tensor out_grad, float alpha, float beta)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录