Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
50cf103e
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看板
提交
50cf103e
编写于
2月 23, 2018
作者:
Q
qijun
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
make memory optimization module compatible with parallel_do
上级
bf9ed4a9
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
74 addition
and
57 deletion
+74
-57
python/paddle/v2/fluid/memory_optimization_transpiler.py
python/paddle/v2/fluid/memory_optimization_transpiler.py
+61
-51
python/paddle/v2/fluid/tests/book_memory_optimization/test_memopt_fit_a_line.py
.../tests/book_memory_optimization/test_memopt_fit_a_line.py
+13
-6
未找到文件。
python/paddle/v2/fluid/memory_optimization_transpiler.py
浏览文件 @
50cf103e
...
...
@@ -29,6 +29,8 @@ dtype_to_size = {
core
.
VarDesc
.
VarType
.
BOOL
:
1
}
sub_block_ops
=
[
"while"
,
"while_grad"
,
"parallel_do"
,
"parallel_do_grad"
]
class
ControlFlowGraph
(
object
):
def
__init__
(
self
,
Program
,
ops
,
forward_num
,
skip_opt
):
...
...
@@ -141,7 +143,7 @@ class ControlFlowGraph(object):
self
.
pool
=
[]
for
i
in
range
(
self
.
op_size
):
op
=
self
.
_ops
[
i
]
if
op
.
type
()
==
"while"
or
op
.
type
()
==
"while_grad"
:
if
op
.
type
()
in
sub_block_ops
:
continue
block_desc
=
op
.
block
()
is_forward
=
i
<
self
.
_forward_num
...
...
@@ -198,67 +200,75 @@ class ControlFlowGraph(object):
block_desc
,
var_name
,
is_forward
).
shape
()))
def
get_cfgs
(
input_program
):
def
_process_sub_block_pair
(
pdesc
,
sub_block_pair
):
ops_list
=
[]
pdesc
=
input_program
.
get_desc
()
block_desc
=
pdesc
.
block
(
0
)
op_size
=
block_desc
.
op_size
()
# Get global block ops
ops_list
.
append
(
([
block_desc
.
op
(
i
)
for
i
in
range
(
op_size
)],
op_size
,
set
()))
while_sub_block_ids
=
[]
while_grad_sub_block_ids
=
[]
while_block_id_pair
=
[]
while_op_dict
=
{}
for
fwd_op
,
bwd_op
in
sub_block_pair
:
sub_block_ids
=
[]
grad_sub_block_ids
=
[]
sub_block_id_pair
=
[]
sub_op_dict
=
{}
for
i
in
range
(
op_size
):
op
=
block_desc
.
op
(
i
)
if
op
.
type
()
==
fwd_op
:
sub_block_ids
.
append
(
op
.
attr
(
"sub_block"
).
id
)
sub_op_dict
[
op
.
attr
(
"sub_block"
).
id
]
=
op
elif
op
.
type
()
==
bwd_op
:
grad_sub_block_ids
.
append
(
op
.
attr
(
"sub_block"
).
id
)
sub_op_dict
[
op
.
attr
(
"sub_block"
).
id
]
=
op
for
i
in
range
(
op_size
):
op
=
block_desc
.
op
(
i
)
if
op
.
type
()
==
"while"
:
while_sub_block_ids
.
append
(
op
.
attr
(
"sub_block"
).
id
)
while_op_dict
[
op
.
attr
(
"sub_block"
).
id
]
=
op
elif
op
.
type
()
==
"while_grad"
:
while_grad_sub_block_ids
.
append
(
op
.
attr
(
"sub_block"
).
id
)
while_op_dict
[
op
.
attr
(
"sub_block"
).
id
]
=
op
# Find fwd_op/bwd_op block pair
for
grad_id
in
grad_sub_block_ids
:
parent_id
=
pdesc
.
block
(
grad_id
).
parent
if
parent_id
in
sub_block_ids
:
sub_block_id_pair
.
append
((
parent_id
,
grad_id
))
sub_block_ids
.
remove
(
parent_id
)
# Find while/while_grad block pair
for
grad_id
in
while_grad_sub_block_ids
:
parent_id
=
pdesc
.
block
(
grad_id
).
parent
if
parent_id
in
while_sub_block_ids
:
while_block_id_pair
.
append
((
parent_id
,
grad_id
))
while_sub_block_ids
.
remove
(
parent_id
)
# Get fwd_op/bwd_op block ops
for
parent_id
,
grad_id
in
sub_block_id_pair
:
sub_block_ops
=
[]
sub_block
=
pdesc
.
block
(
parent_id
)
block_op_size
=
sub_block
.
op_size
()
for
i
in
range
(
block_op_size
):
sub_block_ops
.
append
(
sub_block
.
op
(
i
))
# Get while/while_grad block ops
for
parent_id
,
grad_id
in
while_block_id_pair
:
while_block_ops
=
[]
while_block
=
pdesc
.
block
(
parent_id
)
while_block_op_size
=
while_block
.
op_size
()
for
i
in
range
(
while_block_op_size
):
while_block_ops
.
append
(
while_block
.
op
(
i
))
grad_sub_block
=
pdesc
.
block
(
grad_id
)
grad_sub_block_op_size
=
grad_sub_block
.
op_size
()
for
i
in
range
(
grad_sub_block_op_size
):
sub_block_ops
.
append
(
grad_sub_block
.
op
(
i
))
while_grad_block
=
pdesc
.
block
(
grad_id
)
while_grad_block_op_size
=
while_grad_block
.
op_size
(
)
for
i
in
range
(
while_grad_block_op_size
):
while_block_ops
.
append
(
while_grad_block
.
op
(
i
))
sub_op_output
=
set
(
)
sub_op_output
.
update
(
sub_op_dict
[
parent_id
].
output_arg_names
()
)
sub_op_output
.
update
(
sub_op_dict
[
grad_id
].
output_arg_names
())
ops_list
.
append
((
sub_block_ops
,
block_op_size
,
sub_op_output
))
while_op_output
=
set
()
while_op_output
.
update
(
while_op_dict
[
parent_id
].
output_arg_names
())
while_op_output
.
update
(
while_op_dict
[
grad_id
].
output_arg_names
())
# Process rest fwd_op block ops
for
parent_id
in
sub_block_ids
:
sub_block_ops
=
[]
sub_block
=
pdesc
.
block
(
parent_id
)
sub_block_op_size
=
sub_block
.
op_size
()
for
i
in
range
(
sub_block_op_size
):
sub_block_ops
.
append
(
sub_block
.
op
(
i
))
sub_op_output
=
set
()
sub_op_output
.
update
(
sub_op_dict
[
parent_id
].
output_arg_names
())
ops_list
.
append
((
sub_block_ops
,
sub_block_op_size
,
sub_op_output
))
return
ops_list
ops_list
.
append
((
while_block_ops
,
while_block_op_size
,
while_op_output
))
# Process rest while block ops
for
parent_id
in
while_sub_block_ids
:
while_block_ops
=
[]
while_block
=
pdesc
.
block
(
parent_id
)
while_block_op_size
=
while_block
.
op_size
()
for
i
in
range
(
while_block_op_size
):
while_block_ops
.
append
(
while_block
.
op
(
i
))
def
_get_cfgs
(
input_program
):
ops_list
=
[]
pdesc
=
input_program
.
get_desc
()
block_desc
=
pdesc
.
block
(
0
)
op_size
=
block_desc
.
op_size
()
# Get global block ops
ops_list
.
append
(
([
block_desc
.
op
(
i
)
for
i
in
range
(
op_size
)],
op_size
,
set
()))
while_op_output
=
set
()
while_op_output
.
update
(
while_op_dict
[
parent_id
].
output_arg_names
())
sub_block_pair
=
[(
"while"
,
"while_grad"
),
(
"parallel_do"
,
"parallel_do_grad"
)]
ops_list
.
append
((
while_block_ops
,
while_block_op_size
,
while_op_output
))
ops_list
.
extend
(
_process_sub_block_pair
(
pdesc
,
sub_block_pair
))
cfgs
=
[
ControlFlowGraph
(
input_program
,
ops
,
forward_num
,
skip_opt
)
...
...
@@ -268,6 +278,6 @@ def get_cfgs(input_program):
def
memory_optimize
(
input_program
):
cfgs
=
get_cfgs
(
input_program
)
cfgs
=
_
get_cfgs
(
input_program
)
for
cfg
in
cfgs
:
cfg
.
memory_optimize
()
python/paddle/v2/fluid/tests/book_memory_optimization/test_memopt_fit_a_line.py
浏览文件 @
50cf103e
...
...
@@ -24,15 +24,21 @@ import sys
fluid
.
default_startup_program
().
random_seed
=
111
x
=
fluid
.
layers
.
data
(
name
=
'x'
,
shape
=
[
13
],
dtype
=
'float32'
)
y_predict
=
fluid
.
layers
.
fc
(
input
=
x
,
size
=
1
,
act
=
None
)
y
=
fluid
.
layers
.
data
(
name
=
'y'
,
shape
=
[
1
],
dtype
=
'float32'
)
cost
=
fluid
.
layers
.
square_error_cost
(
input
=
y_predict
,
label
=
y
)
avg_cost
=
fluid
.
layers
.
mean
(
x
=
cost
)
places
=
fluid
.
layers
.
get_places
(
device_count
=
2
,
device_type
=
'CPU'
)
pd
=
fluid
.
layers
.
ParallelDo
(
places
)
with
pd
.
do
():
x_
=
pd
.
read_input
(
x
)
y_
=
pd
.
read_input
(
y
)
y_predict
=
fluid
.
layers
.
fc
(
input
=
x_
,
size
=
1
,
act
=
None
)
cost
=
fluid
.
layers
.
square_error_cost
(
input
=
y_predict
,
label
=
y_
)
avg_cost
=
fluid
.
layers
.
mean
(
x
=
cost
)
pd
.
write_output
(
avg_cost
)
sgd_optimizer
=
fluid
.
optimizer
.
SGD
(
learning_rate
=
0.1
)
cost
=
pd
()
avg_cost
=
fluid
.
layers
.
mean
(
x
=
cost
)
sgd_optimizer
=
fluid
.
optimizer
.
SGD
(
learning_rate
=
0.01
)
sgd_optimizer
.
minimize
(
avg_cost
)
fluid
.
memory_optimize
(
fluid
.
default_main_program
())
...
...
@@ -65,6 +71,7 @@ for pass_id in range(PASS_NUM):
if
avg_loss_value
[
0
]
<
10.0
:
exit
(
0
)
# if avg cost less than 10.0, we think our code is good.
print
avg_loss_value
[
0
]
if
math
.
isnan
(
float
(
avg_loss_value
)):
sys
.
exit
(
"got NaN loss, training failed."
)
exit
(
1
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录