Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Crayon鑫
Paddle
提交
3723caba
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看板
提交
3723caba
编写于
1月 25, 2022
作者:
J
jim19930609
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Added EagerUtils helper functions for final state CodeGen
上级
1d755225
变更
5
显示空白变更内容
内联
并排
Showing
5 changed file
with
89 addition
and
11 deletion
+89
-11
paddle/fluid/eager/auto_code_generator/CMakeLists.txt
paddle/fluid/eager/auto_code_generator/CMakeLists.txt
+1
-1
paddle/fluid/eager/auto_code_generator/final_state_generator/CMakeLists.txt
.../auto_code_generator/final_state_generator/CMakeLists.txt
+2
-1
paddle/fluid/eager/auto_code_generator/final_state_generator/eager_gen.py
...er/auto_code_generator/final_state_generator/eager_gen.py
+37
-9
paddle/fluid/eager/utils.cc
paddle/fluid/eager/utils.cc
+39
-0
paddle/fluid/eager/utils.h
paddle/fluid/eager/utils.h
+10
-0
未找到文件。
paddle/fluid/eager/auto_code_generator/CMakeLists.txt
浏览文件 @
3723caba
#
add_subdirectory(final_state_generator)
add_subdirectory
(
final_state_generator
)
set
(
EAGER_GENERETOR_DEPS
${
GLOB_OP_LIB
}
${
GLOB_OPERATOR_DEPS
}
pybind proto_desc executor layer tracer engine imperative_profiler imperative_flag
)
...
...
paddle/fluid/eager/auto_code_generator/final_state_generator/CMakeLists.txt
浏览文件 @
3723caba
...
...
@@ -9,7 +9,7 @@ set(forwards_h_path "${PADDLE_SOURCE_DIR}/paddle/fluid/eager/api/generated/eager
set
(
nodes_cc_path
"
${
PADDLE_SOURCE_DIR
}
/paddle/fluid/eager/api/generated/eager_generated/backwards/node.cc"
)
set
(
nodes_h_path
"
${
PADDLE_SOURCE_DIR
}
/paddle/fluid/eager/api/generated/eager_generated/backwards/node.h"
)
execute_process
(
add_custom_target
(
eager_final_state_codegen
COMMAND
"
${
PYTHON_EXECUTABLE
}
"
"
${
PADDLE_SOURCE_DIR
}
/paddle/fluid/eager/auto_code_generator/final_state_generator/eager_gen.py"
"--api_yaml_path=
${
api_yaml_path
}
"
"--backward_yaml_path=
${
backward_yaml_path
}
"
...
...
@@ -21,4 +21,5 @@ execute_process(
COMMAND
${
CMAKE_COMMAND
}
-E copy_if_different
${
tmp_forwards_h_path
}
${
forwards_h_path
}
COMMAND
${
CMAKE_COMMAND
}
-E copy_if_different
${
tmp_nodes_cc_path
}
${
nodes_cc_path
}
COMMAND
${
CMAKE_COMMAND
}
-E copy_if_different
${
tmp_nodes_h_path
}
${
nodes_h_path
}
VERBATIM
)
paddle/fluid/eager/auto_code_generator/final_state_generator/eager_gen.py
浏览文件 @
3723caba
...
...
@@ -15,6 +15,7 @@
import
yaml
import
re
import
argparse
import
os
def
ParseArguments
():
...
...
@@ -93,8 +94,8 @@ def ReadBwdFile(filepath):
contents
=
yaml
.
load
(
f
)
ret
=
{}
for
content
in
contents
:
assert
'
gra
d_api'
in
content
.
keys
()
api_name
=
content
[
'
gra
d_api'
]
assert
'
backwar
d_api'
in
content
.
keys
()
api_name
=
content
[
'
backwar
d_api'
]
ret
[
api_name
]
=
content
return
ret
...
...
@@ -435,10 +436,10 @@ def GenerateNodeDeclaration(fwd_api_name, backward_fwd_input_map,
aname
,
GetConstReference
(
atype
),
aname
,
saved_attr_name
,
aname
)
ATTRIBUTE_MEMBER_TEMPLATE
=
"""
{} {};
{} {}
= {}
;
"""
attribute_members_str
+=
ATTRIBUTE_MEMBER_TEMPLATE
.
format
(
GetConstReference
(
atype
),
saved_attr_name
)
GetConstReference
(
atype
),
saved_attr_name
,
default_val
)
# End: SetAttributes & Attribute Members
NODE_DECLARATION_TEMPLATE
=
"""
...
...
@@ -491,15 +492,15 @@ def GenerateNodeDefinition(fwd_api_name, bwd_api_name, backward_fwd_input_map,
tensor_wrapper_name
=
GetSavedName
(
name
)
if
is_fwd_input
:
grad_api_args
[
grad_api_position
]
=
f
"egr::EagerUtils::
RecoverTensorWrapper(&this->
{
tensor_wrapper_name
}
, true
)"
grad_api_position
]
=
f
"egr::EagerUtils::
SyncToPtenTensors( egr::EagerUtils::RecoverTensorWrapper(&this->
{
tensor_wrapper_name
}
, true)
)"
else
:
grad_api_args
[
grad_api_position
]
=
f
"egr::EagerUtils::
RecoverTensorWrapper(&this->
{
tensor_wrapper_name
}
, false
)"
grad_api_position
]
=
f
"egr::EagerUtils::
SyncToPtenTensors( egr::EagerUtils::RecoverTensorWrapper(&this->
{
tensor_wrapper_name
}
, false)
)"
for
_
,
(
_
,
fwd_position
,
grad_api_position
)
in
backward_grad_input_map
.
items
():
grad_api_args
[
grad_api_position
]
=
f
"
*grads[
{
fwd_position
}
].Tensor().get(
)"
grad_api_position
]
=
f
"
egr::EagerUtils::SyncToPtenTensors( *grads[
{
fwd_position
}
]
)"
for
name
,
_
,
_
,
grad_api_position
in
backward_attrs_list
:
saved_attribute_name
=
GetSavedName
(
name
)
...
...
@@ -615,7 +616,7 @@ def GenerateNodeCreationCodes(fwd_api_name, bwd_api_name,
# SetAttributes
set_attributes_list
=
[]
for
name
,
_
,
_
,
_
in
backward_attrs_list
:
set_attributes
=
" grad_node->SetAttribute{name}({name});"
set_attributes
=
f
" grad_node->SetAttribute
{
name
}
(
{
name
}
);"
set_attributes_list
.
append
(
set_attributes
)
set_attributes_str
=
"
\n
"
.
join
(
set_attributes_list
)
...
...
@@ -727,7 +728,7 @@ def GenerateForwardDefinition(fwd_api_name, bwd_api_name,
inputs_args_list
=
[
""
for
i
in
range
(
num_inputs
)]
inputs_call_list
=
[
""
for
i
in
range
(
num_inputs
)]
for
name
,
(
ttype
,
pos
)
in
forward_inputs_position_map
.
items
():
inputs_call_list
[
pos
]
=
f
"
*
{
name
}
.Tensor().get(
)"
inputs_call_list
[
pos
]
=
f
"
egr::EagerUtils::SyncToPtenTensors(
{
name
}
)"
if
IsPlainTensorType
(
ttype
):
inputs_args_list
[
pos
]
=
f
"const egr::EagerTensor&
{
name
}
"
else
:
...
...
@@ -905,10 +906,17 @@ if __name__ == "__main__":
# Collect Forward Inputs/Outputs
forward_inputs_list
,
forward_attrs_list
,
forward_returns_list
=
ParseYamlForwardFromBackward
(
bwd_forward_str
)
print
(
"Parsed Forward Inputs List: "
,
forward_inputs_list
)
print
(
"Prased Forward Attrs List: "
,
forward_attrs_list
)
print
(
"Parsed Forward Returns List: "
,
forward_returns_list
)
# Collect Original Forward Inputs/Outputs and then perform validation checks
orig_forward_inputs_list
,
orig_forward_attrs_list
,
orig_forward_returns_list
=
ParseYamlForward
(
fwd_args_str
,
fwd_returns_str
)
print
(
"Parsed Original Forward Inputs List: "
,
orig_forward_inputs_list
)
print
(
"Prased Original Forward Attrs List: "
,
orig_forward_attrs_list
)
print
(
"Parsed Original Forward Returns List: "
,
orig_forward_returns_list
)
# Forward Validation Checks
ForwardsValidationCheck
(
forward_inputs_list
,
forward_attrs_list
,
...
...
@@ -919,15 +927,25 @@ if __name__ == "__main__":
# Parse Backward Inputs/Outputs
backward_inputs_list
,
backward_attrs_list
,
backward_returns_list
=
ParseYamlBackward
(
bwd_args_str
,
bwd_returns_str
)
print
(
"Parsed Backward Inputs List: "
,
backward_inputs_list
)
print
(
"Prased Backward Attrs List: "
,
backward_attrs_list
)
print
(
"Parsed Backward Returns List: "
,
backward_returns_list
)
# Determine Forward Inputs/Outputs Position
forward_inputs_position_map
,
forward_outputs_position_map
=
DetermineForwardPositionMap
(
forward_inputs_list
,
forward_returns_list
)
print
(
"Generated Forward Input Position Map: "
,
forward_inputs_position_map
)
print
(
"Generated Forward Output Position Map: "
,
forward_outputs_position_map
)
# SlotName Matching
backward_fwd_input_map
,
backward_grad_input_map
,
backward_grad_output_map
=
SlotNameMatching
(
backward_inputs_list
,
backward_returns_list
,
forward_inputs_position_map
,
forward_outputs_position_map
)
print
(
"Generated Backward Fwd Input Map: "
,
backward_fwd_input_map
)
print
(
"Generated Backward Grad Input Map: "
,
backward_grad_input_map
)
print
(
"Generated Backward Grad Output Map: "
,
backward_grad_output_map
)
# Backward Validation Check
BackwardValidationCheck
(
backward_fwd_input_map
,
backward_grad_input_map
,
...
...
@@ -936,11 +954,13 @@ if __name__ == "__main__":
# Node Declaration Generation
node_declaration_str
+=
GenerateNodeDeclaration
(
fwd_api_name
,
backward_fwd_input_map
,
backward_attrs_list
)
print
(
"Generated Node Declaration: "
,
node_declaration_str
)
node_definition_str
+=
GenerateNodeDefinition
(
fwd_api_name
,
bwd_api_name
,
backward_fwd_input_map
,
backward_grad_input_map
,
backward_grad_output_map
,
backward_attrs_list
)
print
(
"Generated Node Definition: "
,
node_definition_str
)
# Node Definition Generation
definition_declaration_pair
=
GenerateForwardDefinition
(
...
...
@@ -948,6 +968,8 @@ if __name__ == "__main__":
forward_outputs_position_map
,
forward_attrs_list
,
backward_fwd_input_map
,
backward_grad_input_map
,
backward_grad_output_map
,
backward_attrs_list
)
print
(
"Generated Forward Definition: "
,
forward_definition_str
)
print
(
"Generated Forward Declaration: "
,
forward_declaration_str
)
forward_definition_str
+=
definition_declaration_pair
[
0
]
forward_declaration_str
+=
definition_declaration_pair
[
1
]
...
...
@@ -957,6 +979,12 @@ if __name__ == "__main__":
forwards_h_path
=
args
.
forwards_h_path
forwards_cc_path
=
args
.
forwards_cc_path
for
path
in
[
nodes_cc_path
,
nodes_h_path
,
forwards_h_path
,
forwards_cc_path
]:
if
os
.
path
.
exists
(
path
):
os
.
remove
(
path
)
GenerateNodeCCFile
(
nodes_cc_path
,
node_definition_str
)
GenerateNodeHFile
(
nodes_h_path
,
node_declaration_str
)
GenerateForwardCCFile
(
forwards_cc_path
,
forward_definition_str
)
...
...
paddle/fluid/eager/utils.cc
浏览文件 @
3723caba
...
...
@@ -286,4 +286,43 @@ void EagerUtils::CheckAndRetainGrad(
}
}
paddle
::
experimental
::
Tensor
EagerUtils
::
SyncToPtenTensors
(
const
egr
::
EagerTensor
&
tensor
)
{
const_cast
<
EagerTensor
*>
(
&
tensor
)
->
SyncToTensor
();
return
*
tensor
.
Tensor
().
get
();
}
std
::
vector
<
paddle
::
experimental
::
Tensor
>
EagerUtils
::
SyncToPtenTensors
(
const
std
::
vector
<
egr
::
EagerTensor
>&
tensors
)
{
std
::
vector
<
paddle
::
experimental
::
Tensor
>
res
;
size_t
num
=
tensors
.
size
();
res
.
reserve
(
num
);
for
(
size_t
i
=
0
;
i
<
num
;
i
++
)
{
const_cast
<
EagerTensor
*>
(
&
(
tensors
[
i
]))
->
SyncToTensor
();
res
.
push_back
(
*
tensors
[
i
].
Tensor
().
get
());
}
return
res
;
}
egr
::
EagerTensor
EagerUtils
::
CreateEagerTensorFromTensor
(
const
paddle
::
experimental
::
Tensor
&
tensor
)
{
egr
::
EagerTensor
ret
;
ret
.
set_tensor
(
std
::
make_shared
<
paddle
::
experimental
::
Tensor
>
(
tensor
));
return
ret
;
}
std
::
vector
<
egr
::
EagerTensor
>
EagerUtils
::
CreateEagerTensorFromTensor
(
const
std
::
vector
<
paddle
::
experimental
::
Tensor
>&
tensors
)
{
std
::
vector
<
egr
::
EagerTensor
>
res
;
size_t
num
=
tensors
.
size
();
res
.
reserve
(
num
);
for
(
size_t
i
=
0
;
i
<
num
;
i
++
)
{
egr
::
EagerTensor
tmp
;
tmp
.
set_tensor
(
std
::
make_shared
<
paddle
::
experimental
::
Tensor
>
(
tensors
[
i
]));
res
.
emplace_back
(
std
::
move
(
tmp
));
}
return
res
;
}
}
// namespace egr
paddle/fluid/eager/utils.h
浏览文件 @
3723caba
...
...
@@ -170,6 +170,16 @@ class EagerUtils {
static
void
CheckAndRetainGrad
(
const
egr
::
EagerTensor
&
tensor
);
static
void
CheckAndRetainGrad
(
const
std
::
vector
<
egr
::
EagerTensor
>&
tensors
);
static
paddle
::
experimental
::
Tensor
SyncToPtenTensors
(
const
egr
::
EagerTensor
&
tensor
);
static
std
::
vector
<
paddle
::
experimental
::
Tensor
>
SyncToPtenTensors
(
const
std
::
vector
<
egr
::
EagerTensor
>&
tensors
);
static
egr
::
EagerTensor
CreateEagerTensorFromTensor
(
const
paddle
::
experimental
::
Tensor
&
tensor
);
static
std
::
vector
<
egr
::
EagerTensor
>
CreateEagerTensorFromTensor
(
const
std
::
vector
<
paddle
::
experimental
::
Tensor
>&
tensors
);
};
}
// namespace egr
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录