Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
521cded2
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看板
未验证
提交
521cded2
编写于
3月 23, 2022
作者:
L
Leo Chen
提交者:
GitHub
3月 23, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[new-exec] gc skip var that is not tensor, selectedrows, tensorarray (#40859)
上级
c751e405
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
20 addition
and
4 deletion
+20
-4
paddle/fluid/framework/new_executor/interpretercore.cc
paddle/fluid/framework/new_executor/interpretercore.cc
+20
-4
未找到文件。
paddle/fluid/framework/new_executor/interpretercore.cc
浏览文件 @
521cded2
...
@@ -234,10 +234,26 @@ void InterpreterCore::Convert(
...
@@ -234,10 +234,26 @@ void InterpreterCore::Convert(
gc_check_input_list
.
erase
(
last
,
gc_check_input_list
.
end
());
gc_check_input_list
.
erase
(
last
,
gc_check_input_list
.
end
());
for
(
auto
var_id
:
gc_check_input_list
)
{
for
(
auto
var_id
:
gc_check_input_list
)
{
vec_meta_info
[
var_id
].
var_ref_count_
++
;
paddle
::
framework
::
Variable
*
var
=
global_scope_
->
Var
(
var_id
);
instr
.
AddGCCheckVar
(
var_id
);
if
(
var
->
IsType
<
LoDTensor
>
()
||
var
->
IsType
<
phi
::
SelectedRows
>
()
||
VLOG
(
4
)
<<
"clear "
<<
global_scope_
->
GetNameById
(
var_id
)
<<
" after "
var
->
IsType
<
LoDTensorArray
>
())
{
<<
instr
.
OpBase
()
->
Type
();
vec_meta_info
[
var_id
].
var_ref_count_
++
;
// TODO(zhiqiu): not all var needs to be checked, var need to be checked
// only
// after the last_live_op. For example,
// b = op1(a)
// c = op2(a, b)
// in this case, a is the input of op1 and op2, we only need to check
// a after op2, because op2 always uses a after op1.
instr
.
AddGCCheckVar
(
var_id
);
VLOG
(
4
)
<<
"clear "
<<
global_scope_
->
GetNameById
(
var_id
)
<<
" after "
<<
instr
.
OpBase
()
->
Type
();
}
else
{
VLOG
(
4
)
<<
"not clear "
<<
global_scope_
->
GetNameById
(
var_id
)
<<
" after "
<<
instr
.
OpBase
()
->
Type
()
<<
" because its type is "
<<
framework
::
ToTypeName
(
var
->
Type
());
}
}
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录