Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
5c5a3660
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看板
未验证
提交
5c5a3660
编写于
3月 28, 2022
作者:
L
Leo Chen
提交者:
GitHub
3月 28, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[new-exec] update the dependency of op that has inplace_back_map (#41009)
上级
77a455c7
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
21 addition
and
9 deletion
+21
-9
paddle/fluid/framework/new_executor/data_transfer.cc
paddle/fluid/framework/new_executor/data_transfer.cc
+0
-5
paddle/fluid/framework/new_executor/interpretercore_util.cc
paddle/fluid/framework/new_executor/interpretercore_util.cc
+17
-0
paddle/phi/kernels/cpu/adam_kernel.cc
paddle/phi/kernels/cpu/adam_kernel.cc
+2
-2
paddle/phi/kernels/gpu/adam_kernel.cu
paddle/phi/kernels/gpu/adam_kernel.cu
+2
-2
未找到文件。
paddle/fluid/framework/new_executor/data_transfer.cc
浏览文件 @
5c5a3660
...
@@ -305,11 +305,6 @@ void ApplyDataTransform(const OpKernelType& expected_kernel_key,
...
@@ -305,11 +305,6 @@ void ApplyDataTransform(const OpKernelType& expected_kernel_key,
var_scope
->
GetIdByName
(
var_name
);
var_scope
->
GetIdByName
(
var_name
);
op_func_node
->
output_index
[
pair
.
first
][
j
]
=
op_func_node
->
output_index
[
pair
.
first
][
j
]
=
var_scope
->
VarId
(
new_var_name
);
var_scope
->
VarId
(
new_var_name
);
// NOTE(zhiqiu): The inplace op with `transfer` also changes
// original output after that
// so add original output as well
op_func_node
->
output_index
[
pair
.
first
].
push_back
(
var_scope
->
VarId
(
var_name
));
}
}
}
}
}
}
...
...
paddle/fluid/framework/new_executor/interpretercore_util.cc
浏览文件 @
5c5a3660
...
@@ -667,6 +667,23 @@ std::map<int, std::list<int>> build_op_downstream_map(
...
@@ -667,6 +667,23 @@ std::map<int, std::list<int>> build_op_downstream_map(
}
}
}
}
}
}
// NOTE(zhiqiu): The inplace op with `transfer` also changes
// original output after that so add original output as well
// original: a->op->a
// after: a->data_transfer->a'->op->a'->transfer_back->a
// which means op writes a and a'
if
(
!
vec_instruction
[
op_idx
].
InplaceBackMap
().
empty
())
{
auto
&
m
=
vec_instruction
[
op_idx
].
InplaceBackMap
();
for
(
auto
&
p
:
m
)
{
auto
var
=
p
.
second
;
var2recent_write_op
[
var
]
=
op_idx
;
// var in input list and in output list, so remove it.
if
(
remove_duplicate
.
count
(
var
)
==
0
)
{
update_var_min_rw_op
(
op2dependences
,
&
var2min_rw_op
,
op_idx
,
var
);
}
}
}
}
}
return
std
::
move
(
get_downstream_map
(
op2dependences
));
return
std
::
move
(
get_downstream_map
(
op2dependences
));
}
}
...
...
paddle/phi/kernels/cpu/adam_kernel.cc
浏览文件 @
5c5a3660
...
@@ -71,8 +71,8 @@ void AdamDenseKernel(const Context& dev_ctx,
...
@@ -71,8 +71,8 @@ void AdamDenseKernel(const Context& dev_ctx,
phi
::
Copy
(
dev_ctx
,
param
,
dev_ctx
.
GetPlace
(),
false
,
param_out
);
phi
::
Copy
(
dev_ctx
,
param
,
dev_ctx
.
GetPlace
(),
false
,
param_out
);
phi
::
Copy
(
dev_ctx
,
moment1
,
dev_ctx
.
GetPlace
(),
false
,
moment1_out
);
phi
::
Copy
(
dev_ctx
,
moment1
,
dev_ctx
.
GetPlace
(),
false
,
moment1_out
);
phi
::
Copy
(
dev_ctx
,
moment2
,
dev_ctx
.
GetPlace
(),
false
,
moment2_out
);
phi
::
Copy
(
dev_ctx
,
moment2
,
dev_ctx
.
GetPlace
(),
false
,
moment2_out
);
phi
::
Copy
(
dev_ctx
,
beta1_pow
,
dev_ctx
.
GetP
lace
(),
false
,
beta1_pow_out
);
phi
::
Copy
(
dev_ctx
,
beta1_pow
,
beta1_pow
.
p
lace
(),
false
,
beta1_pow_out
);
phi
::
Copy
(
dev_ctx
,
beta2_pow
,
dev_ctx
.
GetP
lace
(),
false
,
beta2_pow_out
);
phi
::
Copy
(
dev_ctx
,
beta2_pow
,
beta2_pow
.
p
lace
(),
false
,
beta2_pow_out
);
return
;
return
;
}
}
...
...
paddle/phi/kernels/gpu/adam_kernel.cu
浏览文件 @
5c5a3660
...
@@ -172,8 +172,8 @@ void AdamDenseKernel(const Context& dev_ctx,
...
@@ -172,8 +172,8 @@ void AdamDenseKernel(const Context& dev_ctx,
phi
::
Copy
(
dev_ctx
,
param
,
dev_ctx
.
GetPlace
(),
false
,
param_out
);
phi
::
Copy
(
dev_ctx
,
param
,
dev_ctx
.
GetPlace
(),
false
,
param_out
);
phi
::
Copy
(
dev_ctx
,
moment1
,
dev_ctx
.
GetPlace
(),
false
,
moment1_out
);
phi
::
Copy
(
dev_ctx
,
moment1
,
dev_ctx
.
GetPlace
(),
false
,
moment1_out
);
phi
::
Copy
(
dev_ctx
,
moment2
,
dev_ctx
.
GetPlace
(),
false
,
moment2_out
);
phi
::
Copy
(
dev_ctx
,
moment2
,
dev_ctx
.
GetPlace
(),
false
,
moment2_out
);
phi
::
Copy
(
dev_ctx
,
beta1_pow
,
dev_ctx
.
GetP
lace
(),
false
,
beta1_pow_out
);
phi
::
Copy
(
dev_ctx
,
beta1_pow
,
beta1_pow
.
p
lace
(),
false
,
beta1_pow_out
);
phi
::
Copy
(
dev_ctx
,
beta2_pow
,
dev_ctx
.
GetP
lace
(),
false
,
beta2_pow_out
);
phi
::
Copy
(
dev_ctx
,
beta2_pow
,
beta2_pow
.
p
lace
(),
false
,
beta2_pow_out
);
return
;
return
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录