Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
fb08e163
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看板
提交
fb08e163
编写于
8月 29, 2018
作者:
F
fengjiayi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refine memory usage calc
上级
a22309af
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
21 addition
and
12 deletion
+21
-12
python/paddle/fluid/contrib/memory_usage_calc.py
python/paddle/fluid/contrib/memory_usage_calc.py
+21
-12
未找到文件。
python/paddle/fluid/contrib/memory_usage_calc.py
浏览文件 @
fb08e163
...
@@ -70,23 +70,32 @@ def memory_usage(program, batch_size):
...
@@ -70,23 +70,32 @@ def memory_usage(program, batch_size):
if
not
isinstance
(
program
,
Program
):
if
not
isinstance
(
program
,
Program
):
raise
TypeError
(
raise
TypeError
(
"Calculating Memory Usage requires Program as its Parameter."
"Calculating Memory Usage requires Program as its Parameter."
"But you passed in %s"
%
(
type
(
prgram
)))
"But you passed in %s"
%
(
type
(
pr
o
gram
)))
if
batch_size
<=
0
:
if
batch_size
<=
0
:
raise
ValueError
(
"The batch size need to be positive."
)
raise
ValueError
(
"The batch size need to be positive."
)
# Get the var_name list of first block and calculate
# Get the var_name list of first block and calculate
total_memory
=
0.0
total_memory
=
0.0
for
var
in
six
.
itervalues
(
program
.
global_block
().
vars
):
processed_var_names
=
set
()
data_count
=
1
for
op
in
program
.
global_block
().
ops
:
for
x
in
var
.
shape
:
for
var_name
in
op
.
output_arg_names
:
if
x
==
-
1
:
if
var_name
in
processed_var_names
:
data_count
*=
batch_size
continue
else
:
processed_var_names
.
add
(
var_name
)
data_count
*=
x
var
=
program
.
global_block
().
vars
[
var_name
]
var_memory
=
data_count
*
dtype_to_size
[
var
.
dtype
]
if
var
.
desc
.
type
()
!=
core
.
VarDesc
.
VarType
.
LOD_TENSOR
:
if
DEBUG
:
continue
print
(
"%s memory usage: %d"
%
(
var
.
name
,
var_memory
))
total_memory
+=
var_memory
data_count
=
1
for
x
in
var
.
shape
:
if
x
<
0
:
data_count
*=
batch_size
*
(
-
x
)
else
:
data_count
*=
x
var_memory
=
data_count
*
dtype_to_size
[
var
.
dtype
]
if
DEBUG
:
print
(
"%s memory usage: %d"
%
(
var
.
name
,
var_memory
))
total_memory
+=
var_memory
if
DEBUG
:
if
DEBUG
:
print
(
"total memory usage: %.2f"
%
(
total_memory
))
print
(
"total memory usage: %.2f"
%
(
total_memory
))
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录